Java tutorial
/* * 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.ImmutableList; import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableSet; import com.google.common.collect.Lists; import org.gradle.api.artifacts.component.ModuleComponentSelector; import org.gradle.api.capabilities.CapabilitiesMetadata; import org.gradle.api.internal.artifacts.DefaultModuleIdentifier; import org.gradle.api.internal.attributes.ImmutableAttributes; import org.gradle.internal.component.external.descriptor.Configuration; import org.gradle.internal.component.model.ExcludeMetadata; import java.util.ArrayList; import java.util.Collections; import java.util.List; /** * Utility class to help transform a lazy {@link ModuleComponentResolveMetadata} into a realised one. */ public class LazyToRealisedModuleComponentResolveMetadataHelper { /** * Method to transform lazy variants into realised ones * * @param mutableMetadata the source metadata * @param variantMetadataRules the lazy rules * @param variants the variants to transform * @return a list of realised variants */ public static ImmutableList<AbstractRealisedModuleComponentResolveMetadata.ImmutableRealisedVariantImpl> realiseVariants( ModuleComponentResolveMetadata mutableMetadata, VariantMetadataRules variantMetadataRules, ImmutableList<? extends ComponentVariant> variants) { List<AbstractRealisedModuleComponentResolveMetadata.ImmutableRealisedVariantImpl> realisedVariants = Lists .newArrayListWithExpectedSize(variants.size()); for (ComponentVariant variant : variants) { ImmutableAttributes attributes = variantMetadataRules.applyVariantAttributeRules(variant, variant.getAttributes()); CapabilitiesMetadata capabilitiesMetadata = variantMetadataRules.applyCapabilitiesRules(variant, variant.getCapabilities()); List<GradleDependencyMetadata> dependencies = variantMetadataRules.applyDependencyMetadataRules(variant, convertDependencies(variant.getDependencies(), variant.getDependencyConstraints())); realisedVariants.add(new AbstractRealisedModuleComponentResolveMetadata.ImmutableRealisedVariantImpl( mutableMetadata.getId(), variant.getName(), attributes, variant.getDependencies(), variant.getDependencyConstraints(), variant.getFiles(), ImmutableCapabilities.of(capabilitiesMetadata.getCapabilities()), dependencies)); } return ImmutableList.copyOf(realisedVariants); } private static List<GradleDependencyMetadata> convertDependencies( List<? extends ComponentVariant.Dependency> dependencies, List<? extends ComponentVariant.DependencyConstraint> dependencyConstraints) { List<GradleDependencyMetadata> result = new ArrayList<GradleDependencyMetadata>(dependencies.size()); for (ComponentVariant.Dependency dependency : dependencies) { ModuleComponentSelector selector = DefaultModuleComponentSelector.newSelector( DefaultModuleIdentifier.newId(dependency.getGroup(), dependency.getModule()), dependency.getVersionConstraint(), dependency.getAttributes()); List<ExcludeMetadata> excludes = dependency.getExcludes(); result.add(new GradleDependencyMetadata(selector, excludes, false, dependency.getReason(), false)); } for (ComponentVariant.DependencyConstraint dependencyConstraint : dependencyConstraints) { result.add(new GradleDependencyMetadata( DefaultModuleComponentSelector.newSelector( DefaultModuleIdentifier.newId(dependencyConstraint.getGroup(), dependencyConstraint.getModule()), dependencyConstraint.getVersionConstraint(), dependencyConstraint.getAttributes()), Collections.<ExcludeMetadata>emptyList(), true, dependencyConstraint.getReason(), false)); } return result; } public static ImmutableSet<String> constructHierarchy(Configuration descriptorConfiguration, ImmutableMap<String, Configuration> configurationDefinitions) { if (descriptorConfiguration.getExtendsFrom().isEmpty()) { return ImmutableSet.of(descriptorConfiguration.getName()); } ImmutableSet.Builder<String> accumulator = new ImmutableSet.Builder<String>(); populateHierarchy(descriptorConfiguration, configurationDefinitions, accumulator); return accumulator.build(); } private static void populateHierarchy(Configuration metadata, ImmutableMap<String, Configuration> configurationDefinitions, ImmutableSet.Builder<String> accumulator) { accumulator.add(metadata.getName()); for (String parentName : metadata.getExtendsFrom()) { Configuration parent = configurationDefinitions.get(parentName); populateHierarchy(parent, configurationDefinitions, accumulator); } } }