java.lang.Comparable<Project>, ExtensionAware, PluginAwarepublic interface Project extends java.lang.Comparable<Project>, ExtensionAware, PluginAware
This interface is the main API you use to interact with Gradle from your build file. From a Project,
 you have programmatic access to all of Gradle's features.
There is a one-to-one relationship between a Project and a "build.gradle"
 file. During build initialisation, Gradle assembles a Project object for each project which is to
 participate in the build, as follows:
Settings instance for the build."settings.gradle" script, if
 present, against the Settings object to configure it.Settings object to create the hierarchy of
 Project instances.Project by executing its "build.gradle" file, if
 present, against the project. The projects are evaluated in breadth-wise order, such that a project is evaluated
 before its child projects. This order can be overridden by calling evaluationDependsOnChildren()evaluationDependsOn(String)A project is essentially a collection of Task objects. Each task performs some basic piece of work, such
 as compiling classes, or running unit tests, or zipping up a WAR file. You add tasks to a project using one of the
 create() methods on TaskContainer, such as TaskContainer.create(String).  You can locate existing
 tasks using one of the lookup methods on TaskContainer, such as TaskCollection.getByName(String).
A project generally has a number of dependencies it needs in order to do its work.  Also, a project generally
 produces a number of artifacts, which other projects can use. Those dependencies are grouped in configurations, and
 can be retrieved and uploaded from repositories. You use the ConfigurationContainer
 returned by getConfigurations() method to manage the configurations. The DependencyHandler returned by getDependencies() method to manage the
 dependencies. The ArtifactHandler returned by getArtifacts() method to
 manage the artifacts. The RepositoryHandler returned by getRepositories() method to manage the repositories.
Projects are arranged into a hierarchy of projects. A project has a name, and a fully qualified path which uniquely identifies it in the hierarchy.
 Plugins can be used to modularise and reuse project configuration.
 Plugins can be applied using the PluginAware.apply(java.util.Map) method, or by using the PluginDependenciesSpec plugins script block.
 
Gradle executes the project's build file against the Project instance to configure the project. Any
 property or method which your script uses is delegated through to the associated Project object.  This
 means, that you can use any of the methods and properties on the Project interface directly in your script.
 
For example:
 defaultTasks('some-task')  // Delegates to Project.defaultTasks()
 reportsDir = file('reports') // Delegates to Project.file() and the Java Plugin
 
 You can also access the Project instance using the project property. This can make the
 script clearer in some cases. For example, you could use project.name rather than name to
 access the project's name.
A project has 5 property 'scopes', which it searches for properties. You can access these properties by name in
 your build file, or by calling the project's property(String) method. The scopes are:
Project object itself. This scope includes any property getters and setters declared by the
 Project implementation class.  For example, getRootProject() is accessible as the
 rootProject property.  The properties of this scope are readable or writable depending on the presence
 of the corresponding getter or setter method.Convention object.  The properties of this scope may be readable or writable, depending on the convention objects.compile is accessible as the compile
 property.When reading a property, the project searches the above scopes in order, and returns the value from the first
 scope it finds the property in. If not found, an exception is thrown. See property(String) for more details.
When writing a property, the project searches the above scopes in order, and sets the property in the first scope
 it finds the property in. If not found, an exception is thrown. See setProperty(String, Object) for more details.
 project.ext.prop1 = "foo"
 task doStuff {
     ext.prop2 = "bar"
 }
 subprojects { ext.${prop3} = false }
 
 Reading extra properties is done through the "ext" or through the owning object.
 
 ext.isSnapshot = version.endsWith("-SNAPSHOT")
 if (isSnapshot) {
     // do snapshot stuff
 }
 
 A project has 5 method 'scopes', which it searches for methods:
Project object itself.Action as a parameter.Convention object.Action parameter. The method calls the Task.configure(groovy.lang.Closure) method for the
 associated task with the provided closure. For example, if the project has a task called compile, then a
 method is added with the following signature: void compile(Closure configureClosure).| Modifier and Type | Field | Description | 
|---|---|---|
| static java.lang.String | DEFAULT_BUILD_DIR_NAME | The default build directory name. | 
| static java.lang.String | DEFAULT_BUILD_FILE | The default project build file name. | 
| static java.lang.String | DEFAULT_STATUS | |
| static java.lang.String | DEFAULT_VERSION | |
| static java.lang.String | GRADLE_PROPERTIES | |
| static java.lang.String | PATH_SEPARATOR | The hierarchy separator for project and task path names. | 
| static java.lang.String | SYSTEM_PROP_PREFIX | 
| Modifier and Type | Method | Description | 
|---|---|---|
| java.lang.String | absoluteProjectPath(java.lang.String path) | Converts a name to an absolute project path, resolving names relative to this project. | 
| void | afterEvaluate(Closure closure) | Adds a closure to call immediately after this project is evaluated. | 
| void | afterEvaluate(Action<? super Project> action) | Adds an action to call immediately after this project is evaluated. | 
| void | allprojects(Closure configureClosure) | Configures this project and each of its sub-projects. | 
| void | allprojects(Action<? super Project> action) | Configures this project and each of its sub-projects. | 
| AntBuilder | ant(Closure configureClosure) | Executes the given closure against the  AntBuilderfor this project. | 
| AntBuilder | ant(Action<? super AntBuilder> configureAction) | Executes the given action against the  AntBuilderfor this project. | 
| void | artifacts(Closure configureClosure) | Configures the published artifacts for this project. | 
| void | artifacts(Action<? super ArtifactHandler> configureAction) | Configures the published artifacts for this project. | 
| void | beforeEvaluate(Closure closure) | Adds a closure to call immediately before this project is evaluated. | 
| void | beforeEvaluate(Action<? super Project> action) | Adds an action to call immediately before this project is evaluated. | 
| void | buildscript(Closure configureClosure) | Configures the build script classpath for this project. | 
| void | components(Action<? super SoftwareComponentContainer> configuration) | Configures software components. | 
| void | configurations(Closure configureClosure) | Configures the dependency configurations for this project. | 
| java.lang.Iterable<?> | configure(java.lang.Iterable<?> objects,
         Closure configureClosure) | Configures a collection of objects via a closure. | 
| <T> java.lang.Iterable<T> | configure(java.lang.Iterable<T> objects,
         Action<? super T> configureAction) | Configures a collection of objects via an action. | 
| java.lang.Object | configure(java.lang.Object object,
         Closure configureClosure) | Configures an object via a closure, with the closure's delegate set to the supplied object. | 
| <T> NamedDomainObjectContainer<T> | container(java.lang.Class<T> type) | Creates a container for managing named objects of the specified type. | 
| <T> NamedDomainObjectContainer<T> | container(java.lang.Class<T> type,
         Closure factoryClosure) | Creates a container for managing named objects of the specified type. | 
| <T> NamedDomainObjectContainer<T> | container(java.lang.Class<T> type,
         NamedDomainObjectFactory<T> factory) | Creates a container for managing named objects of the specified type. | 
| WorkResult | copy(Closure closure) | Copies the specified files. | 
| WorkResult | copy(Action<? super CopySpec> action) | Copies the specified files. | 
| CopySpec | copySpec() | Creates a  CopySpecwhich can later be used to copy files or create an archive. | 
| CopySpec | copySpec(Closure closure) | Creates a  CopySpecwhich can later be used to copy files or create an archive. | 
| CopySpec | copySpec(Action<? super CopySpec> action) | Creates a  CopySpecwhich can later be used to copy files or create an archive. | 
| AntBuilder | createAntBuilder() | Creates an additional  AntBuilderfor this project. | 
| void | defaultTasks(java.lang.String... defaultTasks) | Sets the names of the default tasks of this project. | 
| boolean | delete(java.lang.Object... paths) | Deletes files and directories. | 
| WorkResult | delete(Action<? super DeleteSpec> action) | Deletes the specified files. | 
| void | dependencies(Closure configureClosure) | Configures the dependencies for this project. | 
| void | dependencyLocking(Action<? super DependencyLockingHandler> configuration) | Configures dependency locking | 
| int | depthCompare(Project otherProject) | Compares the nesting level of this project with another project of the multi-project hierarchy. | 
| Project | evaluationDependsOn(java.lang.String path) | Declares that this project has an evaluation dependency on the project with the given path. | 
| void | evaluationDependsOnChildren() | Declares that this project has an evaluation dependency on each of its child projects. | 
| ExecResult | exec(Closure closure) | Executes an external command. | 
| ExecResult | exec(Action<? super ExecSpec> action) | Executes an external command. | 
| java.io.File | file(java.lang.Object path) | Resolves a file path relative to the project directory of this project. | 
| java.io.File | file(java.lang.Object path,
    PathValidation validation) | Resolves a file path relative to the project directory of this project and validates it using the given
 scheme. | 
| ConfigurableFileCollection | files(java.lang.Object... paths) | Returns a  ConfigurableFileCollectioncontaining the given files. | 
| ConfigurableFileCollection | files(java.lang.Object paths,
     Closure configureClosure) | Creates a new  ConfigurableFileCollectionusing the given paths. | 
| ConfigurableFileCollection | files(java.lang.Object paths,
     Action<? super ConfigurableFileCollection> configureAction) | Creates a new  ConfigurableFileCollectionusing the given paths. | 
| ConfigurableFileTree | fileTree(java.lang.Object baseDir) | Creates a new  ConfigurableFileTreeusing the given base directory. | 
| ConfigurableFileTree | fileTree(java.lang.Object baseDir,
        Closure configureClosure) | Creates a new  ConfigurableFileTreeusing the given base directory. | 
| ConfigurableFileTree | fileTree(java.lang.Object baseDir,
        Action<? super ConfigurableFileTree> configureAction) | Creates a new  ConfigurableFileTreeusing the given base directory. | 
| ConfigurableFileTree | fileTree(java.util.Map<java.lang.String,?> args) | Creates a new  ConfigurableFileTreeusing the provided map of arguments. | 
| Project | findProject(java.lang.String path) | Locates a project by path. | 
| java.lang.Object | findProperty(java.lang.String propertyName) | Returns the value of the given property or null if not found. | 
| java.util.Set<Project> | getAllprojects() | Returns the set containing this project and its subprojects. | 
| java.util.Map<Project,java.util.Set<Task>> | getAllTasks(boolean recursive) | Returns a map of the tasks contained in this project, and optionally its subprojects. | 
| AntBuilder | getAnt() | Returns the  AntBuilderfor this project. | 
| ArtifactHandler | getArtifacts() | Returns a handler for assigning artifacts produced by the project to configurations. | 
| java.io.File | getBuildDir() | Deprecated.
 Use  getLayout().getBuildDirectory()instead | 
| java.io.File | getBuildFile() | The build script for this project. | 
| ScriptHandler | getBuildscript() | Returns the build script handler for this project. | 
| java.lang.String | getBuildTreePath() | Returns a path to the project for the full build tree. | 
| java.util.Map<java.lang.String,Project> | getChildProjects() | Returns the direct children of this project. | 
| SoftwareComponentContainer | getComponents() | Returns the software components produced by this project. | 
| ConfigurationContainer | getConfigurations() | Returns the configurations of this project. | 
| Convention | getConvention() | Deprecated.
 The concept of conventions is deprecated. | 
| java.util.List<java.lang.String> | getDefaultTasks() | Returns the names of the default tasks of this project. | 
| DependencyHandler | getDependencies() | Returns the dependency handler of this project. | 
| DependencyFactory | getDependencyFactory() | Provides access to methods to create various kinds of  Dependencyinstances. | 
| DependencyLockingHandler | getDependencyLocking() | Provides access to configuring dependency locking | 
| int | getDepth() | Returns the nesting level of a project in a multi-project hierarchy. | 
| java.lang.String | getDescription() | Returns the description of this project, if any. | 
| java.lang.String | getDisplayName() | Returns a human-consumable display name for this project. | 
| ExtensionContainer | getExtensions() | Allows adding DSL extensions to the project. | 
| Gradle | getGradle() | Returns the  Gradleinvocation which this project belongs to. | 
| java.lang.Object | getGroup() | Returns the group of this project. | 
| ProjectLayout | getLayout() | Provides access to various important directories for this project. | 
| Logger | getLogger() | Returns the logger for this project. | 
| LoggingManager | getLogging() | Returns the  LoggingManagerwhich can be used to receive logging and to control the
 standard output/error capture for this project's build script. | 
