aboutsummaryrefslogtreecommitdiff
path: root/build.sbt
diff options
context:
space:
mode:
authorJon Pretty <jon.pretty@propensive.com>2017-11-09 16:34:18 +0000
committerJon Pretty <jon.pretty@propensive.com>2017-11-09 16:34:18 +0000
commit5d862115bd31fcd42484293c1f64652192d95d26 (patch)
tree1e5301cd51192de114db20616e1c18e3d2726a52 /build.sbt
parente396b7a038e458de37ced6b59e0d367883bc3b71 (diff)
downloadmagnolia-5d862115bd31fcd42484293c1f64652192d95d26.tar.gz
magnolia-5d862115bd31fcd42484293c1f64652192d95d26.tar.bz2
magnolia-5d862115bd31fcd42484293c1f64652192d95d26.zip
Upgrade to SBT 1.0 and include testing binariesv0.5.0
Diffstat (limited to 'build.sbt')
-rw-r--r--build.sbt128
1 files changed, 37 insertions, 91 deletions
diff --git a/build.sbt b/build.sbt
index 616fc48..3e04384 100644
--- a/build.sbt
+++ b/build.sbt
@@ -1,86 +1,67 @@
import com.typesafe.sbt.pgp.PgpKeys.publishSigned
-import ReleaseTransformations._
-import sbtcrossproject.{crossProject, CrossType}
-
-lazy val core = crossProject(JSPlatform, JVMPlatform, NativePlatform)
- .crossType(CrossType.Pure)
+lazy val core = project
.in(file("core"))
.settings(buildSettings: _*)
.settings(publishSettings: _*)
.settings(scalaMacroDependencies: _*)
- .settings(examplesDependencies)
.settings(moduleName := "magnolia")
- .nativeSettings(nativeSettings)
-
-lazy val coreJVM = core.jvm
-lazy val coreJS = core.js
-lazy val coreNative = core.native
-lazy val examples = crossProject(JSPlatform, JVMPlatform, NativePlatform)
- .crossType(CrossType.Pure)
+lazy val examples = project
.in(file("examples"))
.settings(buildSettings: _*)
.settings(publishSettings: _*)
.settings(moduleName := "magnolia-examples")
- .settings(quasiQuotesDependencies)
- .settings(examplesDependencies)
- .nativeSettings(nativeSettings)
.dependsOn(core)
-lazy val examplesJVM = examples.jvm
-lazy val examplesJS = examples.js
-lazy val examplesNative = examples.native
-
-lazy val tests = crossProject(JSPlatform, JVMPlatform, NativePlatform)
- .crossType(CrossType.Pure)
+lazy val tests = project
.in(file("tests"))
.settings(buildSettings: _*)
.settings(noPublishSettings: _*)
+ .settings(unmanagedSettings)
.settings(moduleName := "magnolia-tests")
- .settings(quasiQuotesDependencies)
- .nativeSettings(nativeSettings)
.dependsOn(examples)
-lazy val testsJVM = tests.jvm
-lazy val testsJS = tests.js
-lazy val testsNative = tests.native
-
-lazy val benchmarks = crossProject(JSPlatform, JVMPlatform, NativePlatform)
- .crossType(CrossType.Pure)
+lazy val benchmarks = project
.in(file("benchmarks"))
.settings(buildSettings: _*)
.settings(noPublishSettings: _*)
.settings(moduleName := "magnolia-benchmarks")
- .settings(quasiQuotesDependencies)
- .nativeSettings(nativeSettings)
.dependsOn(examples)
-lazy val benchmarksJVM = benchmarks.jvm
-lazy val benchmarksJS = benchmarks.js
-lazy val benchmarksNative = benchmarks.native
-
lazy val buildSettings = Seq(
organization := "com.propensive",
scalaVersion := "2.12.4",
name := "magnolia",
- version := "0.4.0",
- scalacOptions ++= Seq("-deprecation", "-feature", "-Ywarn-value-discard", "-Ywarn-dead-code", "-Ywarn-nullary-unit", "-Ywarn-numeric-widen", "-Ywarn-inaccessible", "-Ywarn-adapted-args"),
- crossScalaVersions := Seq("2.10.6", "2.11.11", "2.12.2"),
- scmInfo := Some(ScmInfo(url("https://github.com/propensive/magnolia"),
- "scm:git:git@github.com:propensive/magnolia.git"))
+ version := "0.5.0",
+ scalacOptions ++= Seq(
+ "-deprecation",
+ "-feature",
+ "-Ywarn-value-discard",
+ "-Ywarn-dead-code",
+ "-Ywarn-nullary-unit",
+ "-Ywarn-numeric-widen",
+ "-Ywarn-inaccessible",
+ "-Ywarn-adapted-args"
+ ),
+ scmInfo := Some(
+ ScmInfo(url("https://github.com/propensive/magnolia"),
+ "scm:git:git@github.com:propensive/magnolia.git")
+ )
)
lazy val publishSettings = Seq(
- homepage := Some(url("http://magnolia.propensive.com/")),
+ homepage := Some(url("http://magnolia.work/")),
licenses := Seq("Apache-2.0" -> url("http://www.apache.org/licenses/LICENSE-2.0.txt")),
autoAPIMappings := true,
publishMavenStyle := true,
publishArtifact in Test := false,
- pomIncludeRepository := { _ => false },
+ pomIncludeRepository := { _ =>
+ false
+ },
publishTo := {
val nexus = "https://oss.sonatype.org/"
- if(isSnapshot.value)
+ if (isSnapshot.value)
Some("snapshots" at nexus + "content/repositories/snapshots")
else
Some("releases" at nexus + "service/local/staging/deploy/maven2")
@@ -93,68 +74,33 @@ lazy val publishSettings = Seq(
<url>https://github.com/propensive/magnolia/</url>
</developer>
</developers>
- ),
- releaseProcess := Seq[ReleaseStep](
- checkSnapshotDependencies,
- inquireVersions,
- runTest,
- setReleaseVersion,
- commitReleaseVersion,
- tagRelease,
- publishArtifacts,
- setNextVersion,
- commitNextVersion,
- ReleaseStep(action = Command.process("sonatypeReleaseAll", _)),
- pushChanges
- ),
- releaseCrossBuild := true,
- releasePublishArtifactsAction := PgpKeys.publishSigned.value
+ )
)
lazy val noPublishSettings = Seq(
- publish := (),
- publishLocal := (),
+ publish := (()),
+ publishLocal := (()),
publishArtifact := false
)
import java.io.File
-def crossVersionSharedSources() = Seq(
- (unmanagedSourceDirectories in Compile) ++= { (unmanagedSourceDirectories in Compile ).value.map {
- dir:File => new File(dir.getPath + "_" + scalaBinaryVersion.value)}}
-)
-
-lazy val nativeSettings: Seq[Setting[_]] = Seq(
- // Scala Native not yet available for 2.12.x, so override the versions
- scalaVersion := "2.11.11",
- crossScalaVersions := Seq("2.10.6", "2.11.11")
-)
-
-lazy val quasiQuotesDependencies: Seq[Setting[_]] =
- libraryDependencies ++= {
- CrossVersion.partialVersion(scalaVersion.value) match {
- case Some((2, scalaMajor)) if scalaMajor >= 11 => Seq()
- case Some((2, 10)) => Seq(
- compilerPlugin("org.scalamacros" % "paradise" % "2.1.0" cross CrossVersion.full),
- "org.scalamacros" %% "quasiquotes" % "2.1.0" cross CrossVersion.binary
- )
- }
- }
+lazy val unmanagedSettings = unmanagedBase := (scalaVersion.value.split("\\.").map(_.toInt).to[List] match {
+ case List(2, 12, _) => baseDirectory.value / "lib" / "2.12"
+ case List(2, 11, _) => baseDirectory.value / "lib" / "2.11"
+})
lazy val scalaMacroDependencies: Seq[Setting[_]] = Seq(
libraryDependencies += "org.typelevel" %% "macro-compat" % "1.1.1",
libraryDependencies += "org.scala-lang" % "scala-reflect" % scalaVersion.value,
libraryDependencies += "org.scala-lang" % "scala-compiler" % scalaVersion.value,
- libraryDependencies += compilerPlugin("org.scalamacros" % "paradise" % "2.1.0" cross CrossVersion.full)
-)
-
-lazy val examplesDependencies: Seq[Setting[_]] = Seq(
- libraryDependencies += "org.typelevel" %% "cats-core" % "0.9.0",
- libraryDependencies += "com.propensive" %% "estrapade" % "1.0.3",
- libraryDependencies += "com.propensive" %% "contextual-data" % "1.0.3"
+ libraryDependencies += compilerPlugin(
+ "org.scalamacros" % "paradise" % "2.1.0" cross CrossVersion.full
+ )
)
credentials ++= (for {
username <- Option(System.getenv().get("SONATYPE_USERNAME"))
password <- Option(System.getenv().get("SONATYPE_PASSWORD"))
-} yield Credentials("Sonatype Nexus Repository Manager", "oss.sonatype.org", username, password)).toSeq
+} yield
+ Credentials("Sonatype Nexus Repository Manager", "oss.sonatype.org", username, password)).toSeq