blob: 0c7222cb7e8f0c8a30bdbfdd14264758738b54b6 (
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
|
package cbt
import java.io.File
import java.net.URL
trait ScalaJsBuild extends DynamicOverrides{
final protected val scalaJsLib = ScalaJsLib(
scalaJsVersion, scalaVersion, context.cbtLastModified, context.paths.mavenCache
)
import scalaJsLib.{link => _,_}
def scalaJsVersion = "0.6.8"
final protected val scalaJsMajorVersion: String = lib.libMajorVersion(scalaJsVersion)
final protected val artifactIdSuffix = s"_sjs$scalaJsMajorVersion"
override def dependencies = super.dependencies :+ scalaJsLibraryDependency
override def scalacOptions = super.scalacOptions ++ scalaJsLib.scalacOptions
/** Note: We make same assumption about scala version.
In order to be able to choose different scala version, one has to use %. */
implicit class ScalaJsDependencyBuilder(groupId: String){
def %%%(artifactId: String) = new DependencyBuilder2(
groupId, artifactId + artifactIdSuffix, Some(scalaMajorVersion))
}
override def compile = {
super.compile
scalaJsLib.link(
scalaJsTargetFile, scalaJsOptions, target +: dependencies.collect{case d: BoundMavenDependency => d.jar}
)
None // FIXME: we need to rethink the concept of a "compile" task I think. There is no time to return here.
}
def scalaJsOptions: Seq[String] = Seq()
/** Where to put the generated js file */
def scalaJsTargetFile: File
override def cleanFiles = super.cleanFiles :+ scalaJsTargetFile :+ (scalaJsTargetFile ++ ".map")
def fullOpt = newBuild[ScalaJsBuild]("""
override def scalaJsOptions = "--fullOpt" +: super.scalaJsOptions
""")
}
|