| java.lang.String | getName() | Returns the name of this project. | 
| InputNormalizationHandler | getNormalization() | Provides access to configuring input normalization. | 
| ObjectFactory | getObjects() | Provides access to methods to create various kinds of model objects. | 
| Project | getParent() | Returns the parent project of this project, if any. | 
| java.lang.String | getPath() | Returns the path of this project. | 
| Project | getProject() | Returns this project. | 
| java.io.File | getProjectDir() | The directory containing the project build file. | 
| java.util.Map<java.lang.String,?> | getProperties() | Returns the properties of this project. | 
| ProviderFactory | getProviders() | Provides access to methods to create various kinds of  Providerinstances. | 
| RepositoryHandler | getRepositories() | Returns a handler to create repositories which are used for retrieving dependencies and uploading artifacts
 produced by the project. | 
| ResourceHandler | getResources() | Provides access to resource-specific utility methods, for example factory methods that create various resources. | 
| java.io.File | getRootDir() | Returns the root directory of this project. | 
| Project | getRootProject() | Returns the root project for the hierarchy that this project belongs to. | 
| ProjectState | getState() | Returns the evaluation state of this project. | 
| java.lang.Object | getStatus() | Returns the status of this project. | 
| java.util.Set<Project> | getSubprojects() | Returns the set containing the subprojects of this project. | 
| TaskContainer | getTasks() | Returns the tasks of this project. | 
| java.util.Set<Task> | getTasksByName(java.lang.String name,
              boolean recursive) | Returns the set of tasks with the given name contained in this project, and optionally its subprojects. | 
| java.lang.Object | getVersion() | Returns the version of this project. | 
| boolean | hasProperty(java.lang.String propertyName) | Determines if this project has the given property. | 
| ExecResult | javaexec(Closure closure) | Executes a Java main class. | 
| ExecResult | javaexec(Action<? super JavaExecSpec> action) | Executes an external Java process. | 
| java.io.File | mkdir(java.lang.Object path) | Creates a directory and returns a file pointing to it. | 
| void | normalization(Action<? super InputNormalizationHandler> configuration) | Configures input normalization. | 
| Project | project(java.lang.String path) | Locates a project by path. | 
| Project | project(java.lang.String path,
       Closure configureClosure) | Locates a project by path and configures it using the given closure. | 
| Project | project(java.lang.String path,
       Action<? super Project> configureAction) | Locates a project by path and configures it using the given action. | 
| java.lang.Object | property(java.lang.String propertyName) | Returns the value of the given property. | 
| <T> Provider<T> | provider(java.util.concurrent.Callable<? extends @Nullable T> value) | Creates a  Providerimplementation based on the provided value. | 
| java.lang.String | relativePath(java.lang.Object path) | Returns the relative path from the project directory to the given path. | 
| java.lang.String | relativeProjectPath(java.lang.String path) | Converts a name to a project path relative to this project. | 
| void | repositories(Closure configureClosure) | Configures the repositories for this project. | 
| void | setBuildDir(java.io.File path) | Deprecated.
 Use  getLayout().getBuildDirectory()and set theDirectoryProperty | 
| void | setBuildDir(java.lang.Object path) | Deprecated.
 Use  getLayout().getBuildDirectory()and set theDirectoryProperty | 
| void | setDefaultTasks(java.util.List<java.lang.String> defaultTasks) | Sets the names of the default tasks of this project. | 
| void | setDescription(java.lang.String description) | Sets a description for this project. | 
| void | setGroup(java.lang.Object group) | Sets the group of this project. | 
| void | setProperty(java.lang.String name,
           java.lang.Object value) | Sets a property of this project. | 
| void | setStatus(java.lang.Object status) | Sets the status of this project. | 
| void | setVersion(java.lang.Object version) | Sets the version of this project. | 
| void | subprojects(Closure configureClosure) | Configures the sub-projects of this project. | 
| void | subprojects(Action<? super Project> action) | Configures the sub-projects of this project | 
| WorkResult | sync(Action<? super SyncSpec> action) | Synchronizes the contents of a destination directory with some source directories and files. | 
| FileTree | tarTree(java.lang.Object tarPath) | Creates a new  FileTreewhich contains the contents of the given TAR file. | 
| Task | task(java.lang.String name) | Creates a  Taskwith the given name and adds it to this project. | 
| Task | task(java.lang.String name,
    Closure configureClosure) | Creates a  Taskwith the given name and adds it to this project. | 
| Task | task(java.lang.String name,
    Action<? super Task> configureAction) | Creates a  Taskwith the given name and adds it to this project. | 
| Task | task(java.util.Map<java.lang.String,?> args,
    java.lang.String name) | Creates a  Taskwith the given name and adds it to this project. | 
| Task | task(java.util.Map<java.lang.String,?> args,
    java.lang.String name,
    Closure configureClosure) | Creates a  Taskwith the given name and adds it to this project. | 
| java.net.URI | uri(java.lang.Object path) | Resolves a file path to a URI, relative to the project directory of this project. | 
| FileTree | zipTree(java.lang.Object zipPath) | Creates a new  FileTreewhich contains the contents of the given ZIP file. | 
apply, apply, apply, getPluginManager, getPluginsstatic final java.lang.String DEFAULT_BUILD_FILE
static final java.lang.String PATH_SEPARATOR
static final java.lang.String DEFAULT_BUILD_DIR_NAME
static final java.lang.String GRADLE_PROPERTIES
static final java.lang.String SYSTEM_PROP_PREFIX
static final java.lang.String DEFAULT_VERSION
static final java.lang.String DEFAULT_STATUS
Project getRootProject()
Returns the root project for the hierarchy that this project belongs to. In the case of a single-project build, this method returns this project.
java.io.File getRootDir()
Returns the root directory of this project. The root directory is the project directory of the root project.
@Deprecated java.io.File getBuildDir()
getLayout().getBuildDirectory() insteadReturns the build directory of this project.  The build directory is the directory which all artifacts are
 generated into.  The default value for the build directory is projectDir/build
@Deprecated void setBuildDir(java.io.File path)
getLayout().getBuildDirectory() and set the DirectoryPropertySets the build directory of this project. The build directory is the directory which all artifacts are generated into.
path - The build directory@Deprecated void setBuildDir(java.lang.Object path)
getLayout().getBuildDirectory() and set the DirectoryPropertySets the build directory of this project. The build directory is the directory which all artifacts are
 generated into. The path parameter is evaluated as described for file(Object). This mean you can use,
 amongst other things, a relative or absolute path or File object to specify the build directory.
path - The build directory. This is evaluated as per file(Object)java.io.File getBuildFile()
If the file exists, it will be evaluated against this project when this project is configured.
@Nullable Project getParent()
Returns the parent project of this project, if any.
java.lang.String getName()
Returns the name of this project. The project's name is not necessarily unique within a project hierarchy. You
 should use the getPath() method for a unique identifier for the project.
 If the root project is unnamed and is located on a file system root it will have a randomly-generated name
 
java.lang.String getDisplayName()
@Nullable java.lang.String getDescription()
void setDescription(@Nullable
                    java.lang.String description)
description - The description of the project. Might be null.java.lang.Object getGroup()
Returns the group of this project. Gradle always uses the toString() value of the group. The group
 defaults to the path with dots as separators.
void setGroup(java.lang.Object group)
Sets the group of this project.
group - The group of this project. Must not be null.java.lang.Object getVersion()
Returns the version of this project. Gradle always uses the toString() value of the version. The
 version defaults to "unspecified".
void setVersion(java.lang.Object version)
Sets the version of this project.
version - The version of this project. Must not be null.java.lang.Object getStatus()
Returns the status of this project. Gradle always uses the toString() value of the status. The status
 defaults to "release".
The status of the project is only relevant, if you upload libraries together with a module descriptor. The status specified here, will be part of this module descriptor.
void setStatus(java.lang.Object status)
status - The status. Must not be null.java.util.Map<java.lang.String,Project> getChildProjects()
Returns the direct children of this project.
void setProperty(java.lang.String name,
                 @Nullable
                 java.lang.Object value)
          throws MissingPropertyException
Sets a property of this project. This method searches for a property with the given name in the following locations, and sets the property on the first location where it finds the property.
rootDir project property.Convention object.  For example, the srcRootName java plugin
 property.MissingPropertyException is thrown.name - The name of the propertyvalue - The value of the propertyMissingPropertyExceptionProject getProject()
Returns this project. This method is useful in build files to explicitly access project properties and
 methods. For example, using project.name can express your intent better than using
 name. This method also allows you to access project properties from a scope where the property may
 be hidden, such as, for example, from a method or closure. 
java.util.Set<Project> getAllprojects()
Returns the set containing this project and its subprojects.
java.util.Set<Project> getSubprojects()
Returns the set containing the subprojects of this project.
Task task(java.lang.String name) throws InvalidUserDataException
Creates a Task with the given name and adds it to this project. Calling this method is equivalent to
 calling task(java.util.Map, String) with an empty options map.
After the task is added to the project, it is made available as a property of the project, so that you can reference the task by name in your build file. See here for more details
If a task with the given name already exists in this project, an exception is thrown.
name - The name of the task to be createdInvalidUserDataException - If a task with the given name already exists in this project.Task task(java.util.Map<java.lang.String,?> args, java.lang.String name) throws InvalidUserDataException
Creates a Task with the given name and adds it to this project. A map of creation options can be
 passed to this method to control how the task is created. The following options are available:
| Option | Description | Default Value | 
|---|---|---|
| "type" | The class of the task to create. | DefaultTask | 
| "overwrite" | Replace an existing task? | false | 
| "dependsOn" | A task name or set of task names which this task depends on | [] | 
| "action" | A closure or Actionto add to the
 task. | null | 
| "description" | A description of the task. | null | 
| "group" | A task group which this task belongs to. | null | 
After the task is added to the project, it is made available as a property of the project, so that you can reference the task by name in your build file. See here for more details
If a task with the given name already exists in this project and the override option is not set
 to true, an exception is thrown.
args - The task creation options.name - The name of the task to be createdInvalidUserDataException - If a task with the given name already exists in this project.Task task(java.util.Map<java.lang.String,?> args, java.lang.String name, Closure configureClosure)
Creates a Task with the given name and adds it to this project. Before the task is returned, the given
 closure is executed to configure the task. A map of creation options can be passed to this method to control how
 the task is created. See task(java.util.Map, String) for the available options.
After the task is added to the project, it is made available as a property of the project, so that you can reference the task by name in your build file. See here for more details
If a task with the given name already exists in this project and the override option is not set
 to true, an exception is thrown.
args - The task creation options.name - The name of the task to be createdconfigureClosure - The closure to use to configure the created task.InvalidUserDataException - If a task with the given name already exists in this project.Task task(java.lang.String name, @DelegatesTo(Task.class) Closure configureClosure)
Creates a Task with the given name and adds it to this project. Before the task is returned, the given
 closure is executed to configure the task.
After the task is added to the project, it is made available as a property of the project, so that you can reference the task by name in your build file. See here for more details
name - The name of the task to be createdconfigureClosure - The closure to use to configure the created task.InvalidUserDataException - If a task with the given name already exists in this project.Task task(java.lang.String name, Action<? super Task> configureAction)
Creates a Task with the given name and adds it to this project. Before the task is returned, the given
 action is executed to configure the task.
After the task is added to the project, it is made available as a property of the project, so that you can reference the task by name in your build file. See here for more details
name - The name of the task to be createdconfigureAction - The action to use to configure the created task.InvalidUserDataException - If a task with the given name already exists in this project.NamedDomainObjectContainer.create(String, Action)java.lang.String getPath()
Returns the path of this project. The path is the fully qualified name of the project.
@Incubating java.lang.String getBuildTreePath()
java.util.List<java.lang.String> getDefaultTasks()
Returns the names of the default tasks of this project. These are used when no tasks names are provided when starting the build.
void setDefaultTasks(java.util.List<java.lang.String> defaultTasks)
Sets the names of the default tasks of this project. These are used when no tasks names are provided when starting the build.
defaultTasks - The default task names.void defaultTasks(java.lang.String... defaultTasks)
Sets the names of the default tasks of this project. These are used when no tasks names are provided when starting the build.
defaultTasks - The default task names.Project evaluationDependsOn(java.lang.String path) throws UnknownProjectException
Declares that this project has an evaluation dependency on the project with the given path.
path - The path of the project which this project depends on.UnknownProjectException - If no project with the given path exists.void evaluationDependsOnChildren()
Declares that this project has an evaluation dependency on each of its child projects.
@Nullable Project findProject(java.lang.String path)
Locates a project by path. If the path is relative, it is interpreted relative to this project.
path - The path.Project project(java.lang.String path) throws UnknownProjectException
Locates a project by path. If the path is relative, it is interpreted relative to this project.
path - The path.UnknownProjectException - If no project with the given path exists.Project project(java.lang.String path, @DelegatesTo(Project.class) Closure configureClosure)
Locates a project by path and configures it using the given closure. If the path is relative, it is interpreted relative to this project. The target project is passed to the closure as the closure's delegate.
path - The path.configureClosure - The closure to use to configure the project.UnknownProjectException - If no project with the given path exists.Project project(java.lang.String path, Action<? super Project> configureAction)
Locates a project by path and configures it using the given action. If the path is relative, it is interpreted relative to this project.
path - The path.configureAction - The action to use to configure the project.UnknownProjectException - If no project with the given path exists.java.util.Map<Project,java.util.Set<Task>> getAllTasks(boolean recursive)
Returns a map of the tasks contained in this project, and optionally its subprojects.
recursive - If true, returns the tasks of this project and its subprojects.  If false, returns the tasks of
 just this project.java.util.Set<Task> getTasksByName(java.lang.String name, boolean recursive)
Returns the set of tasks with the given name contained in this project, and optionally its subprojects. NOTE: This is an expensive operation since it requires all projects to be configured.
name - The name of the task to locate.recursive - If true, returns the tasks of this project and its subprojects. If false, returns the tasks of
 just this project.java.io.File getProjectDir()
The directory containing the project build file.
java.io.File file(java.lang.Object path)
Resolves a file path relative to the project directory of this project. This method converts the supplied path based on its type:
CharSequence, including String or GString. Interpreted relative to the project directory. A string that starts with file: is treated as a file URL.File. If the file is an absolute file, it is returned as is. Otherwise, the file's path is
 interpreted relative to the project directory.Path. The path must be associated with the default provider and is treated the
 same way as an instance of File.URI or URL. The URL's path is interpreted as the file path. Only file: URLs are supported.Directory or RegularFile.Provider of any supported type. The provider's value is resolved recursively.TextResource.Closure or Kotlin function that returns any supported type. The closure's return value is resolved recursively.Callable that returns any supported type. The callable's return value is resolved recursively.path - The object to resolve as a File.java.io.File file(java.lang.Object path,
                  PathValidation validation)
           throws InvalidUserDataException
Resolves a file path relative to the project directory of this project and validates it using the given
 scheme. See PathValidation for the list of possible validations.
path - An object which toString method value is interpreted as a relative path to the project directory.validation - The validation to perform on the file.InvalidUserDataException - When the file does not meet the given validation constraint.java.net.URI uri(java.lang.Object path)
Resolves a file path to a URI, relative to the project directory of this project. Evaluates the provided path
 object as described for file(Object), with the exception that any URI scheme is supported, not just
 'file:' URIs.
path - The object to resolve as a URI.java.lang.String relativePath(java.lang.Object path)
Returns the relative path from the project directory to the given path. The given path object is (logically)
 resolved as described for file(Object), from which a relative path is calculated.
path - The path to convert to a relative path.java.lang.IllegalArgumentException - If the given path cannot be relativized against the project directory.ConfigurableFileCollection files(java.lang.Object... paths)
Returns a ConfigurableFileCollection containing the given files. You can pass any of the following
 types to this method:
CharSequence, including String or GString. Interpreted relative to the project directory, as per file(Object). A string that starts with file: is treated as a file URL.File. Interpreted relative to the project directory, as per file(Object).Path, as per file(Object).URI or URL. The URL's path is interpreted as a file path. Only file: URLs are supported.Directory or RegularFile.Collection, Iterable, or an array that contains objects of any supported type. The elements of the collection are recursively converted to files.FileCollection. The contents of the collection are included in the returned collection.FileTree or DirectoryTree. The contents of the tree are included in the returned collection.Provider of any supported type. The provider's value is recursively converted to files. If the provider represents an output of a task, that task is executed if the file collection is used as an input to another task.
 Callable that returns any supported type. The return value of the call() method is recursively converted to files. A null return value is treated as an empty collection.Closure or Kotlin function that returns any of the types listed here. The return value of the closure is recursively converted to files. A null return value is treated as an empty collection.Task. Converted to the task's output files. The task is executed if the file collection is used as an input to another task.TaskOutputs. Converted to the output files the related task. The task is executed if the file collection is used as an input to another task.The returned file collection is lazy, so that the paths are evaluated only when the contents of the file collection are queried. The file collection is also live, so that it evaluates the above each time the contents of the collection is queried.
The returned file collection maintains the iteration order of the supplied paths.
The returned file collection maintains the details of the tasks that produce the files, so that these tasks are executed if this file collection is used as an input to some task.
This method can also be used to create an empty collection, which can later be mutated to add elements.
paths - The paths to the files. May be empty.ConfigurableFileCollection files(java.lang.Object paths, @DelegatesTo(ConfigurableFileCollection.class) Closure configureClosure)
Creates a new ConfigurableFileCollection using the given paths. The paths are evaluated as per files(Object...). The file collection is configured using the given closure. The file collection is passed to
 the closure as its delegate. Example:
 files "$buildDir/classes" {
     builtBy 'compile'
 }
 
 The returned file collection is lazy, so that the paths are evaluated only when the contents of the file collection are queried. The file collection is also live, so that it evaluates the above each time the contents of the collection is queried.
paths - The contents of the file collection. Evaluated as per files(Object...).configureClosure - The closure to use to configure the file collection.ConfigurableFileCollection files(java.lang.Object paths, Action<? super ConfigurableFileCollection> configureAction)
Creates a new ConfigurableFileCollection using the given paths. The paths are evaluated as per files(Object...). The file collection is configured using the given action. Example:
 files "$buildDir/classes" {
     builtBy 'compile'
 }
 
 The returned file collection is lazy, so that the paths are evaluated only when the contents of the file collection are queried. The file collection is also live, so that it evaluates the above each time the contents of the collection is queried.
paths - The contents of the file collection. Evaluated as per files(Object...).configureAction - The action to use to configure the file collection.ConfigurableFileTree fileTree(java.lang.Object baseDir)
Creates a new ConfigurableFileTree using the given base directory. The given baseDir path is evaluated
 as per file(Object).
The returned file tree is lazy, so that it scans for files only when the contents of the file tree are queried. The file tree is also live, so that it scans for files each time the contents of the file tree are queried.
 def myTree = fileTree("src")
 myTree.include "**/*.java"
 myTree.builtBy "someTask"
 task copy(type: Copy) {
    from myTree
 }
 
 The order of the files in a FileTree is not stable, even on a single computer.
baseDir - The base directory of the file tree. Evaluated as per file(Object).ConfigurableFileTree fileTree(java.lang.Object baseDir, @DelegatesTo(ConfigurableFileTree.class) Closure configureClosure)
Creates a new ConfigurableFileTree using the given base directory. The given baseDir path is evaluated
 as per file(Object). The closure will be used to configure the new file tree.
 The file tree is passed to the closure as its delegate.  Example:
 def myTree = fileTree('src') {
    exclude '**/.data/**'
    builtBy 'someTask'
 }
 task copy(type: Copy) {
    from myTree
 }
 
 The returned file tree is lazy, so that it scans for files only when the contents of the file tree are queried. The file tree is also live, so that it scans for files each time the contents of the file tree are queried.
The order of the files in a FileTree is not stable, even on a single computer.
baseDir - The base directory of the file tree. Evaluated as per file(Object).configureClosure - Closure to configure the ConfigurableFileTree object.ConfigurableFileTree fileTree(java.lang.Object baseDir, Action<? super ConfigurableFileTree> configureAction)
Creates a new ConfigurableFileTree using the given base directory. The given baseDir path is evaluated
 as per file(Object). The action will be used to configure the new file tree. Example:
 def myTree = fileTree('src') {
    exclude '**/.data/**'
    builtBy 'someTask'
 }
 task copy(type: Copy) {
    from myTree
 }
 
 The returned file tree is lazy, so that it scans for files only when the contents of the file tree are queried. The file tree is also live, so that it scans for files each time the contents of the file tree are queried.
The order of the files in a FileTree is not stable, even on a single computer.
baseDir - The base directory of the file tree. Evaluated as per file(Object).configureAction - Action to configure the ConfigurableFileTree object.ConfigurableFileTree fileTree(java.util.Map<java.lang.String,?> args)
Creates a new ConfigurableFileTree using the provided map of arguments.  The map will be applied as
 properties on the new file tree.  Example:
 def myTree = fileTree(dir:'src', excludes:['**/ignore/**', '**/.data/**'])
 task copy(type: Copy) {
     from myTree
 }
 
 The returned file tree is lazy, so that it scans for files only when the contents of the file tree are queried. The file tree is also live, so that it scans for files each time the contents of the file tree are queried.
The order of the files in a FileTree is not stable, even on a single computer.
args - map of property assignments to ConfigurableFileTree objectFileTree zipTree(java.lang.Object zipPath)
Creates a new FileTree which contains the contents of the given ZIP file. The given zipPath path is
 evaluated as per file(Object). You can combine this method with the copy(Action)
 method to unzip a ZIP file.
The returned file tree is lazy, so that it scans for files only when the contents of the file tree are queried. The file tree is also live, so that it scans for files each time the contents of the file tree are queried.
zipPath - The ZIP file. Evaluated as per file(Object).FileTree tarTree(java.lang.Object tarPath)
FileTree which contains the contents of the given TAR file. The given tarPath path can be:
 Resourcefile(Object)Unless custom implementation of resources is passed, the tar tree attempts to guess the compression based on the file extension.
 You can combine this method with the copy(Action)
 method to untar a TAR file:
 
 task untar(type: Copy) {
   from tarTree('someCompressedTar.gzip')
   //tar tree attempts to guess the compression based on the file extension
   //however if you must specify the compression explicitly you can:
   from tarTree(resources.gzip('someTar.ext'))
   //in case you work with unconventionally compressed tars
   //you can provide your own implementation of a ReadableResource:
   //from tarTree(yourOwnResource as ReadableResource)
   into 'dest'
 }
 tarPath - The TAR file or an instance of Resource.<T> Provider<T> provider(java.util.concurrent.Callable<? extends @Nullable T> value)
Provider implementation based on the provided value.
 The provider is live and will call the Callable each time its value is queried. The Callable may return null, in which case the provider is considered to have no value.
value - The Callable use to calculate the value.ProviderFactory.provider(Callable)ProviderFactory getProviders()
Provider instances.ObjectFactory getObjects()
ProjectLayout getLayout()
java.io.File mkdir(java.lang.Object path)
path - The path for the directory to be created. Evaluated as per file(Object).InvalidUserDataException - If the path points to an existing file.boolean delete(java.lang.Object... paths)
 This will not follow symlinks. If you need to follow symlinks too use delete(Action).
paths - Any type of object accepted by files(Object...)WorkResult delete(Action<? super DeleteSpec> action)
DeleteSpec, which is then used to
 delete the files.
 Example:
 project.delete {
     delete 'somefile'
     followSymlinks = true
 }
 action - Action to configure the DeleteSpecWorkResult that can be used to check if delete did any work.ExecResult javaexec(@DelegatesTo(JavaExecSpec.class) Closure closure)
JavaExecSpec.closure - The closure for configuring the execution.ExecResult javaexec(Action<? super JavaExecSpec> action)
 The given action configures a JavaExecSpec, which is used to launch the process.
 This method blocks until the process terminates, with its result being returned.
action - The action for configuring the execution.ExecResult exec(@DelegatesTo(ExecSpec.class) Closure closure)
ExecSpec.closure - The closure for configuring the execution.ExecResult exec(Action<? super ExecSpec> action)
 The given action configures a ExecSpec, which is used to launch the process.
 This method blocks until the process terminates, with its result being returned.
action - The action for configuring the execution.java.lang.String absoluteProjectPath(java.lang.String path)
Converts a name to an absolute project path, resolving names relative to this project.
path - The path to convert.java.lang.String relativeProjectPath(java.lang.String path)
Converts a name to a project path relative to this project.
path - The path to convert.AntBuilder getAnt()
Returns the AntBuilder for this project. You can use this in your build file to execute ant
 tasks. See example below.
 task printChecksum {
   doLast {
     ant {
       //using ant checksum task to store the file checksum in the checksumOut ant property
       checksum(property: 'checksumOut', file: 'someFile.txt')
       //we can refer to the ant property created by checksum task:
       println "The checksum is: " + checksumOut
     }
     //we can refer to the ant property later as well:
     println "I just love to print checksums: " + ant.checksumOut
   }
 }
 
 Consider following example of ant target:
 
 <target name='printChecksum'>
   <checksum property='checksumOut'>
     <fileset dir='.'>
       <include name='agile.txt'/>
     </fileset>
   </checksum>
   <echo>The checksum is: ${checksumOut}</echo>
 </target>
 
 Here's how it would look like in gradle. Observe how the ant XML is represented in groovy by the ant builder
 
 task printChecksum {
   doLast {
     ant {
       checksum(property: 'checksumOut') {
         fileset(dir: '.') {
           include name: 'agile1.txt'
         }
       }
     }
     logger.lifecycle("The checksum is $ant.checksumOut")
   }
 }
 AntBuilder for this project. Never returns null.AntBuilder createAntBuilder()
Creates an additional AntBuilder for this project. You can use this in your build file to execute
 ant tasks.
AntBuilder for this project. Never returns null.getAnt()AntBuilder ant(@DelegatesTo(AntBuilder.class) Closure configureClosure)
Executes the given closure against the AntBuilder for this project. You can use this in your
 build file to execute ant tasks. The AntBuild is passed to the closure as the closure's
 delegate. See example in javadoc for getAnt()
configureClosure - The closure to execute against the AntBuilder.AntBuilder. Never returns null.AntBuilder ant(Action<? super AntBuilder> configureAction)
Executes the given action against the AntBuilder for this project. You can use this in your
 build file to execute ant tasks. See example in javadoc for getAnt()
configureAction - The action to execute against the AntBuilder.AntBuilder. Never returns null.ConfigurationContainer getConfigurations()
ConfigurationContainervoid configurations(Closure configureClosure)
Configures the dependency configurations for this project.
This method executes the given closure against the ConfigurationContainer
 for this project. The ConfigurationContainer is passed to the closure as the closure's delegate.
 
ConfigurationContainerconfigureClosure - the closure to use to configure the dependency configurations.ArtifactHandler getArtifacts()
ArtifactHandlervoid artifacts(@DelegatesTo(ArtifactHandler.class) Closure configureClosure)
Configures the published artifacts for this project.
This method executes the given closure against the ArtifactHandler for this project. The ArtifactHandler is passed to the closure as the closure's delegate.
 
Example:
 configurations {
   //declaring new configuration that will be used to associate with artifacts
   schema
 }
 task schemaJar(type: Jar) {
   //some imaginary task that creates a jar artifact with the schema
 }
 //associating the task that produces the artifact with the configuration
 artifacts {
   //configuration name and the task:
   schema schemaJar
 }
 configureClosure - the closure to use to configure the published artifacts.void artifacts(Action<? super ArtifactHandler> configureAction)
Configures the published artifacts for this project.
This method executes the given action against the ArtifactHandler for this project.
 
Example:
 configurations {
   //declaring new configuration that will be used to associate with artifacts
   schema
 }
 task schemaJar(type: Jar) {
   //some imaginary task that creates a jar artifact with the schema
 }
 //associating the task that produces the artifact with the configuration
 artifacts {
   //configuration name and the task:
   schema schemaJar
 }
 configureAction - the action to use to configure the published artifacts.@Deprecated Convention getConvention()
Returns the Convention for this project.
You can access this property in your build file
 using convention. You can also access the properties and methods of the convention object
 as if they were properties and methods of this project. See here for more details
Convention. Never returns null.ExtensionAware.getExtensions()int depthCompare(Project otherProject)
Compares the nesting level of this project with another project of the multi-project hierarchy.
otherProject - The project to compare the nesting level with.getDepth()int getDepth()
Returns the nesting level of a project in a multi-project hierarchy. For single project builds this is always 0. In a multi-project hierarchy 0 is returned for the root project.
TaskContainer getTasks()
Returns the tasks of this project.
void subprojects(Action<? super Project> action)
Configures the sub-projects of this project
This method executes the given Action against the sub-projects of this project.
action - The action to execute.void subprojects(@DelegatesTo(Project.class) Closure configureClosure)
Configures the sub-projects of this project.
This method executes the given closure against each of the sub-projects of this project. The target Project is passed to the closure as the closure's delegate.
configureClosure - The closure to execute.void allprojects(Action<? super Project> action)
Configures this project and each of its sub-projects.
This method executes the given Action against this project and each of its sub-projects.
action - The action to execute.void allprojects(@DelegatesTo(Project.class) Closure configureClosure)
Configures this project and each of its sub-projects.
This method executes the given closure against this project and its sub-projects. The target Project
 is passed to the closure as the closure's delegate.
configureClosure - The closure to execute.void beforeEvaluate(Action<? super Project> action)
Adds an action to call immediately before this project is evaluated.
Passes the project to the action as a parameter. Actions passed to this method execute in the same order they were passed.
If the project has already been evaluated, the action never executes.
If you call this method within a beforeEvaluate action, the passed action never executes.
action - the action to execute.void afterEvaluate(Action<? super Project> action)
Adds an action to call immediately after this project is evaluated.
Passes the project to the action as a parameter. Actions passed to this method execute in the same order they were passed. A parent project may add an action to its child projects to further configure those projects based on their state after their build files run.
If the project has already been evaluated, this method fails.
If you call this method within an afterEvaluate action, the passed action executes after all
 previously added afterEvaluate actions finish executing.
action - the action to execute.void beforeEvaluate(Closure closure)
Adds a closure to call immediately before this project is evaluated.
closure - The closure to call.beforeEvaluate(Action)void afterEvaluate(@DelegatesTo(Project.class) Closure closure)
Adds a closure to call immediately after this project is evaluated.
closure - The closure to call.afterEvaluate(Action)boolean hasProperty(java.lang.String propertyName)
Determines if this project has the given property. See here for details of the properties which are available for a project.
propertyName - The name of the property to locate.java.util.Map<java.lang.String,?> getProperties()
Returns the properties of this project. See here for details of the properties which are available for a project.
@Nullable
java.lang.Object property(java.lang.String propertyName)
                   throws MissingPropertyException
