org.gradle.api.tasks.diagnostics.AbstractReportTask 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 2010 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 org.gradle.api.Project;
import org.gradle.api.internal.ConventionTask;
import org.gradle.api.tasks.Internal;
import org.gradle.api.tasks.Optional;
import org.gradle.api.tasks.OutputFile;
import org.gradle.api.tasks.TaskAction;
import org.gradle.api.tasks.diagnostics.internal.ProjectDetails;
import org.gradle.api.tasks.diagnostics.internal.ReportGenerator;
import org.gradle.api.tasks.diagnostics.internal.ReportRenderer;
import org.gradle.initialization.BuildClientMetaData;
import org.gradle.internal.logging.ConsoleRenderer;
import org.gradle.internal.logging.text.StyledTextOutputFactory;
import org.gradle.work.DisableCachingByDefault;
import javax.annotation.Nullable;
import javax.inject.Inject;
import java.io.File;
import java.io.IOException;
import java.util.HashSet;
import java.util.Set;
import java.util.TreeSet;
/**
* The base class for all project report tasks.
*
* Preserved for backward compatibility.
*
* @deprecated Use {@link AbstractProjectBasedReportTask} instead.
*/
@Deprecated
@DisableCachingByDefault(because = "Abstract super-class, not to be instantiated directly")
public abstract class AbstractReportTask extends ConventionTask {
private File outputFile;
// todo annotate as required
private Set projects;
protected AbstractReportTask() {
getOutputs().upToDateWhen(element -> false);
projects = new HashSet<>();
projects.add(getProject());
}
@Inject
protected BuildClientMetaData getClientMetaData() {
throw new UnsupportedOperationException();
}
@Inject
protected StyledTextOutputFactory getTextOutputFactory() {
throw new UnsupportedOperationException();
}
@TaskAction
public void generate() {
reportGenerator().generateReport(
new TreeSet<>(getProjects()),
ProjectDetails::of,
project -> {
generate(project);
logClickableOutputFileUrl();
}
);
}
ReportGenerator reportGenerator() {
return new ReportGenerator(
getRenderer(),
getClientMetaData(),
getOutputFile(),
getTextOutputFactory()
);
}
void logClickableOutputFileUrl() {
if (shouldCreateReportFile()) {
getLogger().lifecycle("See the report at: {}", clickableOutputFileUrl());
}
}
String clickableOutputFileUrl() {
return new ConsoleRenderer().asClickableFileUrl(getOutputFile());
}
boolean shouldCreateReportFile() {
return getOutputFile() != null;
}
@Internal
protected abstract ReportRenderer getRenderer();
protected abstract void generate(Project project) throws IOException;
/**
* Returns the file which the report will be written to. When set to {@code null}, the report is written to {@code System.out}.
* Defaults to {@code null}.
*
* @return The output file. May be null.
*/
@Nullable
@Optional
@OutputFile
public File getOutputFile() {
return outputFile;
}
/**
* Sets the file which the report will be written to. Set this to {@code null} to write the report to {@code System.out}.
*
* @param outputFile The output file. May be null.
*/
public void setOutputFile(@Nullable File outputFile) {
this.outputFile = outputFile;
}
/**
* Returns the set of project to generate this report for. By default, the report is generated for the task's
* containing project.
*
* @return The set of files.
*/
@Internal
// TODO:LPTR Have the paths of the projects serve as @Input maybe?
public Set getProjects() {
return projects;
}
/**
* 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 = projects;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy