summaryrefslogtreecommitdiff
path: root/core
diff options
context:
space:
mode:
Diffstat (limited to 'core')
-rw-r--r--core/src/main/scala/forge/define/Target.scala20
-rw-r--r--core/src/test/scala/forge/JavaCompileJarTests.scala21
2 files changed, 10 insertions, 31 deletions
diff --git a/core/src/main/scala/forge/define/Target.scala b/core/src/main/scala/forge/define/Target.scala
index 667fe467..b98d3902 100644
--- a/core/src/main/scala/forge/define/Target.scala
+++ b/core/src/main/scala/forge/define/Target.scala
@@ -91,26 +91,6 @@ object Target extends Applicative.Applyer[Target, Target, Args]{
val inputs = Nil
}
- class Subprocess(val inputs: Seq[Target[_]],
- command: Args => Seq[String]) extends Target[Subprocess.Result] {
-
- def evaluate(args: Args) = {
- mkdir(args.dest)
- import ammonite.ops._
- implicit val path = ammonite.ops.Path(args.dest, pwd)
- val toTarget = () // Shadow the implicit conversion :/
- val output = %%(command(args))
- assert(output.exitCode == 0)
- Subprocess.Result(output, PathRef(args.dest))
- }
- }
- object Subprocess{
- case class Result(result: ammonite.ops.CommandResult, dest: PathRef)
- object Result{
- private implicit val crFormat: Format[CommandResult] = JsonFormatters.crFormat
- implicit val tsFormat: Format[Target.Subprocess.Result] = Json.format
- }
- }
def mapCtx[A, B](t: Target[A])(f: (A, Args) => B) = t.mapDest(f)
def zip() = new Target.Target0(())
diff --git a/core/src/test/scala/forge/JavaCompileJarTests.scala b/core/src/test/scala/forge/JavaCompileJarTests.scala
index 081290ca..4c3ce06c 100644
--- a/core/src/test/scala/forge/JavaCompileJarTests.scala
+++ b/core/src/test/scala/forge/JavaCompileJarTests.scala
@@ -1,7 +1,8 @@
package forge
-import ammonite.ops._, ImplicitWd._
+import ammonite.ops._
+import ImplicitWd._
import forge.define.Target
import forge.discover.Discovered
import forge.eval.{Evaluator, PathRef}
@@ -10,14 +11,12 @@ import forge.util.OSet
import utest._
object JavaCompileJarTests extends TestSuite{
- def compileAll(sources: Target[Seq[PathRef]]) = {
- new Target.Subprocess(
- Seq(sources),
- args =>
- Seq("javac") ++
- args[Seq[PathRef]](0).map(_.path.toString) ++
- Seq("-d", args.dest.toString)
- ).map(_.dest)
+ def compileAll(dest: Path, sources: Seq[PathRef]) = {
+ mkdir(dest)
+ import ammonite.ops._
+ %("javac", sources.map(_.path.toString()), "-d", dest)(wd = dest)
+ PathRef(dest)
+//
}
@@ -42,7 +41,7 @@ object JavaCompileJarTests extends TestSuite{
def sourceRoot = T{ Target.path(sourceRootPath) }
def resourceRoot = T{ Target.path(resourceRootPath) }
def allSources = T{ ls.rec(sourceRoot().path).map(PathRef(_)) }
- def classFiles = T{ compileAll(allSources) }
+ def classFiles = T{ compileAll(Target.ctx().dest, allSources()) }
def jar = T{ jarUp(resourceRoot, classFiles) }
@forge.discover.Router.main
@@ -153,7 +152,7 @@ object JavaCompileJarTests extends TestSuite{
val (runOutput2, evalCount2) = eval(Build.run("test.BarFour"))
assert(
runOutput2.out.string == "New Cls!\n",
- evalCount2 == 5
+ evalCount2 == 4
)
val (runOutput3, evalCount3) = eval(Build.run("test.BarFour"))
assert(