summaryrefslogtreecommitdiff
path: root/build.sc
blob: b3f636b025ddc1a4b91acf182b807e2893e266f6 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
import ammonite.ops._
import mill._
import mill.scalaplugin._

trait MillModule extends ScalaModule{ outer =>
  def scalaVersion = "2.12.4"
  override def sources = basePath/'src/'main/'scala
  object test extends this.Tests{
    def basePath = outer.basePath
    override def ivyDeps = Seq(Dep("com.lihaoyi", "utest", "0.6.0"))
    override def sources = basePath/'src/'test/'scala
    def testFramework = "mill.UTestFramework"
  }
}

object Core extends MillModule {
  override def compileIvyDeps = Seq(
    Dep.Java("org.scala-lang", "scala-reflect", scalaVersion())
  )

  override def ivyDeps = Seq(
    Dep("com.lihaoyi", "sourcecode", "0.1.4"),
    Dep("com.lihaoyi", "pprint", "0.5.3"),
    Dep.Point("com.lihaoyi", "ammonite", "1.0.3"),
    Dep("com.typesafe.play", "play-json", "2.6.6"),
    Dep("org.scala-sbt", "zinc", "1.0.3"),
    Dep.Java("org.scala-sbt", "test-interface", "1.0")
  )

  def basePath = pwd / 'core

  val cross =
    for(jarLabel <- mill.define.Cross("jarA", "jarB", "jarC"))
    yield new mill.Module{
      def printIt() = T.command{
        println("PRINTING IT: " + jarLabel)
      }
      def jar = T{
        val dest = T.ctx().dest
        ammonite.ops.mkdir(dest/ammonite.ops.up)
        ammonite.ops.cp(Core.jar().path, dest)

        PathRef(dest)
      }
    }
}

object ScalaPlugin extends MillModule {

  override def projectDeps = Seq(Core)
  def basePath = pwd / 'scalaplugin
  override def prependShellScript =
    "#!/usr/bin/env sh\n" +
    "exec java -cp \"$0\" mill.scalaplugin.Main \"$@\""
}