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

org.gradle.api.reporting.dependencies.HtmlDependencyReportTask Maven / Gradle / Ivy

There is a newer version: 8.11.1
Show newest version
/*
 * Copyright 2013 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.reporting.dependencies;

import groovy.lang.Closure;
import org.gradle.api.Action;
import org.gradle.api.Project;
import org.gradle.api.file.DirectoryProperty;
import org.gradle.api.internal.CollectionCallbackActionDecorator;
import org.gradle.api.internal.ConventionTask;
import org.gradle.api.internal.artifacts.configurations.ConfigurationInternal;
import org.gradle.api.internal.artifacts.ivyservice.ivyresolve.strategy.VersionComparator;
import org.gradle.api.internal.artifacts.ivyservice.ivyresolve.strategy.VersionParser;
import org.gradle.api.internal.artifacts.ivyservice.ivyresolve.strategy.VersionSelectorScheme;
import org.gradle.api.model.ObjectFactory;
import org.gradle.api.reporting.Reporting;
import org.gradle.api.reporting.dependencies.internal.DefaultDependencyReportContainer;
import org.gradle.api.reporting.dependencies.internal.HtmlDependencyReporter;
import org.gradle.api.tasks.Internal;
import org.gradle.api.tasks.Nested;
import org.gradle.api.tasks.TaskAction;
import org.gradle.api.tasks.UntrackedTask;
import org.gradle.api.tasks.diagnostics.internal.ConfigurationDetails;
import org.gradle.api.tasks.diagnostics.internal.ProjectDetails;
import org.gradle.api.tasks.diagnostics.internal.ProjectsWithConfigurations;
import org.gradle.internal.logging.ConsoleRenderer;
import org.gradle.internal.serialization.Cached;
import org.gradle.internal.serialization.Transient;
import org.gradle.util.internal.ClosureBackedAction;

import javax.inject.Inject;
import java.util.Set;
import java.util.stream.Stream;

import static java.util.Collections.singleton;
import static org.gradle.internal.Cast.uncheckedCast;

/**
 * Generates an HTML dependency report. This report
 * combines the features of the ASCII dependency report and those of the ASCII
 * dependency insight report. For a given project, it generates a tree of the dependencies
 * of every configuration, and each dependency can be clicked to show the insight of
 * this dependency.
 * 

* This task generates a report for the task's containing project by default. But it can also generate * a report for multiple projects, by setting the value of the * projects property. Here's how to generate an HTML * dependency report for all the projects of a multi-project build, for example: *

 * htmlDependencyReport {
 *     projects = project.allprojects
 * }
 * 
*

* The report is generated in the build/reports/project/dependencies directory by default. * This can also be changed by setting the reports.html.destination property: *

 * htmlDependencyReport {
 *     reports.html.outputLocation = file("build/reports/project/dependencies")
 * }
 * 
*/ @UntrackedTask(because = "We can't describe the dependency tree of all projects as input") public abstract class HtmlDependencyReportTask extends ConventionTask implements Reporting { private final Transient.Var> projects = Transient.varOf(uncheckedCast(singleton(getProject()))); private final Cached> projectsWithConfigurations = Cached.of(this::computeProjectsWithConfigurations); private final DirectoryProperty reportDir; private final DependencyReportContainer reports; public HtmlDependencyReportTask() { reports = getObjectFactory().newInstance(DefaultDependencyReportContainer.class, this, getCallbackActionDecorator()); reportDir = getObjectFactory().directoryProperty(); reports.getHtml().getRequired().set(true); } /** * Returns the project report directory. * * @return the directory to store project reports * * @since 7.1 */ @Internal public DirectoryProperty getProjectReportDirectory() { return reportDir; } @Nested @Override public DependencyReportContainer getReports() { return reports; } @Override @SuppressWarnings("rawtypes") public DependencyReportContainer reports(Closure closure) { return reports(new ClosureBackedAction<>(closure)); } @Override public DependencyReportContainer reports(Action configureAction) { configureAction.execute(reports); return reports; } @Inject protected ObjectFactory getObjectFactory() { throw new UnsupportedOperationException(); } @Inject protected VersionSelectorScheme getVersionSelectorScheme() { throw new UnsupportedOperationException(); } @Inject protected VersionComparator getVersionComparator() { throw new UnsupportedOperationException(); } @Inject protected VersionParser getVersionParser() { throw new UnsupportedOperationException(); } /** * Required for decorating reports container callbacks for tracing user code application. * * @since 5.1 */ @Inject protected CollectionCallbackActionDecorator getCallbackActionDecorator() { throw new UnsupportedOperationException(); } @TaskAction public void generate() { if (!reports.getHtml().getRequired().get()) { setDidWork(false); return; } HtmlDependencyReporter reporter = new HtmlDependencyReporter(getVersionSelectorScheme(), getVersionComparator(), getVersionParser()); reporter.render(projectsWithConfigurations.get(), reports.getHtml().getOutputLocation().getAsFile().get()); getLogger().lifecycle("See the report at: {}", new ConsoleRenderer().asClickableFileUrl(reports.getHtml().getEntryPoint())); } /** * Returns the set of projects to generate a report for. By default, the report is generated for the task's * containing project. * * @return The set of files. */ @Internal public Set getProjects() { return projects.get(); } /** * Specifies the set of projects to generate this report for. * * @param projects The set of projects. Must not be null. */ public void setProjects(Set projects) { this.projects.set(projects); } private ProjectsWithConfigurations computeProjectsWithConfigurations() { return ProjectsWithConfigurations.from( getProjects(), ProjectDetails::withNameAndPath, HtmlDependencyReportTask::getConfigurationsWhichCouldHaveDependencyInfo ); } private static Stream getConfigurationsWhichCouldHaveDependencyInfo(Project project) { return project.getConfigurations().stream() .map(ConfigurationInternal.class::cast) .filter(c -> c.isDeclarableByExtension()) .map(ConfigurationDetails::of); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy