All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.gradle.api.Project Maven / Gradle / Ivy

There is a newer version: 8.11.1
Show newest version
/*
 * Copyright 2010 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;

import groovy.lang.Closure;
import groovy.lang.MissingPropertyException;
import org.gradle.api.artifacts.ConfigurationContainer;
import org.gradle.api.artifacts.dsl.ArtifactHandler;
import org.gradle.api.artifacts.dsl.DependencyHandler;
import org.gradle.api.artifacts.dsl.DependencyLockingHandler;
import org.gradle.api.artifacts.dsl.RepositoryHandler;
import org.gradle.api.component.SoftwareComponentContainer;
import org.gradle.api.file.ConfigurableFileCollection;
import org.gradle.api.file.ConfigurableFileTree;
import org.gradle.api.file.CopySpec;
import org.gradle.api.file.DeleteSpec;
import org.gradle.api.file.FileTree;
import org.gradle.api.file.ProjectLayout;
import org.gradle.api.initialization.dsl.ScriptHandler;
import org.gradle.api.invocation.Gradle;
import org.gradle.api.logging.Logger;
import org.gradle.api.logging.LoggingManager;
import org.gradle.api.model.ObjectFactory;
import org.gradle.api.plugins.Convention;
import org.gradle.api.plugins.ExtensionAware;
import org.gradle.api.plugins.ExtensionContainer;
import org.gradle.api.plugins.PluginAware;
import org.gradle.api.provider.Provider;
import org.gradle.api.provider.ProviderFactory;
import org.gradle.api.resources.ResourceHandler;
import org.gradle.api.tasks.TaskContainer;
import org.gradle.api.tasks.WorkResult;
import org.gradle.internal.HasInternalProtocol;
import org.gradle.normalization.InputNormalizationHandler;
import org.gradle.process.ExecResult;
import org.gradle.process.ExecSpec;
import org.gradle.process.JavaExecSpec;

import javax.annotation.Nullable;
import java.io.File;
import java.net.URI;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.Callable;

/**
 * 

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.

* *

Lifecycle

* *

There is a one-to-one relationship between a Project and a {@value #DEFAULT_BUILD_FILE} * file. During build initialisation, Gradle assembles a Project object for each project which is to * participate in the build, as follows:

* *
    * *
  • Create a {@link org.gradle.api.initialization.Settings} instance for the build.
  • * *
  • Evaluate the {@value org.gradle.api.initialization.Settings#DEFAULT_SETTINGS_FILE} script, if * present, against the {@link org.gradle.api.initialization.Settings} object to configure it.
  • * *
  • Use the configured {@link org.gradle.api.initialization.Settings} object to create the hierarchy of * Project instances.
  • * *
  • Finally, evaluate each Project by executing its {@value #DEFAULT_BUILD_FILE} 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 {@link #evaluationDependsOnChildren()} or by adding an * explicit evaluation dependency using {@link #evaluationDependsOn(String)}.
  • * *
* *

Tasks

* *

A project is essentially a collection of {@link 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 * {@code create()} methods on {@link TaskContainer}, such as {@link TaskContainer#create(String)}. You can locate existing * tasks using one of the lookup methods on {@link TaskContainer}, such as {@link org.gradle.api.tasks.TaskCollection#getByName(String)}.

* *

Dependencies

* *

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 {@link org.gradle.api.artifacts.ConfigurationContainer} * returned by {@link #getConfigurations()} method to manage the configurations. The {@link * org.gradle.api.artifacts.dsl.DependencyHandler} returned by {@link #getDependencies()} method to manage the * dependencies. The {@link org.gradle.api.artifacts.dsl.ArtifactHandler} returned by {@link #getArtifacts()} method to * manage the artifacts. The {@link org.gradle.api.artifacts.dsl.RepositoryHandler} returned by {@link * #getRepositories()} method to manage the repositories.

* *

Multi-project Builds

* *

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

* *

* Plugins can be used to modularise and reuse project configuration. * Plugins can be applied using the {@link PluginAware#apply(java.util.Map)} method, or by using the {@link org.gradle.plugin.use.PluginDependenciesSpec} plugins script block. *

* *

Dynamic Project Properties

* *

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 {@link #property(String)} method. The scopes are:

* *
    * *
  • The Project object itself. This scope includes any property getters and setters declared by the * Project implementation class. For example, {@link #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.
  • * *
  • The extra properties of the project. Each project maintains a map of extra properties, which * can contain any arbitrary name -> value pair. Once defined, the properties of this scope are readable and writable. * See extra properties for more details.
  • * *
  • The extensions added to the project by the plugins. Each extension is available as a read-only property with the same name as the extension.
  • * *
  • The convention properties added to the project by the plugins. A plugin can add properties and methods * to a project through the project's {@link Convention} object. The properties of this scope may be readable or writable, depending on the convention objects.
  • * *
  • The tasks of the project. A task is accessible by using its name as a property name. The properties of this * scope are read-only. For example, a task called compile is accessible as the compile * property.
  • * *
  • The extra properties and convention properties are inherited from the project's parent, recursively up to the root * project. The properties of this scope are read-only.
  • * *
* *

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 {@link #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 {@link #setProperty(String, Object)} for more details.

* *

Extra Properties

* * All extra properties must be defined through the "ext" namespace. Once an extra property has been defined, * it is available directly on the owning object (in the below case the Project, Task, and sub-projects respectively) and can * be read and updated. Only the initial declaration that needs to be done via the namespace. * *
 * 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
 * }
 * 
* *

Dynamic Methods

* *

A project has 5 method 'scopes', which it searches for methods:

* *
    * *
  • The Project object itself.
  • * *
  • The build file. The project searches for a matching method declared in the build file.
  • * *
  • The extensions added to the project by the plugins. Each extension is available as a method which takes * a closure or {@link org.gradle.api.Action} as a parameter.
  • * *
  • The convention methods added to the project by the plugins. A plugin can add properties and method to * a project through the project's {@link Convention} object.
  • * *
  • The tasks of the project. A method is added for each task, using the name of the task as the method name and * taking a single closure or {@link org.gradle.api.Action} parameter. The method calls the {@link 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).
  • * *
  • The methods of the parent project, recursively up to the root project.
  • * *
  • A property of the project whose value is a closure. The closure is treated as a method and called with the provided parameters. * The property is located as described above.
  • * *
*/ @HasInternalProtocol public interface Project extends Comparable, ExtensionAware, PluginAware { /** * The default project build file name. */ String DEFAULT_BUILD_FILE = "build.gradle"; /** * The hierarchy separator for project and task path names. */ String PATH_SEPARATOR = ":"; /** * The default build directory name. */ String DEFAULT_BUILD_DIR_NAME = "build"; String GRADLE_PROPERTIES = "gradle.properties"; String SYSTEM_PROP_PREFIX = "systemProp"; String DEFAULT_VERSION = "unspecified"; String DEFAULT_STATUS = "release"; /** *

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.

* * @return The root project. Never returns null. */ Project getRootProject(); /** *

Returns the root directory of this project. The root directory is the project directory of the root * project.

* * @return The root directory. Never returns null. */ File getRootDir(); /** *

Returns 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

* * @return The build directory. Never returns null. */ File getBuildDir(); /** *

Sets the build directory of this project. The build directory is the directory which all artifacts are * generated into.

* * @param path The build directory * @since 4.0 */ void setBuildDir(File path); /** *

Sets 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 {@link #file(Object)}. This mean you can use, * amongst other things, a relative or absolute path or File object to specify the build directory.

* * @param path The build directory. This is evaluated as per {@link #file(Object)} */ void setBuildDir(Object path); /** * The build script for this project. *

* If the file exists, it will be evaluated against this project when this project is configured. * * @return the build script for this project. */ File getBuildFile(); /** *

Returns the parent project of this project, if any.

* * @return The parent project, or null if this is the root project. */ @Nullable Project getParent(); /** *

Returns the name of this project. The project's name is not necessarily unique within a project hierarchy. You * should use the {@link #getPath()} method for a unique identifier for the project.

* * @return The name of this project. Never return null. */ String getName(); /** * Returns a human-consumable display name for this project. */ String getDisplayName(); /** * Returns the description of this project, if any. * * @return the description. May return null. */ @Nullable String getDescription(); /** * Sets a description for this project. * * @param description The description of the project. Might be null. */ void setDescription(@Nullable String description); /** *

Returns the group of this project. Gradle always uses the {@code toString()} value of the group. The group * defaults to the path with dots as separators.

* * @return The group of this project. Never returns null. */ Object getGroup(); /** *

Sets the group of this project.

* * @param group The group of this project. Must not be null. */ void setGroup(Object group); /** *

Returns the version of this project. Gradle always uses the {@code toString()} value of the version. The * version defaults to {@value #DEFAULT_VERSION}.

* * @return The version of this project. Never returns null. */ Object getVersion(); /** *

Sets the version of this project.

* * @param version The version of this project. Must not be null. */ void setVersion(Object version); /** *

Returns the status of this project. Gradle always uses the {@code toString()} value of the status. The status * defaults to {@value #DEFAULT_STATUS}.

* *

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.

* * @return The status of this project. Never returns null. */ Object getStatus(); /** * Sets the status of this project. * * @param status The status. Must not be null. */ void setStatus(Object status); /** *

Returns the direct children of this project.

* * @return A map from child project name to child project. Returns an empty map if this project does not have * any children. */ Map getChildProjects(); /** *

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.

* *
    * *
  1. The project object itself. For example, the rootDir project property.
  2. * *
  3. The project's {@link Convention} object. For example, the srcRootName java plugin * property.
  4. * *
  5. The project's extra properties.
  6. * *
* * If the property is not found, a {@link groovy.lang.MissingPropertyException} is thrown. * * @param name The name of the property * @param value The value of the property */ void setProperty(String name, @Nullable Object value) throws MissingPropertyException; /** *

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.

* * @return This project. Never returns null. */ Project getProject(); /** *

Returns the set containing this project and its subprojects.

* * @return The set of projects. */ Set getAllprojects(); /** *

Returns the set containing the subprojects of this project.

* * @return The set of projects. Returns an empty set if this project has no subprojects. */ Set getSubprojects(); /** *

Creates a {@link Task} with the given name and adds it to this project. Calling this method is equivalent to * calling {@link #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.

* * @param name The name of the task to be created * @return The newly created task object * @throws InvalidUserDataException If a task with the given name already exists in this project. */ Task task(String name) throws InvalidUserDataException; /** *

Creates a {@link 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:

* * * * * * * * * * * * * * * * * * *
OptionDescriptionDefault Value
{@value org.gradle.api.Task#TASK_TYPE}The class of the task to * create.{@link org.gradle.api.DefaultTask}
{@value org.gradle.api.Task#TASK_OVERWRITE}Replace an existing * task?false
{@value org.gradle.api.Task#TASK_DEPENDS_ON}A task name or set of task names which * this task depends on[]
{@value org.gradle.api.Task#TASK_ACTION}A closure or {@link Action} to add to the * task.null
{@value org.gradle.api.Task#TASK_DESCRIPTION}A description of the task. * null
{@value org.gradle.api.Task#TASK_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.

* * @param args The task creation options. * @param name The name of the task to be created * @return The newly created task object * @throws InvalidUserDataException If a task with the given name already exists in this project. */ Task task(Map args, String name) throws InvalidUserDataException; /** *

Creates a {@link 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 {@link #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.

* * @param args The task creation options. * @param name The name of the task to be created * @param configureClosure The closure to use to configure the created task. * @return The newly created task object * @throws InvalidUserDataException If a task with the given name already exists in this project. */ Task task(Map args, String name, Closure configureClosure); /** *

Creates a {@link 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

* * @param name The name of the task to be created * @param configureClosure The closure to use to configure the created task. * @return The newly created task object * @throws InvalidUserDataException If a task with the given name already exists in this project. */ Task task(String name, Closure configureClosure); /** *

Creates a {@link 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

* * @param name The name of the task to be created * @param configureAction The action to use to configure the created task. * @return The newly created task object * @throws InvalidUserDataException If a task with the given name already exists in this project. * @see TaskContainer#create(String, Action) * @since 4.10 */ Task task(String name, Action configureAction); /** *

Returns the path of this project. The path is the fully qualified name of the project.

* * @return The path. Never returns null. */ String getPath(); /** *

Returns the names of the default tasks of this project. These are used when no tasks names are provided when * starting the build.

* * @return The default task names. Returns an empty list if this project has no default tasks. */ List getDefaultTasks(); /** *

Sets the names of the default tasks of this project. These are used when no tasks names are provided when * starting the build.

* * @param defaultTasks The default task names. */ void setDefaultTasks(List defaultTasks); /** *

Sets the names of the default tasks of this project. These are used when no tasks names are provided when * starting the build.

* * @param defaultTasks The default task names. */ void defaultTasks(String... defaultTasks); /** *

Declares that this project has an evaluation dependency on the project with the given path.

* * @param path The path of the project which this project depends on. * @return The project which this project depends on. * @throws UnknownProjectException If no project with the given path exists. */ Project evaluationDependsOn(String path) throws UnknownProjectException; /** *

Declares that this project has an evaluation dependency on each of its child projects.

* */ void evaluationDependsOnChildren(); /** *

Locates a project by path. If the path is relative, it is interpreted relative to this project.

* * @param path The path. * @return The project with the given path. Returns null if no such project exists. */ @Nullable Project findProject(String path); /** *

Locates a project by path. If the path is relative, it is interpreted relative to this project.

* * @param path The path. * @return The project with the given path. Never returns null. * @throws UnknownProjectException If no project with the given path exists. */ Project project(String path) throws UnknownProjectException; /** *

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.

* * @param path The path. * @param configureClosure The closure to use to configure the project. * @return The project with the given path. Never returns null. * @throws UnknownProjectException If no project with the given path exists. */ Project project(String path, Closure configureClosure); /** *

Locates a project by path and configures it using the given action. If the path is relative, it is * interpreted relative to this project.

* * @param path The path. * @param configureAction The action to use to configure the project. * @return The project with the given path. Never returns null. * @throws UnknownProjectException If no project with the given path exists. * * @since 3.4 */ Project project(String path, Action configureAction); /** *

Returns a map of the tasks contained in this project, and optionally its subprojects.

* * @param recursive If true, returns the tasks of this project and its subprojects. If false, returns the tasks of * just this project. * @return A map from project to a set of tasks. */ Map> getAllTasks(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. *

* * @param name The name of the task to locate. * @param recursive If true, returns the tasks of this project and its subprojects. If false, returns the tasks of * just this project. * @return The set of tasks. Returns an empty set if no such tasks exist in this project. */ Set getTasksByName(String name, boolean recursive); /** *

The directory containing the project build file.

* * @return The project directory. Never returns null. */ File getProjectDir(); /** *

Resolves a file path relative to the project directory of this project. This method converts the supplied path * based on its type:

* *
    * *
  • A {@link CharSequence}, including {@link String} or {@link groovy.lang.GString}. Interpreted relative to the project directory. A string that starts with {@code file:} is treated as a file URL.
  • * *
  • A {@link 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.
  • * *
  • A {@link java.nio.file.Path}. The path must be associated with the default provider and is treated the * same way as an instance of {@code File}.
  • * *
  • A {@link java.net.URI} or {@link java.net.URL}. The URL's path is interpreted as the file path. Only {@code file:} URLs are supported.
  • * *
  • A {@link org.gradle.api.file.Directory} or {@link org.gradle.api.file.RegularFile}.
  • * *
  • A {@link Provider} of any supported type. The provider's value is resolved recursively.
  • * *
  • A {@link org.gradle.api.resources.TextResource}.
  • * *
  • A Groovy {@link Closure} or Kotlin function that returns any supported type. The closure's return value is resolved recursively.
  • * *
  • A {@link java.util.concurrent.Callable} that returns any supported type. The callable's return value is resolved recursively.
  • * *
* * @param path The object to resolve as a File. * @return The resolved file. Never returns null. */ File file(Object path); /** *

Resolves a file path relative to the project directory of this project and validates it using the given * scheme. See {@link PathValidation} for the list of possible validations.

* * @param path An object which toString method value is interpreted as a relative path to the project directory. * @param validation The validation to perform on the file. * @return The resolved file. Never returns null. * @throws InvalidUserDataException When the file does not meet the given validation constraint. */ File file(Object path, PathValidation validation) throws InvalidUserDataException; /** *

Resolves a file path to a URI, relative to the project directory of this project. Evaluates the provided path * object as described for {@link #file(Object)}, with the exception that any URI scheme is supported, not just * 'file:' URIs.

* * @param path The object to resolve as a URI. * @return The resolved URI. Never returns null. */ URI uri(Object path); /** *

Returns the relative path from the project directory to the given path. The given path object is (logically) * resolved as described for {@link #file(Object)}, from which a relative path is calculated.

* * @param path The path to convert to a relative path. * @return The relative path. Never returns null. */ String relativePath(Object path); /** *

Returns a {@link ConfigurableFileCollection} containing the given files. You can pass any of the following * types to this method:

* *
  • A {@link CharSequence}, including {@link String} or {@link groovy.lang.GString}. Interpreted relative to the project directory, as per {@link #file(Object)}. A string that starts with {@code file:} is treated as a file URL.
  • * *
  • A {@link File}. Interpreted relative to the project directory, as per {@link #file(Object)}.
  • * *
  • A {@link java.nio.file.Path}, as per {@link #file(Object)}.
  • * *
  • A {@link java.net.URI} or {@link java.net.URL}. The URL's path is interpreted as a file path. Only {@code file:} URLs are supported.
  • * *
  • A {@link org.gradle.api.file.Directory} or {@link org.gradle.api.file.RegularFile}.
  • * *
  • A {@link java.util.Collection}, {@link Iterable}, or an array that contains objects of any supported type. The elements of the collection are recursively converted to files.
  • * *
  • A {@link org.gradle.api.file.FileCollection}. The contents of the collection are included in the returned collection.
  • * *
  • A {@link org.gradle.api.file.FileTree} or {@link org.gradle.api.file.DirectoryTree}. The contents of the tree are included in the returned collection.
  • * *
  • A {@link 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. * *
  • A {@link java.util.concurrent.Callable} that returns any supported type. The return value of the {@code call()} method is recursively converted to files. A {@code null} return value is treated as an empty collection.
  • * *
  • A Groovy {@link Closure} or Kotlin function that returns any of the types listed here. The return value of the closure is recursively converted to files. A {@code null} return value is treated as an empty collection.
  • * *
  • A {@link Task}. Converted to the task's output files. The task is executed if the file collection is used as an input to another task.
  • * *
  • A {@link org.gradle.api.tasks.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.
  • * *
  • Anything else is treated as an error.
  • * *
* *

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.

* * @param paths The paths to the files. May be empty. * @return The file collection. Never returns null. */ ConfigurableFileCollection files(Object... paths); /** *

Creates a new {@code ConfigurableFileCollection} using the given paths. The paths are evaluated as per {@link * #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.

* * @param paths The contents of the file collection. Evaluated as per {@link #files(Object...)}. * @param configureClosure The closure to use to configure the file collection. * @return the configured file tree. Never returns null. */ ConfigurableFileCollection files(Object paths, Closure configureClosure); /** *

Creates a new {@code ConfigurableFileCollection} using the given paths. The paths are evaluated as per {@link * #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.

* * @param paths The contents of the file collection. Evaluated as per {@link #files(Object...)}. * @param configureAction The action to use to configure the file collection. * @return the configured file tree. Never returns null. * @since 3.5 */ ConfigurableFileCollection files(Object paths, Action configureAction); /** *

Creates a new {@code ConfigurableFileTree} using the given base directory. The given baseDir path is evaluated * as per {@link #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
     * }
     * 
* * @param baseDir The base directory of the file tree. Evaluated as per {@link #file(Object)}. * @return the file tree. Never returns null. */ ConfigurableFileTree fileTree(Object baseDir); /** *

Creates a new {@code ConfigurableFileTree} using the given base directory. The given baseDir path is evaluated * as per {@link #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.

* * @param baseDir The base directory of the file tree. Evaluated as per {@link #file(Object)}. * @param configureClosure Closure to configure the {@code ConfigurableFileTree} object. * @return the configured file tree. Never returns null. */ ConfigurableFileTree fileTree(Object baseDir, Closure configureClosure); /** *

Creates a new {@code ConfigurableFileTree} using the given base directory. The given baseDir path is evaluated * as per {@link #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.

* * @param baseDir The base directory of the file tree. Evaluated as per {@link #file(Object)}. * @param configureAction Action to configure the {@code ConfigurableFileTree} object. * @return the configured file tree. Never returns null. * @since 3.5 */ ConfigurableFileTree fileTree(Object baseDir, Action configureAction); /** *

Creates a new {@code 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.

* * @param args map of property assignments to {@code ConfigurableFileTree} object * @return the configured file tree. Never returns null. */ ConfigurableFileTree fileTree(Map args); /** *

Creates a new {@code FileTree} which contains the contents of the given ZIP file. The given zipPath path is * evaluated as per {@link #file(Object)}. You can combine this method with the {@link #copy(groovy.lang.Closure)} * 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.

* * @param zipPath The ZIP file. Evaluated as per {@link #file(Object)}. * @return the file tree. Never returns null. */ FileTree zipTree(Object zipPath); /** * Creates a new {@code FileTree} which contains the contents of the given TAR file. The given tarPath path can be: *
    *
  • an instance of {@link org.gradle.api.resources.Resource}
  • *
  • any other object is evaluated as per {@link #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. *

* 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 {@link #copy(groovy.lang.Closure)} * 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'
     * }
     * 
* * @param tarPath The TAR file or an instance of {@link org.gradle.api.resources.Resource}. * @return the file tree. Never returns null. */ FileTree tarTree(Object tarPath); /** * Creates a {@code Provider} implementation based on the provided value. * * @param value The {@code java.util.concurrent.Callable} use to calculate the value. * @return The provider. Never returns null. * @throws org.gradle.api.InvalidUserDataException If the provided value is null. * @see org.gradle.api.provider.ProviderFactory#provider(Callable) * @since 4.0 */ Provider provider(Callable value); /** * Provides access to methods to create various kinds of {@link Provider} instances. * * @since 4.0 */ ProviderFactory getProviders(); /** * Provides access to methods to create various kinds of model objects. * * @since 4.0 */ ObjectFactory getObjects(); /** * Provides access to various important directories for this project. * * @since 4.1 */ ProjectLayout getLayout(); /** * Creates a directory and returns a file pointing to it. * * @param path The path for the directory to be created. Evaluated as per {@link #file(Object)}. * @return the created directory * @throws org.gradle.api.InvalidUserDataException If the path points to an existing file. */ File mkdir(Object path); /** * Deletes files and directories. *

* This will not follow symlinks. If you need to follow symlinks too use {@link #delete(Action)}. * * @param paths Any type of object accepted by {@link org.gradle.api.Project#files(Object...)} * @return true if anything got deleted, false otherwise */ boolean delete(Object... paths); /** * Deletes the specified files. The given action is used to configure a {@link DeleteSpec}, which is then used to * delete the files. *

Example: *

     * project.delete {
     *     delete 'somefile'
     *     followSymlinks = true
     * }
     * 
* * @param action Action to configure the DeleteSpec * @return {@link WorkResult} that can be used to check if delete did any work. */ WorkResult delete(Action action); /** * Executes a Java main class. The closure configures a {@link org.gradle.process.JavaExecSpec}. * * @param closure The closure for configuring the execution. * @return the result of the execution */ ExecResult javaexec(Closure closure); /** * Executes an external Java process. *

* The given action configures a {@link org.gradle.process.JavaExecSpec}, which is used to launch the process. * This method blocks until the process terminates, with its result being returned. * * @param action The action for configuring the execution. * @return the result of the execution */ ExecResult javaexec(Action action); /** * Executes an external command. The closure configures a {@link org.gradle.process.ExecSpec}. * * @param closure The closure for configuring the execution. * @return the result of the execution */ ExecResult exec(Closure closure); /** * Executes an external command. *

* The given action configures a {@link org.gradle.process.ExecSpec}, which is used to launch the process. * This method blocks until the process terminates, with its result being returned. * * @param action The action for configuring the execution. * @return the result of the execution */ ExecResult exec(Action action); /** *

Converts a name to an absolute project path, resolving names relative to this project.

* * @param path The path to convert. * @return The absolute path. */ String absoluteProjectPath(String path); /** *

Converts a name to a project path relative to this project.

* * @param path The path to convert. * @return The relative path. */ String relativeProjectPath(String path); /** *

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")
     *   }
     * }
     * 
* * @return The AntBuilder for this project. Never returns null. */ AntBuilder getAnt(); /** *

Creates an additional AntBuilder for this project. You can use this in your build file to execute * ant tasks.

* * @return Creates an AntBuilder for this project. Never returns null. * @see #getAnt() */ AntBuilder createAntBuilder(); /** *

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 {@link #getAnt()}

* * @param configureClosure The closure to execute against the AntBuilder. * @return The AntBuilder. Never returns null. */ AntBuilder ant(Closure configureClosure); /** *

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 {@link #getAnt()}

* * @param configureAction The action to execute against the AntBuilder. * @return The AntBuilder. Never returns null. * @since 3.5 */ AntBuilder ant(Action configureAction); /** * Returns the configurations of this project. * *

Examples:

See docs for {@link ConfigurationContainer} * * @return The configuration of this project. */ ConfigurationContainer getConfigurations(); /** *

Configures the dependency configurations for this project. * *

This method executes the given closure against the {@link ConfigurationContainer} * for this project. The {@link ConfigurationContainer} is passed to the closure as the closure's delegate. * *

Examples:

See docs for {@link ConfigurationContainer} * * @param configureClosure the closure to use to configure the dependency configurations. */ void configurations(Closure configureClosure); /** * Returns a handler for assigning artifacts produced by the project to configurations. *

Examples:

See docs for {@link ArtifactHandler} */ ArtifactHandler getArtifacts(); /** *

Configures the published artifacts for this project. * *

This method executes the given closure against the {@link ArtifactHandler} for this project. The {@link * 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
     * }
     * 
* * @param configureClosure the closure to use to configure the published artifacts. */ void artifacts(Closure configureClosure); /** *

Configures the published artifacts for this project. * *

This method executes the given action against the {@link 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
     * }
     * 
* * @param configureAction the action to use to configure the published artifacts. * @since 3.5 */ void artifacts(Action configureAction); /** *

Returns the {@link 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

* * @return The Convention. Never returns null. */ Convention getConvention(); /** *

Compares the nesting level of this project with another project of the multi-project hierarchy.

* * @param otherProject The project to compare the nesting level with. * @return a negative integer, zero, or a positive integer as this project has a nesting level less than, equal to, * or greater than the specified object. * @see #getDepth() */ int depthCompare(Project otherProject); /** *

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.

*/ int getDepth(); /** *

Returns the tasks of this project.

* * @return the tasks of this project. */ TaskContainer getTasks(); /** *

Configures the sub-projects of this project

* *

This method executes the given {@link Action} against the sub-projects of this project.

* * @param action The action to execute. */ void subprojects(Action action); /** *

Configures the sub-projects of this project.

* *

This method executes the given closure against each of the sub-projects of this project. The target {@link * Project} is passed to the closure as the closure's delegate.

* * @param configureClosure The closure to execute. */ void subprojects(Closure configureClosure); /** *

Configures this project and each of its sub-projects.

* *

This method executes the given {@link Action} against this project and each of its sub-projects.

* * @param action The action to execute. */ void allprojects(Action action); /** *

Configures this project and each of its sub-projects.

* *

This method executes the given closure against this project and its sub-projects. The target {@link Project} * is passed to the closure as the closure's delegate.

* * @param configureClosure The closure to execute. */ void allprojects(Closure configureClosure); /** * Adds an action to execute immediately before this project is evaluated. * * @param action the action to execute. */ void beforeEvaluate(Action action); /** * Adds an action to execute immediately after this project is evaluated. * * @param action the action to execute. */ void afterEvaluate(Action action); /** *

Adds a closure to be called immediately before this project is evaluated. The project is passed to the closure * as a parameter.

* * @param closure The closure to call. */ void beforeEvaluate(Closure closure); /** *

Adds a closure to be called immediately after this project has been evaluated. The project is passed to the * closure as a parameter. Such a listener gets notified when the build file belonging to this project has been * executed. A parent project may for example add such a listener to its child project. Such a listener can further * configure those child projects based on the state of the child projects after their build files have been * run.

* * @param closure The closure to call. */ void afterEvaluate(Closure closure); /** *

Determines if this project has the given property. See here for details of the * properties which are available for a project.

* * @param propertyName The name of the property to locate. * @return True if this project has the given property, false otherwise. */ boolean hasProperty(String propertyName); /** *

Returns the properties of this project. See here for details of the properties which * are available for a project.

* * @return A map from property name to value. */ Map getProperties(); /** *

Returns the value of the given property. This method locates a property as follows:

* *
    * *
  1. If this project object has a property with the given name, return the value of the property.
  2. * *
  3. If this project has an extension with the given name, return the extension.
  4. * *
  5. If this project's convention object has a property with the given name, return the value of the * property.
  6. * *
  7. If this project has an extra property with the given name, return the value of the property.
  8. * *
  9. If this project has a task with the given name, return the task.
  10. * *
  11. Search up through this project's ancestor projects for a convention property or extra property with the * given name.
  12. * *
  13. If not found, a {@link MissingPropertyException} is thrown.
  14. * *
* * @param propertyName The name of the property. * @return The value of the property, possibly null. * @throws MissingPropertyException When the given property is unknown. * @see Project#findProperty(String) */ @Nullable Object property(String propertyName) throws MissingPropertyException; /** *

Returns the value of the given property or null if not found. * This method locates a property as follows:

* *
    * *
  1. If this project object has a property with the given name, return the value of the property.
  2. * *
  3. If this project has an extension with the given name, return the extension.
  4. * *
  5. If this project's convention object has a property with the given name, return the value of the * property.
  6. * *
  7. If this project has an extra property with the given name, return the value of the property.
  8. * *
  9. If this project has a task with the given name, return the task.
  10. * *
  11. Search up through this project's ancestor projects for a convention property or extra property with the * given name.
  12. * *
  13. If not found, null value is returned.
  14. * *
* * @param propertyName The name of the property. * @since 2.13 * @return The value of the property, possibly null or null if not found. * @see Project#property(String) */ @Nullable Object findProperty(String propertyName); /** *

Returns the logger for this project. You can use this in your build file to write log messages.

* * @return The logger. Never returns null. */ Logger getLogger(); /** *

Returns the {@link org.gradle.api.invocation.Gradle} invocation which this project belongs to.

* * @return The Gradle object. Never returns null. */ Gradle getGradle(); /** * Returns the {@link org.gradle.api.logging.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. * * @return the LoggingManager. Never returns null. */ LoggingManager getLogging(); /** *

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() }
     * 
* * @param object The object to configure * @param configureClosure The closure with configure statements * @return The configured object */ Object configure(Object object, Closure configureClosure); /** * Configures a collection of objects via a closure. This is equivalent to calling {@link #configure(Object, * groovy.lang.Closure)} for each of the given objects. * * @param objects The objects to configure * @param configureClosure The closure with configure statements * @return The configured objects. */ Iterable configure(Iterable objects, Closure configureClosure); /** * Configures a collection of objects via an action. * * @param objects The objects to configure * @param configureAction The action to apply to each object * @return The configured objects. */ Iterable configure(Iterable objects, Action configureAction); /** * Returns a handler to create repositories which are used for retrieving dependencies and uploading artifacts * produced by the project. * * @return the repository handler. Never returns null. */ RepositoryHandler getRepositories(); /** *

Configures the repositories for this project. * *

This method executes the given closure against the {@link RepositoryHandler} for this project. The {@link * RepositoryHandler} is passed to the closure as the closure's delegate. * * @param configureClosure the closure to use to configure the repositories. */ void repositories(Closure configureClosure); /** * Returns the dependency handler of this project. The returned dependency handler instance can be used for adding * new dependencies. For accessing already declared dependencies, the configurations can be used. * *

Examples:

* See docs for {@link DependencyHandler} * * @return the dependency handler. Never returns null. * @see #getConfigurations() */ DependencyHandler getDependencies(); /** *

Configures the dependencies for this project. * *

This method executes the given closure against the {@link DependencyHandler} for this project. The {@link * DependencyHandler} is passed to the closure as the closure's delegate. * *

Examples:

* See docs for {@link DependencyHandler} * * @param configureClosure the closure to use to configure the dependencies. */ void dependencies(Closure configureClosure); /** * Returns the build script handler for this project. You can use this handler to query details about the build * script for this project, and manage the classpath used to compile and execute the project's build script. * * @return the classpath handler. Never returns null. */ ScriptHandler getBuildscript(); /** *

Configures the build script classpath for this project. * *

The given closure is executed against this project's {@link ScriptHandler}. The {@link ScriptHandler} is * passed to the closure as the closure's delegate. * * @param configureClosure the closure to use to configure the build script classpath. */ void buildscript(Closure configureClosure); /** * Copies the specified files. The given closure is used to configure a {@link 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'
     *    }
     * }
     * 
* * @param closure Closure to configure the CopySpec * @return {@link WorkResult} that can be used to check if the copy did any work. */ WorkResult copy(Closure closure); /** * Copies the specified files. The given action is used to configure a {@link CopySpec}, which is then used to * copy the files. * @see #copy(Closure) * @param action Action to configure the CopySpec * @return {@link WorkResult} that can be used to check if the copy did any work. */ WorkResult copy(Action action); /** * Creates a {@link CopySpec} which can later be used to copy files or create an archive. The given closure is used * to configure the {@link CopySpec} before it is returned by this method. * *
     * def baseSpec = copySpec {
     *    from "source"
     *    include "**/*.java"
     * }
     *
     * task copy(type: Copy) {
     *    into "target"
     *    with baseSpec
     * }
     * 
* * @param closure Closure to configure the CopySpec * @return The CopySpec */ CopySpec copySpec(Closure closure); /** * Creates a {@link CopySpec} which can later be used to copy files or create an archive. The given action is used * to configure the {@link CopySpec} before it is returned by this method. * * @see #copySpec(Closure) * @param action Action to configure the CopySpec * @return The CopySpec */ CopySpec copySpec(Action action); /** * Creates a {@link CopySpec} which can later be used to copy files or create an archive. * * @return a newly created copy spec */ CopySpec copySpec(); /** * Synchronizes the contents of a destination directory with some source directories and files. * The given action is used to configure a {@link CopySpec}, which is then used to synchronize the files. * *

* This method is like the {@link #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'
     *     }
     * }
     * 
* * @param action Action to configure the CopySpec. * @since 4.0 * @return {@link WorkResult} that can be used to check if the sync did any work. */ WorkResult sync(Action action); /** * Returns the evaluation state of this project. You can use this to access information about the evaluation of this * project, such as whether it has failed. * * @return the project state. Never returns null. */ ProjectState getState(); /** *

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.

* * @param type The type of objects for the container to contain. * @param The type of objects for the container to contain. * @return The container. */ NamedDomainObjectContainer container(Class type); /** *

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.

* * @param type The type of objects for the container to contain. * @param factory The factory to use to create object instances. * @param The type of objects for the container to contain. * @return The container. */ NamedDomainObjectContainer container(Class type, NamedDomainObjectFactory factory); /** *

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.

* * @param type The type of objects for the container to contain. * @param factoryClosure The closure to use to create object instances. * @param The type of objects for the container to contain. * @return The container. */ NamedDomainObjectContainer container(Class type, Closure factoryClosure); /** * Allows adding DSL extensions to the project. Useful for plugin authors. * * @return Returned instance allows adding DSL extensions to the project */ @Override ExtensionContainer getExtensions(); /** * Provides access to resource-specific utility methods, for example factory methods that create various resources. * * @return Returned instance contains various resource-specific utility methods. */ ResourceHandler getResources(); /** * Returns the software components produced by this project. * * @return The components for this project. */ SoftwareComponentContainer getComponents(); /** * Provides access to configuring input normalization. * * @since 4.0 */ InputNormalizationHandler getNormalization(); /** * Configures input normalization. * * @since 4.0 */ void normalization(Action configuration); /** * Configures dependency locking * * @since 4.8 */ void dependencyLocking(Action configuration); /** * Provides access to configuring dependency locking * * @since 4.8 */ DependencyLockingHandler getDependencyLocking(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy