aboutsummaryrefslogtreecommitdiff
path: root/build.sbt
diff options
context:
space:
mode:
authorGrigory Pomadchin <gr.pomadchin@gmail.com>2016-11-29 12:20:34 +0300
committerGrigory Pomadchin <gr.pomadchin@gmail.com>2016-11-29 12:21:36 +0300
commit29ef6610f74477c77ef6540a839dd49c2f040e05 (patch)
tree6748c81905a8474d68bda5d9af7c686943d09bb9 /build.sbt
parent5b47d022a8fe5b76b27ad29ff011c4ed94a7526a (diff)
downloadsbt-jni-29ef6610f74477c77ef6540a839dd49c2f040e05.tar.gz
sbt-jni-29ef6610f74477c77ef6540a839dd49c2f040e05.tar.bz2
sbt-jni-29ef6610f74477c77ef6540a839dd49c2f040e05.zip
move from Build.scala to build.sbt
Diffstat (limited to 'build.sbt')
-rw-r--r--build.sbt80
1 files changed, 80 insertions, 0 deletions
diff --git a/build.sbt b/build.sbt
new file mode 100644
index 0000000..2b1271f
--- /dev/null
+++ b/build.sbt
@@ -0,0 +1,80 @@
+import sbt._
+import sbt.Keys._
+import sbt.ScriptedPlugin._
+
+import sbtdoge.CrossPerProjectPlugin
+
+import scalariform.formatter.preferences._
+import com.typesafe.sbt.SbtScalariform
+import com.typesafe.sbt.SbtScalariform.ScalariformKeys
+
+val commonSettings = Seq(
+ organization := "ch.jodersky",
+ licenses := Seq(("BSD New", url("http://opensource.org/licenses/BSD-3-Clause"))),
+ scalacOptions ++= Seq("-deprecation", "-feature"),
+ resolvers += Resolver.sonatypeRepo("releases"),
+ ScalariformKeys.preferences := ScalariformKeys.preferences.value
+ .setPreference(DoubleIndentClassDeclaration, true)
+ .setPreference(DanglingCloseParenthesis, Preserve)
+ .setPreference(MultilineScaladocCommentsStartOnFirstLine, true)
+ .setPreference(PlaceScaladocAsterisksBeneathSecondAsterisk, true)
+)
+
+lazy val root = Project(
+ id = "root",
+ base = file("."),
+ aggregate = Seq(
+ macros, plugin
+ ),
+ settings = commonSettings ++ Seq(
+ publish := {},
+ publishLocal := {},
+ // make sbt-pgp happy
+ publishTo := Some(Resolver.file("Unused transient repository", target.value / "unusedrepo"))
+ ) ++ addCommandAlias("test-plugin", ";+sbt-jni-macros/publishLocal;scripted")
+).enablePlugins(CrossPerProjectPlugin)
+
+lazy val macros = Project(
+ id = "sbt-jni-macros",
+ base = file("macros"),
+ settings = commonSettings ++ Seq(
+ scalaVersion := Version.scala.head,
+ crossScalaVersions := Version.scala,
+ addCompilerPlugin("org.scalamacros" % "paradise" % Version.macrosParadise cross CrossVersion.full),
+ libraryDependencies += "org.typelevel" %% "macro-compat" % "1.1.1",
+ libraryDependencies += "org.scala-lang" % "scala-compiler" % scalaVersion.value % Provided,
+ libraryDependencies += "org.scala-lang" % "scala-reflect" % scalaVersion.value
+ )
+)
+
+lazy val plugin = Project(
+ id = "sbt-jni",
+ base = file("plugin"),
+ settings = commonSettings ++ scriptedSettings ++ Seq(
+ sbtPlugin := true,
+ publishMavenStyle := false,
+ scalaVersion := "2.10.6",
+ crossScalaVersions := Seq(scalaVersion.value),
+
+ libraryDependencies += "org.ow2.asm" % "asm" % "5.0.4",
+
+ // make project settings available to source
+ sourceGenerators in Compile += Def.task {
+ val src = s"""|/* Generated by sbt */
+ |package ch.jodersky.sbt.jni
+ |
+ |private[jni] object ProjectVersion {
+ | final val MacrosParadise = "${Version.macrosParadise}"
+ | final val Macros = "${version.value}"
+ |}
+ |""".stripMargin
+ val file = sourceManaged.value / "ch" / "jodersky" / "sbt" / "jni" / "ProjectVersion.scala"
+ IO.write(file, src)
+ Seq(file)
+ }.taskValue,
+ scriptedLaunchOpts := Seq(
+ "-Dplugin.version=" + version.value,
+ "-XX:MaxPermSize=256m", "-Xmx2g", "-Xss2m"
+ )
+ )
+)