From ef465e0c635fc13390c4a78397d2063e87bc9459 Mon Sep 17 00:00:00 2001 From: David Gregory Date: Thu, 21 Jul 2022 15:38:38 +0100 Subject: [PATCH 1/4] Add a Scalafix migration for v0.5.0 --- build.sbt | 98 ++++++------ .../davidgregory084/JavaMajorVersion.scala | 0 .../github/davidgregory084/OptionsMode.scala | 0 .../github/davidgregory084/ScalaVersion.scala | 0 .../github/davidgregory084/ScalacOption.scala | 0 .../davidgregory084/ScalacOptions.scala | 0 .../davidgregory084/TpolecatPlugin.scala | 0 .../modePerConfiguration/build.sbt | 0 .../project/build.properties | 0 .../modePerConfiguration/project/build.sbt | 0 .../modePerConfiguration/project/plugins.sbt | 0 .../src/main/scala/Main.scala | 0 .../src/test/scala/HasWarnings.scala | 0 .../sbt-tpolecat/modePerConfiguration/test | 0 .../sbt-tpolecat/scalacOptions/build.sbt | 0 .../scalacOptions/project/build.properties | 0 .../scalacOptions/project/build.sbt | 0 .../scalacOptions/project/plugins.sbt | 0 .../scalacOptions/src/main/scala/Main.scala | 0 .../sbt-test/sbt-tpolecat/scalacOptions/test | 0 .../davidgregory084/TpolecatPluginSuite.scala | 0 project/ScalafixProjectPlugin.scala | 141 ++++++++++++++++++ project/plugins.sbt | 2 +- .../scala/org/typelevel/fix/v0_5Tests.scala | 9 ++ .../scala/org/typelevel/fix/v0_5Tests.scala | 6 + .../META-INF/services/scalafix.v1.Rule | 1 + .../main/scala/org/typelevel/fix/v0_5.scala | 14 ++ .../scala/org/typelevel/fix/RuleSuite.scala | 8 + 28 files changed, 233 insertions(+), 46 deletions(-) rename {src => plugin/src}/main/scala/io/github/davidgregory084/JavaMajorVersion.scala (100%) rename {src => plugin/src}/main/scala/io/github/davidgregory084/OptionsMode.scala (100%) rename {src => plugin/src}/main/scala/io/github/davidgregory084/ScalaVersion.scala (100%) rename {src => plugin/src}/main/scala/io/github/davidgregory084/ScalacOption.scala (100%) rename {src => plugin/src}/main/scala/io/github/davidgregory084/ScalacOptions.scala (100%) rename {src => plugin/src}/main/scala/io/github/davidgregory084/TpolecatPlugin.scala (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/modePerConfiguration/build.sbt (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/modePerConfiguration/project/build.properties (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/modePerConfiguration/project/build.sbt (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/modePerConfiguration/project/plugins.sbt (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/modePerConfiguration/src/main/scala/Main.scala (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/modePerConfiguration/src/test/scala/HasWarnings.scala (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/modePerConfiguration/test (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/scalacOptions/build.sbt (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/scalacOptions/project/build.properties (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/scalacOptions/project/build.sbt (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/scalacOptions/project/plugins.sbt (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/scalacOptions/src/main/scala/Main.scala (100%) rename {src => plugin/src}/sbt-test/sbt-tpolecat/scalacOptions/test (100%) rename {src => plugin/src}/test/scala/io/github/davidgregory084/TpolecatPluginSuite.scala (100%) create mode 100644 project/ScalafixProjectPlugin.scala create mode 100644 scalafix/input/src/main/scala/org/typelevel/fix/v0_5Tests.scala create mode 100644 scalafix/output/src/main/scala/org/typelevel/fix/v0_5Tests.scala create mode 100644 scalafix/rules/src/main/resources/META-INF/services/scalafix.v1.Rule create mode 100644 scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala create mode 100644 scalafix/tests/src/test/scala/org/typelevel/fix/RuleSuite.scala diff --git a/build.sbt b/build.sbt index fa30622..ad7120e 100644 --- a/build.sbt +++ b/build.sbt @@ -1,21 +1,17 @@ import com.typesafe.tools.mima.core._ -// Common settings +ThisBuild / organization := "io.github.davidgregory084" +ThisBuild / organizationName := "David Gregory" -name := "sbt-tpolecat" -description := "scalac options for the enlightened" -organization := "io.github.davidgregory084" - -organizationName := "David Gregory" -startYear := Some(2022) -licenses += ("Apache-2.0", url("https://www.apache.org/licenses/LICENSE-2.0.html")) -scmInfo := Some( +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/DavidGregory084/sbt-tpolecat"), "scm:git:git@github.com:DavidGregory084/sbt-tpolecat.git" ) ) -developers := List( +ThisBuild / developers := List( Developer( "DavidGregory084", "David Gregory", @@ -23,24 +19,8 @@ developers := List( url("https://github.com/DavidGregory084") ) ) -homepage := scmInfo.value.map(_.browseUrl) - -crossSbtVersions := Seq("1.6.2") - -enablePlugins(SbtPlugin) - -// License headers -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.11" % Test, - "org.scalacheck" %% "scalacheck" % "1.15.4" % Test, - "org.scalatestplus" %% "scalacheck-1-15" % "3.2.11.0" % Test -) +ThisBuild / homepage := scmInfo.value.map(_.browseUrl) ThisBuild / semanticdbEnabled := true ThisBuild / semanticdbVersion := scalafixSemanticdb.revision @@ -48,23 +28,51 @@ ThisBuild / scalafixDependencies += "com.github.liancheng" %% "organize-imports" ThisBuild / versionScheme := Some(VersionScheme.EarlySemVer) -mimaPreviousArtifacts := Set( - projectID.value.withRevision("0.4.0") -) - -mimaBinaryIssueFilters ++= Seq( -) - -// Testing - -scriptedBufferLog := false +ThisBuild / crossSbtVersions := Seq("1.6.2") + +lazy val `sbt-tpolecat` = project + .in(file(".")) + .aggregate(`sbt-tpolecat-plugin`) + .settings( + publish := {}, + publishLocal := {}, + publishArtifact := false, + publish / skip := true, + mimaReportBinaryIssues := {} + ) -scriptedLaunchOpts := scriptedLaunchOpts.value ++ Seq( - "-Xmx1024M", - "-Dplugin.version=" + version.value -) +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.11" % Test, + "org.scalacheck" %% "scalacheck" % "1.15.4" % Test, + "org.scalatestplus" %% "scalacheck-1-15" % "3.2.11.0" % Test + ), + mimaPreviousArtifacts := Set( + projectID.value.withRevision("0.4.0") + ), + mimaBinaryIssueFilters ++= Seq( + ), + scriptedBufferLog := false, + scriptedLaunchOpts := scriptedLaunchOpts.value ++ Seq( + "-Xmx1024M", + "-Dplugin.version=" + version.value + ), + test := { + (Test / test).value + scripted.toTask("").value + } + ) -test := { - (Test / test).value - scripted.toTask("").value -} +lazy val `sbt-tpolecat-scalafix` = scalafixProject("sbt-tpolecat") + .inputSettings( + libraryDependencies += (`sbt-tpolecat-plugin` / projectID).value.withRevision("0.4.0") + ) diff --git a/src/main/scala/io/github/davidgregory084/JavaMajorVersion.scala b/plugin/src/main/scala/io/github/davidgregory084/JavaMajorVersion.scala similarity index 100% rename from src/main/scala/io/github/davidgregory084/JavaMajorVersion.scala rename to plugin/src/main/scala/io/github/davidgregory084/JavaMajorVersion.scala diff --git a/src/main/scala/io/github/davidgregory084/OptionsMode.scala b/plugin/src/main/scala/io/github/davidgregory084/OptionsMode.scala similarity index 100% rename from src/main/scala/io/github/davidgregory084/OptionsMode.scala rename to plugin/src/main/scala/io/github/davidgregory084/OptionsMode.scala diff --git a/src/main/scala/io/github/davidgregory084/ScalaVersion.scala b/plugin/src/main/scala/io/github/davidgregory084/ScalaVersion.scala similarity index 100% rename from src/main/scala/io/github/davidgregory084/ScalaVersion.scala rename to plugin/src/main/scala/io/github/davidgregory084/ScalaVersion.scala diff --git a/src/main/scala/io/github/davidgregory084/ScalacOption.scala b/plugin/src/main/scala/io/github/davidgregory084/ScalacOption.scala similarity index 100% rename from src/main/scala/io/github/davidgregory084/ScalacOption.scala rename to plugin/src/main/scala/io/github/davidgregory084/ScalacOption.scala diff --git a/src/main/scala/io/github/davidgregory084/ScalacOptions.scala b/plugin/src/main/scala/io/github/davidgregory084/ScalacOptions.scala similarity index 100% rename from src/main/scala/io/github/davidgregory084/ScalacOptions.scala rename to plugin/src/main/scala/io/github/davidgregory084/ScalacOptions.scala diff --git a/src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala b/plugin/src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala similarity index 100% rename from src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala rename to plugin/src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala diff --git a/src/sbt-test/sbt-tpolecat/modePerConfiguration/build.sbt b/plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/build.sbt similarity index 100% rename from src/sbt-test/sbt-tpolecat/modePerConfiguration/build.sbt rename to plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/build.sbt diff --git a/src/sbt-test/sbt-tpolecat/modePerConfiguration/project/build.properties b/plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/project/build.properties similarity index 100% rename from src/sbt-test/sbt-tpolecat/modePerConfiguration/project/build.properties rename to plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/project/build.properties diff --git a/src/sbt-test/sbt-tpolecat/modePerConfiguration/project/build.sbt b/plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/project/build.sbt similarity index 100% rename from src/sbt-test/sbt-tpolecat/modePerConfiguration/project/build.sbt rename to plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/project/build.sbt diff --git a/src/sbt-test/sbt-tpolecat/modePerConfiguration/project/plugins.sbt b/plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/project/plugins.sbt similarity index 100% rename from src/sbt-test/sbt-tpolecat/modePerConfiguration/project/plugins.sbt rename to plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/project/plugins.sbt diff --git a/src/sbt-test/sbt-tpolecat/modePerConfiguration/src/main/scala/Main.scala b/plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/src/main/scala/Main.scala similarity index 100% rename from src/sbt-test/sbt-tpolecat/modePerConfiguration/src/main/scala/Main.scala rename to plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/src/main/scala/Main.scala diff --git a/src/sbt-test/sbt-tpolecat/modePerConfiguration/src/test/scala/HasWarnings.scala b/plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/src/test/scala/HasWarnings.scala similarity index 100% rename from src/sbt-test/sbt-tpolecat/modePerConfiguration/src/test/scala/HasWarnings.scala rename to plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/src/test/scala/HasWarnings.scala diff --git a/src/sbt-test/sbt-tpolecat/modePerConfiguration/test b/plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/test similarity index 100% rename from src/sbt-test/sbt-tpolecat/modePerConfiguration/test rename to plugin/src/sbt-test/sbt-tpolecat/modePerConfiguration/test diff --git a/src/sbt-test/sbt-tpolecat/scalacOptions/build.sbt b/plugin/src/sbt-test/sbt-tpolecat/scalacOptions/build.sbt similarity index 100% rename from src/sbt-test/sbt-tpolecat/scalacOptions/build.sbt rename to plugin/src/sbt-test/sbt-tpolecat/scalacOptions/build.sbt diff --git a/src/sbt-test/sbt-tpolecat/scalacOptions/project/build.properties b/plugin/src/sbt-test/sbt-tpolecat/scalacOptions/project/build.properties similarity index 100% rename from src/sbt-test/sbt-tpolecat/scalacOptions/project/build.properties rename to plugin/src/sbt-test/sbt-tpolecat/scalacOptions/project/build.properties diff --git a/src/sbt-test/sbt-tpolecat/scalacOptions/project/build.sbt b/plugin/src/sbt-test/sbt-tpolecat/scalacOptions/project/build.sbt similarity index 100% rename from src/sbt-test/sbt-tpolecat/scalacOptions/project/build.sbt rename to plugin/src/sbt-test/sbt-tpolecat/scalacOptions/project/build.sbt diff --git a/src/sbt-test/sbt-tpolecat/scalacOptions/project/plugins.sbt b/plugin/src/sbt-test/sbt-tpolecat/scalacOptions/project/plugins.sbt similarity index 100% rename from src/sbt-test/sbt-tpolecat/scalacOptions/project/plugins.sbt rename to plugin/src/sbt-test/sbt-tpolecat/scalacOptions/project/plugins.sbt diff --git a/src/sbt-test/sbt-tpolecat/scalacOptions/src/main/scala/Main.scala b/plugin/src/sbt-test/sbt-tpolecat/scalacOptions/src/main/scala/Main.scala similarity index 100% rename from src/sbt-test/sbt-tpolecat/scalacOptions/src/main/scala/Main.scala rename to plugin/src/sbt-test/sbt-tpolecat/scalacOptions/src/main/scala/Main.scala diff --git a/src/sbt-test/sbt-tpolecat/scalacOptions/test b/plugin/src/sbt-test/sbt-tpolecat/scalacOptions/test similarity index 100% rename from src/sbt-test/sbt-tpolecat/scalacOptions/test rename to plugin/src/sbt-test/sbt-tpolecat/scalacOptions/test diff --git a/src/test/scala/io/github/davidgregory084/TpolecatPluginSuite.scala b/plugin/src/test/scala/io/github/davidgregory084/TpolecatPluginSuite.scala similarity index 100% rename from src/test/scala/io/github/davidgregory084/TpolecatPluginSuite.scala rename to plugin/src/test/scala/io/github/davidgregory084/TpolecatPluginSuite.scala diff --git a/project/ScalafixProjectPlugin.scala b/project/ScalafixProjectPlugin.scala new file mode 100644 index 0000000..6bbc6af --- /dev/null +++ b/project/ScalafixProjectPlugin.scala @@ -0,0 +1,141 @@ +import sbt._, Keys._ + +import com.typesafe.tools.mima.plugin.MimaPlugin.autoImport._ +import de.heikoseeberger.sbtheader.HeaderPlugin.autoImport._ +import scalafix.sbt._ +import ScalafixPlugin.autoImport._ +import ScalafixTestkitPlugin.autoImport._ + +object ScalafixProjectPlugin extends AutoPlugin { + object autoImport { + lazy val V = _root_.scalafix.sbt.BuildInfo + def scalafixProject(name: String) = ScalafixProject(name) + } +} + +class ScalafixProject private ( + val name: String, + val rules: Project, + val input: Project, + val output: Project, + val tests: Project +) extends CompositeProject { + + lazy val componentProjects = Seq(all, rules, input, output, tests) + + lazy val all = Project(name, file(s"target/$name-scalafix-aggregate")) + .aggregate(rules, input, output, tests) + .settings( + publish := {}, + publishLocal := {}, + publishArtifact := false, + publish / skip := true, + mimaReportBinaryIssues := {} + ) + + def rulesSettings(ss: Def.SettingsDefinition*): ScalafixProject = + rulesConfigure(_.settings(ss: _*)) + + def inputSettings(ss: Def.SettingsDefinition*): ScalafixProject = + inputConfigure(_.settings(ss: _*)) + + def outputSettings(ss: Def.SettingsDefinition*): ScalafixProject = + outputConfigure(_.settings(ss: _*)) + + def testsSettings(ss: Def.SettingsDefinition*): ScalafixProject = + testsConfigure(_.settings(ss: _*)) + + def rulesConfigure(transforms: (Project => Project)*): ScalafixProject = + new ScalafixProject( + name, + rules.configure(transforms: _*), + input, + output, + tests + ) + + def inputConfigure(transforms: (Project => Project)*): ScalafixProject = + new ScalafixProject( + name, + rules, + input.configure(transforms: _*), + output, + tests + ) + + def outputConfigure(transforms: (Project => Project)*): ScalafixProject = + new ScalafixProject( + name, + rules, + input, + output.configure(transforms: _*), + tests + ) + + def testsConfigure(transforms: (Project => Project)*): ScalafixProject = + new ScalafixProject( + name, + rules, + input, + output, + tests.configure(transforms: _*) + ) + +} + +object ScalafixProject { + def apply(name: String): ScalafixProject = { + + lazy val rules = Project(s"$name-scalafix", file(s"scalafix/rules")) + .settings( + moduleName := s"$name-scalafix", + libraryDependencies += "ch.epfl.scala" %% "scalafix-core" % _root_.scalafix.sbt.BuildInfo.scalafixVersion + ) + + lazy val input = Project(s"$name-scalafix-input", file(s"scalafix/input")) + .settings( + headerSources / excludeFilter := AllPassFilter, + scalacOptions ~= { opts => opts.filterNot(Set("-Xfatal-warnings", "-Werror")) } + ) + .settings( + publish := {}, + publishLocal := {}, + publishArtifact := false, + publish / skip := true, + mimaReportBinaryIssues := {} + ) + + lazy val output = Project(s"$name-scalafix-output", file(s"scalafix/output")) + .settings( + headerSources / excludeFilter := AllPassFilter, + scalacOptions ~= { opts => opts.filterNot(Set("-Xfatal-warnings", "-Werror")) } + ) + .settings( + publish := {}, + publishLocal := {}, + publishArtifact := false, + publish / skip := true, + mimaReportBinaryIssues := {} + ) + + lazy val tests = Project(s"$name-scalafix-tests", file(s"scalafix/tests")) + .settings( + scalafixTestkitOutputSourceDirectories := (output / Compile / unmanagedSourceDirectories).value, + scalafixTestkitInputSourceDirectories := (input / Compile / unmanagedSourceDirectories).value, + scalafixTestkitInputClasspath := (input / Compile / fullClasspath).value, + scalafixTestkitInputScalacOptions := (input / Compile / scalacOptions).value, + scalafixTestkitInputScalaVersion := (input / Compile / scalaVersion).value + ) + .dependsOn(rules) + .enablePlugins(ScalafixTestkitPlugin) + .settings( + publish := {}, + publishLocal := {}, + publishArtifact := false, + publish / skip := true, + mimaReportBinaryIssues := {} + ) + + new ScalafixProject(name, rules, input, output, tests) + } +} diff --git a/project/plugins.sbt b/project/plugins.sbt index ae7942a..d95f45c 100644 --- a/project/plugins.sbt +++ b/project/plugins.sbt @@ -6,6 +6,6 @@ addSbtPlugin("com.timushev.sbt" % "sbt-updates" % "0.6.2") addSbtPlugin("org.scalameta" % "sbt-scalafmt" % "2.4.6") -addSbtPlugin("ch.epfl.scala" % "sbt-scalafix" % "0.9.34") +addSbtPlugin("ch.epfl.scala" % "sbt-scalafix" % "0.10.1") addSbtPlugin("com.typesafe" % "sbt-mima-plugin" % "1.0.1") diff --git a/scalafix/input/src/main/scala/org/typelevel/fix/v0_5Tests.scala b/scalafix/input/src/main/scala/org/typelevel/fix/v0_5Tests.scala new file mode 100644 index 0000000..3097c16 --- /dev/null +++ b/scalafix/input/src/main/scala/org/typelevel/fix/v0_5Tests.scala @@ -0,0 +1,9 @@ +/* +rule = v0_5 +*/ +import io.github.davidgregory084.TpolecatPlugin +import io.github.davidgregory084._ +import _root_.io.github.davidgregory084.ScalacOption +import _root_.io.github.davidgregory084._ + +object Tests diff --git a/scalafix/output/src/main/scala/org/typelevel/fix/v0_5Tests.scala b/scalafix/output/src/main/scala/org/typelevel/fix/v0_5Tests.scala new file mode 100644 index 0000000..e8864f1 --- /dev/null +++ b/scalafix/output/src/main/scala/org/typelevel/fix/v0_5Tests.scala @@ -0,0 +1,6 @@ +import org.typelevel.sbt.TpolecatPlugin +import org.typelevel.sbt._ +import _root_.org.typelevel.sbt.ScalacOption +import _root_.org.typelevel.sbt._ + +object Tests diff --git a/scalafix/rules/src/main/resources/META-INF/services/scalafix.v1.Rule b/scalafix/rules/src/main/resources/META-INF/services/scalafix.v1.Rule new file mode 100644 index 0000000..eaef793 --- /dev/null +++ b/scalafix/rules/src/main/resources/META-INF/services/scalafix.v1.Rule @@ -0,0 +1 @@ +org.typelevel.fix.v0_5 diff --git a/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala b/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala new file mode 100644 index 0000000..14a3536 --- /dev/null +++ b/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala @@ -0,0 +1,14 @@ +package org.typelevel.fix + +import scalafix.v1._ +import scala.meta._ + +class v0_5 extends SemanticRule("v0_5") { + override def fix(implicit doc: SemanticDocument): Patch = + doc.tree.collect { + case Importer(ref , _) if ref.toString == "io.github.davidgregory084" => + Patch.replaceTree(ref, "org.typelevel.sbt") + case Importer(ref, _) if ref.toString == "_root_.io.github.davidgregory084" => + Patch.replaceTree(ref, "_root_.org.typelevel.sbt") + }.asPatch +} diff --git a/scalafix/tests/src/test/scala/org/typelevel/fix/RuleSuite.scala b/scalafix/tests/src/test/scala/org/typelevel/fix/RuleSuite.scala new file mode 100644 index 0000000..80c3deb --- /dev/null +++ b/scalafix/tests/src/test/scala/org/typelevel/fix/RuleSuite.scala @@ -0,0 +1,8 @@ +package org.typelevel.fix + +import scalafix.testkit._ +import org.scalatest.FunSuiteLike + +class RuleSuite extends AbstractSemanticRuleSuite with FunSuiteLike { + runAllTests() +} From 2a2853d042c927f97b1e979cd1c513e567c5388b Mon Sep 17 00:00:00 2001 From: David Gregory Date: Thu, 21 Jul 2022 16:05:56 +0100 Subject: [PATCH 2/4] Add another layer of package nesting for the v0.5.0 migration --- .../src/main/scala/org/typelevel/fix/v0_5Tests.scala | 8 ++++---- .../rules/src/main/scala/org/typelevel/fix/v0_5.scala | 4 ++-- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/scalafix/output/src/main/scala/org/typelevel/fix/v0_5Tests.scala b/scalafix/output/src/main/scala/org/typelevel/fix/v0_5Tests.scala index e8864f1..a244f0c 100644 --- a/scalafix/output/src/main/scala/org/typelevel/fix/v0_5Tests.scala +++ b/scalafix/output/src/main/scala/org/typelevel/fix/v0_5Tests.scala @@ -1,6 +1,6 @@ -import org.typelevel.sbt.TpolecatPlugin -import org.typelevel.sbt._ -import _root_.org.typelevel.sbt.ScalacOption -import _root_.org.typelevel.sbt._ +import org.typelevel.sbt.tpolecat.TpolecatPlugin +import org.typelevel.sbt.tpolecat._ +import _root_.org.typelevel.sbt.tpolecat.ScalacOption +import _root_.org.typelevel.sbt.tpolecat._ object Tests diff --git a/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala b/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala index 14a3536..51db844 100644 --- a/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala +++ b/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala @@ -7,8 +7,8 @@ class v0_5 extends SemanticRule("v0_5") { override def fix(implicit doc: SemanticDocument): Patch = doc.tree.collect { case Importer(ref , _) if ref.toString == "io.github.davidgregory084" => - Patch.replaceTree(ref, "org.typelevel.sbt") + Patch.replaceTree(ref, "org.typelevel.sbt.tpolecat") case Importer(ref, _) if ref.toString == "_root_.io.github.davidgregory084" => - Patch.replaceTree(ref, "_root_.org.typelevel.sbt") + Patch.replaceTree(ref, "_root_.org.typelevel.sbt.tpolecat") }.asPatch } From d7a390462efd35839438e6102da9587ea905e7cb Mon Sep 17 00:00:00 2001 From: David Gregory Date: Thu, 21 Jul 2022 16:33:28 +0100 Subject: [PATCH 3/4] Add the scalafix subproject to the root aggregate --- build.sbt | 19 ++++++++++++++----- project/ScalafixProjectPlugin.scala | 4 ++-- .../main/scala/org/typelevel/fix/v0_5.scala | 4 ++-- 3 files changed, 18 insertions(+), 9 deletions(-) diff --git a/build.sbt b/build.sbt index ad7120e..2a9a8e3 100644 --- a/build.sbt +++ b/build.sbt @@ -32,7 +32,15 @@ ThisBuild / crossSbtVersions := Seq("1.6.2") lazy val `sbt-tpolecat` = project .in(file(".")) - .aggregate(`sbt-tpolecat-plugin`) + .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 := {}, @@ -57,7 +65,7 @@ lazy val `sbt-tpolecat-plugin` = project "org.scalatestplus" %% "scalacheck-1-15" % "3.2.11.0" % Test ), mimaPreviousArtifacts := Set( - projectID.value.withRevision("0.4.0") + projectID.value.withRevision("0.4.0").withExplicitArtifacts(Vector.empty) ), mimaBinaryIssueFilters ++= Seq( ), @@ -73,6 +81,7 @@ lazy val `sbt-tpolecat-plugin` = project ) lazy val `sbt-tpolecat-scalafix` = scalafixProject("sbt-tpolecat") - .inputSettings( - libraryDependencies += (`sbt-tpolecat-plugin` / projectID).value.withRevision("0.4.0") - ) + // TODO: Re-enable mimaReportBinaryIssues once the scalafix project is published + .rulesSettings(mimaReportBinaryIssues := {}) + .inputSettings(addSbtPlugin("io.github.davidgregory084" %% "sbt-tpolecat" % "0.4.0")) + .outputConfigure(_.dependsOn(`sbt-tpolecat-plugin`)) diff --git a/project/ScalafixProjectPlugin.scala b/project/ScalafixProjectPlugin.scala index 6bbc6af..c794e5e 100644 --- a/project/ScalafixProjectPlugin.scala +++ b/project/ScalafixProjectPlugin.scala @@ -23,7 +23,7 @@ class ScalafixProject private ( lazy val componentProjects = Seq(all, rules, input, output, tests) - lazy val all = Project(name, file(s"target/$name-scalafix-aggregate")) + lazy val all = Project(s"$name-scalafix", file(s"target/$name-scalafix-aggregate")) .aggregate(rules, input, output, tests) .settings( publish := {}, @@ -86,7 +86,7 @@ class ScalafixProject private ( object ScalafixProject { def apply(name: String): ScalafixProject = { - lazy val rules = Project(s"$name-scalafix", file(s"scalafix/rules")) + lazy val rules = Project(s"$name-scalafix-rules", file(s"scalafix/rules")) .settings( moduleName := s"$name-scalafix", libraryDependencies += "ch.epfl.scala" %% "scalafix-core" % _root_.scalafix.sbt.BuildInfo.scalafixVersion diff --git a/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala b/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala index 51db844..0e53dea 100644 --- a/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala +++ b/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala @@ -3,8 +3,8 @@ package org.typelevel.fix import scalafix.v1._ import scala.meta._ -class v0_5 extends SemanticRule("v0_5") { - override def fix(implicit doc: SemanticDocument): Patch = +class v0_5 extends SyntacticRule("v0_5") { + override def fix(implicit doc: SyntacticDocument): Patch = doc.tree.collect { case Importer(ref , _) if ref.toString == "io.github.davidgregory084" => Patch.replaceTree(ref, "org.typelevel.sbt.tpolecat") From a94a366ffd7afca993ec1b21ac1c5f7572701bee Mon Sep 17 00:00:00 2001 From: David Gregory Date: Thu, 21 Jul 2022 16:41:04 +0100 Subject: [PATCH 4/4] Go back to previous input project dependency style --- build.sbt | 2 +- .../src/main/scala/org/typelevel/fix/v0_5.scala | 16 ++++++++++++++++ 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/build.sbt b/build.sbt index 2a9a8e3..f16fc3f 100644 --- a/build.sbt +++ b/build.sbt @@ -83,5 +83,5 @@ lazy val `sbt-tpolecat-plugin` = project lazy val `sbt-tpolecat-scalafix` = scalafixProject("sbt-tpolecat") // TODO: Re-enable mimaReportBinaryIssues once the scalafix project is published .rulesSettings(mimaReportBinaryIssues := {}) - .inputSettings(addSbtPlugin("io.github.davidgregory084" %% "sbt-tpolecat" % "0.4.0")) + .inputSettings(libraryDependencies += (`sbt-tpolecat-plugin` / projectID).value.withRevision("0.4.0")) .outputConfigure(_.dependsOn(`sbt-tpolecat-plugin`)) diff --git a/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala b/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala index 0e53dea..337fd58 100644 --- a/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala +++ b/scalafix/rules/src/main/scala/org/typelevel/fix/v0_5.scala @@ -1,3 +1,19 @@ +/* + * Copyright 2022 David Gregory + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + package org.typelevel.fix import scalafix.v1._