org.gradle.api.internal.resolve.LocalLibraryDependencyResolver 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 2015 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.api.internal.resolve;
import com.google.common.base.Predicate;
import com.google.common.collect.Iterables;
import org.gradle.api.UnknownProjectException;
import org.gradle.api.artifacts.component.ComponentArtifactIdentifier;
import org.gradle.api.artifacts.component.ComponentIdentifier;
import org.gradle.api.artifacts.component.LibraryBinaryIdentifier;
import org.gradle.api.artifacts.component.LibraryComponentSelector;
import org.gradle.api.internal.artifacts.ResolvedVersionConstraint;
import org.gradle.api.internal.artifacts.ivyservice.ivyresolve.ComponentResolvers;
import org.gradle.api.internal.artifacts.ivyservice.resolveengine.artifact.ArtifactSet;
import org.gradle.api.internal.artifacts.ivyservice.resolveengine.artifact.ResolvableArtifact;
import org.gradle.api.internal.artifacts.ivyservice.resolveengine.excludes.ModuleExclusion;
import org.gradle.api.internal.artifacts.type.ArtifactTypeRegistry;
import org.gradle.api.internal.attributes.ImmutableAttributes;
import org.gradle.api.internal.component.ArtifactType;
import org.gradle.internal.component.external.model.MetadataSourcedComponentArtifacts;
import org.gradle.internal.component.local.model.LocalComponentMetadata;
import org.gradle.internal.component.local.model.PublishArtifactLocalArtifactMetadata;
import org.gradle.internal.component.model.ComponentArtifactMetadata;
import org.gradle.internal.component.model.ComponentOverrideMetadata;
import org.gradle.internal.component.model.ComponentResolveMetadata;
import org.gradle.internal.component.model.ConfigurationMetadata;
import org.gradle.internal.component.model.DependencyMetadata;
import org.gradle.internal.component.model.ModuleSource;
import org.gradle.internal.resolve.ArtifactResolveException;
import org.gradle.internal.resolve.ModuleVersionResolveException;
import org.gradle.internal.resolve.resolver.ArtifactResolver;
import org.gradle.internal.resolve.resolver.ComponentMetaDataResolver;
import org.gradle.internal.resolve.resolver.DependencyToComponentIdResolver;
import org.gradle.internal.resolve.resolver.OriginArtifactSelector;
import org.gradle.internal.resolve.result.BuildableArtifactResolveResult;
import org.gradle.internal.resolve.result.BuildableArtifactSetResolveResult;
import org.gradle.internal.resolve.result.BuildableComponentIdResolveResult;
import org.gradle.internal.resolve.result.BuildableComponentResolveResult;
import org.gradle.language.base.internal.resolve.LibraryResolveException;
import org.gradle.model.internal.registry.ModelRegistry;
import org.gradle.platform.base.Binary;
import org.gradle.platform.base.VariantComponent;
import javax.annotation.Nullable;
import java.util.Collection;
import java.util.Collections;
import java.util.concurrent.ConcurrentHashMap;
public class LocalLibraryDependencyResolver implements DependencyToComponentIdResolver, ComponentMetaDataResolver, ArtifactResolver, OriginArtifactSelector, ComponentResolvers {
private final VariantBinarySelector variantSelector;
private final LibraryResolutionErrorMessageBuilder errorMessageBuilder;
private final LocalLibraryMetaDataAdapter libraryMetaDataAdapter;
private final LocalLibraryResolver libraryResolver;
private final Class extends Binary> binaryType;
private final Predicate binaryPredicate;
private final ProjectModelResolver projectModelResolver;
public LocalLibraryDependencyResolver(final Class extends Binary> binaryType,
ProjectModelResolver projectModelResolver,
LocalLibraryResolver libraryResolver,
VariantBinarySelector variantSelector,
LocalLibraryMetaDataAdapter libraryMetaDataAdapter,
LibraryResolutionErrorMessageBuilder errorMessageBuilder) {
this.libraryMetaDataAdapter = libraryMetaDataAdapter;
this.variantSelector = variantSelector;
this.errorMessageBuilder = errorMessageBuilder;
this.projectModelResolver = projectModelResolver;
this.libraryResolver = libraryResolver;
this.binaryType = binaryType;
this.binaryPredicate = new Predicate() {
@Override
public boolean apply(VariantComponent input) {
return Iterables.any(input.getVariants(), new Predicate() {
@Override
public boolean apply(Binary input) {
return binaryType.isAssignableFrom(input.getClass());
}
});
}
};
}
@Override
public ArtifactResolver getArtifactResolver() {
return this;
}
@Override
public DependencyToComponentIdResolver getComponentIdResolver() {
return this;
}
@Override
public ComponentMetaDataResolver getComponentResolver() {
return this;
}
@Override
public OriginArtifactSelector getArtifactSelector() {
return this;
}
@Override
public void resolve(DependencyMetadata dependency, ResolvedVersionConstraint versionConstraint, final BuildableComponentIdResolveResult result) {
if (dependency.getSelector() instanceof LibraryComponentSelector) {
LibraryComponentSelector selector = (LibraryComponentSelector) dependency.getSelector();
resolveLibraryAndChooseBinary(result, selector);
}
}
private void resolveLibraryAndChooseBinary(BuildableComponentIdResolveResult result, LibraryComponentSelector selector) {
final String selectorProjectPath = selector.getProjectPath();
final String libraryName = selector.getLibraryName();
final String variant = selector.getVariant();
LibraryResolutionResult resolutionResult = doResolve(selectorProjectPath, libraryName);
VariantComponent selectedLibrary = resolutionResult.getSelectedLibrary();
if (selectedLibrary == null) {
String message = resolutionResult.toResolutionErrorMessage(selector);
ModuleVersionResolveException failure = new ModuleVersionResolveException(selector, new LibraryResolveException(message));
result.failed(failure);
return;
}
Collection extends Binary> matchingVariants = chooseMatchingVariants(selectedLibrary, variant);
if (matchingVariants.isEmpty()) {
// no compatible variant found
Iterable extends Binary> values = selectedLibrary.getVariants();
result.failed(new ModuleVersionResolveException(selector, errorMessageBuilder.noCompatibleVariantErrorMessage(libraryName, values)));
} else if (matchingVariants.size() > 1) {
result.failed(new ModuleVersionResolveException(selector, errorMessageBuilder.multipleCompatibleVariantsErrorMessage(libraryName, matchingVariants)));
} else {
Binary selectedBinary = matchingVariants.iterator().next();
// TODO:Cedric This is not quite right. We assume that if we are asking for a specific binary, then we resolve to the assembly instead
// of the jar, but it should be somehow parametrized
LocalComponentMetadata metaData;
if (variant == null) {
metaData = libraryMetaDataAdapter.createLocalComponentMetaData(selectedBinary, selectorProjectPath, false);
} else {
metaData = libraryMetaDataAdapter.createLocalComponentMetaData(selectedBinary, selectorProjectPath, true);
}
result.resolved(metaData);
}
}
@Nullable
private LibraryResolutionResult doResolve(String selectorProjectPath, String libraryName) {
try {
ModelRegistry projectModel = projectModelResolver.resolveProjectModel(selectorProjectPath);
Collection candidates = libraryResolver.resolveCandidates(projectModel, libraryName);
if (candidates.isEmpty()) {
return LibraryResolutionResult.emptyResolutionResult(binaryType);
}
return LibraryResolutionResult.of(binaryType, candidates, libraryName, binaryPredicate);
} catch (UnknownProjectException e) {
return LibraryResolutionResult.projectNotFound(binaryType);
}
}
private Collection extends Binary> chooseMatchingVariants(VariantComponent selectedLibrary, String variant) {
return variantSelector.selectVariants(selectedLibrary, variant);
}
@Override
public void resolve(ComponentIdentifier identifier, ComponentOverrideMetadata componentOverrideMetadata, BuildableComponentResolveResult result) {
if (isLibrary(identifier)) {
throw new RuntimeException("Not yet implemented");
}
}
@Override
public boolean isFetchingMetadataCheap(ComponentIdentifier identifier) {
return true;
}
private boolean isLibrary(ComponentIdentifier identifier) {
return identifier instanceof LibraryBinaryIdentifier;
}
@Nullable
@Override
public ArtifactSet resolveArtifacts(ComponentResolveMetadata component, ConfigurationMetadata configuration, ArtifactTypeRegistry artifactTypeRegistry, ModuleExclusion exclusions, ImmutableAttributes overriddenAttributes) {
ComponentIdentifier componentId = component.getId();
if (isLibrary(componentId)) {
return new MetadataSourcedComponentArtifacts().getArtifactsFor(component, configuration, this, new ConcurrentHashMap(), artifactTypeRegistry, exclusions, overriddenAttributes);
}
return null;
}
@Override
public void resolveArtifactsWithType(ComponentResolveMetadata component, ArtifactType artifactType, BuildableArtifactSetResolveResult result) {
if (isLibrary(component.getId())) {
result.resolved(Collections.emptySet());
}
}
@Override
public void resolveArtifact(ComponentArtifactMetadata artifact, ModuleSource moduleSource, BuildableArtifactResolveResult result) {
if (isLibrary(artifact.getComponentId())) {
if (artifact instanceof PublishArtifactLocalArtifactMetadata) {
result.resolved(((PublishArtifactLocalArtifactMetadata) artifact).getFile());
} else {
result.failed(new ArtifactResolveException("Unsupported artifact metadata type: " + artifact));
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy