org.gradle.internal.component.external.model.AbstractRealisedModuleResolveMetadataSerializationHelper Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.1 API redistribution.
/*
* Copyright 2018 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.gradle.internal.component.external.model;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import org.gradle.api.artifacts.component.ModuleComponentSelector;
import org.gradle.api.capabilities.Capability;
import org.gradle.api.internal.artifacts.ImmutableModuleIdentifierFactory;
import org.gradle.api.internal.artifacts.ModuleComponentSelectorSerializer;
import org.gradle.api.internal.artifacts.ivyservice.moduleconverter.dependencies.DefaultExcludeRuleConverter;
import org.gradle.api.internal.artifacts.ivyservice.moduleconverter.dependencies.ExcludeRuleConverter;
import org.gradle.api.internal.artifacts.ivyservice.resolveengine.result.AttributeContainerSerializer;
import org.gradle.internal.component.external.descriptor.DefaultExclude;
import org.gradle.internal.component.model.ConfigurationMetadata;
import org.gradle.internal.component.model.DefaultIvyArtifactName;
import org.gradle.internal.component.model.ExcludeMetadata;
import org.gradle.internal.component.model.IvyArtifactName;
import org.gradle.internal.serialize.Decoder;
import org.gradle.internal.serialize.Encoder;
import java.io.IOException;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
public abstract class AbstractRealisedModuleResolveMetadataSerializationHelper {
protected static final byte GRADLE_DEPENDENCY_METADATA = 1;
protected static final byte MAVEN_DEPENDENCY_METADATA = 2;
protected static final byte IVY_DEPENDENCY_METADATA = 3;
protected static final byte FORCED_DEPENDENCY_METADATA = 4;
protected final AttributeContainerSerializer attributeContainerSerializer;
private final ModuleComponentSelectorSerializer componentSelectorSerializer;
private final ExcludeRuleConverter excludeRuleConverter;
private final ImmutableModuleIdentifierFactory moduleIdentifierFactory;
public AbstractRealisedModuleResolveMetadataSerializationHelper(AttributeContainerSerializer attributeContainerSerializer, ImmutableModuleIdentifierFactory moduleIdentifierFactory) {
this.attributeContainerSerializer = attributeContainerSerializer;
this.componentSelectorSerializer = new ModuleComponentSelectorSerializer(attributeContainerSerializer);
this.excludeRuleConverter = new DefaultExcludeRuleConverter(moduleIdentifierFactory);
this.moduleIdentifierFactory = moduleIdentifierFactory;
}
protected AttributeContainerSerializer getAttributeContainerSerializer() {
return attributeContainerSerializer;
}
protected ModuleComponentSelectorSerializer getComponentSelectorSerializer() {
return componentSelectorSerializer;
}
public void writeRealisedVariantsData(Encoder encoder, AbstractRealisedModuleComponentResolveMetadata transformed) throws IOException {
encoder.writeSmallInt(transformed.getVariants().size());
for (ComponentVariant variant: transformed.getVariants()) {
if (variant instanceof AbstractRealisedModuleComponentResolveMetadata.ImmutableRealisedVariantImpl) {
AbstractRealisedModuleComponentResolveMetadata.ImmutableRealisedVariantImpl realisedVariant = (AbstractRealisedModuleComponentResolveMetadata.ImmutableRealisedVariantImpl) variant;
encoder.writeString(realisedVariant.getName());
encoder.writeSmallInt(realisedVariant.getDependencyMetadata().size());
for (GradleDependencyMetadata dependencyMetadata: realisedVariant.getDependencyMetadata()) {
writeDependencyMetadata(encoder, dependencyMetadata);
}
} else {
throw new IllegalStateException("Unknown type of variant: " + variant.getClass());
}
}
}
public void writeRealisedConfigurationsData(Encoder encoder, AbstractRealisedModuleComponentResolveMetadata transformed, Map deduplicationDependencyCache) throws IOException {
encoder.writeSmallInt(transformed.getConfigurationNames().size());
for (String configurationName: transformed.getConfigurationNames()) {
ConfigurationMetadata configuration = transformed.getConfiguration(configurationName);
writeConfiguration(encoder, configuration);
writeDependencies(encoder, configuration, deduplicationDependencyCache);
}
}
protected void writeConfiguration(Encoder encoder, ConfigurationMetadata configuration) throws IOException {
assert configuration != null;
encoder.writeString(configuration.getName());
attributeContainerSerializer.write(encoder, configuration.getAttributes());
writeCapabilities(encoder, configuration.getCapabilities().getCapabilities());
}
protected Map> readVariantDependencies(Decoder decoder) throws IOException {
int variantsCount = decoder.readSmallInt();
Map> variantsToDependencies = Maps.newHashMapWithExpectedSize(variantsCount);
for (int i = 0; i < variantsCount; i++) {
String variantName = decoder.readString();
int dependencyCount = decoder.readSmallInt();
List dependencies = Lists.newArrayListWithExpectedSize(dependencyCount);
for (int j = 0; j < dependencyCount; j++) {
dependencies.add(readDependencyMetadata(decoder));
}
variantsToDependencies.put(variantName, dependencies);
}
return variantsToDependencies;
}
protected GradleDependencyMetadata readDependencyMetadata(Decoder decoder) throws IOException {
ModuleComponentSelector selector = componentSelectorSerializer.read(decoder);
List excludes = readMavenExcludes(decoder);
boolean constraint = decoder.readBoolean();
boolean force = decoder.readBoolean();
String reason = decoder.readNullableString();
return new GradleDependencyMetadata(selector, excludes, constraint, reason, force);
}
protected List readMavenExcludes(Decoder decoder) throws IOException {
int excludeCount = decoder.readSmallInt();
List excludes = Lists.newArrayListWithCapacity(excludeCount);
for (int i = 0; i < excludeCount; i++) {
String group = decoder.readString();
String name = decoder.readString();
excludes.add(excludeRuleConverter.createExcludeRule(group, name));
}
return excludes;
}
protected ImmutableCapabilities readCapabilities(Decoder decoder) throws IOException {
int capabilitiesCount = decoder.readSmallInt();
List rawCapabilities = Lists.newArrayListWithCapacity(capabilitiesCount);
for (int j = 0; j < capabilitiesCount; j++) {
String appendix = decoder.readNullableString();
CapabilityInternal capability = new ImmutableCapability(decoder.readString(), decoder.readString(), decoder.readString());
if (appendix != null) {
capability = new DefaultShadowedCapability(capability, appendix);
}
rawCapabilities.add(capability);
}
return ImmutableCapabilities.of(rawCapabilities);
}
protected abstract void writeDependencies(Encoder encoder, ConfigurationMetadata configuration, Map deduplicationDependencyCache) throws IOException;
private void writeCapabilities(Encoder encoder, List extends Capability> capabilities) throws IOException {
encoder.writeSmallInt(capabilities.size());
for (Capability capability: capabilities) {
boolean shadowed = capability instanceof ShadowedCapability;
if (shadowed) {
ShadowedCapability shadowedCapability = (ShadowedCapability) capability;
encoder.writeNullableString(shadowedCapability.getAppendix());
capability = shadowedCapability.getShadowedCapability();
} else {
encoder.writeNullableString(null);
}
encoder.writeString(capability.getGroup());
encoder.writeString(capability.getName());
encoder.writeString(capability.getVersion());
}
}
protected void writeDependencyMetadata(Encoder encoder, GradleDependencyMetadata dependencyMetadata) throws IOException {
componentSelectorSerializer.write(encoder, dependencyMetadata.getSelector());
List excludes = dependencyMetadata.getExcludes();
writeMavenExcludeRules(encoder, excludes);
encoder.writeBoolean(dependencyMetadata.isConstraint());
encoder.writeBoolean(dependencyMetadata.isForce());
encoder.writeNullableString(dependencyMetadata.getReason());
}
protected void writeMavenExcludeRules(Encoder encoder, List excludes) throws IOException {
encoder.writeSmallInt(excludes.size());
for (ExcludeMetadata exclude : excludes) {
encoder.writeString(exclude.getModuleId().getGroup());
encoder.writeString(exclude.getModuleId().getName());
}
}
protected IvyArtifactName readNullableArtifact(Decoder decoder) throws IOException {
boolean hasArtifact = decoder.readBoolean();
IvyArtifactName artifactName = null;
if (hasArtifact) {
String artifact = decoder.readString();
String type = decoder.readString();
String ext = decoder.readNullableString();
String classifier = decoder.readNullableString();
artifactName = new DefaultIvyArtifactName(artifact, type, ext, classifier);
}
return artifactName;
}
protected void writeNullableArtifact(Encoder encoder, IvyArtifactName artifact) throws IOException {
if (artifact == null) {
encoder.writeBoolean(false);
} else {
encoder.writeBoolean(true);
encoder.writeString(artifact.getName());
encoder.writeString(artifact.getType());
encoder.writeNullableString(artifact.getExtension());
encoder.writeNullableString(artifact.getClassifier());
}
}
protected DefaultExclude readExcludeRule(Decoder decoder) throws IOException {
String moduleOrg = decoder.readString();
String moduleName = decoder.readString();
IvyArtifactName artifactName = readNullableArtifact(decoder);
String[] confs = readStringSet(decoder).toArray(new String[0]);
String matcher = decoder.readNullableString();
return new DefaultExclude(moduleIdentifierFactory.module(moduleOrg, moduleName), artifactName, confs, matcher);
}
protected Set readStringSet(Decoder decoder) throws IOException {
int size = decoder.readSmallInt();
Set set = new LinkedHashSet(3 * size / 2, 0.9f);
for (int i = 0; i < size; i++) {
set.add(decoder.readString());
}
return set;
}
protected void writeStringSet(Encoder encoder, Set values) throws IOException {
encoder.writeSmallInt(values.size());
for (String configuration : values) {
encoder.writeString(configuration);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy