aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThibault Gagnaux <thibault.gagnaux@bit.admin.ch>2021-07-02 12:52:16 +0200
committerThibault Gagnaux <thibault.gagnaux@bit.admin.ch>2021-07-02 12:52:16 +0200
commit587d0943327c7bf26a6378c1a710b3b971102ea2 (patch)
tree0d467753e8f8a2176fd87c1d75463b2a7a000de1
parent5ad88075e8e67ece6673999ffd06260c2b5d298d (diff)
downloadfrege-gradle-plugin-587d0943327c7bf26a6378c1a710b3b971102ea2.tar.gz
frege-gradle-plugin-587d0943327c7bf26a6378c1a710b3b971102ea2.tar.bz2
frege-gradle-plugin-587d0943327c7bf26a6378c1a710b3b971102ea2.zip
Adds `fregeCompile` task with some tests
Upgrades gradle-wrapper to version `7.1`.
-rw-r--r--gradle/wrapper/gradle-wrapper.properties2
-rw-r--r--src/main/java/ch/fhnw/thga/gradleplugins/FregeCompileTask.java42
-rw-r--r--src/main/java/ch/fhnw/thga/gradleplugins/FregeExtension.java10
-rw-r--r--src/main/java/ch/fhnw/thga/gradleplugins/FregePlugin.java12
-rw-r--r--src/test/java/ch/fhnw/thga/gradleplugins/FregePluginFunctionalTest.java21
5 files changed, 85 insertions, 2 deletions
diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties
index f371643..69a9715 100644
--- a/gradle/wrapper/gradle-wrapper.properties
+++ b/gradle/wrapper/gradle-wrapper.properties
@@ -1,5 +1,5 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
-distributionUrl=https\://services.gradle.org/distributions/gradle-7.0-bin.zip
+distributionUrl=https\://services.gradle.org/distributions/gradle-7.1-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
diff --git a/src/main/java/ch/fhnw/thga/gradleplugins/FregeCompileTask.java b/src/main/java/ch/fhnw/thga/gradleplugins/FregeCompileTask.java
new file mode 100644
index 0000000..0f19f08
--- /dev/null
+++ b/src/main/java/ch/fhnw/thga/gradleplugins/FregeCompileTask.java
@@ -0,0 +1,42 @@
+package ch.fhnw.thga.gradleplugins;
+
+import java.util.List;
+
+import javax.inject.Inject;
+
+import org.gradle.api.DefaultTask;
+import org.gradle.api.file.DirectoryProperty;
+import org.gradle.api.file.RegularFileProperty;
+import org.gradle.api.model.ObjectFactory;
+import org.gradle.api.tasks.InputDirectory;
+import org.gradle.api.tasks.InputFile;
+import org.gradle.api.tasks.JavaExec;
+import org.gradle.api.tasks.OutputDirectory;
+import org.gradle.api.tasks.TaskAction;
+
+public abstract class FregeCompileTask extends DefaultTask {
+ private final JavaExec javaExec;
+
+ @InputFile
+ public abstract RegularFileProperty getFregeCompilerJar();
+
+ @InputDirectory
+ public abstract DirectoryProperty getFregeMainSourceDir();
+
+ @OutputDirectory
+ public abstract DirectoryProperty getFregeOutputDir();
+
+ @Inject
+ public FregeCompileTask(ObjectFactory objectFactory) {
+ javaExec = objectFactory.newInstance(JavaExec.class);
+
+ }
+
+
+ @TaskAction
+ public void compileFrege() {
+ String fregeMainSourceDir = getFregeMainSourceDir().getAsFile().get().getAbsolutePath();
+ List<String> args = List.of("-v", "-d", getFregeOutputDir().get().getAsFile().getAbsolutePath(), "-sp", fregeMainSourceDir, fregeMainSourceDir);
+ javaExec.setClasspath(getProject().files(getFregeCompilerJar())).setArgs(args).exec();
+ }
+}
diff --git a/src/main/java/ch/fhnw/thga/gradleplugins/FregeExtension.java b/src/main/java/ch/fhnw/thga/gradleplugins/FregeExtension.java
index 8a6d175..2763ebc 100644
--- a/src/main/java/ch/fhnw/thga/gradleplugins/FregeExtension.java
+++ b/src/main/java/ch/fhnw/thga/gradleplugins/FregeExtension.java
@@ -1,5 +1,7 @@
package ch.fhnw.thga.gradleplugins;
+import java.io.File;
+
import javax.inject.Inject;
import org.gradle.api.file.DirectoryProperty;
@@ -19,8 +21,16 @@ public abstract class FregeExtension {
public abstract DirectoryProperty getFregeCompilerOutputDirectory();
+ public abstract DirectoryProperty getFregeMainSourceDir();
+
+ public abstract DirectoryProperty getFregeOutputDir();
+
@Inject
public FregeExtension(ProjectLayout projectLayout) {
getFregeCompilerOutputDirectory().convention(projectLayout.getProjectDirectory().dir("lib"));
+ // TODO: change to projectDir/src/main/frege
+ getFregeMainSourceDir().convention(projectLayout.getProjectDirectory());
+ getFregeOutputDir().convention(projectLayout.getBuildDirectory().dir("classes/main/frege"));
}
+
}
diff --git a/src/main/java/ch/fhnw/thga/gradleplugins/FregePlugin.java b/src/main/java/ch/fhnw/thga/gradleplugins/FregePlugin.java
index 709552c..429edbb 100644
--- a/src/main/java/ch/fhnw/thga/gradleplugins/FregePlugin.java
+++ b/src/main/java/ch/fhnw/thga/gradleplugins/FregePlugin.java
@@ -2,20 +2,30 @@ package ch.fhnw.thga.gradleplugins;
import org.gradle.api.Plugin;
import org.gradle.api.Project;
+import org.gradle.api.tasks.TaskProvider;
public class FregePlugin implements Plugin<Project> {
public static final String SETUP_FREGE_COMPILER_TASK_NAME = "setupFregeCompiler";
+ public static final String FREGE_COMPILE_TASK_NAME = "fregeCompile";
public static final String FREGE_PLUGIN_ID = "ch.fhnw.thga.frege";
public static final String FREGE_EXTENSION_NAME = "frege";
@Override
public void apply(Project project) {
FregeExtension extension = project.getExtensions().create(FREGE_EXTENSION_NAME, FregeExtension.class);
- project.getTasks().register(SETUP_FREGE_COMPILER_TASK_NAME, SetupFregeCompilerTask.class, task -> {
+ TaskProvider<SetupFregeCompilerTask> setupFregeCompilerTask =
+ project.getTasks().register(SETUP_FREGE_COMPILER_TASK_NAME, SetupFregeCompilerTask.class, task -> {
task.getFregeVersion().set(extension.getFregeVersion());
task.getFregeRelease().set(extension.getFregeRelease());
task.getFregeCompilerOutputDirectory().set(extension.getFregeCompilerOutputDirectory());
});
+
+ project.getTasks().register(FREGE_COMPILE_TASK_NAME, FregeCompileTask.class, task -> {
+ task.dependsOn(setupFregeCompilerTask);
+ task.getFregeCompilerJar().set(setupFregeCompilerTask.get().getFregeCompilerOutputPath());
+ task.getFregeMainSourceDir().set(extension.getFregeMainSourceDir());
+ task.getFregeOutputDir().set(extension.getFregeOutputDir());
+ });
//Configuration fregeCompiler = project.getConfigurations().create("fregeCompiler", c -> {
// c.setVisible(false);
// c.setCanBeConsumed(false);
diff --git a/src/test/java/ch/fhnw/thga/gradleplugins/FregePluginFunctionalTest.java b/src/test/java/ch/fhnw/thga/gradleplugins/FregePluginFunctionalTest.java
index 4f22bc2..31f8d21 100644
--- a/src/test/java/ch/fhnw/thga/gradleplugins/FregePluginFunctionalTest.java
+++ b/src/test/java/ch/fhnw/thga/gradleplugins/FregePluginFunctionalTest.java
@@ -6,6 +6,7 @@ import static ch.fhnw.thga.gradleplugins.FregeExtension.FREGE_VERSION_BUILD_FILE
import static ch.fhnw.thga.gradleplugins.FregePlugin.FREGE_EXTENSION_NAME;
import static ch.fhnw.thga.gradleplugins.FregePlugin.FREGE_PLUGIN_ID;
import static ch.fhnw.thga.gradleplugins.FregePlugin.SETUP_FREGE_COMPILER_TASK_NAME;
+import static ch.fhnw.thga.gradleplugins.FregePlugin.FREGE_COMPILE_TASK_NAME;
import static org.gradle.testkit.runner.TaskOutcome.SUCCESS;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertTrue;
@@ -151,4 +152,24 @@ public class FregePluginFunctionalTest {
assertSetupFregeCompilerTask(fregeConfig);
assertTrue(new File(testProjectDir.getAbsolutePath() + "/build/dist/frege3.25.84.jar").exists());
}
+
+ @Test
+ void frege_compile_task_is_correctly_executed()
+ throws Exception {
+ String fregeConfig = buildFileFregeExtension("'3.25.84'", "'3.25alpha'", Optional.of("layout.buildDirectory.dir('dist')"));
+ String fregeCode = "module ch.fhnw.thga.Completion where\n\n" +
+ "complete :: Int -> (Int, String)\n" +
+ "complete i = (i, \"Frege rocks\")\n";
+ File completionFr = new File(testProjectDir, "Completion.fr");
+ writeToFile(completionFr, fregeCode);
+ System.out.println(fregeConfig);
+ appendToFile(buildFile, fregeConfig);
+ assertTrue(project.getTasks().getByName(FREGE_COMPILE_TASK_NAME) instanceof FregeCompileTask);
+ BuildResult result = GradleRunner.create().withProjectDir(testProjectDir).withPluginClasspath()
+ .withArguments(FREGE_COMPILE_TASK_NAME).build();
+ System.out.println(result.getOutput());
+ assertEquals(SUCCESS, result.task(":" + FREGE_COMPILE_TASK_NAME).getOutcome());
+ assertTrue(new File(testProjectDir.getAbsolutePath() + "/build/classes/main/frege/ch/fhnw/thga/Completion.java").exists());
+ assertTrue(new File(testProjectDir.getAbsolutePath() + "/build/classes/main/frege/ch/fhnw/thga/Completion.class").exists());
+ }
} \ No newline at end of file