Returns the value of the given property. This method locates a property as follows:
MissingPropertyException is thrown.propertyName - The name of the property.MissingPropertyException - When the given property is unknown.findProperty(String)@Nullable java.lang.Object findProperty(java.lang.String propertyName)
Returns the value of the given property or null if not found. This method locates a property as follows:
propertyName - The name of the property.property(String)Logger getLogger()
Returns the logger for this project. You can use this in your build file to write log messages.
Gradle getGradle()
Returns the Gradle invocation which this project belongs to.
LoggingManager getLogging()
LoggingManager which can be used to receive logging and to control the
 standard output/error capture for this project's build script. By default, System.out is redirected to the Gradle
 logging system at the QUIET log level, and System.err is redirected at the ERROR log level.java.lang.Object configure(java.lang.Object object,
                           Closure configureClosure)
Configures an object via a closure, with the closure's delegate set to the supplied object. This way you don't have to specify the context of a configuration statement multiple times.
Instead of:
MyType myType = new MyType() myType.doThis() myType.doThat()
you can do:
 MyType myType = configure(new MyType()) {
     doThis()
     doThat()
 }
 
 The object being configured is also passed to the closure as a parameter, so you can access it explicitly if required:
 configure(someObj) { obj -> obj.doThis() }
 object - The object to configureconfigureClosure - The closure with configure statementsjava.lang.Iterable<?> configure(java.lang.Iterable<?> objects,
                                Closure configureClosure)
configure(Object,
 groovy.lang.Closure) for each of the given objects.objects - The objects to configureconfigureClosure - The closure with configure statements<T> java.lang.Iterable<T> configure(java.lang.Iterable<T> objects,
                                    Action<? super T> configureAction)
objects - The objects to configureconfigureAction - The action to apply to each objectRepositoryHandler getRepositories()
void repositories(Closure configureClosure)
Configures the repositories for this project.
This method executes the given closure against the RepositoryHandler for this project. The RepositoryHandler is passed to the closure as the closure's delegate.
configureClosure - the closure to use to configure the repositories.DependencyHandler getDependencies()
DependencyHandlergetConfigurations()void dependencies(Closure configureClosure)
Configures the dependencies for this project.
This method executes the given closure against the DependencyHandler for this project. The DependencyHandler is passed to the closure as the closure's delegate.
 
DependencyHandlerconfigureClosure - the closure to use to configure the dependencies.@Incubating DependencyFactory getDependencyFactory()
Dependency instances.ScriptHandler getBuildscript()
void buildscript(Closure configureClosure)
Configures the build script classpath for this project.
The given closure is executed against this project's ScriptHandler. The ScriptHandler is
 passed to the closure as the closure's delegate.
configureClosure - the closure to use to configure the build script classpath.WorkResult copy(@DelegatesTo(CopySpec.class) Closure closure)
CopySpec, which is then used to
 copy the files. Example:
 
 copy {
    from configurations.runtimeClasspath
    into 'build/deploy/lib'
 }
 
 Note that CopySpecs can be nested:
 
 copy {
    into 'build/webroot'
    exclude '**/.svn/**'
    from('src/main/webapp') {
       include '**/*.jsp'
       filter(ReplaceTokens, tokens:[copyright:'2009', version:'2.3.1'])
    }
    from('src/main/js') {
       include '**/*.js'
    }
 }
 closure - Closure to configure the CopySpecWorkResult that can be used to check if the copy did any work.WorkResult copy(Action<? super CopySpec> action)
CopySpec, which is then used to
 copy the files.action - Action to configure the CopySpecWorkResult that can be used to check if the copy did any work.copy(Closure)CopySpec copySpec(@DelegatesTo(CopySpec.class) Closure closure)
CopySpec which can later be used to copy files or create an archive. The given closure is used
 to configure the CopySpec before it is returned by this method.
 
 def baseSpec = copySpec {
    from "source"
    include "**/*.java"
 }
 task copy(type: Copy) {
    into "target"
    with baseSpec
 }
 closure - Closure to configure the CopySpecCopySpec copySpec(Action<? super CopySpec> action)
CopySpec which can later be used to copy files or create an archive. The given action is used
 to configure the CopySpec before it is returned by this method.action - Action to configure the CopySpeccopySpec(Closure)CopySpec copySpec()
CopySpec which can later be used to copy files or create an archive.WorkResult sync(Action<? super SyncSpec> action)
SyncSpec, which is then used to synchronize the files.
 
 This method is like the copy(Action) task, except the destination directory will only contain the files copied.
 All files that exist in the destination directory will be deleted before copying files, unless a preserve option is specified.
 
Example:
 project.sync {
    from 'my/shared/dependencyDir'
    into 'build/deps/compile'
 }
 
 Note that you can preserve output that already exists in the destination directory:
 
 project.sync {
     from 'source'
     into 'dest'
     preserve {
         include 'extraDir/**'
         include 'dir1/**'
         exclude 'dir1/extra.txt'
     }
 }
 action - Action to configure the SyncSpec.WorkResult that can be used to check if the sync did any work.ProjectState getState()
<T> NamedDomainObjectContainer<T> container(java.lang.Class<T> type)
Creates a container for managing named objects of the specified type. The specified type must have a public constructor which takes the name as a String parameter.
All objects MUST expose their name as a bean property named "name". The name must be constant for the life of the object.
T - The type of objects for the container to contain.type - The type of objects for the container to contain.<T> NamedDomainObjectContainer<T> container(java.lang.Class<T> type, NamedDomainObjectFactory<T> factory)
Creates a container for managing named objects of the specified type. The given factory is used to create object instances.
All objects MUST expose their name as a bean property named "name". The name must be constant for the life of the object.
T - The type of objects for the container to contain.type - The type of objects for the container to contain.factory - The factory to use to create object instances.<T> NamedDomainObjectContainer<T> container(java.lang.Class<T> type, Closure factoryClosure)
Creates a container for managing named objects of the specified type. The given closure is used to create object instances. The name of the instance to be created is passed as a parameter to the closure.
All objects MUST expose their name as a bean property named "name". The name must be constant for the life of the object.
T - The type of objects for the container to contain.type - The type of objects for the container to contain.factoryClosure - The closure to use to create object instances.ExtensionContainer getExtensions()
getExtensions in interface ExtensionAwareResourceHandler getResources()
SoftwareComponentContainer getComponents()
@Incubating void components(Action<? super SoftwareComponentContainer> configuration)
configuration - Action to configure the software components.InputNormalizationHandler getNormalization()
void normalization(Action<? super InputNormalizationHandler> configuration)
void dependencyLocking(Action<? super DependencyLockingHandler> configuration)
DependencyLockingHandler getDependencyLocking()