org.gradle.internal.component.local.model.BuildableLocalComponentMetadata 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 2013 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.local.model;
import com.google.common.collect.ImmutableSet;
import org.gradle.api.artifacts.DependencyConstraint;
import org.gradle.api.artifacts.PublishArtifact;
import org.gradle.api.artifacts.component.ComponentIdentifier;
import org.gradle.api.internal.artifacts.configurations.ConfigurationInternal;
import org.gradle.api.internal.artifacts.ivyservice.moduleconverter.dependencies.LocalConfigurationMetadataBuilder;
import org.gradle.api.internal.attributes.ImmutableAttributes;
import org.gradle.internal.DisplayName;
import org.gradle.internal.component.external.model.ImmutableCapabilities;
import org.gradle.internal.component.model.VariantResolveMetadata;
import java.util.Collection;
import java.util.List;
import java.util.Set;
import java.util.function.Supplier;
public interface BuildableLocalComponentMetadata {
/**
* Returns the identifier for this component.
*/
ComponentIdentifier getId();
/**
* Adds some artifacts to this component. Artifacts are attached to the given configuration and each of its children. These are used only for publishing.
*/
void addArtifacts(String configuration, Collection extends PublishArtifact> artifacts);
/**
* Adds a variant to this component, extending from the given configuration. Every configuration should include at least one variant.
*/
void addVariant(String configuration, String name, VariantResolveMetadata.Identifier identifier, DisplayName displayName, ImmutableAttributes attributes, Collection extends PublishArtifact> artifacts);
/**
* Adds a configuration to this component.
* @param hierarchy Must include name
* @param attributes the attributes of the configuration.
* @param consistentResolutionConstraints the consistent resolution constraints
*/
BuildableLocalConfigurationMetadata addConfiguration(String name, String description, Set extendsFrom, ImmutableSet hierarchy, boolean visible, boolean transitive, ImmutableAttributes attributes, boolean canBeConsumed, List consumptionAlternatives, boolean canBeResolved, ImmutableCapabilities capabilities, Supplier> consistentResolutionConstraints);
/**
* Provides a backing configuration instance from which dependencies and excludes will be sourced.
*
* @param configuration The configuration instance that provides dependencies and excludes
* @param localConfigurationMetadataBuilder A builder for translating Configuration to LocalConfigurationMetadata
*/
void addDependenciesAndExcludesForConfiguration(ConfigurationInternal configuration, LocalConfigurationMetadataBuilder localConfigurationMetadataBuilder);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy