forked from typelevel/sbt-tpolecat
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild.sbt
92 lines (84 loc) · 3.09 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
import com.typesafe.tools.mima.core._
ThisBuild / organization := "io.github.davidgregory084"
ThisBuild / organizationName := "David Gregory"
ThisBuild / startYear := Some(2022)
ThisBuild / licenses += ("Apache-2.0", url("https://www.apache.org/licenses/LICENSE-2.0.html"))
ThisBuild / scmInfo := Some(
ScmInfo(
url("https://github.com/typelevel/sbt-tpolecat"),
"scm:git:[email protected]:typelevel/sbt-tpolecat.git"
)
)
ThisBuild / developers := List(
Developer(
"DavidGregory084",
"David Gregory",
url("https://github.com/DavidGregory084")
)
)
ThisBuild / homepage := scmInfo.value.map(_.browseUrl)
ThisBuild / semanticdbEnabled := true
ThisBuild / semanticdbVersion := scalafixSemanticdb.revision
ThisBuild / scalafixDependencies += "com.github.liancheng" %% "organize-imports" % "0.6.0"
ThisBuild / versionScheme := Some(VersionScheme.EarlySemVer)
lazy val `sbt-tpolecat` = project
.in(file("."))
.aggregate(
`sbt-tpolecat-plugin`,
`sbt-tpolecat-scalafix`.rules,
`sbt-tpolecat-scalafix`.input,
`sbt-tpolecat-scalafix`.tests
/* TODO: change individual Scalafix project dependencies to `sbt-tpolecat-scalafix`.all when the package rename is in main;
* the Scalafix `output` project will not compile until the package renaming is done.
*/
)
.settings(
publish := {},
publishLocal := {},
publishArtifact := false,
publish / skip := true,
mimaReportBinaryIssues := {}
)
lazy val `sbt-tpolecat-plugin` = project
.in(file("plugin"))
.enablePlugins(SbtPlugin)
.settings(
name := "sbt-tpolecat",
moduleName := "sbt-tpolecat",
description := "scalac options for the enlightened",
Compile / headerCreate := { (Compile / headerCreate).triggeredBy(Compile / compile).value },
Test / headerCreate := { (Test / headerCreate).triggeredBy(Test / compile).value },
scalacOptions += "-Xlint:unused",
libraryDependencies ++= Seq(
"org.scalatest" %% "scalatest" % "3.2.15" % Test,
"org.scalacheck" %% "scalacheck" % "1.17.0" % Test,
"org.scalatestplus" %% "scalacheck-1-16" % "3.2.14.0" % Test
),
mimaPreviousArtifacts := Set(
projectID.value.withRevision("0.4.0").withExplicitArtifacts(Vector.empty)
),
mimaBinaryIssueFilters ++= Seq(
),
scriptedBufferLog := false,
scriptedLaunchOpts := scriptedLaunchOpts.value ++ Seq(
"-Xmx1024M",
"-Dplugin.version=" + version.value
),
test := {
(Test / test).value
scripted.toTask("").value
}
)
lazy val `sbt-tpolecat-scalafix` = scalafixProject("sbt-tpolecat")
.rulesConfigure(project =>
project.settings(
mimaPreviousArtifacts := Set(
(project / projectID).value.withRevision("0.4.1").withExplicitArtifacts(Vector.empty)
)
)
)
.inputSettings(
libraryDependencies += (`sbt-tpolecat-plugin` / projectID).value.withRevision("0.4.0")
)
.outputConfigure(_.dependsOn(`sbt-tpolecat-plugin`))