Skip to content

Commit

Permalink
Initial commit to remove warning in Gradle 4:
Browse files Browse the repository at this point in the history
- classesDir -> classesDirs
- deprecated classesDir
- make plugin-init.groovy detect correct behaviour using hasProperty()
  • Loading branch information
uschindler committed Jul 19, 2017
1 parent 355dbc7 commit 5ded20c
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 18 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
import java.net.URL;
import java.net.URLClassLoader;
import java.util.EnumSet;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Locale;
import java.util.Set;
Expand All @@ -43,7 +44,7 @@
import org.gradle.api.tasks.Input;
import org.gradle.api.tasks.InputFiles;
import org.gradle.api.tasks.Optional;
import org.gradle.api.tasks.OutputDirectory;
import org.gradle.api.tasks.OutputDirectories;
import org.gradle.api.tasks.ParallelizableTask;
import org.gradle.api.tasks.SkipWhenEmpty;
import org.gradle.api.tasks.TaskAction;
Expand Down Expand Up @@ -109,23 +110,43 @@ public class CheckForbiddenApis extends DefaultTask implements PatternFilterable

private final CheckForbiddenApisExtension data = new CheckForbiddenApisExtension();
private final PatternSet patternSet = new PatternSet().include("**/*.class");
private File classesDir;
private FileCollection classesDirs;
private FileCollection classpath;
private String targetCompatibility;

/**
* Directories with the class files to check.
* Defaults to current sourseSet's output directory (Gradle 2/3) or output directories (Gradle 4.0+).
*/
@OutputDirectories
// no @InputDirectories, we use separate getter for a list of all input files
public FileCollection getClassesDirs() {
return classesDirs;
}

/** @see #getClassesDirs */
public void setClassesDirs(FileCollection classesDirs) {
this.classesDirs = classesDirs;
}

/**
* Directory with the class files to check.
* Defaults to current sourseSet's output directory.
* @deprecated use {@link #getClassesDirs()} instead
*/
@OutputDirectory
// no @InputDirectory, we use separate getter for a list of all input files
@Deprecated
public File getClassesDir() {
return classesDir;
final FileCollection col = getClassesDirs();
return (col == null) ? null : col.getSingleFile();
}

/** @see #getClassesDir */
/** Sets the directory where to look for classes. Overwrites any value set by {@link #setClassesDirs()}!
* @deprecated use {@link #setClassesDirs()} instead
* @see #getClassesDir
*/
@Deprecated
public void setClassesDir(File classesDir) {
this.classesDir = classesDir;
setClassesDirs(getProject().files(classesDir));
}

/** Returns the pattern set to match against class files in {@link #getClassesDir()}. */
Expand Down Expand Up @@ -453,16 +474,16 @@ public CheckForbiddenApis include(@SuppressWarnings("rawtypes") Closure arg0) {
@InputFiles
@SkipWhenEmpty
public FileTree getClassFiles() {
return getProject().files(getClassesDir()).getAsFileTree().matching(getPatternSet());
return getClassesDirs().getAsFileTree().matching(getPatternSet());
}

/** Executes the forbidden apis task. */
@TaskAction
public void checkForbidden() throws ForbiddenApiException {
final File classesDir = getClassesDir();
final FileCollection classesDirs = getClassesDirs();
final FileCollection classpath = getClasspath();
if (classesDir == null || classpath == null) {
throw new InvalidUserDataException("Missing 'classesDir' or 'classpath' property.");
if (classesDirs == null || classpath == null) {
throw new InvalidUserDataException("Missing 'classesDirs' or 'classpath' property.");
}

final Logger log = new Logger() {
Expand All @@ -482,14 +503,15 @@ public void info(String msg) {
}
};

final Set<File> cpElements = classpath.getFiles();
final URL[] urls = new URL[cpElements.size() + 1];
final Set<File> cpElements = new LinkedHashSet<File>();
cpElements.addAll(classpath.getFiles());
cpElements.addAll(classesDirs.getFiles());
final URL[] urls = new URL[cpElements.size()];
try {
int i = 0;
for (final File cpElement : cpElements) {
urls[i++] = cpElement.toURI().toURL();
}
urls[i++] = classesDir.toURI().toURL();
assert i == urls.length;
} catch (MalformedURLException mfue) {
throw new InvalidUserDataException("Failed to build classpath URLs.", mfue);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -45,19 +45,20 @@ def extensionProps = CheckForbiddenApisExtension.class.declaredFields.findAll{ f

// Define our tasks (one for each SourceSet):
def forbiddenTasks = project.sourceSets.collect{ sourceSet ->
def getClassesDirs = { sourceSet.output.hasProperty('classesDirs') ? sourceSet.output.classesDirs : project.files(sourceSet.output.classesDir) }
project.tasks.create(sourceSet.getTaskName(FORBIDDEN_APIS_TASK_NAME, null), CheckForbiddenApis.class) {
description = "Runs forbidden-apis checks on '${sourceSet.name}' classes.";
conventionMapping.with{
extensionProps.each{ key ->
map(key, { extension[key] });
}
classesDir = { sourceSet.output.classesDir }
classesDirs = { getClassesDirs() }
classpath = { sourceSet.compileClasspath }
targetCompatibility = { project.targetCompatibility?.toString() }
}
// add dependency to compile task after evaluation, if the classesDir is from our SourceSet:
project.afterEvaluate{
if (classesDir == sourceSet.output.classesDir) {
// add dependency to compile task after evaluation, if the classesDirs collection has overlaps with our SourceSet:
project.afterEvaluate{
if (!classesDirs.minus(getClassesDirs()).isEmpty()) {
dependsOn(sourceSet.output);
}
}
Expand Down

0 comments on commit 5ded20c

Please sign in to comment.