org.gradle.invocation.DefaultGradle Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-test-kit Show documentation
Show all versions of gradle-test-kit Show documentation
Gradle 6.2.1 API redistribution.
/*
* Copyright 2009 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.invocation;
import com.google.common.collect.ImmutableList;
import groovy.lang.Closure;
import org.gradle.BuildListener;
import org.gradle.BuildResult;
import org.gradle.StartParameter;
import org.gradle.api.Action;
import org.gradle.api.IsolatedAction;
import org.gradle.api.Project;
import org.gradle.api.ProjectEvaluationListener;
import org.gradle.api.UnknownDomainObjectException;
import org.gradle.api.artifacts.DependencyResolutionListener;
import org.gradle.api.execution.TaskExecutionGraphListener;
import org.gradle.api.initialization.IncludedBuild;
import org.gradle.api.initialization.Settings;
import org.gradle.api.internal.BuildScopeListenerRegistrationListener;
import org.gradle.api.internal.GradleInternal;
import org.gradle.api.internal.MutationGuards;
import org.gradle.api.internal.SettingsInternal;
import org.gradle.api.internal.StartParameterInternal;
import org.gradle.api.internal.file.FileResolver;
import org.gradle.api.internal.initialization.ClassLoaderScope;
import org.gradle.api.internal.initialization.ScriptHandlerFactory;
import org.gradle.api.internal.plugins.DefaultObjectConfigurationAction;
import org.gradle.api.internal.plugins.PluginManagerInternal;
import org.gradle.api.internal.project.AbstractPluginAware;
import org.gradle.api.internal.project.CrossProjectConfigurator;
import org.gradle.api.internal.project.ProjectInternal;
import org.gradle.api.internal.project.ProjectRegistry;
import org.gradle.api.invocation.Gradle;
import org.gradle.api.invocation.GradleLifecycle;
import org.gradle.api.model.ObjectFactory;
import org.gradle.api.services.BuildServiceRegistry;
import org.gradle.configuration.ScriptPluginFactory;
import org.gradle.configuration.internal.ListenerBuildOperationDecorator;
import org.gradle.execution.taskgraph.TaskExecutionGraphInternal;
import org.gradle.initialization.ClassLoaderScopeRegistry;
import org.gradle.initialization.SettingsState;
import org.gradle.internal.Cast;
import org.gradle.internal.DeprecatedInGradleScope;
import org.gradle.internal.InternalBuildAdapter;
import org.gradle.internal.InternalListener;
import org.gradle.internal.MutableActionSet;
import org.gradle.internal.build.BuildState;
import org.gradle.internal.build.PublicBuildPath;
import org.gradle.internal.composite.IncludedBuildInternal;
import org.gradle.internal.enterprise.core.GradleEnterprisePluginManager;
import org.gradle.internal.event.ListenerBroadcast;
import org.gradle.internal.event.ListenerManager;
import org.gradle.internal.installation.CurrentGradleInstallation;
import org.gradle.internal.installation.GradleInstallation;
import org.gradle.internal.reflect.JavaPropertyReflectionUtil;
import org.gradle.internal.resource.TextUriResourceLoader;
import org.gradle.internal.service.ServiceRegistry;
import org.gradle.internal.service.scopes.ServiceRegistryFactory;
import org.gradle.listener.ClosureBackedMethodInvocationDispatch;
import org.gradle.util.GradleVersion;
import org.gradle.util.Path;
import javax.annotation.Nullable;
import javax.inject.Inject;
import java.io.Closeable;
import java.io.File;
import java.util.Collection;
import java.util.List;
import java.util.function.Supplier;
public abstract class DefaultGradle extends AbstractPluginAware implements GradleInternal, Closeable {
private SettingsState settings;
private ProjectInternal rootProject;
private ProjectInternal defaultProject;
private final BuildState parent;
private final StartParameter startParameter;
private final ServiceRegistry services;
private final ListenerBroadcast buildListenerBroadcast;
private final ListenerBroadcast projectEvaluationListenerBroadcast;
private final CrossProjectConfigurator crossProjectConfigurator;
private List includedBuilds;
private final MutableActionSet rootProjectActions = new MutableActionSet<>();
private final IsolatedProjectEvaluationListenerProvider isolatedProjectEvaluationListenerProvider;
private GradleLifecycle lifecycle;
private boolean projectsLoaded;
private Path identityPath;
private Supplier extends ClassLoaderScope> classLoaderScope;
private ClassLoaderScope baseProjectClassLoaderScope;
public DefaultGradle(@Nullable BuildState parent, StartParameter startParameter, ServiceRegistryFactory parentRegistry) {
this.parent = parent;
this.startParameter = startParameter;
this.services = parentRegistry.createFor(this);
this.crossProjectConfigurator = services.get(CrossProjectConfigurator.class);
this.isolatedProjectEvaluationListenerProvider = services.get(IsolatedProjectEvaluationListenerProvider.class);
buildListenerBroadcast = getListenerManager().createAnonymousBroadcaster(BuildListener.class);
projectEvaluationListenerBroadcast = getListenerManager().createAnonymousBroadcaster(ProjectEvaluationListener.class);
buildListenerBroadcast.add(new InternalBuildAdapter() {
@Override
public void projectsLoaded(Gradle gradle) {
if (!rootProjectActions.isEmpty()) {
services.get(CrossProjectConfigurator.class).rootProject(rootProject, rootProjectActions);
}
ProjectEvaluationListener isolatedListener = isolatedProjectEvaluationListenerProvider.isolateFor(DefaultGradle.this);
if (isolatedListener != null) {
projectEvaluationListenerBroadcast.add(isolatedListener);
}
projectsLoaded = true;
}
});
if (parent == null) {
services.get(GradleEnterprisePluginManager.class).registerMissingPluginWarning(this);
}
}
@Override
public String toString() {
return rootProject == null ? "build" : ("build '" + rootProject.getName() + "'");
}
@Override
public Path getIdentityPath() {
if (identityPath == null) {
identityPath = services.get(PublicBuildPath.class).getBuildPath();
}
return identityPath;
}
@Override
public String contextualize(String description) {
if (isRootBuild()) {
return description;
} else {
Path contextPath = getIdentityPath();
String context = contextPath == null ? getStartParameter().getCurrentDir().getName() : contextPath.getPath();
return description + " (" + context + ")";
}
}
@Override
public GradleInternal getParent() {
return parent == null ? null : parent.getMutableModel();
}
@Override
public GradleInternal getRoot() {
GradleInternal parent = getParent();
if (parent == null) {
return this;
} else {
return parent.getRoot();
}
}
@Override
public boolean isRootBuild() {
return parent == null;
}
@Override
public BuildState getOwner() {
return getServices().get(BuildState.class);
}
@Override
public String getGradleVersion() {
return GradleVersion.current().getVersion();
}
@Override
public File getGradleHomeDir() {
GradleInstallation gradleInstallation = getCurrentGradleInstallation().getInstallation();
return gradleInstallation == null ? null : gradleInstallation.getGradleHome();
}
@Override
public File getGradleUserHomeDir() {
return startParameter.getGradleUserHomeDir();
}
@Override
public StartParameterInternal getStartParameter() {
return (StartParameterInternal) startParameter;
}
@Override
public GradleLifecycle getLifecycle() {
if (lifecycle == null) {
lifecycle = instantiateGradleLifecycle();
}
return lifecycle;
}
@Override
public void resetState() {
classLoaderScope = null;
baseProjectClassLoaderScope = null;
rootProject = null;
defaultProject = null;
projectsLoaded = false;
includedBuilds = null;
rootProjectActions.clear();
isolatedProjectEvaluationListenerProvider.clear();
buildListenerBroadcast.removeAll();
projectEvaluationListenerBroadcast.removeAll();
getTaskGraph().resetState();
if (settings != null) {
settings.close();
settings = null;
}
}
@Override
public void close() {
if (settings != null) {
settings.close();
settings = null;
}
}
@Override
public ClassLoaderScope baseProjectClassLoaderScope() {
if (baseProjectClassLoaderScope == null) {
throw new IllegalStateException("baseProjectClassLoaderScope not yet set");
}
return baseProjectClassLoaderScope;
}
@Override
public void setBaseProjectClassLoaderScope(ClassLoaderScope classLoaderScope) {
if (classLoaderScope == null) {
throw new IllegalArgumentException("classLoaderScope must not be null");
}
if (baseProjectClassLoaderScope != null) {
throw new IllegalStateException("baseProjectClassLoaderScope is already set");
}
this.baseProjectClassLoaderScope = classLoaderScope;
}
@Override
public SettingsInternal getSettings() {
if (settings == null) {
throw new IllegalStateException("The settings are not yet available for " + this + ".");
}
return settings.getSettings();
}
@Override
public void attachSettings(@Nullable SettingsState settings) {
if (this.settings != null) {
this.settings.close();
}
this.settings = settings;
}
@Override
public ProjectInternal getRootProject() {
if (rootProject == null) {
throw new IllegalStateException("The root project is not yet available for " + this + ".");
}
return rootProject;
}
@Override
public void setRootProject(ProjectInternal rootProject) {
this.rootProject = rootProject;
}
@Override
public void rootProject(Action super Project> action) {
rootProject("Gradle.rootProject", action);
}
private void rootProject(String registrationPoint, Action super Project> action) {
if (projectsLoaded) {
assert rootProject != null;
action.execute(rootProject);
} else {
// only need to decorate when this callback is delayed
rootProjectActions.add(decorate(registrationPoint, action));
}
}
@Override
public void allprojects(final Action super Project> action) {
rootProject("Gradle.allprojects", project -> project.allprojects(action));
}
@Override
public ProjectInternal getDefaultProject() {
if (defaultProject == null) {
throw new IllegalStateException("The default project is not yet available for " + this + ".");
}
return defaultProject;
}
@Override
public void setDefaultProject(ProjectInternal defaultProject) {
this.defaultProject = defaultProject;
}
@Inject
@Override
public abstract TaskExecutionGraphInternal getTaskGraph();
@Override
public ProjectEvaluationListener addProjectEvaluationListener(ProjectEvaluationListener listener) {
addListener("Gradle.addProjectEvaluationListener", listener);
return listener;
}
@Override
public void removeProjectEvaluationListener(ProjectEvaluationListener listener) {
removeListener(listener);
}
private void assertProjectMutatingMethodAllowed(String methodName) {
MutationGuards.of(crossProjectConfigurator).assertMutationAllowed(methodName, this, Gradle.class);
}
@Override
public void beforeProject(Closure closure) {
registerProjectEvaluationListener("Gradle.beforeProject", "beforeEvaluate", "beforeProject(Closure)", closure);
}
@Override
public void beforeProject(Action super Project> action) {
registerProjectEvaluationListener("Gradle.beforeProject", "beforeEvaluate", "beforeProject(Action)", action);
}
@Override
public void afterProject(Closure closure) {
registerProjectEvaluationListener("Gradle.afterProject", "afterEvaluate", "afterProject(Closure)", closure);
}
@Override
public void afterProject(Action super Project> action) {
registerProjectEvaluationListener("Gradle.afterProject", "afterEvaluate", "afterProject(Action)", action);
}
@Override
public void beforeSettings(Closure> closure) {
registerBuildListener("beforeSettings", closure);
}
@Override
public void beforeSettings(Action super Settings> action) {
buildListenerBroadcast.add("beforeSettings", action);
}
@Override
public void settingsEvaluated(Closure closure) {
registerBuildListener("settingsEvaluated", closure);
}
@Override
public void settingsEvaluated(Action super Settings> action) {
buildListenerBroadcast.add("settingsEvaluated", action);
}
@Override
public void projectsLoaded(Closure closure) {
registerBuildListener("Gradle.projectsLoaded", "projectsLoaded", "projectsLoaded(Closure)", closure);
}
@Override
public void projectsLoaded(Action super Gradle> action) {
registerBuildListener("Gradle.projectsLoaded", "projectsLoaded", "projectsLoaded(Action)", action);
}
@Override
public void projectsEvaluated(Closure closure) {
registerBuildListener("Gradle.projectsEvaluated", "projectsEvaluated", "projectsEvaluated(Closure)", closure);
}
@Override
public void projectsEvaluated(Action super Gradle> action) {
registerBuildListener("Gradle.projectsEvaluated", "projectsEvaluated", "projectsEvaluated(Action)", action);
}
@SuppressWarnings("deprecation")
@Override
public void buildFinished(Closure closure) {
notifyListenerRegistration("Gradle.buildFinished", closure);
registerBuildListener("buildFinished", closure);
}
@SuppressWarnings("deprecation")
@Override
public void buildFinished(Action super BuildResult> action) {
notifyListenerRegistration("Gradle.buildFinished", action);
buildListenerBroadcast.add("buildFinished", action);
}
@Override
public void addListener(Object listener) {
addListener("Gradle.addListener", listener);
}
@Override
public void removeListener(Object listener) {
// do same decoration as in addListener to remove correctly
getListenerManager().removeListener(decorateUnknownListener(null, listener));
}
private void registerProjectEvaluationListener(String registrationPoint, String methodName, String signature, Action super Project> action) {
assertProjectMutatingMethodAllowed(signature);
projectEvaluationListenerBroadcast.add(methodName, decorate(registrationPoint, action));
}
private void registerProjectEvaluationListener(String registrationPoint, String methodName, String signature, Closure closure) {
assertProjectMutatingMethodAllowed(signature);
projectEvaluationListenerBroadcast.add(new ClosureBackedMethodInvocationDispatch(methodName, decorate(registrationPoint, closure)));
}
private void registerBuildListener(String methodName, Closure> closure) {
buildListenerBroadcast.add(new ClosureBackedMethodInvocationDispatch(methodName, closure));
}
private void registerBuildListener(String registrationPoint, String methodName, String signature, Action super Gradle> action) {
assertProjectMutatingMethodAllowed(signature);
buildListenerBroadcast.add(methodName, decorate(registrationPoint, action));
}
private void registerBuildListener(String registrationPoint, String methodName, String signature, Closure closure) {
assertProjectMutatingMethodAllowed(signature);
buildListenerBroadcast.add(new ClosureBackedMethodInvocationDispatch(methodName, decorate(registrationPoint, closure)));
}
private void addListener(String registrationPoint, Object listener) {
notifyListenerRegistration(registrationPoint, listener);
getListenerManager().addListener(decorateUnknownListener(registrationPoint, listener));
}
private void notifyListenerRegistration(String registrationPoint, Object listener) {
if (isListenerSupportedWithConfigurationCache(listener)) {
return;
}
getBuildScopeListenerRegistrationListener().onBuildScopeListenerRegistration(listener, registrationPoint, this);
}
private BuildScopeListenerRegistrationListener getBuildScopeListenerRegistrationListener() {
return getListenerManager().getBroadcaster(BuildScopeListenerRegistrationListener.class);
}
private Object decorateUnknownListener(String registrationPoint, Object listener) {
return getListenerBuildOperationDecorator().decorateUnknownListener(registrationPoint, listener);
}
private Closure> decorate(String registrationPoint, Closure closure) {
return getListenerBuildOperationDecorator().decorate(registrationPoint, Cast.>uncheckedNonnullCast(closure));
}
private Action decorate(String registrationPoint, Action action) {
return getListenerBuildOperationDecorator().decorate(registrationPoint, action);
}
private static boolean isListenerSupportedWithConfigurationCache(Object listener) {
if (listener instanceof InternalListener) {
// Internal listeners are always allowed: we know their lifecycle and ensure there are no problems when configuration cache is reused.
return true;
}
if (JavaPropertyReflectionUtil.getAnnotation(listener.getClass(), DeprecatedInGradleScope.class) != null) {
// Explicitly unsupported Listener types are disallowed.
return false;
}
// We had to check for unsupported first to reject a listener that implements both allowed and disallowed interfaces.
// Just reject everything we don't know.
return listener instanceof ProjectEvaluationListener
|| listener instanceof TaskExecutionGraphListener
|| listener instanceof DependencyResolutionListener;
}
@Override
public void useLogger(Object logger) {
notifyListenerRegistration("Gradle.useLogger", logger);
getListenerManager().useLogger(logger);
}
@Override
public ProjectEvaluationListener getProjectEvaluationBroadcaster() {
return projectEvaluationListenerBroadcast.getSource();
}
@Override
public void addBuildListener(BuildListener buildListener) {
addListener("Gradle.addBuildListener", buildListener);
}
@Override
public BuildListener getBuildListenerBroadcaster() {
return buildListenerBroadcast.getSource();
}
@Override
public Gradle getGradle() {
return this;
}
@Override
@Inject
public abstract BuildServiceRegistry getSharedServices();
@Override
public Collection getIncludedBuilds() {
return Cast.uncheckedCast(includedBuilds());
}
@Override
public void setIncludedBuilds(Collection extends IncludedBuildInternal> includedBuilds) {
this.includedBuilds = ImmutableList.copyOf(includedBuilds);
}
@Override
public List extends IncludedBuildInternal> includedBuilds() {
if (includedBuilds == null) {
throw new IllegalStateException("Included builds are not yet available for this build.");
}
return includedBuilds;
}
@Override
public IncludedBuild includedBuild(final String name) {
for (IncludedBuild includedBuild : includedBuilds()) {
if (includedBuild.getName().equals(name)) {
return includedBuild;
}
}
throw new UnknownDomainObjectException("Included build '" + name + "' not found in " + this + ".");
}
@Override
public ServiceRegistry getServices() {
return services;
}
@Override
protected DefaultObjectConfigurationAction createObjectConfigurationAction() {
return new DefaultObjectConfigurationAction(
getFileResolver(),
getScriptPluginFactory(),
getScriptHandlerFactory(),
getClassLoaderScope(),
getResourceLoaderFactory(),
this
);
}
@Override
public void setClassLoaderScope(Supplier extends ClassLoaderScope> classLoaderScope) {
if (this.classLoaderScope != null) {
throw new IllegalStateException("Class loader scope already used");
}
this.classLoaderScope = classLoaderScope;
}
@Override
public ClassLoaderScope getClassLoaderScope() {
if (classLoaderScope == null) {
classLoaderScope = () -> getClassLoaderScopeRegistry().getCoreAndPluginsScope();
}
return classLoaderScope.get();
}
@Inject
protected abstract ClassLoaderScopeRegistry getClassLoaderScopeRegistry();
@Override
@Inject
public abstract ProjectRegistry getProjectRegistry();
@Inject
protected abstract TextUriResourceLoader.Factory getResourceLoaderFactory();
@Inject
protected abstract ScriptHandlerFactory getScriptHandlerFactory();
@Inject
protected abstract ScriptPluginFactory getScriptPluginFactory();
@Inject
protected abstract FileResolver getFileResolver();
@Inject
protected abstract CurrentGradleInstallation getCurrentGradleInstallation();
@Inject
protected abstract ListenerManager getListenerManager();
@Inject
protected abstract ListenerBuildOperationDecorator getListenerBuildOperationDecorator();
@Override
@Inject
public abstract PluginManagerInternal getPluginManager();
@Override
@Inject
public abstract PublicBuildPath getPublicBuildPath();
/**
* Instantiate {@link DefaultGradleLifecycle} via {@link ObjectFactory} in order to get
* {@link Closure} overloads for the {@link IsolatedAction} based methods.
*/
private DefaultGradleLifecycle instantiateGradleLifecycle() {
return services.get(ObjectFactory.class).newInstance(DefaultGradleLifecycle.class, this);
}
static class DefaultGradleLifecycle implements GradleLifecycle {
private final DefaultGradle gradle;
@Inject
public DefaultGradleLifecycle(DefaultGradle gradle) {
this.gradle = gradle;
}
@Override
public void beforeProject(IsolatedAction super Project> action) {
assertBeforeProjectsLoaded("beforeProject");
gradle.isolatedProjectEvaluationListenerProvider.beforeProject(action);
}
@Override
public void afterProject(IsolatedAction super Project> action) {
assertBeforeProjectsLoaded("afterProject");
gradle.isolatedProjectEvaluationListenerProvider.afterProject(action);
}
private void assertBeforeProjectsLoaded(String methodName) {
if (gradle.projectsLoaded) {
throw new IllegalStateException("GradleLifecycle#" + methodName + " cannot be called after settings have been evaluated.");
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy