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

org.gradle.api.tasks.diagnostics.TaskReportTask Maven / Gradle / Ivy

/*
 * Copyright 2008 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.tasks.diagnostics;

import com.google.common.base.Strings;
import org.gradle.api.Incubating;
import org.gradle.api.Project;
import org.gradle.api.internal.project.ProjectState;
import org.gradle.api.internal.project.ProjectStateRegistry;
import org.gradle.api.internal.project.ProjectTaskLister;
import org.gradle.api.provider.Property;
import org.gradle.api.tasks.Console;
import org.gradle.api.tasks.TaskAction;
import org.gradle.api.tasks.diagnostics.internal.AggregateMultiProjectTaskReportModel;
import org.gradle.api.tasks.diagnostics.internal.DefaultGroupTaskReportModel;
import org.gradle.api.tasks.diagnostics.internal.ProjectDetails;
import org.gradle.api.tasks.diagnostics.internal.ReportRenderer;
import org.gradle.api.tasks.diagnostics.internal.RuleDetails;
import org.gradle.api.tasks.diagnostics.internal.SingleProjectTaskReportModel;
import org.gradle.api.tasks.diagnostics.internal.TaskDetails;
import org.gradle.api.tasks.diagnostics.internal.TaskDetailsFactory;
import org.gradle.api.tasks.diagnostics.internal.TaskReportRenderer;
import org.gradle.api.tasks.options.Option;
import org.gradle.internal.Try;
import org.gradle.internal.instrumentation.api.annotations.ToBeReplacedByLazyProperty;
import org.gradle.internal.serialization.Cached;
import org.gradle.work.DisableCachingByDefault;

import javax.inject.Inject;
import java.util.ArrayList;
import java.util.List;
import java.util.TreeSet;
import java.util.stream.Collectors;

import static java.util.Collections.emptyList;

/**
 * 

Displays a list of tasks in the project. An instance of this type is used when you execute the {@code tasks} task * from the command-line.

* * By default, this report shows only those tasks which have been assigned to a task group, so-called visible * tasks. Tasks which have not been assigned to a task group, so-called hidden tasks, can be included in the report * by enabling the command line option {@code --all}. */ @DisableCachingByDefault(because = "Not worth caching") public abstract class TaskReportTask extends ConventionReportTask { private boolean detail; private final Property showTypes = getProject().getObjects().property(Boolean.class); private String group; private List groups; private final Cached model = Cached.of(this::computeTaskReportModel); private transient TaskReportRenderer renderer; @Override @ToBeReplacedByLazyProperty public ReportRenderer getRenderer() { if (renderer == null) { renderer = new TaskReportRenderer(); } return renderer; } public void setRenderer(TaskReportRenderer renderer) { this.renderer = renderer; } /** * Sets whether to show "invisible" tasks without a group or dependent tasks. * * This property can be set via command-line option '--all'. */ @Option(option = "all", description = "Show additional tasks and detail.") public void setShowDetail(boolean detail) { this.detail = detail; } // TODO config-cache - should invalidate the cache or the filtering and merging should be moved to task execution time @Console @ToBeReplacedByLazyProperty public boolean isDetail() { return detail; } /** * Set a specific task group to be displayed. * * @since 5.1 */ @Option(option = "group", description = "Show tasks for a specific group.") public void setDisplayGroup(String group) { this.group = group; } /** * Returns the task group to be displayed. * * This property can be set via command-line option '--group'. * * @since 5.1 */ @Console @ToBeReplacedByLazyProperty public String getDisplayGroup() { return group; } /** * Add a specific task group to be displayed. * Same functionality as the '--group' option, but unlike '--group', '--groups' can be chained. * * @since 7.5 */ @Incubating @Option(option = "groups", description = "Show tasks for specific groups (can be used multiple times to specify multiple groups).") public void setDisplayGroups(List groups) { if (this.groups == null) { this.groups = new ArrayList<>(); } this.groups.addAll(groups); } /** * Returns the task groups to be displayed. * * Task groups can be added via command-line option '--groups'. * * @since 7.5 */ @Incubating @Console @ToBeReplacedByLazyProperty public List getDisplayGroups() { return groups == null ? new ArrayList<>() : groups; } /** * Whether to show the task types next to their names in the output. * * This property can be set via command-line option '--types'. * * @since 7.4 */ @Console @Option(option = "types", description = "Show task class types") public Property getShowTypes() { return showTypes; } @TaskAction void generate() { reportGenerator().generateReport( model.get().projects, projectModel -> projectModel.get().project, projectModel -> { render(projectModel.get()); logClickableOutputFileUrl(); } ); } private TaskReportModel computeTaskReportModel() { return new TaskReportModel(computeProjectModels()); } private List> computeProjectModels() { List> result = new ArrayList<>(); for (Project project : new TreeSet<>(getProjects())) { result.add(Try.ofFailable(() -> projectReportModelFor(project))); } return result; } private static class TaskReportModel { final List> projects; public TaskReportModel(List> projects) { this.projects = projects; } } private static class ProjectReportModel { public final ProjectDetails project; public final List defaultTasks; public final DefaultGroupTaskReportModel tasks; public final List rules; public ProjectReportModel( ProjectDetails project, List defaultTasks, DefaultGroupTaskReportModel tasks, List rules ) { this.project = project; this.defaultTasks = defaultTasks; this.tasks = tasks; this.rules = rules; } } private ProjectReportModel projectReportModelFor(Project project) { return new ProjectReportModel( ProjectDetails.of(project), project.getDefaultTasks(), taskReportModelFor(project, isDetail()), (Strings.isNullOrEmpty(group) && (groups == null || groups.isEmpty())) ? ruleDetailsFor(project) : emptyList() ); } private void render(ProjectReportModel reportModel) { renderer.showDetail(isDetail()); renderer.showTypes(getShowTypes().get()); renderer.addDefaultTasks(reportModel.defaultTasks); DefaultGroupTaskReportModel model = reportModel.tasks; for (String group : model.getGroups()) { renderer.startTaskGroup(group); for (TaskDetails task : model.getTasksForGroup(group)) { renderer.addTask(task); } } renderer.completeTasks(); for (RuleDetails rule : reportModel.rules) { renderer.addRule(rule); } } private List ruleDetailsFor(Project project) { return project.getTasks().getRules().stream().map(rule -> RuleDetails.of(rule.getDescription())).collect(Collectors.toList()); } private DefaultGroupTaskReportModel taskReportModelFor(Project project, boolean detail) { final AggregateMultiProjectTaskReportModel aggregateModel = new AggregateMultiProjectTaskReportModel(!detail, detail, getDisplayGroup(), getDisplayGroups()); final TaskDetailsFactory taskDetailsFactory = new TaskDetailsFactory(project); final SingleProjectTaskReportModel projectTaskModel = buildTaskReportModelFor(taskDetailsFactory, project); aggregateModel.add(projectTaskModel); for (final Project subproject : project.getSubprojects()) { aggregateModel.add(buildTaskReportModelFor(taskDetailsFactory, subproject)); } aggregateModel.build(); return DefaultGroupTaskReportModel.of(aggregateModel); } private SingleProjectTaskReportModel buildTaskReportModelFor( final TaskDetailsFactory taskDetailsFactory, final Project subproject ) { return projectStateFor(subproject).fromMutableState( project -> SingleProjectTaskReportModel.forTasks( getProjectTaskLister().listProjectTasks(project), taskDetailsFactory ) ); } private ProjectState projectStateFor(Project subproject) { return getProjectStateRegistry().stateFor(subproject); } /** * Injects a {@code ProjectStateRegistry} service. * * @since 5.0 */ @Inject protected ProjectStateRegistry getProjectStateRegistry() { throw new UnsupportedOperationException(); } @Inject protected ProjectTaskLister getProjectTaskLister() { throw new UnsupportedOperationException(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy