Package org.gradle.api.artifacts
Interface Configuration
- All Superinterfaces:
AntBuilderAware
,Buildable
,FileCollection
,HasAttributes
,HasConfigurableAttributes<Configuration>
,Iterable<File>
A
Configuration
represents a group of artifacts and their dependencies.
Find more information about declaring dependencies to a configuration
or about managing configurations in docs for ConfigurationContainer
Configuration is an instance of a FileCollection
that contains all dependencies (see also getAllDependencies()
) but not artifacts.
If you want to refer to the artifacts declared in this configuration
please use getArtifacts()
or getAllArtifacts()
.
Read more about declaring artifacts in the configuration in docs for ArtifactHandler
-
Nested Class Summary
Modifier and TypeInterfaceDescriptionstatic class
static enum
The states a configuration can be into.Nested classes/interfaces inherited from interface org.gradle.api.file.FileCollection
FileCollection.AntType
-
Method Summary
Modifier and TypeMethodDescriptioncopy()
Creates a copy of this configuration that only contains the dependencies directly in this configuration (without contributions from superconfigurations).Takes a closure which gets coerced into aSpec
.copy
(Spec<? super Dependency> dependencySpec) Creates a copy of this configuration ignoring superconfigurations (seecopy()
but filtering the dependencies using the specified dependency spec.Creates a copy of this configuration that contains the dependencies directly in this configuration and those derived from superconfigurations.copyRecursive
(Closure dependencySpec) Takes a closure which gets coerced into aSpec
.copyRecursive
(Spec<? super Dependency> dependencySpec) Creates a copy of this configuration with dependencies from superconfigurations (seecopyRecursive()
) but filtering the dependencies using the dependencySpec.defaultDependencies
(Action<? super DependencySet> action) Execute the given action if the configuration has no defined dependencies when it first participates in dependency resolution.Adds an exclude rule to exclude transitive dependencies for all dependencies of this configuration.extendsFrom
(Configuration... superConfigs) Adds the given configurations to the set of configuration which this configuration extends from.fileCollection
(Closure dependencySpecClosure) Takes a closure which gets coerced into aSpec
.fileCollection
(Dependency... dependencies) Resolves this configuration lazily.fileCollection
(Spec<? super Dependency> dependencySpec) Resolves this configuration lazily.Takes a closure which gets coerced into aSpec
.files
(Dependency... dependencies) Resolves this configuration.files
(Spec<? super Dependency> dependencySpec) Resolves this configuration.getAll()
Returns all the configurations belonging to the same configuration container as this configuration (including this configuration).Returns the artifacts of this configuration including the artifacts of extended configurations.Gets the complete set of dependencies including those contributed by superconfigurations.Returns the artifacts of this configuration excluding the artifacts of extended configurations.Returns aTaskDependency
object containing all required dependencies to build the local dependencies (e.g. project dependencies) belonging to this configuration or to one of its super configurations.Gets the set of dependencies directly contained in this configuration (ignoring superconfigurations).Returns the description for this configuration.Returns the exclude rules applied for resolving any dependency of this configuration.Returns the names of the configurations which this configuration extends from.Gets a ordered set including this configuration and all superconfigurations recursively.Returns the incoming dependencies of this configuration.getName()
Returns the name of this configuration.Returns the outgoing artifacts of this configuration.Returns the resolution strategy used by this configuration.Resolves this configuration.getState()
Returns the state of the configuration.getTaskDependencyFromProjectDependency
(boolean useDependedOn, String taskName) Returns a TaskDependency object containing dependencies on all tasks with the specified name from project dependencies related to this configuration or one of its super configurations.Returns the name of the task that upload the artifacts of this configuration to repositories declared by the user.boolean
Returns true if this configuration can be consumed from another project, or published.boolean
Returns true if it is allowed to query or resolve this configuration.boolean
Returns the transitivity of this configuration.boolean
Returns true if this is a visible configuration.void
outgoing
(Action<? super ConfigurationPublications> action) Configures the outgoing artifacts of this configuration.resolutionStrategy
(Closure closure) The resolution strategy provides extra details on how to resolve this configuration.resolutionStrategy
(Action<? super ResolutionStrategy> action) The resolution strategy provides extra details on how to resolve this configuration.resolve()
Resolves this configuration.void
setCanBeConsumed
(boolean allowed) Configures if a configuration can be consumed.void
setCanBeResolved
(boolean allowed) Configures if a configuration can be resolved.setDescription
(String description) Sets the description for this configuration.setExtendsFrom
(Iterable<Configuration> superConfigs) Sets the configurations which this configuration extends from.setTransitive
(boolean t) Sets the transitivity of this configuration.setVisible
(boolean visible) Sets the visibility of this configuration.withDependencies
(Action<? super DependencySet> action) Execute the given action before the configuration first participates in dependency resolution.Methods inherited from interface org.gradle.api.file.FileCollection
add, addToAntBuilder, addToAntBuilder, asType, contains, filter, filter, getAsFileTree, getAsPath, getFiles, getSingleFile, isEmpty, minus, plus, stopExecutionIfEmpty
Methods inherited from interface org.gradle.api.attributes.HasAttributes
getAttributes
Methods inherited from interface org.gradle.api.attributes.HasConfigurableAttributes
attributes
Methods inherited from interface java.lang.Iterable
forEach, iterator, spliterator
-
Method Details
-
getResolutionStrategy
ResolutionStrategy getResolutionStrategy()Returns the resolution strategy used by this configuration. The resolution strategy provides extra details on how to resolve this configuration. See docs forResolutionStrategy
for more info and examples.- Returns:
- resolution strategy
- Since:
- 1.0-milestone-6
-
resolutionStrategy
Configuration resolutionStrategy(@DelegatesTo(value=ResolutionStrategy.class,strategy=1) Closure closure) The resolution strategy provides extra details on how to resolve this configuration. See docs forResolutionStrategy
for more info and examples.- Parameters:
closure
- closure applied to theResolutionStrategy
- Returns:
- this configuration instance
- Since:
- 1.0-milestone-6
-
resolutionStrategy
The resolution strategy provides extra details on how to resolve this configuration. See docs forResolutionStrategy
for more info and examples.- Parameters:
action
- action applied to theResolutionStrategy
- Returns:
- this configuration instance
- Since:
- 3.1
-
getState
Configuration.State getState()Returns the state of the configuration.- Returns:
- The state of the configuration
- See Also:
-
getName
String getName()Returns the name of this configuration.- Returns:
- The configuration name, never null.
-
isVisible
boolean isVisible()Returns true if this is a visible configuration. A visible configuration is usable outside the project it belongs to. The default value is true.- Returns:
- true if this is a visible configuration.
-
setVisible
Sets the visibility of this configuration. When visible is set to true, this configuration is visible outside the project it belongs to. The default value is true.- Parameters:
visible
- true if this is a visible configuration- Returns:
- this configuration
-
getExtendsFrom
Set<Configuration> getExtendsFrom()Returns the names of the configurations which this configuration extends from. The artifacts of the super configurations are also available in this configuration.- Returns:
- The super configurations. Returns an empty set when this configuration does not extend any others.
-
setExtendsFrom
Sets the configurations which this configuration extends from.- Parameters:
superConfigs
- The super configuration. Should not be null.- Returns:
- this configuration
-
extendsFrom
Adds the given configurations to the set of configuration which this configuration extends from.- Parameters:
superConfigs
- The super configurations.- Returns:
- this configuration
-
isTransitive
boolean isTransitive()Returns the transitivity of this configuration. A transitive configuration contains the transitive closure of its direct dependencies, and all their dependencies. An intransitive configuration contains only the direct dependencies. The default value is true.- Returns:
- true if this is a transitive configuration, false otherwise.
-
setTransitive
Sets the transitivity of this configuration. When set to true, this configuration will contain the transitive closure of its dependencies and their dependencies. The default value is true.- Parameters:
t
- true if this is a transitive configuration.- Returns:
- this configuration
-
getDescription
Returns the description for this configuration.- Returns:
- the description. May be null.
-
setDescription
Sets the description for this configuration.- Parameters:
description
- the description. May be null- Returns:
- this configuration
-
getHierarchy
Set<Configuration> getHierarchy()Gets a ordered set including this configuration and all superconfigurations recursively.- Returns:
- the list of all configurations
-
resolve
Resolves this configuration. This locates and downloads the files which make up this configuration, and returns the resulting set of files.- Returns:
- The files of this configuration.
-
files
Takes a closure which gets coerced into aSpec
. Behaves otherwise in the same way asfiles(org.gradle.api.specs.Spec)
.- Parameters:
dependencySpecClosure
- The closure describing a filter applied to the all the dependencies of this configuration (including dependencies from extended configurations).- Returns:
- The files of a subset of dependencies of this configuration.
-
files
Resolves this configuration. This locates and downloads the files which make up this configuration. But only the resulting set of files belonging to the subset of dependencies specified by the dependencySpec is returned.- Parameters:
dependencySpec
- The spec describing a filter applied to the all the dependencies of this configuration (including dependencies from extended configurations).- Returns:
- The files of a subset of dependencies of this configuration.
-
files
Resolves this configuration. This locates and downloads the files which make up this configuration. But only the resulting set of files belonging to the specified dependencies is returned.- Parameters:
dependencies
- The dependencies to be resolved- Returns:
- The files of a subset of dependencies of this configuration.
-
fileCollection
Resolves this configuration lazily. The resolve happens when the elements of the returnedFileCollection
get accessed the first time. This locates and downloads the files which make up this configuration. Only the resulting set of files belonging to the subset of dependencies specified by the dependencySpec is contained in the FileCollection.- Parameters:
dependencySpec
- The spec describing a filter applied to the all the dependencies of this configuration (including dependencies from extended configurations).- Returns:
- The FileCollection with a subset of dependencies of this configuration.
-
fileCollection
Takes a closure which gets coerced into aSpec
. Behaves otherwise in the same way asfileCollection(org.gradle.api.specs.Spec)
.- Parameters:
dependencySpecClosure
- The closure describing a filter applied to the all the dependencies of this configuration (including dependencies from extended configurations).- Returns:
- The FileCollection with a subset of dependencies of this configuration.
-
fileCollection
Resolves this configuration lazily. The resolve happens when the elements of the returnedFileCollection
get accessed the first time. This locates and downloads the files which make up this configuration. Only the resulting set of files belonging to specified dependencies is contained in the FileCollection.- Parameters:
dependencies
- The dependencies for which the FileCollection should contain the files.- Returns:
- The FileCollection with a subset of dependencies of this configuration.
-
getResolvedConfiguration
ResolvedConfiguration getResolvedConfiguration()Resolves this configuration. This locates and downloads the files which make up this configuration, and returns aResolvedConfiguration
that may be used to determine information about the resolve (including errors).- Returns:
- The ResolvedConfiguration object
-
getUploadTaskName
String getUploadTaskName()Returns the name of the task that upload the artifacts of this configuration to repositories declared by the user.- Returns:
- The name of the associated upload task
- See Also:
-
getBuildDependencies
TaskDependency getBuildDependencies()Returns aTaskDependency
object containing all required dependencies to build the local dependencies (e.g. project dependencies) belonging to this configuration or to one of its super configurations.- Specified by:
getBuildDependencies
in interfaceBuildable
- Returns:
- a TaskDependency object
-
getTaskDependencyFromProjectDependency
Returns a TaskDependency object containing dependencies on all tasks with the specified name from project dependencies related to this configuration or one of its super configurations. These other projects may be projects this configuration depends on or projects with a similarly named configuration that depend on this one based on the useDependOn argument.- Parameters:
useDependedOn
- if true, add tasks from project dependencies in this configuration, otherwise use projects from configurations with the same name that depend on this one.taskName
- name of task to depend on- Returns:
- the populated TaskDependency object
-
getDependencies
DependencySet getDependencies()Gets the set of dependencies directly contained in this configuration (ignoring superconfigurations).- Returns:
- the set of dependencies
-
getAllDependencies
DependencySet getAllDependencies()Gets the complete set of dependencies including those contributed by superconfigurations.
- Returns:
- the (read-only) set of dependencies
-
getArtifacts
PublishArtifactSet getArtifacts()Returns the artifacts of this configuration excluding the artifacts of extended configurations.- Returns:
- The set.
-
getAllArtifacts
PublishArtifactSet getAllArtifacts()Returns the artifacts of this configuration including the artifacts of extended configurations.- Returns:
- The (read-only) set.
-
getExcludeRules
Set<ExcludeRule> getExcludeRules()Returns the exclude rules applied for resolving any dependency of this configuration.- Returns:
- The exclude rules
- See Also:
-
exclude
Adds an exclude rule to exclude transitive dependencies for all dependencies of this configuration. You can also add exclude rules per-dependency. SeeModuleDependency.exclude(java.util.Map)
.- Parameters:
excludeProperties
- the properties to define the exclude rule.- Returns:
- this
-
defaultDependencies
Execute the given action if the configuration has no defined dependencies when it first participates in dependency resolution. AConfiguration
will participate in dependency resolution when:- The
Configuration
itself is resolved - Another
Configuration
that extends this one is resolved - Another
Configuration
that references this one as a project dependency is resolved
configurations { conf } configurations['conf'].defaultDependencies { dependencies -> dependencies.add(owner.project.dependencies.create("org.gradle:my-util:1.0")) }
AConfiguration
is considered empty even if it extends another, non-emptyConfiguration
. If multiple actions are supplied, each action will be executed until the set of dependencies is no longer empty. Remaining actions will be ignored.- Parameters:
action
- the action to execute when the configuration has no defined dependencies.- Returns:
- this
- The
-
withDependencies
Execute the given action before the configuration first participates in dependency resolution. AConfiguration
will participate in dependency resolution when:- The
Configuration
itself is resolved - Another
Configuration
that extends this one is resolved - Another
Configuration
that references this one as a project dependency is resolved
configurations { conf } configurations['conf'].withDependencies { dependencies -> dependencies.each { dependency -> if (dependency.version == null) { dependency.version { prefer '1.0' } } } }
Actions will be executed in the order provided.- Parameters:
action
- a dependency action to execute before the configuration is used.- Returns:
- this
- Since:
- 4.4
- The
-
getAll
Set<Configuration> getAll()Returns all the configurations belonging to the same configuration container as this configuration (including this configuration).- Returns:
- All of the configurations belong to the configuration container that this set belongs to.
-
getIncoming
ResolvableDependencies getIncoming()Returns the incoming dependencies of this configuration.- Returns:
- The incoming dependencies of this configuration. Never
null
.
-
getOutgoing
Returns the outgoing artifacts of this configuration.- Returns:
- The outgoing artifacts of this configuration.
- Since:
- 3.4
-
outgoing
Configures the outgoing artifacts of this configuration.- Parameters:
action
- The action to perform the configuration.- Since:
- 3.4
-
copy
Configuration copy()Creates a copy of this configuration that only contains the dependencies directly in this configuration (without contributions from superconfigurations). The new configuration will be in the UNRESOLVED state, but will retain all other attributes of this configuration except superconfigurations.getHierarchy()
for the copy will not include any superconfigurations.- Returns:
- copy of this configuration
-
copyRecursive
Configuration copyRecursive()Creates a copy of this configuration that contains the dependencies directly in this configuration and those derived from superconfigurations. The new configuration will be in the UNRESOLVED state, but will retain all other attributes of this configuration except superconfigurations.getHierarchy()
for the copy will not include any superconfigurations.- Returns:
- copy of this configuration
-
copy
Creates a copy of this configuration ignoring superconfigurations (seecopy()
but filtering the dependencies using the specified dependency spec.- Parameters:
dependencySpec
- filtering requirements- Returns:
- copy of this configuration
-
copyRecursive
Creates a copy of this configuration with dependencies from superconfigurations (seecopyRecursive()
) but filtering the dependencies using the dependencySpec.- Parameters:
dependencySpec
- filtering requirements- Returns:
- copy of this configuration
-
copy
Takes a closure which gets coerced into aSpec
. Behaves otherwise in the same way ascopy(org.gradle.api.specs.Spec)
- Parameters:
dependencySpec
- filtering requirements- Returns:
- copy of this configuration
-
copyRecursive
Takes a closure which gets coerced into aSpec
. Behaves otherwise in the same way ascopyRecursive(org.gradle.api.specs.Spec)
- Parameters:
dependencySpec
- filtering requirements- Returns:
- copy of this configuration
-
setCanBeConsumed
Configures if a configuration can be consumed.- Since:
- 3.3
-
isCanBeConsumed
Returns true if this configuration can be consumed from another project, or published. Defaults to true.- Returns:
- true if this configuration can be consumed or published.
- Since:
- 3.3
-
setCanBeResolved
Configures if a configuration can be resolved.- Since:
- 3.3
-
isCanBeResolved
Returns true if it is allowed to query or resolve this configuration. Defaults to true.- Returns:
- true if this configuration can be queried or resolved.
- Since:
- 3.3
-