diff options
author | tricktron <tgagnaux@gmail.com> | 2021-11-24 08:11:55 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-11-24 08:11:55 +0100 |
commit | 438bcfecbe73e401e86179ae0d49792f1fc7af34 (patch) | |
tree | 06022a059a1966d3b202fcf56995256eb8417408 /src/main/java/ch/fhnw/thga/gradleplugins/CompileFregeTask.java | |
parent | 7d98c27eaebb17d18ddb7fff1c2930db6f149521 (diff) | |
parent | fd2fee1260a494ea24887eb1512c27938e8fa230 (diff) | |
download | frege-gradle-plugin-438bcfecbe73e401e86179ae0d49792f1fc7af34.tar.gz frege-gradle-plugin-438bcfecbe73e401e86179ae0d49792f1fc7af34.tar.bz2 frege-gradle-plugin-438bcfecbe73e401e86179ae0d49792f1fc7af34.zip |
Merge pull request #5 from tricktron/f-classpath-config
Implementation Dependency Configuration
Diffstat (limited to 'src/main/java/ch/fhnw/thga/gradleplugins/CompileFregeTask.java')
-rw-r--r-- | src/main/java/ch/fhnw/thga/gradleplugins/CompileFregeTask.java | 26 |
1 files changed, 21 insertions, 5 deletions
diff --git a/src/main/java/ch/fhnw/thga/gradleplugins/CompileFregeTask.java b/src/main/java/ch/fhnw/thga/gradleplugins/CompileFregeTask.java index 9dc148f..e81fe76 100644 --- a/src/main/java/ch/fhnw/thga/gradleplugins/CompileFregeTask.java +++ b/src/main/java/ch/fhnw/thga/gradleplugins/CompileFregeTask.java @@ -1,6 +1,7 @@ package ch.fhnw.thga.gradleplugins; import java.util.Collection; +import java.util.Collections; import java.util.List; import java.util.stream.Collectors; import java.util.stream.Stream; @@ -12,6 +13,7 @@ import org.gradle.api.file.DirectoryProperty; import org.gradle.api.file.RegularFileProperty; import org.gradle.api.model.ObjectFactory; import org.gradle.api.provider.ListProperty; +import org.gradle.api.provider.Property; import org.gradle.api.provider.Provider; import org.gradle.api.tasks.CacheableTask; import org.gradle.api.tasks.Input; @@ -39,6 +41,9 @@ public abstract class CompileFregeTask extends DefaultTask { @Input public abstract ListProperty<String> getFregeCompilerFlags(); + @Input + public abstract Property<String> getFregeDependencies(); + @OutputDirectory public abstract DirectoryProperty getFregeOutputDir(); @@ -52,18 +57,29 @@ public abstract class CompileFregeTask extends DefaultTask { return getFregeMainSourcePath().map(srcPath -> List.of("-sp", srcPath)); } + @Internal + public final Provider<List<String>> getDependencyArg() { + return getFregeDependencies().map(depsClasspath -> { + return depsClasspath.isEmpty() ? Collections.emptyList() : List.of("-fp", depsClasspath); + }); + } + @Inject public CompileFregeTask(ObjectFactory objectFactory) { javaExec = objectFactory.newInstance(JavaExec.class); } + private List<String> buildCompilerArgsFromProperties(List<String> directoryArg) { + return Stream + .of(getDependencyArg().get(), getFregeCompilerFlags().get(), directoryArg, getSourcePathArg().get(), + List.of(getFregeMainSourcePath().get())) + .filter(lists -> !lists.isEmpty()).flatMap(Collection::stream).collect(Collectors.toList()); + } + @TaskAction public void compileFrege() { List<String> directoryArg = List.of("-d", getFregeOutputDir().getAsFile().get().getAbsolutePath()); - List<String> compilerArgs = Stream - .of(getFregeCompilerFlags().get(), directoryArg, getSourcePathArg().get(), - List.of(getFregeMainSourcePath().get())) - .flatMap(Collection::stream).collect(Collectors.toList()); - javaExec.setClasspath(getProject().files(getFregeCompilerJar())).setArgs(compilerArgs).exec(); + javaExec.setClasspath(getProject().files(getFregeCompilerJar())) + .setArgs(buildCompilerArgsFromProperties(directoryArg)).exec(); } }
\ No newline at end of file |