-
Notifications
You must be signed in to change notification settings - Fork 411
/
Copy pathbuild.sbt
69 lines (68 loc) · 4.42 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
val scala3 = "3.6.3"
lazy val root = project
.in(file("."))
.settings(
name := "programming-scala-3rd-ed-code-examples",
description := "Code examples for Programming Scala, Third Edition (O'Reilly).",
version := s"$scala3-final",
scalaVersion := scala3,
organization := "org.programming-scala",
organizationName := "ProgrammingScala",
organizationHomepage := Some(url("http://programming-scala.org")),
homepage := Some(url("https://github.com/deanwampler/programming-scala-book-code-examples/")),
licenses += "Apache2" -> url("http://www.apache.org/licenses/LICENSE-2.0"),
maxErrors := 10,
// At the time of publication, Scala 3 builds of Akka were not yet available.
// Notice how the Scala 2.13-built libraries are used. For more information:
// https://www.scala-lang.org/blog/2021/04/08/scala-3-in-sbt.html
libraryDependencies ++= Seq(
"com.typesafe.akka" %% "akka-actor-typed" % "2.6.20",
"com.typesafe.akka" %% "akka-slf4j" % "2.6.20",
).map(dep => dep.cross(CrossVersion.for3Use2_13)) ++ Seq(
// Libraries that already fully support Scala 3:
"org.typelevel" %% "cats-core" % "2.13.0",
"org.scala-lang" %% "scala3-staging" % scalaVersion.value,
"org.scala-lang.modules" %% "scala-parser-combinators" % "2.4.0",
"ch.qos.logback" % "logback-classic" % "1.5.16",
"org.scalacheck" %% "scalacheck" % "1.18.1" % Test,
"org.scalameta" %% "munit" % "1.1.0" % Test,
"org.scalameta" %% "munit-scalacheck" % "1.0.0" % Test,
"com.eed3si9n.expecty" %% "expecty" % "0.17.0" % Test,
),
// For Scala 3
// The -rewrite and -migration options are best used while migrating
// from Scala 2 to Scala 3, then removed.
// The default value for -source is 3.0. I'm using future to force more
// deprecation warnings for obsolete concepts that are being transitioned
// out. Use the default value if you are migrating from Scala 2!!
scalacOptions := Seq(
// "-classpath", "foo:bar:...", // Add to the classpath.
"-encoding", "utf-8", // Specify character encoding used by source files.
"-deprecation", // Emit warning and location for usages of deprecated APIs.
"-unchecked", // Enable additional warnings where generated code depends on assumptions.
"-feature", // Emit warning and location for usages of features that should be imported explicitly.
"-explain", // Explain errors in more detail.
// "-explain-types", // Explain type errors in more detail.
// "-indent", // Together with -rewrite, remove {...} syntax when possible due to significant indentation.
// "-no-indent", // Require classical {...} syntax, indentation is not significant.
"-new-syntax", // Require `then` and `do` in control expressions.
// "-old-syntax", // Require `(...)` around conditions.
// "-language:Scala2", // Compile Scala 2 code, highlight what needs updating
// "-language:strictEquality", // Require +derives Eql+ for using == or != comparisons
// "-rewrite", // Attempt to fix code automatically. Use with -indent and ...-migration.
// "-scalajs", // Compile in Scala.js mode (requires scalajs-library.jar on the classpath).
"-source:future", // Choices: future and future-migration. I use this to force future deprecation warnings, etc.
"-Xfatal-warnings", // Fail on warnings, not just errors
// "-Xmigration", // Warn about constructs whose behavior may have changed since version.
// "-Ysafe-init", // Warn on field access before initialization
// "-Yexplicit-nulls", // For explicit nulls behavior.
// "-coverage-out", "coverage" // Output "scoverage" metrics (new for Scala 3.2.0)
),
Compile / console / scalacOptions := scalacOptions.value,
fork := true,
javaOptions ++= Seq(
"-Duser.language=en_US"
),
javacOptions ++= Seq(
"-Xlint:unchecked", "-Xlint:deprecation") // Java 8: "-Xdiags:verbose"),
)