Ant: Add support for fork-mode

#KT-44293
This commit is contained in:
scaventz
2020-12-04 18:00:54 +08:00
committed by Alexander Udalov
parent ee952db1a2
commit 0110b4e4b4
11 changed files with 190 additions and 3 deletions
@@ -16,9 +16,12 @@
package org.jetbrains.kotlin.ant
import org.apache.tools.ant.types.Path
import org.apache.tools.ant.types.Reference
import org.apache.tools.ant.BuildException
import org.apache.tools.ant.taskdefs.Execute
import org.apache.tools.ant.taskdefs.Redirector
import org.apache.tools.ant.types.*
import java.io.File.pathSeparator
import java.io.File.separator
class Kotlin2JvmTask : KotlinCompilerBaseTask() {
override val compilerFqName = "org.jetbrains.kotlin.cli.jvm.K2JVMCompiler"
@@ -28,6 +31,9 @@ class Kotlin2JvmTask : KotlinCompilerBaseTask() {
var noReflect: Boolean = false
private val cmdl = CommandlineJava()
var fork: Boolean = false
private var compileClasspath: Path? = null
fun setClasspath(classpath: Path) {
@@ -73,4 +79,47 @@ class Kotlin2JvmTask : KotlinCompilerBaseTask() {
if (noReflect) args.add("-no-reflect")
if (includeRuntime) args.add("-include-runtime")
}
override fun execute() {
if (!fork)
super.execute()
else {
exec()
}
}
private fun exec() {
val javaHome = System.getProperty("java.home")
val javaBin = javaHome + separator + "bin" + separator + "java"
val redirector = Redirector(this)
fillArguments()
val command = ArrayList<String>()
command.add(javaBin)
command.addAll(cmdl.vmCommand.arguments) // jvm args
command.add("-Dorg.jetbrains.kotlin.cliMessageRenderer=FullPath") // same MessageRenderer as non-forking mode
command.add("-cp")
command.add(KotlinAntTaskUtil.compilerJar.canonicalPath)
command.add(compilerFqName)
command.addAll(args) // compiler args
// streamHandler: used to handle the input and output streams of the subprocess.
// watchdog: a watchdog for the subprocess or <code>null</code> to disable a timeout for the subprocess.
// TODO: support timeout for the subprocess
val exe = Execute(redirector.createHandler(), null)
exe.setAntRun(getProject())
exe.commandline = command.toTypedArray()
log("Executing command: ${command.joinToString(" ")}", LogLevel.DEBUG.level)
log("Compiling ${src!!.list().toList()} => [${output!!.canonicalPath}]")
val exitCode = exe.execute()
redirector.complete()
if (failOnError && exitCode != 0) {
throw BuildException("Compile failed; see the compiler error output for details.")
}
}
fun createJvmarg(): Commandline.Argument {
return cmdl.createVmArgument()
}
}
@@ -80,7 +80,7 @@ abstract class KotlinCompilerBaseTask : Task() {
fillSpecificArguments()
}
final override fun execute() {
override fun execute() {
fillArguments()
val compilerClass = KotlinAntTaskUtil.getOrCreateClassLoader().loadClass(compilerFqName)
@@ -0,0 +1,16 @@
OUT:
Buildfile: [TestData]/build.xml
premain:
[javac] Compiling 1 source file to [Temp]
[jar] Building jar: [Temp]/premain.jar
build:
[kotlinc] Compiling [[TestData]] => [[Temp]/fork.jar]
[kotlinc] -Xms64m
[kotlinc] -Xmx128m
BUILD SUCCESSFUL
Total time: [time]
Return code: 0
+25
View File
@@ -0,0 +1,25 @@
<project name="Ant Task Test" default="build">
<taskdef resource="org/jetbrains/kotlin/ant/antlib.xml" classpath="${kotlin.lib}/kotlin-ant.jar"/>
<target name="premain">
<sequential>
<javac srcdir="${test.data}/premain" destdir="${temp}" includeAntRuntime="false"/>
<jar destfile="${temp}/premain.jar"
basedir="${temp}"
excludes="*.java *.jar">
<manifest>
<attribute name="Premain-Class" value="Premain"/>
</manifest>
</jar>
</sequential>
</target>
<target name="build" depends="premain">
<kotlinc src="${test.data}" output="${temp}/fork.jar" fork="true">
<jvmarg value="-Xms64m"/>
<jvmarg value="-Xmx128m"/>
<jvmarg value="-javaagent:${temp}/premain.jar"/>
<compilerarg value="-nowarn"/>
</kotlinc>
</target>
</project>
+5
View File
@@ -0,0 +1,5 @@
package hello
fun main() {
println(0 as String)
}
@@ -0,0 +1,14 @@
import java.lang.instrument.Instrumentation;
import java.lang.management.ManagementFactory;
import java.lang.management.RuntimeMXBean;
import java.util.List;
public class Premain {
public static void premain(String agentArgs, Instrumentation inst) {
RuntimeMXBean bean = ManagementFactory.getRuntimeMXBean();
List<String> arguments = bean.getInputArguments();
arguments.stream().filter(param ->
param.startsWith("-Xmx") || param.startsWith("-Xms")
).sorted().forEach(System.out::println);
}
}
@@ -0,0 +1,24 @@
OUT:
Buildfile: [TestData]/build.xml
premain:
[javac] Compiling 1 source file to [Temp]
[jar] Building jar: [Temp]/premain.jar
build:
[kotlinc] Compiling [[TestData]] => [[Temp]/fork.jar]
[kotlinc] -Xms64m
[kotlinc] -Xmx128m
[kotlinc] error: warnings found and -Werror specified
[kotlinc] [TestData]/test.kt:4:15: warning: this cast can never succeed
[kotlinc] println(0 as String)
[kotlinc] ^
ERR:
BUILD FAILED
[TestData]/build.xml:18: Compile failed; see the compiler error output for details.
Total time: [time]
Return code: 1
@@ -0,0 +1,25 @@
<project name="Ant Task Test" default="build">
<taskdef resource="org/jetbrains/kotlin/ant/antlib.xml" classpath="${kotlin.lib}/kotlin-ant.jar"/>
<target name="premain">
<sequential>
<javac srcdir="${test.data}/premain" destdir="${temp}" includeAntRuntime="false"/>
<jar destfile="${temp}/premain.jar"
basedir="${temp}"
excludes="*.java *.jar">
<manifest>
<attribute name="Premain-Class" value="Premain"/>
</manifest>
</jar>
</sequential>
</target>
<target name="build" depends="premain">
<kotlinc src="${test.data}" output="${temp}/fork.jar" fork="true">
<jvmarg value="-Xms64m"/>
<jvmarg value="-Xmx128m"/>
<jvmarg value="-javaagent:${temp}/premain.jar"/>
<compilerarg value="-Werror"/>
</kotlinc>
</target>
</project>
@@ -0,0 +1,14 @@
import java.lang.instrument.Instrumentation;
import java.lang.management.ManagementFactory;
import java.lang.management.RuntimeMXBean;
import java.util.List;
public class Premain {
public static void premain(String agentArgs, Instrumentation inst) {
RuntimeMXBean bean = ManagementFactory.getRuntimeMXBean();
List<String> arguments = bean.getInputArguments();
arguments.stream().filter(param ->
param.startsWith("-Xmx") || param.startsWith("-Xms")
).sorted().forEach(System.out::println);
}
}
@@ -0,0 +1,5 @@
package hello
fun main() {
println(0 as String)
}
@@ -44,6 +44,16 @@ public class AntTaskTestGenerated extends AbstractAntTaskTest {
runTest("compiler/testData/integration/ant/jvm/failOnErrorByDefault/");
}
@TestMetadata("fork")
public void testFork() throws Exception {
runTest("compiler/testData/integration/ant/jvm/fork/");
}
@TestMetadata("forkOnError")
public void testForkOnError() throws Exception {
runTest("compiler/testData/integration/ant/jvm/forkOnError/");
}
@TestMetadata("helloWorld")
public void testHelloWorld() throws Exception {
runTest("compiler/testData/integration/ant/jvm/helloWorld/");