-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathbuild.sbt
64 lines (54 loc) · 2.12 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
import sbt.Keys.crossScalaVersions
import sbtcrossproject.CrossPlugin.autoImport.crossProject
lazy val scala210 = "2.10.7"
lazy val scala211 = "2.11.12"
lazy val scala212 = "2.12.20"
lazy val scala213 = "2.13.16"
lazy val scala3 = "3.6.3"
lazy val scalatestVersion = "3.2.19"
name := "sha"
ThisBuild / organization := "pt.kcry"
ThisBuild / dynverSeparator := "-"
ThisBuild / scalaVersion := scala213
ThisBuild / crossScalaVersions := Seq()
ThisBuild / scalacOptions ++=
Seq("-target:jvm-1.8", "-unchecked", "-deprecation")
ThisBuild / publishTo := sonatypePublishToBundle.value
headerLicense := LicenseDefinition.template
lazy val sha = crossProject(JSPlatform, JVMPlatform, NativePlatform)
.crossType(CrossType.Full).enablePlugins(BuildInfoPlugin)
.enablePlugins(AutomateHeaderPlugin).in(file(".")).settings(
Test / publishArtifact := false,
buildInfoKeys := Seq(
BuildInfoKey.action("commit") {
scala.sys.process.Process("git rev-parse HEAD").!!.trim
}
),
headerLicense := LicenseDefinition.template,
buildInfoPackage := "pt.kcry.sha",
libraryDependencies ++=
Seq("org.scalatest" %%% "scalatest" % scalatestVersion % Test)
).jvmSettings(
scalaVersion := scala213,
crossScalaVersions := Seq(scala210, scala211, scala212, scala213, scala3)
).jsSettings(
scalaVersion := scala213,
crossScalaVersions := Seq(scala212, scala213, scala3)
).nativeSettings(
scalaVersion := scala213,
crossScalaVersions := Seq(scala212, scala213, scala3)
)
lazy val bench = project.in(file("bench")).dependsOn(sha.jvm)
.enablePlugins(AutomateHeaderPlugin).settings(
name := "blake3-bench",
publish / skip := true,
assembly / assemblyJarName := "bench.jar",
assembly / mainClass := Some("org.openjdk.jmh.Main"),
assembly / test := {},
headerLicense := LicenseDefinition.template,
assembly / assemblyMergeStrategy := {
case PathList("META-INF", "MANIFEST.MF") => MergeStrategy.discard
case _ => MergeStrategy.first
},
Jmh / assembly := (Jmh / assembly).dependsOn(Jmh / Keys.compile).value
).enablePlugins(JmhPlugin)