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.Task;
import org.gradle.api.internal.ConventionTask;
import org.gradle.api.specs.Spec;
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.ProjectReportGenerator;
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 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.
*/
public abstract class AbstractReportTask extends ConventionTask {
private File outputFile;
// todo annotate as required
private Set projects;
protected AbstractReportTask() {
getOutputs().upToDateWhen(new Spec() {
public boolean isSatisfiedBy(Task element) {
return 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() {
ProjectReportGenerator projectReportGenerator = new ProjectReportGenerator() {
@Override
public void generateReport(Project project) throws IOException {
generate(project);
if (shouldCreateReportFile()) {
project.getLogger().lifecycle("See the report at: {}", new ConsoleRenderer().asClickableFileUrl(getOutputFile()));
}
}
};
ReportGenerator reportGenerator = new ReportGenerator(getRenderer(), getClientMetaData(), getOutputFile(),
getTextOutputFactory(), projectReportGenerator);
reportGenerator.generateReport(new TreeSet(getProjects()));
}
private 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