-
-
Notifications
You must be signed in to change notification settings - Fork 11
/
build.sbt
134 lines (123 loc) · 3.96 KB
/
build.sbt
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
import com.typesafe.sbt.pgp.PgpKeys._
import com.typesafe.tools.mima.plugin.MimaPlugin.mimaDefaultSettings
import sbt.Keys.scalacOptions
import sbt.url
import scala.sys.process._
lazy val oldVersion = "git describe --abbrev=0".!!.trim.replaceAll("^v", "")
def mimaSettings = mimaDefaultSettings ++ Seq(
mimaCheckDirection := {
def isPatch = {
val Array(newMajor, newMinor, _) = version.value.split('.')
val Array(oldMajor, oldMinor, _) = oldVersion.split('.')
newMajor == oldMajor && newMinor == oldMinor
}
if (isPatch) "both" else "backward"
},
mimaPreviousArtifacts := {
def isCheckingRequired = {
val Array(newMajor, newMinor, _) = version.value.split('.')
val Array(oldMajor, oldMinor, _) = oldVersion.split('.')
newMajor == oldMajor && (newMajor != "0" || newMinor == oldMinor)
}
if (isCheckingRequired) Set(organization.value %% moduleName.value % oldVersion)
else Set()
}
)
lazy val commonSettings = Seq(
organization := "com.sizmek.rtree2d",
organizationHomepage := Some(url("https://sizmek.com")),
homepage := Some(url("https://github.com/Sizmek/rtree2d")),
licenses := Seq(("Apache-2.0", url("https://www.apache.org/licenses/LICENSE-2.0.html"))),
startYear := Some(2018),
developers := List(
Developer(
id = "loony-bean",
name = "Alexey Suslov",
email = "[email protected]",
url = url("https://github.com/loony-bean")
),
Developer(
id = "AnderEnder",
name = "Andrii Radyk",
email = "[email protected]",
url = url("https://github.com/AnderEnder")
),
Developer(
id = "plokhotnyuk",
name = "Andriy Plokhotnyuk",
email = "[email protected]",
url = url("https://twitter.com/aplokhotnyuk")
),
),
resolvers += Resolver.jcenterRepo,
scalaVersion := "2.12.6",
scalacOptions ++= Seq(
"-deprecation",
"-encoding", "UTF-8",
"-feature",
"-unchecked",
"-Yno-adapted-args",
"-Ywarn-dead-code",
"-Xfuture",
"-Xlint"
),
testOptions in Test += Tests.Argument("-oDF"),
parallelExecution in ThisBuild := false
)
lazy val noPublishSettings = Seq(
skip in publish := true,
publishArtifact := false
)
lazy val publishSettings = Seq(
bintrayOrganization := Some("sizmek"),
bintrayRepository := "sizmek-maven",
scmInfo := Some(
ScmInfo(
url("https://github.com/Sizmek/rtree2d"),
"scm:[email protected]:Sizmek/rtree2d.git"
)
),
publishMavenStyle := true,
pomIncludeRepository := { _ => false }
)
lazy val rtree2d = project.in(file("."))
.aggregate(core, benchmark)
.settings(commonSettings: _*)
.settings(noPublishSettings: _*)
lazy val core = project
.settings(commonSettings: _*)
.settings(mimaSettings: _*)
.settings(publishSettings: _*)
.settings(
crossScalaVersions := Seq("2.13.0-M3", "2.12.6", "2.11.12"),
libraryDependencies ++= Seq(
"org.scalacheck" %% "scalacheck" % "1.14.0" % Test,
"org.scalatest" %% "scalatest" % "3.0.5-M1" % Test
)
)
lazy val benchmark = project
.enablePlugins(JmhPlugin)
.dependsOn(core)
.settings(commonSettings: _*)
.settings(noPublishSettings: _*)
.settings(
crossScalaVersions := Seq("2.12.6", "2.11.12"),
libraryDependencies ++= Seq(
"com.github.davidmoten" % "rtree" % "0.8.5",
"org.spire-math" %% "archery" % "0.6.0",
"pl.project13.scala" % "sbt-jmh-extras" % "0.3.4",
"org.scalatest" %% "scalatest" % "3.0.5-M1" % Test
),
charts := Def.inputTaskDyn {
val jmhParams = Def.spaceDelimited().parsed
val targetDir = crossTarget.value
val jmhReport = targetDir / "benchmark.json"
val runTask = run in Jmh
Def.inputTask {
val _ = runTask.evaluated
Bencharts(jmhReport, "Execution time (ns/op)", targetDir)
targetDir
}.toTask(s" -rf json -rff ${jmhReport.absolutePath} ${jmhParams.mkString(" ")}")
}.evaluated
)
lazy val charts = inputKey[File]("Runs the benchmarks and produce charts")