Skip to content

Instantly share code, notes, and snippets.

@battermann
Created February 28, 2018 14:03
Show Gist options
  • Save battermann/143995edec7ee5511a41c297dcfb97ea to your computer and use it in GitHub Desktop.
Save battermann/143995edec7ee5511a41c297dcfb97ea to your computer and use it in GitHub Desktop.
javacOptions ++= Seq("-source", "1.8", "-target", "1.8", "-Xlint", "-g:none")
resolvers += Resolver.sonatypeRepo("releases")
val http4sVersion = "0.18.0"
val circeVersion = "0.9.1"
val catsEffectVersion = "0.9"
libraryDependencies ++= Seq(
"org.http4s" %% "http4s-dsl" % http4sVersion exclude ("org.typelevel", "cats-effect_2.12"),
"org.http4s" %% "http4s-blaze-server" % http4sVersion exclude ("org.typelevel", "cats-effect_2.12"),
"org.http4s" %% "http4s-blaze-client" % http4sVersion exclude ("org.typelevel", "cats-effect_2.12"),
"org.http4s" %% "http4s-circe" % http4sVersion exclude ("org.typelevel", "cats-effect_2.12"),
"io.circe" %% "circe-generic" % circeVersion,
"io.circe" %% "circe-parser" % circeVersion,
"org.typelevel" %% "cats-effect" % catsEffectVersion,
"org.seleniumhq.selenium" % "selenium-java" % "3.9.1"
)
libraryDependencies ++= Seq(
"com.amazonaws" % "aws-lambda-java-core" % "1.2.0" % Provided,
"com.amazonaws" % "aws-lambda-java-events" % "1.2.0" % Provided
)
libraryDependencies += "org.scalatest" %% "scalatest" % "3.0.4" % Test
proguardOptions in Proguard ++= Seq(
"-dontnote",
"-dontwarn",
"-ignorewarnings",
"-dontobfuscate",
"-dontoptimize",
"-keepattributes EnclosingMethod,InnerClasses,Signature",
"-keepattributes Annotation",
"-keep class com.ProxyWithStream { *; }",
"-keep class scala.ScalaObject { *; }",
"-keep class scala.Symbol { *; }"
)
proguardOptions in Proguard += """-keep class com.xing.ds.Lambda {
| public void fetch(java.io.InputStream, java.io.OutputStream);
|}""".stripMargin
proguardOptions in Proguard += """-keepclassmembers,allowshrinking,allowobfuscation class * {
| synthetic <methods>;
|}""".stripMargin
javaOptions in (Proguard, proguard) := Seq("-Xmx2G")
proguardInputs in Proguard := Seq(baseDirectory.value / "target" / s"scala-${scalaVersion.value.dropRight(2)}" / s"${name.value}-assembly-${version.value}.jar")
proguardInputFilter in Proguard := { filter =>
None
}
proguard in Proguard := (proguard in Proguard).dependsOn(assembly).value
assemblyMergeStrategy in assembly := {
case PathList("META-INF", xs @ _*) => MergeStrategy.discard
case _ => MergeStrategy.first
}
scalacOptions ++= Seq(
"-deprecation", // Emit warning and location for usages of deprecated APIs.
"-encoding",
"utf-8", // Specify character encoding used by source files.
"-explaintypes", // Explain type errors in more detail.
"-feature", // Emit warning and location for usages of features that should be imported explicitly.
"-language:existentials", // Existential types (besides wildcard types) can be written and inferred
"-language:experimental.macros", // Allow macro definition (besides implementation and application)
"-language:higherKinds", // Allow higher-kinded types
"-language:implicitConversions", // Allow definition of implicit functions called views
"-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.
"-Xfuture", // Turn on future language features.
"-Xlint:adapted-args", // Warn if an argument list is modified to match the receiver.
"-Xlint:by-name-right-associative", // By-name parameter of right associative operator.
"-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-override", // Warn when non-nullary `def f()' overrides nullary `def f'.
"-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.
"-Xlint:unsound-match", // Pattern match may not be typesafe.
"-Yno-adapted-args", // Do not adapt an argument list (either by inserting () or creating a tuple) to match the receiver.
"-Ypartial-unification", // Enable partial unification in type constructor inference
"-Ywarn-dead-code", // Warn when dead code is identified.
"-Ywarn-extra-implicit", // Warn when more than one implicit parameter section is defined.
"-Ywarn-inaccessible", // Warn about inaccessible types in method signatures.
"-Ywarn-infer-any", // Warn when a type argument is inferred to be `Any`.
"-Ywarn-nullary-override", // Warn when non-nullary `def f()' overrides nullary `def f'.
"-Ywarn-nullary-unit", // Warn when nullary methods return Unit.
"-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.
)
scalacOptions in (Compile, console) --= Seq("-Ywarn-unused:imports", "-Xfatal-warnings")
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment