From 20f29c425733c8994400b333803e582215caf4fe Mon Sep 17 00:00:00 2001 From: Ivan Stanislavciuc Date: Thu, 14 Apr 2022 17:12:25 +0200 Subject: [PATCH 1/5] Introduce `tpolecatExcludeOptions` setting key and fix wrong addition of unwanted options to console task Fix test reference Fix test reference Fix test reference --- .../davidgregory084/ScalacOptions.scala | 8 +++++ .../davidgregory084/TpolecatPlugin.scala | 32 +++++++++-------- .../sbt-tpolecat/scalacOptions/build.sbt | 34 +++++++++++++++++++ src/sbt-test/sbt-tpolecat/scalacOptions/test | 8 +++++ 4 files changed, 68 insertions(+), 14 deletions(-) diff --git a/src/main/scala/io/github/davidgregory084/ScalacOptions.scala b/src/main/scala/io/github/davidgregory084/ScalacOptions.scala index 772e204..118021f 100644 --- a/src/main/scala/io/github/davidgregory084/ScalacOptions.scala +++ b/src/main/scala/io/github/davidgregory084/ScalacOptions.scala @@ -630,4 +630,12 @@ trait ScalacOptions { optimizerInline, optimizerInlineFrom(inlineFromPackages: _*) ) + + /** Default options to exclude in console tasks + */ + val defaultConsoleExclude: Set[ScalacOption] = privateWarnUnusedOptions ++ + warnUnusedOptions ++ + fatalWarningOptions + + privateWarnDeadCode + + warnDeadCode } diff --git a/src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala b/src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala index dd4b3dc..e7c31af 100644 --- a/src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala +++ b/src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala @@ -34,7 +34,7 @@ object TpolecatPlugin extends AutoPlugin { modeScalacOptions: Set[ScalacOption] ): Seq[String] = { val supportedOptions = (CrossVersion.partialVersion(version), version.split('.')) match { - case (Some((0, min)), _) => // dotty prereleases use 0 as major version + case (Some((0, _)), _) => // dotty prereleases use 0 as major version modeScalacOptions .filter(_.isSupported(V3_0_0)) // treat dotty prereleases as 3.0.0 case (Some((maj, min)), Array(maj2, min2, patch)) @@ -51,16 +51,6 @@ object TpolecatPlugin extends AutoPlugin { supportedOptions.toList.flatMap(_.tokens) } - val tpolecatConsoleOptionsFilter = { options: Set[ScalacOption] => - options.filterNot( - ScalacOptions.privateWarnUnusedOptions ++ - ScalacOptions.warnUnusedOptions ++ - ScalacOptions.fatalWarningOptions + - ScalacOptions.privateWarnDeadCode + - ScalacOptions.warnDeadCode - ) - } - val tpolecatDefaultOptionsMode = settingKey[OptionsMode]( "The default mode to use for configuring scalac options via the sbt-tpolecat plugin." ) @@ -96,6 +86,10 @@ object TpolecatPlugin extends AutoPlugin { val tpolecatScalacOptions = settingKey[Set[ScalacOption]]( "The set of scalac options that will be applied by the sbt-tpolecat plugin." ) + + val tpolecatExcludeOptions = settingKey[Set[ScalacOption]]( + "The set of scalac options that will be excluded." + ) } import autoImport._ @@ -129,7 +123,13 @@ object TpolecatPlugin extends AutoPlugin { override def projectSettings: Seq[Setting[_]] = Seq( Def.derive( - scalacOptions ++= scalacOptionsFor(scalaVersion.value, tpolecatScalacOptions.value) + scalacOptions := { + val previous = scalacOptions.value + val scalaV = scalaVersion.value + val filters = scalacOptionsFor(scalaV, tpolecatExcludeOptions.value).toSet + val newOptions = scalacOptionsFor(scalaV, tpolecatScalacOptions.value) + (previous ++ newOptions).filterNot(filters).distinct + } ), tpolecatDevModeOptions := ScalacOptions.default, Def.derive( @@ -145,7 +145,11 @@ object TpolecatPlugin extends AutoPlugin { case ReleaseMode => tpolecatReleaseModeOptions.value } }), - Compile / console / tpolecatScalacOptions ~= tpolecatConsoleOptionsFilter, - Test / console / tpolecatScalacOptions ~= tpolecatConsoleOptionsFilter + Compile / console / tpolecatExcludeOptions ++= ScalacOptions.defaultConsoleExclude, + Test / console / tpolecatExcludeOptions ++= ScalacOptions.defaultConsoleExclude + ) + + override def globalSettings: Seq[Def.Setting[_]] = Seq( + tpolecatExcludeOptions := Set.empty ) } diff --git a/src/sbt-test/sbt-tpolecat/scalacOptions/build.sbt b/src/sbt-test/sbt-tpolecat/scalacOptions/build.sbt index 9d05c05..fb38efe 100644 --- a/src/sbt-test/sbt-tpolecat/scalacOptions/build.sbt +++ b/src/sbt-test/sbt-tpolecat/scalacOptions/build.sbt @@ -244,3 +244,37 @@ TaskKey[Unit]("checkReleaseMode") := { assertEquals(actualOptions, expectedOptions) } + +TaskKey[Unit]("checkConsoleScalacOptions") := { + val shouldBeMissing = ScalacOptions.defaultConsoleExclude.flatMap(_.tokens).toSet + val testConsoleOptions = (Test / console / scalacOptions).value + val compileConsoleOptions = (Compile / console / scalacOptions).value + + testConsoleOptions.foreach { opt => + assert(!shouldBeMissing.contains(opt), s"$opt is not excluded from Test/console") + } + + compileConsoleOptions.foreach { opt => + assert(!shouldBeMissing.contains(opt), s"$opt is not excluded from Compile/console") + } +} + +addCommandAlias( + "addScalacOptionsToThisProject", + "set ThisProject / scalacOptions += \"non-existent-key\"" +) + +TaskKey[Unit]("checkThisProjectScalacOptions") := { + val options = (Compile / scalacOptions).value + assert(options.contains("non-existent-key"), "Scope ThisProject was ignored") +} + +addCommandAlias( + "addScalacOptionsToThisBuild", + "set ThisBuild / scalacOptions += \"non-existent-key-2\"" +) + +TaskKey[Unit]("checkThisBuildScalacOptions") := { + val options = (Compile / scalacOptions).value + assert(options.contains("non-existent-key-2"), "Scope ThisBuild was ignored") +} diff --git a/src/sbt-test/sbt-tpolecat/scalacOptions/test b/src/sbt-test/sbt-tpolecat/scalacOptions/test index 382df71..90a8e71 100644 --- a/src/sbt-test/sbt-tpolecat/scalacOptions/test +++ b/src/sbt-test/sbt-tpolecat/scalacOptions/test @@ -13,3 +13,11 @@ > tpolecatReleaseMode > +checkReleaseMode > +compile +# Check console options +> +checkConsoleScalacOptions +# Check ThisProject +> addScalacOptionsToThisProject +> +checkThisProjectScalacOptions +# Check ThisBuild (Ignored) +> addScalacOptionsToThisBuild +> +checkThisBuildScalacOptions From de569313910c4d9399d6191399879732255aa42a Mon Sep 17 00:00:00 2001 From: Ivan Stanislavciuc Date: Fri, 15 Apr 2022 10:42:00 +0200 Subject: [PATCH 2/5] Fix README.md --- .gitignore | 1 + README.md | 6 +++--- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/.gitignore b/.gitignore index 302f780..eed0d66 100644 --- a/.gitignore +++ b/.gitignore @@ -4,3 +4,4 @@ .vscode/ target/ metals.sbt +.idea/ diff --git a/README.md b/README.md index a3e201d..e504dd9 100644 --- a/README.md +++ b/README.md @@ -25,14 +25,14 @@ Instead you should modify the `tpolecatScalacOptions` key or the options key for ### Configuring the REPL -To filter out scala compiler options that don't work well in the REPL, use the `tpolecatConsoleOptionsFilter`. +To filter out scala compiler options that don't work well in the REPL, use the `tpolecatExcludeOptions`. -By default the plugin only applies this filter to the `console` task in the `Compile` and `Test` configurations. +By default, the plugin only applies this filter to the `console` task in the `Compile` and `Test` configurations. For example, to apply this filter to the `console` task in the `IntegrationTest` configuration you can do the following: ```scala -IntegrationTest / console / tpolecatScalacOptions ~= tpolecatConsoleOptionsFilter +IntegrationTest / console / tpolecatExcludeOptions ++= ScalacOptions.defaultConsoleExclude ``` ### Modes From 9f7cdafec730d231dd2308218bb89c95db56b913 Mon Sep 17 00:00:00 2001 From: Ivan Stanislavciuc Date: Fri, 15 Apr 2022 10:46:22 +0200 Subject: [PATCH 3/5] Remove ignored keyword --- src/sbt-test/sbt-tpolecat/scalacOptions/test | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/sbt-test/sbt-tpolecat/scalacOptions/test b/src/sbt-test/sbt-tpolecat/scalacOptions/test index 90a8e71..da44457 100644 --- a/src/sbt-test/sbt-tpolecat/scalacOptions/test +++ b/src/sbt-test/sbt-tpolecat/scalacOptions/test @@ -18,6 +18,6 @@ # Check ThisProject > addScalacOptionsToThisProject > +checkThisProjectScalacOptions -# Check ThisBuild (Ignored) +# Check ThisBuild > addScalacOptionsToThisBuild > +checkThisBuildScalacOptions From 930a4bbdfea1b48ce416e454280ce046dc1a15e8 Mon Sep 17 00:00:00 2001 From: Ivan Stanislavciuc Date: Fri, 22 Apr 2022 18:09:33 +0200 Subject: [PATCH 4/5] Move tpolecatDevModeOptions to build scope --- src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala b/src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala index e7c31af..f50833b 100644 --- a/src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala +++ b/src/main/scala/io/github/davidgregory084/TpolecatPlugin.scala @@ -118,7 +118,8 @@ object TpolecatPlugin extends AutoPlugin { else if (sys.env.contains(tpolecatCiModeEnvVar.value)) CiMode else if (sys.env.contains(tpolecatDevModeEnvVar.value)) DevMode else tpolecatDefaultOptionsMode.value - } + }, + tpolecatDevModeOptions := ScalacOptions.default ) ++ commandAliases override def projectSettings: Seq[Setting[_]] = Seq( @@ -131,7 +132,6 @@ object TpolecatPlugin extends AutoPlugin { (previous ++ newOptions).filterNot(filters).distinct } ), - tpolecatDevModeOptions := ScalacOptions.default, Def.derive( tpolecatCiModeOptions := tpolecatDevModeOptions.value + ScalacOptions.fatalWarnings ), From d245e641fc1b29e3200b4395ed3b93bc1d0cbd8b Mon Sep 17 00:00:00 2001 From: Ivan Stanislavciuc Date: Fri, 22 Apr 2022 18:10:38 +0200 Subject: [PATCH 5/5] Reset mimaPreviousArtifacts and mimaBinaryIssueFilters --- build.sbt | 62 ++----------------------------------------------------- 1 file changed, 2 insertions(+), 60 deletions(-) diff --git a/build.sbt b/build.sbt index 78ef041..9c25699 100644 --- a/build.sbt +++ b/build.sbt @@ -52,67 +52,9 @@ ThisBuild / scalafixDependencies += "com.github.liancheng" %% "organize-imports" ThisBuild / versionScheme := Some(VersionScheme.EarlySemVer) -mimaPreviousArtifacts := Set( - projectID.value.withRevision("0.2.0") -) +mimaPreviousArtifacts := Set.empty -mimaBinaryIssueFilters ++= Seq( - // New ScalacOptions DSL methods - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.source210" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.source211" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.source212" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.source213" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.source3" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.sourceFuture" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.sourceFutureMigration" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.source3Migration" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.source31" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.io$github$davidgregory084$ScalacOptions$_setter_$source210_=" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.io$github$davidgregory084$ScalacOptions$_setter_$source211_=" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.io$github$davidgregory084$ScalacOptions$_setter_$source212_=" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.io$github$davidgregory084$ScalacOptions$_setter_$source213_=" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.io$github$davidgregory084$ScalacOptions$_setter_$source3_=" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.io$github$davidgregory084$ScalacOptions$_setter_$sourceFuture_=" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.io$github$davidgregory084$ScalacOptions$_setter_$sourceFutureMigration_=" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.io$github$davidgregory084$ScalacOptions$_setter_$source3Migration_=" - ), - ProblemFilters.exclude[ReversedMissingMethodProblem]( - "io.github.davidgregory084.ScalacOptions.io$github$davidgregory084$ScalacOptions$_setter_$source31_=" - ) -) +mimaBinaryIssueFilters ++= Seq() // Testing