-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbuild.sbt
122 lines (111 loc) · 5.24 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
import xerial.sbt.Sonatype._
// Common settings
val defaultScalaVersion = "2.13.3"
organization in ThisBuild := "com.davideicardi"
scalaVersion in ThisBuild := defaultScalaVersion
crossScalaVersions in ThisBuild := Seq(defaultScalaVersion, "2.12.12")
scalacOptions in ThisBuild ++= Seq(
"-language:higherKinds", // Allow higher kinds types (for scala 2.12 only)
"-deprecation", // Emit warning and location for usages of deprecated APIs.
"-explaintypes", // Explain type errors in more detail.
"-feature", // Emit warning and location for usages of features that should be imported explicitly.
"-unchecked", // Enable additional warnings where generated code depends on assumptions.
"-Xcheckinit", // Wrap field accessors to throw an exception on uninitialized access.
"-Xfatal-warnings", // Fail the compilation if there are any warnings.
"-Xlint:adapted-args", // Warn if an argument list is modified to match the receiver.
"-Xlint:constant", // Evaluation of a constant arithmetic expression results in an error.
"-Xlint:delayedinit-select", // Selecting member of DelayedInit.
"-Xlint:doc-detached", // A Scaladoc comment appears to be detached from its element.
"-Xlint:inaccessible", // Warn about inaccessible types in method signatures.
"-Xlint:infer-any", // Warn when a type argument is inferred to be `Any`.
"-Xlint:missing-interpolator", // A string literal appears to be missing an interpolator id.
"-Xlint:nullary-unit", // Warn when nullary methods return Unit.
"-Xlint:option-implicit", // Option.apply used implicit view.
"-Xlint:package-object-classes", // Class or object defined in package object.
"-Xlint:poly-implicit-overload", // Parameterized overloaded implicit methods are not visible as view bounds.
"-Xlint:private-shadow", // A private field (or class parameter) shadows a superclass field.
"-Xlint:stars-align", // Pattern sequence wildcard must align with sequence component.
"-Xlint:type-parameter-shadow", // A local type parameter shadows a type already in scope.
"-Ywarn-dead-code", // Warn when dead code is identified.
"-Ywarn-extra-implicit", // Warn when more than one implicit parameter section is defined.
"-Ywarn-numeric-widen", // Warn when numerics are widened.
"-Ywarn-unused:implicits", // Warn if an implicit parameter is unused.
"-Ywarn-unused:imports", // Warn if an import selector is not referenced.
"-Ywarn-unused:locals", // Warn if a local definition is unused.
"-Ywarn-unused:params", // Warn if a value parameter is unused.
"-Ywarn-unused:patvars", // Warn if a variable bound in a pattern is unused.
"-Ywarn-unused:privates", // Warn if a private member is unused.
"-Ywarn-value-discard", // Warn when non-Unit expression results are unused.
)
// sbt-dynver version settings
dynverSonatypeSnapshots in ThisBuild := true
// publish to sonatype/maven central
publishTo in ThisBuild := sonatypePublishToBundle.value
publishMavenStyle in ThisBuild := true
credentials in ThisBuild += Credentials(
"Sonatype Nexus Repository Manager",
"oss.sonatype.org",
"davide.icardi",
System.getenv("SONATYPE_PASSWORD")
)
licenses in ThisBuild := Seq("MIT License" -> url("https://mit-license.org/"))
homepage in ThisBuild := Some(url("https://github.com/davideicardi/kaa"))
scmInfo in ThisBuild := Some(
ScmInfo(
url("https://github.com/davideicardi/kaa"),
"scm:git@github.com:davideicardi/kaa.git"
)
)
developers in ThisBuild := List(
Developer(id="davideicardi", name="Davide Icardi", email="davide.icardi@gmail.com", url=url("http://davideicardi.com"))
)
val avro4sVersion = "4.0.0"
val kafkaVersion = "2.4.0" // NOTE: there is a dependencies to kafka also from avro4s-kafka
val testDependencies = Seq(
"org.scalatest" %% "scalatest" % "3.2.0" % "it,test",
"ch.qos.logback" % "logback-classic" % "1.2.3" % "it" exclude("org.slf4j", "slf4j-api"),
)
val dependencies = Seq(
"com.sksamuel.avro4s" %% "avro4s-core" % avro4sVersion exclude("org.slf4j", "slf4j-api"),
"com.sksamuel.avro4s" %% "avro4s-kafka" % avro4sVersion exclude("org.slf4j", "slf4j-api"),
"org.apache.kafka" % "kafka-clients" % kafkaVersion,
"com.github.blemale" %% "scaffeine" % "4.0.1",
)
lazy val kaa = project
.configs(IntegrationTest)
.settings(
Defaults.itSettings,
name := "kaa",
// set pinentry=loopback if we have the env variable, to avoid asking for passphrase
useGpgPinentry := Option(System.getenv("PGP_PASSPHRASE")).isDefined,
libraryDependencies ++= testDependencies,
libraryDependencies ++= dependencies,
)
lazy val sample = project
.settings(
name := "sample",
publish / skip := true,
libraryDependencies ++= Seq(
"ch.qos.logback" % "logback-classic" % "1.2.3",
),
)
.dependsOn(kaa)
val AkkaVersion = "2.6.8"
val AkkaHttpVersion = "10.2.1"
lazy val kaaRegistryServer = (project in file("kaa-registry-server"))
.settings(
name := "kaa-registry-server",
publish / skip := true,
libraryDependencies ++= Seq(
"com.typesafe.akka" %% "akka-stream" % AkkaVersion,
"com.typesafe.akka" %% "akka-http" % AkkaHttpVersion,
"com.typesafe.akka" %% "akka-http-spray-json" % AkkaHttpVersion,
),
)
.dependsOn(kaa)
lazy val kaaRoot = (project in file("."))
.aggregate(kaa, sample)
.settings(
publish / skip := true,
crossScalaVersions := Nil,
)