From be3adfe4c4d9c5d795a1793ddcc293dc341a3cf2 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Sat, 1 Jul 2023 19:30:22 +0000 Subject: [PATCH 1/3] Deprecate `tlSkipIrrelevantScalas` --- .../org/typelevel/sbt/CrossRootProject.scala | 4 +- docs/customization.md | 1 - .../typelevel/sbt/TypelevelKernelPlugin.scala | 38 +++---------------- .../typelevel/sbt/TypelevelMimaPlugin.scala | 5 +-- 4 files changed, 10 insertions(+), 38 deletions(-) diff --git a/ci/src/main/scala/org/typelevel/sbt/CrossRootProject.scala b/ci/src/main/scala/org/typelevel/sbt/CrossRootProject.scala index 5fc94810..f9981038 100644 --- a/ci/src/main/scala/org/typelevel/sbt/CrossRootProject.scala +++ b/ci/src/main/scala/org/typelevel/sbt/CrossRootProject.scala @@ -18,6 +18,7 @@ package org.typelevel.sbt import org.typelevel.sbt.gha.GenerativePlugin.autoImport._ import sbt._ +import Keys._ /** * Simultaneously creates a root project, a Scala JVM aggregate project, a Scala.js aggregate @@ -132,7 +133,8 @@ object CrossRootProject { Some((rootProject.all, rootProject.jvm, rootProject.js, rootProject.native)) def apply(id: String): CrossRootProject = new CrossRootProject( - Project(id, file(".")), + Project(id, file(".")) + .settings(crossScalaVersions := Nil, scalaVersion := (ThisBuild / scalaVersion).value), Project(s"${id}JVM", file(".jvm")), Project(s"${id}JS", file(".js")), Project(s"${id}Native", file(".native")) diff --git a/docs/customization.md b/docs/customization.md index 69b4c264..6a8e512f 100644 --- a/docs/customization.md +++ b/docs/customization.md @@ -13,7 +13,6 @@ Instead of using the super-plugins, for finer-grained control you can always add `TypelevelKernelPlugin` - `tlIsScala3` (setting): `true`, if `scalaVersion` is 3.x. -- `tlSkipIrrelevantScalas` (setting): `true`, if should `skip` for `scalaVersion` not in `crossScalaVersions`. - `tlReplaceCommandAlias` (method): Replace a `addCommandAlias` definition. - `tlReleaseLocal` (command): Alias for `+publishLocal`. diff --git a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala index 93028a36..7380aa77 100644 --- a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala +++ b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala @@ -32,6 +32,10 @@ object TypelevelKernelPlugin extends AutoPlugin { lazy val CompileTime: Configuration = config("compile-time").hide lazy val tlIsScala3 = settingKey[Boolean]("True if building with Scala 3") + + @deprecated( + "No longer has an effect. Use tlCrossRootProject for your root project.", + "0.5.0") lazy val tlSkipIrrelevantScalas = settingKey[Boolean]( "Sets skip := true for compile/test/publish/etc. tasks on a project if the current scalaVersion is not in that project's crossScalaVersions (default: false)") @@ -51,45 +55,15 @@ object TypelevelKernelPlugin extends AutoPlugin { ) override def buildSettings = - Seq(tlSkipIrrelevantScalas := false) ++ - addCommandAlias("tlReleaseLocal", mkCommand(List("reload", "project /", "+publishLocal"))) + addCommandAlias("tlReleaseLocal", mkCommand(List("reload", "project /", "+publishLocal"))) override def projectSettings = Seq( ivyConfigurations += CompileTime, - Compile / unmanagedClasspath ++= update.value.select(configurationFilter(CompileTime.name)), - (Test / test) := { - if (tlSkipIrrelevantScalas.value && (Test / test / skip).value) - () - else (Test / test).value - }, - (Compile / doc) := { - if (tlSkipIrrelevantScalas.value && (Compile / doc / skip).value) - (Compile / doc / target).value - else (Compile / doc).value - }, - skipIfIrrelevant(compile), - skipIfIrrelevant(test), - skipIfIrrelevant(doc), - skipIfIrrelevant(publishLocal), - skipIfIrrelevant(publish) + Compile / unmanagedClasspath ++= update.value.select(configurationFilter(CompileTime.name)) ) private[sbt] def mkCommand(commands: List[String]): String = commands.mkString("; ", "; ", "") - /** - * A setting that will make a task respect the `tlSkipIrrelevantScalas` setting. Note that the - * task itself must respect `skip` for this to take effect. - */ - def skipIfIrrelevant[T](task: TaskKey[T]) = { - task / skip := { - (task / skip).value || { - val cross = crossScalaVersions.value - val ver = (LocalRootProject / scalaVersion).value - (task / tlSkipIrrelevantScalas).value && !cross.contains(ver) - } - } - } - private[sbt] lazy val currentRelease: Def.Initialize[Option[String]] = Def.setting { // some tricky logic here ... // if the latest release is a pre-release (e.g., M or RC) diff --git a/mima/src/main/scala/org/typelevel/sbt/TypelevelMimaPlugin.scala b/mima/src/main/scala/org/typelevel/sbt/TypelevelMimaPlugin.scala index e85f6c63..86087346 100644 --- a/mima/src/main/scala/org/typelevel/sbt/TypelevelMimaPlugin.scala +++ b/mima/src/main/scala/org/typelevel/sbt/TypelevelMimaPlugin.scala @@ -40,7 +40,6 @@ object TypelevelMimaPlugin extends AutoPlugin { import autoImport._ import TypelevelKernelPlugin.autoImport._ - import TypelevelKernelPlugin.skipIfIrrelevant override def buildSettings = Seq[Setting[_]]( tlVersionIntroduced := Map.empty, @@ -65,11 +64,9 @@ object TypelevelMimaPlugin extends AutoPlugin { override def projectSettings = Seq[Setting[_]]( mimaReportBinaryIssues := { - if (!publishArtifact.value || (tlSkipIrrelevantScalas.value && (mimaReportBinaryIssues / skip).value)) - () + if (!publishArtifact.value) () else mimaReportBinaryIssues.value }, - skipIfIrrelevant(mimaReportBinaryIssues), tlMimaPreviousVersions := { val introduced = tlVersionIntroduced .value From 89593e5ca8ce0ee5027fa5a2cbfaf62d3f2d9867 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Sat, 1 Jul 2023 19:42:06 +0000 Subject: [PATCH 2/3] Unused import --- mima/src/main/scala/org/typelevel/sbt/TypelevelMimaPlugin.scala | 1 - 1 file changed, 1 deletion(-) diff --git a/mima/src/main/scala/org/typelevel/sbt/TypelevelMimaPlugin.scala b/mima/src/main/scala/org/typelevel/sbt/TypelevelMimaPlugin.scala index 86087346..82fa26b2 100644 --- a/mima/src/main/scala/org/typelevel/sbt/TypelevelMimaPlugin.scala +++ b/mima/src/main/scala/org/typelevel/sbt/TypelevelMimaPlugin.scala @@ -39,7 +39,6 @@ object TypelevelMimaPlugin extends AutoPlugin { } import autoImport._ - import TypelevelKernelPlugin.autoImport._ override def buildSettings = Seq[Setting[_]]( tlVersionIntroduced := Map.empty, From f1c5423939e4d1d2904ce5cff8bdb39290e66c33 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Sat, 1 Jul 2023 19:49:47 +0000 Subject: [PATCH 3/3] organize imports --- ci/src/main/scala/org/typelevel/sbt/CrossRootProject.scala | 1 + 1 file changed, 1 insertion(+) diff --git a/ci/src/main/scala/org/typelevel/sbt/CrossRootProject.scala b/ci/src/main/scala/org/typelevel/sbt/CrossRootProject.scala index f9981038..063527e7 100644 --- a/ci/src/main/scala/org/typelevel/sbt/CrossRootProject.scala +++ b/ci/src/main/scala/org/typelevel/sbt/CrossRootProject.scala @@ -18,6 +18,7 @@ package org.typelevel.sbt import org.typelevel.sbt.gha.GenerativePlugin.autoImport._ import sbt._ + import Keys._ /**