build.sc
author Tomas Zeman <tzeman@volny.cz>
Tue, 18 Jun 2019 09:04:00 +0200
changeset 26 6ba55bf93ab7
parent 25 950431e16cb4
child 27 c4534300acdc
permissions -rw-r--r--
Fixed artifact name
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
20
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     1
import ammonite.ops._
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     2
import mill._
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     3
import mill.define.{Input, Sources, Target}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     4
import mill.scalajslib._
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     5
import mill.scalalib._
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     6
import mill.scalalib.publish._
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     7
import mill.util.Loose
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     8
25
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
     9
import scala.language.postfixOps
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    10
20
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    11
object V {
24
782f121133c7 fatags: 0.4 -> 0.5-SNAPSHOT
Tomas Zeman <tzeman@volny.cz>
parents: 22
diff changeset
    12
  val fatags = "0.5-SNAPSHOT"
20
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    13
  val scalaJs = "0.6.26"
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    14
  val scala211 = "2.11.12"
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    15
  val scala212 = "2.12.8"
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    16
}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    17
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    18
object D {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    19
  val scalatags = ivy"com.lihaoyi::scalatags::0.6.7"
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    20
}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    21
25
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    22
def camelCase(s: String): String = {
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    23
  def inner(l: List[Char]): List[Char] = l match {
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    24
    case '-' :: '-' :: c :: rest => c.toUpper :: inner(rest)
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    25
    case '-' :: c :: rest => c.toUpper :: inner(rest)
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    26
    case c :: rest => c :: inner(rest)
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    27
    case Nil => Nil
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    28
  }
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    29
  inner(s toList) mkString ""
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    30
}
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    31
20
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    32
trait Common extends CrossSbtModule with PublishModule {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    33
26
6ba55bf93ab7 Fixed artifact name
Tomas Zeman <tzeman@volny.cz>
parents: 25
diff changeset
    34
  override def artifactName = "fatags"
6ba55bf93ab7 Fixed artifact name
Tomas Zeman <tzeman@volny.cz>
parents: 25
diff changeset
    35
20
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    36
  def publishVersion: Target[String] = V.fatags
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    37
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    38
  def pomSettings = PomSettings(
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    39
    description = "FontAwesome Scala DSL (tags)",
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    40
    organization = "net.tz",
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    41
    url = "https://bitbucket.org/tzeman/fatags",
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    42
    licenses = Seq(License.`Apache-2.0`),
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    43
    versionControl = VersionControl(developerConnection = Some(
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    44
      "ssh://hg@bitbucket.org/tzeman/fatags")),
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    45
    developers = Seq(
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    46
      Developer("tzeman", "Tomas Zeman", "")
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    47
    )
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    48
  )
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    49
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    50
  override def scalacOptions = T{Seq(
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    51
    "-deprecation",                      // Emit warning and location for usages of deprecated APIs.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    52
    "-encoding", "utf-8",                // Specify character encoding used by source files.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    53
    "-explaintypes",                     // Explain type errors in more detail.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    54
    "-feature",                          // Emit warning and location for usages of features that should be imported explicitly.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    55
    "-language:higherKinds",             // Allow higher-kinded types
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    56
    "-language:implicitConversions",     // Allow definition of implicit functions called views
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    57
    "-language:reflectiveCalls",
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    58
    "-language:postfixOps",
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    59
    "-unchecked",                        // Enable additional warnings where generated code depends on assumptions.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    60
    "-Xcheckinit",                       // Wrap field accessors to throw an exception on uninitialized access.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    61
    "-Xfuture",                          // Turn on future language features.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    62
    "-target:jvm-1.8",
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    63
  )}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    64
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    65
  def hgId: Input[String] = T.input {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    66
    os.proc("hg", "id", "-i").call().out.string.trim
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    67
  }
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    68
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    69
  def hgNum: Input[String] = T.input {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    70
    os.proc("hg", "id", "-n").call().out.string.trim
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    71
  }
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    72
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    73
  def hgTag: Input[Option[String]] = T.input {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    74
    os.proc("hg", "id", "-t").call().out.string.trim.split(' ').headOption
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    75
  }
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    76
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    77
  override def ivyDeps: Target[Loose.Agg[Dep]] = Agg(D.scalatags)
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    78
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    79
  override def sources: Sources = T.sources{
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    80
    super.sources() :+ PathRef(millSourcePath / 'shared / 'src / 'main / 'scala)
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    81
  }
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    82
21
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    83
  // https://github.com/FortAwesome/Font-Awesome/raw/5.6.3/metadata/icons.json
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    84
  type IcoDef = (String, Set[String])
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    85
  def parseIcons: Target[List[IcoDef]] = T{
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    86
    ujson.read(os.read! pwd / "icons.json").obj.map(e => (e._1, e._2.obj("styles").arr.map(_.str).toSet)).toList
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    87
  }
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    88
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    89
  private def tpl(d: IcoDef): String = {
25
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    90
    val sym = d._1
21
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    91
    d._2.map {
25
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    92
      case "brands" =>  s"""      val ${camelCase(s"fab-$sym")}: T = fab("$sym")\n"""
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    93
      case "solid" =>   s"""      val ${camelCase(s"fas-$sym")}: T = fas("$sym")\n"""
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
    94
      case "regular" => s"""      val ${camelCase(s"far-$sym")}: T = far("$sym")\n"""
21
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    95
    }.mkString
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    96
  }
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    97
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    98
  override def generatedSources: Sources = T.sources{
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    99
    val d = T.ctx().dest
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   100
    val icons = parseIcons()
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   101
    write(d / "generated.scala",
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   102
      s"""
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   103
        | package fontawesome.generic
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   104
        | import scalatags.generic._
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   105
        | class GenericFA[Builder, Output <: FragT, FragT](
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   106
        |   val bun: Bundle[Builder, Output, FragT]) {
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   107
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   108
        |   import bun.all._
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   109
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   110
        |   type T = FA[Builder, Output, FragT]
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   111
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   112
        |   val faStack: Modifier = cls := "fa-stack fa-lg"
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   113
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   114
        |   implicit val bundle: Bundle[Builder, Output, FragT] = bun
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   115
        |   implicit def fa2tag(x: T): TypedTag[Builder, Output, FragT] = x()
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   116
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   117
        |   private def fab(w: String): T = FA(FaStyle.Brands, w)
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   118
        |   private def far(w: String): T = FA(FaStyle.Regular, w)
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   119
        |   private def fas(w: String): T = FA(FaStyle.Solid, w)
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   120
        |
25
950431e16cb4 Restored CamelCase for icon idents/names
Tomas Zeman <tzeman@volny.cz>
parents: 24
diff changeset
   121
        |   ${icons map tpl mkString}
21
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   122
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   123
        | }
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   124
      """.stripMargin)
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   125
    d
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   126
  }
20
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   127
}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   128
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   129
class JvmModule(val crossScalaVersion: String) extends Common
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   130
class JsModule(val crossScalaVersion: String) extends ScalaJSModule
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   131
  with Common {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   132
  override def scalaJSVersion: Target[String] = V.scalaJs
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   133
}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   134
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   135
object jvm extends Cross[JvmModule](V.scala211, V.scala212)
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   136
object js extends Cross[JsModule](V.scala211, V.scala212)
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   137
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   138
def publishLocal(): define.Command[Unit] = T.command{
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   139
  jvm(V.scala212).publishLocal()()
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   140
  js(V.scala212).publishLocal()()
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   141
  jvm(V.scala211).publishLocal()()
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   142
  js(V.scala211).publishLocal()()
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   143
}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   144
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   145
object example extends ScalaModule with ScalaJSModule {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   146
  override def scalaVersion: Target[String] = T{V.scala212}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   147
  override def scalaJSVersion: Target[String] = V.scalaJs
21
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   148
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   149
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   150
  /* Ugly hack to prevent
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   151
   * "Referring to non-existent method fontawesome.generic.FA... error"
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   152
   */
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   153
  //override def moduleDeps: Seq[PublishModule] = Seq(js(V.scala212))
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   154
  override def ivyDeps: Target[Loose.Agg[Dep]] = Agg(D.scalatags)
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   155
  override def sources: Sources = T.sources{super.sources() ++ js(V.scala212).sources()}
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   156
  override def generatedSources = T{js(V.scala212).generatedSources()}
20
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   157
}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   158
21
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   159
20
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   160
// vim: et ts=2 sw=2 syn=scala