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

org.gradle.tooling.BuildLauncher Maven / Gradle / Ivy

/*
 * Copyright 2011 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.tooling;

import org.gradle.tooling.model.Launchable;
import org.gradle.tooling.model.Task;

/**
 * A {@code BuildLauncher} allows you to configure and execute a Gradle build.
 * 

* Instances of {@code BuildLauncher} are not thread-safe. You use a {@code BuildLauncher} as follows: * *

    *
  • Create an instance of {@code BuildLauncher} by calling {@link org.gradle.tooling.ProjectConnection#newBuild()}. *
  • Configure the launcher as appropriate. *
  • Call either {@link #run()} or {@link #run(ResultHandler)} to execute the build. *
  • Optionally, you can reuse the launcher to launch additional builds. *
* * Example: *
 * ProjectConnection connection = GradleConnector.newConnector()
 *    .forProjectDirectory(new File("some-folder"))
 *    .connect();
 *
 * try {
 *    BuildLauncher build = connection.newBuild();
 *
 *    //select tasks to run:
 *    build.forTasks("clean", "test");
 *
 *    //include some build arguments:
 *    build.withArguments("-i", "--project-dir", "some-project-dir");
 *
 *    //configure the standard input:
 *    build.setStandardInput(new ByteArrayInputStream("consume this!".getBytes()));
 *
 *    //in case you want the build to use java different than default:
 *    build.setJavaHome(new File("/path/to/java"));
 *
 *    //if your build needs crazy amounts of memory:
 *    build.setJvmArguments("-Xmx2048m", "-XX:MaxPermSize=512m");
 *
 *    //if you want to listen to the progress events:
 *    ProgressListener listener = null; // use your implementation
 *    build.addProgressListener(listener);
 *
 *    //kick the build off:
 *    build.run();
 * } finally {
 *    connection.close();
 * }
 * 
* *

If the target Gradle version is >=6.8 then you can use {@code BuildLauncher} to execute tasks from included builds. You can target tasks from included builds by specifying the task * identity path (i.e. {@code ':included-build-name:subproject-name:taskName'}).

* * @since 1.0-milestone-3 */ public interface BuildLauncher extends ConfigurableLauncher { /** * Sets the tasks to be executed. If no tasks are specified, the project's default tasks are executed. * * @param tasks The paths of the tasks to be executed. Relative paths are evaluated relative to the project for which this launcher was created. * @return this * @since 1.0-milestone-3 */ BuildLauncher forTasks(String... tasks); /** * Sets the tasks to be executed. If no tasks are specified, the project's default tasks are executed. * *

Note that the supplied tasks do not necessarily need to belong to the project which this launcher was created for. * * @param tasks The tasks to be executed. * @return this * @since 1.0-milestone-3 */ BuildLauncher forTasks(Task... tasks); /** * Sets the tasks to be executed. If no tasks are specified, the project's default tasks are executed. * *

Note that the supplied tasks do not necessarily need to belong to the project which this launcher was created for. * * @param tasks The tasks to be executed. * @return this * @since 1.0-milestone-3 */ BuildLauncher forTasks(Iterable tasks); /** * Sets the launchables to execute. If no entries are specified, the project's default tasks are executed. * * @param launchables The launchables for this build. * @return this * @since 1.12 */ BuildLauncher forLaunchables(Launchable... launchables); /** * Sets the launchables to execute. If no entries are specified, the project's default tasks are executed. * * @param launchables The launchables for this build. * @return this * @since 1.12 */ BuildLauncher forLaunchables(Iterable launchables); /** * Executes the build, blocking until it is complete. * * @throws UnsupportedVersionException When the target Gradle version does not support build execution. * @throws org.gradle.tooling.exceptions.UnsupportedOperationConfigurationException * When the target Gradle version does not support some requested configuration option such as {@link #withArguments(String...)}. * @throws org.gradle.tooling.exceptions.UnsupportedBuildArgumentException When there is a problem with build arguments provided by {@link #withArguments(String...)}. * @throws BuildException On some failure executing the Gradle build. * @throws BuildCancelledException When the operation was cancelled before it completed successfully. * @throws GradleConnectionException On some other failure using the connection. * @throws IllegalStateException When the connection has been closed or is closing. * @since 1.0-milestone-3 */ void run() throws GradleConnectionException, IllegalStateException; /** * Launches the build. This method returns immediately, and the result is later passed to the given handler. * *

If the operation fails, the handler's {@link ResultHandler#onFailure(GradleConnectionException)} * method is called with the appropriate exception. See {@link #run()} for a description of the various exceptions that the operation may fail with. * * @param handler The handler to supply the result to. * @throws IllegalStateException When the connection has been closed or is closing. * @since 1.0-milestone-3 */ void run(ResultHandler handler) throws IllegalStateException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy