org.gradle.api.plugins.HelpTasksPlugin Maven / Gradle / Ivy
/*
* Copyright 2012 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.plugins;
import org.gradle.api.Action;
import org.gradle.api.Incubating;
import org.gradle.api.Plugin;
import org.gradle.api.Project;
import org.gradle.api.internal.project.ProjectInternal;
import org.gradle.api.tasks.TaskContainer;
import org.gradle.api.tasks.diagnostics.BuildEnvironmentReportTask;
import org.gradle.api.tasks.diagnostics.DependencyInsightReportTask;
import org.gradle.api.tasks.diagnostics.DependencyReportTask;
import org.gradle.api.tasks.diagnostics.OutgoingVariantsReportTask;
import org.gradle.api.tasks.diagnostics.ProjectReportTask;
import org.gradle.api.tasks.diagnostics.PropertyReportTask;
import org.gradle.api.tasks.diagnostics.ResolvableConfigurationsReportTask;
import org.gradle.api.tasks.diagnostics.TaskReportTask;
import org.gradle.configuration.Help;
import static org.gradle.api.internal.project.ProjectHierarchyUtils.getChildProjectsForInternalUse;
/**
* Adds various reporting tasks that provide information about the project.
*
* @see Getting additional help with Gradle
*/
public abstract class HelpTasksPlugin implements Plugin {
public static final String HELP_GROUP = "help";
public static final String PROPERTIES_TASK = "properties";
public static final String DEPENDENCIES_TASK = "dependencies";
public static final String DEPENDENCY_INSIGHT_TASK = "dependencyInsight";
public static final String COMPONENTS_TASK = "components";
/**
* The name of the outgoing variants report task.
*
* @since 6.0
*/
public static final String OUTGOING_VARIANTS_TASK = "outgoingVariants";
/**
* The name of the requested configurations report task.
*
* @since 7.5
*/
@Incubating
public static final String RESOLVABLE_CONFIGURATIONS_TASK = "resolvableConfigurations";
public static final String MODEL_TASK = "model";
public static final String DEPENDENT_COMPONENTS_TASK = "dependentComponents";
@Override
public void apply(final Project project) {
final TaskContainer tasks = project.getTasks();
// static classes are used for the actions to avoid implicitly dragging project/tasks into the model registry
String projectName = project.toString();
tasks.register(ProjectInternal.HELP_TASK, Help.class, new HelpAction());
tasks.register(ProjectInternal.PROJECTS_TASK, ProjectReportTask.class, new ProjectReportTaskAction(projectName));
tasks.register(ProjectInternal.TASKS_TASK, TaskReportTask.class, new TaskReportTaskAction(projectName, getChildProjectsForInternalUse(project).isEmpty()));
tasks.register(PROPERTIES_TASK, PropertyReportTask.class, new PropertyReportTaskAction(projectName));
tasks.register(DEPENDENCY_INSIGHT_TASK, DependencyInsightReportTask.class, new DependencyInsightReportTaskAction(projectName));
tasks.register(DEPENDENCIES_TASK, DependencyReportTask.class, new DependencyReportTaskAction(projectName));
tasks.register(BuildEnvironmentReportTask.TASK_NAME, BuildEnvironmentReportTask.class, new BuildEnvironmentReportTaskAction(projectName));
registerDeprecatedTasks(tasks, projectName);
tasks.register(OUTGOING_VARIANTS_TASK, OutgoingVariantsReportTask.class, task -> {
task.setDescription("Displays the outgoing variants of " + projectName + ".");
task.setGroup(HELP_GROUP);
task.setImpliesSubProjects(true);
task.getShowAll().convention(false);
});
tasks.register(RESOLVABLE_CONFIGURATIONS_TASK, ResolvableConfigurationsReportTask.class, task -> {
task.setDescription("Displays the configurations that can be resolved in " + projectName + ".");
task.setGroup(HELP_GROUP);
task.setImpliesSubProjects(true);
task.getShowAll().convention(false);
task.getRecursive().convention(false);
});
tasks.withType(TaskReportTask.class).configureEach(task -> {
task.getShowTypes().convention(false);
});
}
@SuppressWarnings("deprecation")
private void registerDeprecatedTasks(TaskContainer tasks, String projectName) {
tasks.register(COMPONENTS_TASK, org.gradle.api.reporting.components.ComponentReport.class, new ComponentReportAction(projectName));
tasks.register(MODEL_TASK, org.gradle.api.reporting.model.ModelReport.class, new ModelReportAction(projectName));
tasks.register(DEPENDENT_COMPONENTS_TASK, org.gradle.api.reporting.dependents.DependentComponentsReport.class, new DependentComponentsReportAction(projectName));
}
private static class HelpAction implements Action {
@Override
public void execute(Help task) {
task.setDescription("Displays a help message.");
task.setGroup(HELP_GROUP);
task.setImpliesSubProjects(true);
}
}
private static class ProjectReportTaskAction implements Action {
private final String project;
public ProjectReportTaskAction(String projectName) {
this.project = projectName;
}
@Override
public void execute(ProjectReportTask task) {
task.setDescription("Displays the sub-projects of " + project + ".");
task.setGroup(HELP_GROUP);
task.setImpliesSubProjects(true);
}
}
private static class TaskReportTaskAction implements Action {
private final String projectName;
private final boolean noChildren;
public TaskReportTaskAction(String projectName, boolean noChildren) {
this.projectName = projectName;
this.noChildren = noChildren;
}
@Override
public void execute(TaskReportTask task) {
String description;
if (noChildren) {
description = "Displays the tasks runnable from " + projectName + ".";
} else {
description = "Displays the tasks runnable from " + projectName + " (some of the displayed tasks may belong to subprojects).";
}
task.setDescription(description);
task.setGroup(HELP_GROUP);
task.setImpliesSubProjects(true);
}
}
private static class PropertyReportTaskAction implements Action {
private final String projectName;
public PropertyReportTaskAction(String projectName) {
this.projectName = projectName;
}
@Override
public void execute(PropertyReportTask task) {
task.setDescription("Displays the properties of " + projectName + ".");
task.setGroup(HELP_GROUP);
task.setImpliesSubProjects(true);
}
}
private static class DependencyInsightReportTaskAction implements Action {
private final String projectName;
public DependencyInsightReportTaskAction(String projectName) {
this.projectName = projectName;
}
@Override
public void execute(final DependencyInsightReportTask task) {
task.setDescription("Displays the insight into a specific dependency in " + projectName + ".");
task.setGroup(HELP_GROUP);
task.setImpliesSubProjects(true);
task.getShowingAllVariants().convention(false);
}
}
private static class DependencyReportTaskAction implements Action {
private final String projectName;
public DependencyReportTaskAction(String projectName) {
this.projectName = projectName;
}
@Override
public void execute(DependencyReportTask task) {
task.setDescription("Displays all dependencies declared in " + projectName + ".");
task.setGroup(HELP_GROUP);
task.setImpliesSubProjects(true);
}
}
private static class BuildEnvironmentReportTaskAction implements Action {
private final String projectName;
public BuildEnvironmentReportTaskAction(String projectName) {
this.projectName = projectName;
}
@Override
public void execute(BuildEnvironmentReportTask task) {
task.setDescription("Displays all buildscript dependencies declared in " + projectName + ".");
task.setGroup(HELP_GROUP);
task.setImpliesSubProjects(true);
}
}
@SuppressWarnings("deprecation")
private static class ComponentReportAction implements Action {
private final String projectName;
public ComponentReportAction(String projectName) {
this.projectName = projectName;
}
@Override
public void execute(org.gradle.api.reporting.components.ComponentReport task) {
task.setDescription("Displays the components produced by " + projectName + ". [deprecated]");
task.setImpliesSubProjects(true);
}
}
@SuppressWarnings("deprecation")
private static class ModelReportAction implements Action {
private final String projectName;
public ModelReportAction(String projectName) {
this.projectName = projectName;
}
@Override
public void execute(org.gradle.api.reporting.model.ModelReport task) {
task.setDescription("Displays the configuration model of " + projectName + ". [deprecated]");
task.setImpliesSubProjects(true);
}
}
@SuppressWarnings("deprecation")
private static class DependentComponentsReportAction implements Action {
private final String projectName;
public DependentComponentsReportAction(String projectName) {
this.projectName = projectName;
}
@Override
public void execute(org.gradle.api.reporting.dependents.DependentComponentsReport task) {
task.setDescription("Displays the dependent components of components in " + projectName + ". [deprecated]");
task.setImpliesSubProjects(true);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy