diff options
author | Guillaume Grossetie <ggrossetie@gmail.com> | 2018-08-31 16:51:21 +0200 |
---|---|---|
committer | Tobias Roeser <le.petit.fou@web.de> | 2019-02-14 17:45:16 +0100 |
commit | 7dba8cb31d929b56c65d66e579352f8bd83ff9ce (patch) | |
tree | 176bac4df74d07a257248909ae6dbe833565da43 /contrib | |
parent | fc18309865baf869d9c6f7ff7879f33f4cc122e6 (diff) | |
download | mill-7dba8cb31d929b56c65d66e579352f8bd83ff9ce.tar.gz mill-7dba8cb31d929b56c65d66e579352f8bd83ff9ce.tar.bz2 mill-7dba8cb31d929b56c65d66e579352f8bd83ff9ce.zip |
Load/convert instances from classloader
Diffstat (limited to 'contrib')
-rw-r--r-- | contrib/playlib/src/mill/playlib/RouterGeneratorWorker.scala | 39 | ||||
-rw-r--r-- | contrib/playlib/test/src/mill/playlib/HelloWorldRouterTests.scala | 2 |
2 files changed, 32 insertions, 9 deletions
diff --git a/contrib/playlib/src/mill/playlib/RouterGeneratorWorker.scala b/contrib/playlib/src/mill/playlib/RouterGeneratorWorker.scala index dd3a818c..a246bf2a 100644 --- a/contrib/playlib/src/mill/playlib/RouterGeneratorWorker.scala +++ b/contrib/playlib/src/mill/playlib/RouterGeneratorWorker.scala @@ -8,6 +8,8 @@ import ammonite.ops.Path import mill.eval.PathRef import mill.scalalib.CompilationResult +import scala.collection.JavaConverters._ + class RouterGeneratorWorker { private var routerGeneratorInstances = Option.empty[(Long, RouterGeneratorWorkerApi)] @@ -34,11 +36,17 @@ class RouterGeneratorWorker { classOf[java.io.File]) val instance = new RouterGeneratorWorkerApi { override def compile(task: RoutesCompilerTask, generatorType: String = "injected", generatedDir: File): Either[Seq[CompilationResult], Seq[File]] = { - val args = Array[AnyRef](task.file: java.io.File, - task.additionalImports: scala.collection.Seq[String], - Boolean.box(true), - Boolean.box(true), - Boolean.box(false)) + // Since the classloader is isolated, we do not share any classes with the Mill classloader. + // Thus both classloaders have different copies of "scala.collection.Seq" which are not compatible. + val additionalImports = cl.loadClass("scala.collection.mutable.WrappedArray$ofRef") + .getConstructors()(0) + .newInstance(task.additionalImports.toArray) + .asInstanceOf[AnyRef] + val args = Array[AnyRef](task.file, + additionalImports, + Boolean.box(task.forwardsRouter), + Boolean.box(task.reverseRouter), + Boolean.box(task.namespaceReverseRouter)) val routesCompilerTaskInstance = routerCompilerTaskConstructor.newInstance(args: _*).asInstanceOf[Object] val routesGeneratorInstance = generatorType match { case "injected" => injectedRoutesGeneratorModule.get(null) @@ -49,9 +57,24 @@ class RouterGeneratorWorker { routesCompilerTaskInstance, routesGeneratorInstance, generatedDir) - result.asInstanceOf[Either[AnyVal, Seq[File]]] match { - case Right(value) => Right(value) - case Left(_) => Left(Seq(CompilationResult(Path(""), PathRef(Path(""))))) // FIXME: convert the error to a CompilationResult + // compile method returns an object of type Either[Seq[RoutesCompilationError], Seq[File]] + result.getClass.getName match { + case "scala.util.Right" => + val files = cl.loadClass("scala.util.Right") + .getMethod("value") + .invoke(result) + val asJavaMethod = cl.loadClass("scala.collection.convert.DecorateAsJava") + .getMethod("seqAsJavaListConverter", cl.loadClass("scala.collection.Seq")) + val javaConverters = cl.loadClass("scala.collection.JavaConverters$") + val javaConvertersInstance = javaConverters.getField("MODULE$").get(javaConverters) + val filesJava = cl.loadClass("scala.collection.convert.Decorators$AsJava") + .getMethod("asJava") + .invoke(asJavaMethod.invoke(javaConvertersInstance, files)) + .asInstanceOf[java.util.List[File]] + Right(filesJava.asScala) + case "scala.util.Left" => + // TODO: convert the error of type RoutesCompilationError to a CompilationResult + Left(Seq(CompilationResult(Path(""), PathRef(Path(""))))) } } } diff --git a/contrib/playlib/test/src/mill/playlib/HelloWorldRouterTests.scala b/contrib/playlib/test/src/mill/playlib/HelloWorldRouterTests.scala index 03742714..f98ba749 100644 --- a/contrib/playlib/test/src/mill/playlib/HelloWorldRouterTests.scala +++ b/contrib/playlib/test/src/mill/playlib/HelloWorldRouterTests.scala @@ -36,7 +36,7 @@ object HelloWorldRouterTests extends TestSuite { } def tests: Tests = Tests { - 'twirlVersion - { + 'playVersion - { 'fromBuild - workspaceTest(HelloWorld) { eval => val Right((result, evalCount)) = eval.apply(HelloWorld.core.playVersion) |