build.sc
author Tomas Zeman <tzeman@volny.cz>
Thu, 17 Jan 2019 18:26:38 +0100
changeset 22 35f19c3873e2
parent 21 175e7d7ce5b3
child 24 782f121133c7
permissions -rw-r--r--
fatags: 0.4-SNAPSHOT -> 0.4
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
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
     9
object V {
22
35f19c3873e2 fatags: 0.4-SNAPSHOT -> 0.4
Tomas Zeman <tzeman@volny.cz>
parents: 21
diff changeset
    10
  val fatags = "0.4"
20
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    11
  val scalaJs = "0.6.26"
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    12
  val scala211 = "2.11.12"
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    13
  val scala212 = "2.12.8"
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    14
}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    15
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    16
object D {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    17
  val scalatags = ivy"com.lihaoyi::scalatags::0.6.7"
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    18
}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    19
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    20
trait Common extends CrossSbtModule with PublishModule {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    21
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    22
  def publishVersion: Target[String] = V.fatags
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    23
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    24
  def pomSettings = PomSettings(
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    25
    description = "FontAwesome Scala DSL (tags)",
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    26
    organization = "net.tz",
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    27
    url = "https://bitbucket.org/tzeman/fatags",
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    28
    licenses = Seq(License.`Apache-2.0`),
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    29
    versionControl = VersionControl(developerConnection = Some(
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    30
      "ssh://hg@bitbucket.org/tzeman/fatags")),
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    31
    developers = Seq(
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    32
      Developer("tzeman", "Tomas Zeman", "")
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    33
    )
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    34
  )
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    35
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    36
  override def scalacOptions = T{Seq(
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    37
    "-deprecation",                      // Emit warning and location for usages of deprecated APIs.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    38
    "-encoding", "utf-8",                // Specify character encoding used by source files.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    39
    "-explaintypes",                     // Explain type errors in more detail.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    40
    "-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
    41
    "-language:higherKinds",             // Allow higher-kinded types
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    42
    "-language:implicitConversions",     // Allow definition of implicit functions called views
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    43
    "-language:reflectiveCalls",
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    44
    "-language:postfixOps",
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    45
    "-unchecked",                        // Enable additional warnings where generated code depends on assumptions.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    46
    "-Xcheckinit",                       // Wrap field accessors to throw an exception on uninitialized access.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    47
    "-Xfuture",                          // Turn on future language features.
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    48
    "-target:jvm-1.8",
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
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    51
  def hgId: Input[String] = T.input {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    52
    os.proc("hg", "id", "-i").call().out.string.trim
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    53
  }
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    54
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    55
  def hgNum: Input[String] = T.input {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    56
    os.proc("hg", "id", "-n").call().out.string.trim
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    57
  }
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    58
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    59
  def hgTag: Input[Option[String]] = T.input {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    60
    os.proc("hg", "id", "-t").call().out.string.trim.split(' ').headOption
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    61
  }
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    62
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    63
  override def ivyDeps: Target[Loose.Agg[Dep]] = Agg(D.scalatags)
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
  override def sources: Sources = T.sources{
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
    66
    super.sources() :+ PathRef(millSourcePath / 'shared / 'src / 'main / 'scala)
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
21
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    69
  // 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
    70
  type IcoDef = (String, Set[String])
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    71
  def parseIcons: Target[List[IcoDef]] = T{
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    72
    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
    73
  }
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    74
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    75
  private def tpl(d: IcoDef): String = {
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    76
    val sym = d._1 match {
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    77
      //case "clone" => "clone_"
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    78
      case x => x
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    79
    }
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    80
    d._2.map {
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    81
      case "brands" => s"""      val `fab-$sym`: T = fab("${d._1}")\n"""
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    82
      case "solid" => s"""      val `fas-$sym`: T = fas("${d._1}")\n"""
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    83
      case "regular" => s"""      val `far-$sym`: T = far("${d._1}")\n"""
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    84
    }.mkString
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    85
  }
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    86
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    87
  override def generatedSources: Sources = T.sources{
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    88
    val d = T.ctx().dest
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    89
    val icons = parseIcons()
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    90
    write(d / "generated.scala",
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    91
      s"""
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    92
        | package fontawesome.generic
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    93
        | import scalatags.generic._
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    94
        | class GenericFA[Builder, Output <: FragT, FragT](
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    95
        |   val bun: Bundle[Builder, Output, FragT]) {
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
        |   import bun.all._
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    98
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
    99
        |   type T = FA[Builder, Output, FragT]
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   100
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   101
        |   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
   102
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   103
        |   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
   104
        |   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
   105
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   106
        |   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
   107
        |   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
   108
        |   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
   109
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   110
        |   ${icons map(tpl) mkString}
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
        |   /*
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   113
        |   object fab {
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   114
        |     private def fa(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
   115
        |     {icons.filter(_._2.contains("brands")).map(tpl).mkString}
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
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   118
        |   object fas {
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   119
        |     private def fa(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
        |     {icons.filter(_._2.contains("solid")).map(tpl).mkString}
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   121
        |   }
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
        |   object far {
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   124
        |     private def fa(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
   125
        |     {icons.filter(_._2.contains("regular")).map(tpl).mkString}
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   126
        |   }
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   127
        |   */
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   128
        |
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   129
        | }
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   130
      """.stripMargin)
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   131
    d
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   132
  }
20
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
class JvmModule(val crossScalaVersion: String) extends Common
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   136
class JsModule(val crossScalaVersion: String) extends ScalaJSModule
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   137
  with Common {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   138
  override def scalaJSVersion: Target[String] = V.scalaJs
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   139
}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   140
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   141
object jvm extends Cross[JvmModule](V.scala211, V.scala212)
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   142
object js extends Cross[JsModule](V.scala211, V.scala212)
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
def publishLocal(): define.Command[Unit] = T.command{
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   145
  jvm(V.scala212).publishLocal()()
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   146
  js(V.scala212).publishLocal()()
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   147
  jvm(V.scala211).publishLocal()()
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   148
  js(V.scala211).publishLocal()()
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   149
}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   150
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   151
object example extends ScalaModule with ScalaJSModule {
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   152
  override def scalaVersion: Target[String] = T{V.scala212}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   153
  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
   154
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   155
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   156
  /* Ugly hack to prevent
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   157
   * "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
   158
   */
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   159
  //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
   160
  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
   161
  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
   162
  override def generatedSources = T{js(V.scala212).generatedSources()}
20
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   163
}
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   164
21
175e7d7ce5b3 Font-Awesome upgrade 4.7 -> 5.6.3
Tomas Zeman <tzeman@volny.cz>
parents: 20
diff changeset
   165
20
529418651908 Build refactoring: sbt -> mill
Tomas Zeman <tzeman@volny.cz>
parents:
diff changeset
   166
// vim: et ts=2 sw=2 syn=scala