-
Notifications
You must be signed in to change notification settings - Fork 4.6k
/
GradleConnector.java
183 lines (170 loc) · 8.25 KB
/
GradleConnector.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
/*
* 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.internal.consumer.ConnectorServices;
import java.io.File;
import java.net.URI;
/**
* <p>A {@code GradleConnector} is the main entry point to the Gradle tooling API. You use this API as follows:</p>
*
* <ol>
*
* <li>Call {@link #newConnector()} to create a new connector instance.</li>
*
* <li>Configure the connector. You must call {@link #forProjectDirectory(java.io.File)} to specify which project you wish to connect to. Other methods are optional.</li>
*
* <li>Call {@link #connect()} to create the connection to a project.</li>
*
* <li>When finished with the connection, call {@link ProjectConnection#close()} to clean up.</li>
*
* </ol>
*
* <p>Example:</p>
* <pre class='autoTested'>
* ProjectConnection connection = GradleConnector.newConnector()
* .forProjectDirectory(new File("someProjectFolder"))
* .connect();
*
* try {
* connection.newBuild().forTasks("tasks").run();
* } finally {
* connection.close();
* }
* </pre>
*
* <p>The connection will use the version of Gradle that the target build is configured to use, for example in the Gradle wrapper properties file. When no Gradle version is defined for the build, the connection will use the tooling API's version as the Gradle version to run the build.
* Generally, you should avoid configuring a Gradle distribution or version and instead use the default provided by the tooling API.
* </p>
*
* <p>Similarly, the connection will use the JVM and JVM arguments that the target build is configured to use, for example in the {@code gradle.properties} file. When no JVM or JVM arguments are defined for the build, the connection will use the current JVM and some default JVM arguments.</p>
*
* <p>{@code GradleConnector} instances are not thread-safe. If you want to use a {@code GradleConnector} concurrently you <em>must</em> always create a
* new instance for each thread using {@link #newConnector()}. Note, however, the {@link ProjectConnection} instances that a connector creates are completely thread-safe.</p>
*
* <h2>Gradle version compatibility</h2>
*
* <p>The Tooling API is both forwards and backwards compatible with other versions of Gradle. It supports execution of Gradle builds that use older or newer versions of Gradle. Each release of Gradle contains a new release of the Tooling API as well.</p>
*
* <p>The Tooling API supports running builds using Gradle version 3.0 and up.</p>
*
* <p>You should note that not all features of the Tooling API are available for all versions of Gradle. Refer to the documentation for each class and method for more details.</p>
*
* <p>Builds using Gradle 5.0 and up require the use of Tooling API version 3.0 or later.
*
* <h2>Java version compatibility</h2>
*
* <p>The Tooling API requires Java 8 or later. The Gradle version used by builds may have additional Java version requirements.</p>
*
* @since 1.0-milestone-3
*/
public abstract class GradleConnector {
/**
* Creates a new connector instance.
*
* @return The instance. Never returns null.
* @since 1.0-milestone-3
*/
public static GradleConnector newConnector() {
return ConnectorServices.createConnector();
}
/**
* Creates a new {@link CancellationTokenSource} that can be used to cancel one or more {@link org.gradle.tooling.LongRunningOperation} executions.
*
* @return The instance. Never returns {@code null}.
* @since 2.1
*/
public static CancellationTokenSource newCancellationTokenSource() {
return ConnectorServices.createCancellationTokenSource();
}
/**
* Specifies which Gradle installation to use. This replaces any value specified using {@link #useDistribution(URI)}, {@link #useGradleVersion(String)}, or {@link #useBuildDistribution()}.
* Defaults to a project-specific Gradle version.
*
* @param gradleHome The Gradle installation directory.
* @return this
* @since 1.0-milestone-3
*/
public abstract GradleConnector useInstallation(File gradleHome);
/**
* Specifies which Gradle version to use. The appropriate distribution is downloaded and installed into the user's Gradle home directory. This replaces any value specified using {@link
* #useInstallation(File)}, {@link #useDistribution(URI)}, or {@link #useBuildDistribution()}. Defaults to a project-specific Gradle version.
*
* @param gradleVersion The version to use.
* @return this
* @since 1.0-milestone-3
*/
public abstract GradleConnector useGradleVersion(String gradleVersion);
/**
* Specifies which Gradle distribution to use. The appropriate distribution is downloaded and installed into the user's Gradle home directory. This replaces any value specified using {@link
* #useInstallation(File)}, {@link #useGradleVersion(String)}, or {@link #useBuildDistribution()}. Defaults to a project-specific Gradle version.
*
* @param gradleDistribution The distribution to use.
* @return this
* @since 1.0-milestone-3
*/
public abstract GradleConnector useDistribution(URI gradleDistribution);
/**
* Specifies to use the Gradle distribution defined by the target Gradle build. The appropriate distribution defined by the target Gradle build is downloaded and installed into the user's
* Gradle home directory. If the target Gradle build does not define the distribution that it should be built with, the Gradle version of this connector is used. This replaces any value
* specified using {@link #useInstallation(File)}, {@link #useDistribution(URI)}, or {@link #useGradleVersion(String)}. Acts as the default behavior.
*
* @return this
* @since 2.3
*/
public abstract GradleConnector useBuildDistribution();
/**
* Specifies the working directory to use.
*
* @param projectDir The working directory.
* @return this
* @since 1.0-milestone-3
*/
public abstract GradleConnector forProjectDirectory(File projectDir);
/**
* Specifies the user's Gradle home directory to use. Defaults to {@code ~/.gradle}.
*
* @param gradleUserHomeDir The user's Gradle home directory to use.
* @return this
* @since 1.0-milestone-3
*/
public abstract GradleConnector useGradleUserHomeDir(File gradleUserHomeDir);
/**
* Creates a connection to the project in the specified project directory. You should call {@link org.gradle.tooling.ProjectConnection#close()} when you are finished with the connection.
*
* <p>
* Note, that the returned instance does not automatically pick up changes if the connection configuration (e.g. the gradle.properties file) changes. It's the client's responsibility to close the connection and create a new one in that scenario.
*
* @return The connection. Never return null.
* @throws UnsupportedVersionException When the target Gradle version does not support this version of the tooling API.
* @throws GradleConnectionException On failure to establish a connection with the target Gradle version.
* @since 1.0-milestone-3
*/
public abstract ProjectConnection connect() throws GradleConnectionException;
/**
* Disconnects all ProjectConnection instances created by this connector.
*
* <p>
* Calling this method tries to do a best effort to clean up resources used by the tooling API.
* It tries to cancel any builds and shut down running daemons.
* <p>
*
* After calling {@code disconnect}, creating new project connections will be rejected and the existing ones
* created by this instance will also deny future build operations.
*
* @since 6.5
*/
public abstract void disconnect();
}