org.gradle.api.internal.GradleInternal Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.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.api.internal;
import org.gradle.BuildListener;
import org.gradle.api.ProjectEvaluationListener;
import org.gradle.api.initialization.IncludedBuild;
import org.gradle.api.internal.initialization.ClassLoaderScope;
import org.gradle.api.internal.plugins.PluginAwareInternal;
import org.gradle.api.internal.project.ProjectInternal;
import org.gradle.api.invocation.Gradle;
import org.gradle.execution.taskgraph.TaskExecutionGraphInternal;
import org.gradle.internal.build.BuildState;
import org.gradle.internal.build.PublicBuildPath;
import org.gradle.internal.scan.UsedByScanPlugin;
import org.gradle.internal.service.ServiceRegistry;
import org.gradle.internal.service.scopes.ServiceRegistryFactory;
import org.gradle.util.Path;
import javax.annotation.Nullable;
import java.util.Collection;
/**
* An internal interface for Gradle that exposed objects and concepts that are not intended for public
* consumption.
*/
@UsedByScanPlugin
public interface GradleInternal extends Gradle, PluginAwareInternal {
/**
* {@inheritDoc}
*/
ProjectInternal getRootProject() throws IllegalStateException;
GradleInternal getParent();
GradleInternal getRoot();
/**
* Returns the {@link BuildState} that manages the state of this instance.
*/
BuildState getOwner();
/**
* {@inheritDoc}
*/
TaskExecutionGraphInternal getTaskGraph();
/**
* Returns the default project. This is used to resolve relative names and paths provided on the UI.
*/
ProjectInternal getDefaultProject();
/**
* Returns the broadcaster for {@link ProjectEvaluationListener} events for this build
*/
ProjectEvaluationListener getProjectEvaluationBroadcaster();
/**
* The settings for this build.
*
* @throws IllegalStateException when the build is not loaded yet, see {@link #setSettings(SettingsInternal)}
* @return the settings for this build
*/
SettingsInternal getSettings() throws IllegalStateException;
/**
* Called by the BuildLoader after the settings are loaded.
* Until the BuildLoader is executed, {@link #getSettings()} will throw {@link IllegalStateException}.
*
* @param settings The settings for this build.
*/
void setSettings(SettingsInternal settings);
/**
* Called by the BuildLoader after the default project is determined. Until the BuildLoader
* is executed, {@link #getDefaultProject()} will return null.
*
* @param defaultProject The default project for this build.
*/
void setDefaultProject(ProjectInternal defaultProject);
/**
* Called by the BuildLoader after the root project is determined. Until the BuildLoader
* is executed, {@link #getRootProject()} will throw {@link IllegalStateException}.
*
* @param rootProject The root project for this build.
*/
void setRootProject(ProjectInternal rootProject);
/**
* Returns the broadcaster for {@link BuildListener} events
*/
BuildListener getBuildListenerBroadcaster();
@UsedByScanPlugin
ServiceRegistry getServices();
ServiceRegistryFactory getServiceRegistryFactory();
ClassLoaderScope getClassLoaderScope();
void setIncludedBuilds(Collection extends IncludedBuild> includedBuilds);
/**
* Returns a unique path for this build within the current Gradle invocation.
*
* @throws IllegalStateException When the path is not yet known. The path is often a function of the name of the root project, which is not known when this `Gradle` instance is created.
*/
Path getIdentityPath() throws IllegalStateException;
/**
* Returns a unique path for this build within the current Gradle invocation, or null when not yet known
*/
@Nullable
Path findIdentityPath();
void setIdentityPath(Path path);
String contextualize(String description);
PublicBuildPath getPublicBuildPath();
enum BuildType {
NONE,
TASKS,
MODEL
}
void setBuildType(BuildType buildType);
BuildType getBuildType();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy