From bce023039d1dd240c24ce3e2b22362d6849d2ffa Mon Sep 17 00:00:00 2001 From: Ben Plommer Date: Fri, 15 Jul 2022 12:00:51 +0100 Subject: [PATCH 01/10] Expose versioning info in version plugin --- build.sbt | 2 +- .../typelevel/sbt/TypelevelSitePlugin.scala | 35 ++----------------- .../sbt/TypelevelVersioningPlugin.scala | 32 ++++++++++++++++- 3 files changed, 34 insertions(+), 35 deletions(-) diff --git a/build.sbt b/build.sbt index c6c624cf..81bc1eb4 100644 --- a/build.sbt +++ b/build.sbt @@ -184,7 +184,7 @@ lazy val site = project .settings( name := "sbt-typelevel-site" ) - .dependsOn(kernel, github, githubActions, noPublish) + .dependsOn(kernel, github, githubActions, versioning, noPublish) lazy val unidoc = project .in(file("unidoc")) diff --git a/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala b/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala index d3d8558a..baace341 100644 --- a/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala +++ b/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala @@ -26,8 +26,6 @@ import laika.helium.config.ImageLink import laika.sbt.LaikaPlugin import laika.theme.ThemeProvider import mdoc.MdocPlugin -import org.typelevel.sbt.kernel.GitHelper -import org.typelevel.sbt.kernel.V import org.typelevel.sbt.site._ import sbt._ @@ -39,6 +37,7 @@ import LaikaPlugin.autoImport._ import gha.GenerativePlugin import GenerativePlugin.autoImport._ import TypelevelKernelPlugin.autoImport._ +import TypelevelVersioningPlugin.autoImport._ object TypelevelSitePlugin extends AutoPlugin { @@ -77,7 +76,7 @@ object TypelevelSitePlugin extends AutoPlugin { import TypelevelGitHubPlugin._ override def requires = - MdocPlugin && LaikaPlugin && TypelevelGitHubPlugin && GenerativePlugin && NoPublishPlugin + MdocPlugin && LaikaPlugin && TypelevelGitHubPlugin && TypelevelVersioningPlugin && GenerativePlugin && NoPublishPlugin override def globalSettings = Seq( tlSiteApiModule := None @@ -250,36 +249,6 @@ object TypelevelSitePlugin extends AutoPlugin { ) ) - private lazy val currentRelease = Def.setting { - // some tricky logic here ... - // if the latest release is a pre-release (e.g., M or RC) - // and there are no stable releases it is bincompatible with, - // then for all effective purposes it is the current release - - val release = previousReleases.value match { - case head :: tail if head.isPrerelease => - tail - .filterNot(_.isPrerelease) - .find(head.copy(prerelease = None).mustBeBinCompatWith(_)) - .orElse(Some(head)) - case releases => releases.headOption - } - - release.map(_.toString) - } - - // latest tagged release, including pre-releases - private lazy val currentPreRelease = Def.setting { - previousReleases.value.headOption.map(_.toString) - } - - private lazy val previousReleases = Def.setting { - val currentVersion = V(version.value).map(_.copy(prerelease = None)) - GitHelper.previousReleases(fromHead = true, strict = false).filter { v => - currentVersion.forall(v.copy(prerelease = None) <= _) - } - } - private def previewTask = Def .taskDyn { // inlined from https://github.com/planet42/Laika/blob/9022f6f37c9017f7612fa59398f246c8e8c42c3e/sbt/src/main/scala/laika/sbt/Tasks.scala#L192 diff --git a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala index 6e17ee2e..057d3d9b 100644 --- a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala +++ b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala @@ -23,7 +23,6 @@ import org.typelevel.sbt.kernel.V import sbt._ import scala.util.Try - import Keys._ object TypelevelVersioningPlugin extends AutoPlugin { @@ -37,6 +36,37 @@ object TypelevelVersioningPlugin extends AutoPlugin { lazy val tlUntaggedAreSnapshots = settingKey[Boolean]( "If true, an untagged commit is given a snapshot version, e.g. 0.4-00218f9-SNAPSHOT. If false, it is given a release version, e.g. 0.4-00218f9. (default: true)") + + lazy val currentRelease = Def.setting { + // some tricky logic here ... + // if the latest release is a pre-release (e.g., M or RC) + // and there are no stable releases it is bincompatible with, + // then for all effective purposes it is the current release + + val release = previousReleases.value match { + case head :: tail if head.isPrerelease => + tail + .filterNot(_.isPrerelease) + .find(head.copy(prerelease = None).mustBeBinCompatWith(_)) + .orElse(Some(head)) + case releases => releases.headOption + } + + release.map(_.toString) + } + + // latest tagged release, including pre-releases + lazy val currentPreRelease = Def.setting { + previousReleases.value.headOption.map(_.toString) + } + + lazy val previousReleases = Def.setting { + val currentVersion = V(version.value).map(_.copy(prerelease = None)) + GitHelper.previousReleases(fromHead = true, strict = false).filter { v => + currentVersion.forall(v.copy(prerelease = None) <= _) + } + } + } import autoImport._ From defe6b33b3d0e563a800d1c46897edab6fe75d8e Mon Sep 17 00:00:00 2001 From: Ben Plommer Date: Fri, 15 Jul 2022 12:12:55 +0100 Subject: [PATCH 02/10] Remove dependency of site plugin on versioning plugin --- build.sbt | 2 +- .../typelevel/sbt/TypelevelKernelPlugin.scala | 36 +++++++++++++++++-- .../typelevel/sbt/TypelevelSitePlugin.scala | 7 ++-- .../sbt/TypelevelVersioningPlugin.scala | 32 +++-------------- 4 files changed, 41 insertions(+), 36 deletions(-) diff --git a/build.sbt b/build.sbt index 81bc1eb4..c6c624cf 100644 --- a/build.sbt +++ b/build.sbt @@ -184,7 +184,7 @@ lazy val site = project .settings( name := "sbt-typelevel-site" ) - .dependsOn(kernel, github, githubActions, versioning, noPublish) + .dependsOn(kernel, github, githubActions, noPublish) lazy val unidoc = project .in(file("unidoc")) diff --git a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala index dcec2960..96c96ec1 100644 --- a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala +++ b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala @@ -16,10 +16,10 @@ package org.typelevel.sbt -import sbt._ +import sbt.* import sbt.plugins.JvmPlugin - -import Keys._ +import Keys.* +import org.typelevel.sbt.kernel.{GitHelper, V} object TypelevelKernelPlugin extends AutoPlugin { @@ -37,6 +37,36 @@ object TypelevelKernelPlugin extends AutoPlugin { BasicCommands.addAlias(BasicCommands.removeAlias(s, name), name, contents) } }) + + private[sbt] lazy val currentReleaseImpl = Def.setting { + // some tricky logic here ... + // if the latest release is a pre-release (e.g., M or RC) + // and there are no stable releases it is bincompatible with, + // then for all effective purposes it is the current release + + val release = previousReleasesImpl.value match { + case head :: tail if head.isPrerelease => + tail + .filterNot(_.isPrerelease) + .find(head.copy(prerelease = None).mustBeBinCompatWith(_)) + .orElse(Some(head)) + case releases => releases.headOption + } + + release.map(_.toString) + } + + // latest tagged release, including pre-releases + private[sbt] lazy val currentPreReleaseImpl = Def.setting { + previousReleasesImpl.value.headOption.map(_.toString) + } + + private[sbt] lazy val previousReleasesImpl = Def.setting { + val currentVersion = V(version.value).map(_.copy(prerelease = None)) + GitHelper.previousReleases(fromHead = true, strict = false).filter { v => + currentVersion.forall(v.copy(prerelease = None) <= _) + } + } } import autoImport._ diff --git a/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala b/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala index baace341..1abfc761 100644 --- a/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala +++ b/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala @@ -37,7 +37,6 @@ import LaikaPlugin.autoImport._ import gha.GenerativePlugin import GenerativePlugin.autoImport._ import TypelevelKernelPlugin.autoImport._ -import TypelevelVersioningPlugin.autoImport._ object TypelevelSitePlugin extends AutoPlugin { @@ -110,8 +109,8 @@ object TypelevelSitePlugin extends AutoPlugin { mdocVariables := { mdocVariables.value ++ Map( - "VERSION" -> currentRelease.value.getOrElse(version.value), - "PRERELEASE_VERSION" -> currentPreRelease.value.getOrElse(version.value), + "VERSION" -> currentReleaseImpl.value.getOrElse(version.value), + "PRERELEASE_VERSION" -> currentPreReleaseImpl.value.getOrElse(version.value), "SNAPSHOT_VERSION" -> version.value ) ++ tlSiteApiUrl.value.map("API_URL" -> _.toString).toMap @@ -129,7 +128,7 @@ object TypelevelSitePlugin extends AutoPlugin { scalaVersion.value, scalaBinaryVersion.value ) - version <- currentRelease.value + version <- currentReleaseImpl.value } yield { val o = moduleId.organization val n = cross(moduleId.name) diff --git a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala index 057d3d9b..05dfb50d 100644 --- a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala +++ b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala @@ -24,6 +24,7 @@ import sbt._ import scala.util.Try import Keys._ +import org.typelevel.sbt.TypelevelKernelPlugin.autoImport._ object TypelevelVersioningPlugin extends AutoPlugin { @@ -37,36 +38,11 @@ object TypelevelVersioningPlugin extends AutoPlugin { settingKey[Boolean]( "If true, an untagged commit is given a snapshot version, e.g. 0.4-00218f9-SNAPSHOT. If false, it is given a release version, e.g. 0.4-00218f9. (default: true)") - lazy val currentRelease = Def.setting { - // some tricky logic here ... - // if the latest release is a pre-release (e.g., M or RC) - // and there are no stable releases it is bincompatible with, - // then for all effective purposes it is the current release - - val release = previousReleases.value match { - case head :: tail if head.isPrerelease => - tail - .filterNot(_.isPrerelease) - .find(head.copy(prerelease = None).mustBeBinCompatWith(_)) - .orElse(Some(head)) - case releases => releases.headOption - } - - release.map(_.toString) - } + lazy val currentRelease = currentReleaseImpl - // latest tagged release, including pre-releases - lazy val currentPreRelease = Def.setting { - previousReleases.value.headOption.map(_.toString) - } - - lazy val previousReleases = Def.setting { - val currentVersion = V(version.value).map(_.copy(prerelease = None)) - GitHelper.previousReleases(fromHead = true, strict = false).filter { v => - currentVersion.forall(v.copy(prerelease = None) <= _) - } - } + lazy val currentPreRelease = currentPreReleaseImpl + lazy val previousReleases = previousReleasesImpl } import autoImport._ From 9572683628884603eb9776e43a8b0113a26590bd Mon Sep 17 00:00:00 2001 From: Ben Plommer Date: Fri, 15 Jul 2022 12:13:54 +0100 Subject: [PATCH 03/10] Revert syntax changes --- .../main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala index 96c96ec1..88946645 100644 --- a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala +++ b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala @@ -16,9 +16,9 @@ package org.typelevel.sbt -import sbt.* +import sbt._ import sbt.plugins.JvmPlugin -import Keys.* +import Keys._ import org.typelevel.sbt.kernel.{GitHelper, V} object TypelevelKernelPlugin extends AutoPlugin { From 210a174435e8662536ab3614bb6104b075b685c8 Mon Sep 17 00:00:00 2001 From: Ben Plommer Date: Fri, 15 Jul 2022 12:14:45 +0100 Subject: [PATCH 04/10] Revert whitespace changes --- .../src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala | 1 + .../main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala | 1 + 2 files changed, 2 insertions(+) diff --git a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala index 88946645..a8c8ba9c 100644 --- a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala +++ b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala @@ -18,6 +18,7 @@ package org.typelevel.sbt import sbt._ import sbt.plugins.JvmPlugin + import Keys._ import org.typelevel.sbt.kernel.{GitHelper, V} diff --git a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala index 05dfb50d..a6f562b5 100644 --- a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala +++ b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala @@ -23,6 +23,7 @@ import org.typelevel.sbt.kernel.V import sbt._ import scala.util.Try + import Keys._ import org.typelevel.sbt.TypelevelKernelPlugin.autoImport._ From f23c6d2d88a47963a19aaae9274d69b1472fa051 Mon Sep 17 00:00:00 2001 From: Ben Plommer Date: Fri, 15 Jul 2022 12:25:41 +0100 Subject: [PATCH 05/10] Use setting keys for exposed settings --- .../org/typelevel/sbt/TypelevelKernelPlugin.scala | 10 +++++----- .../org/typelevel/sbt/TypelevelSitePlugin.scala | 6 +++--- .../typelevel/sbt/TypelevelVersioningPlugin.scala | 13 ++++++++----- 3 files changed, 16 insertions(+), 13 deletions(-) diff --git a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala index a8c8ba9c..6f927fce 100644 --- a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala +++ b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala @@ -39,13 +39,13 @@ object TypelevelKernelPlugin extends AutoPlugin { } }) - private[sbt] lazy val currentReleaseImpl = Def.setting { + 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) // and there are no stable releases it is bincompatible with, // then for all effective purposes it is the current release - val release = previousReleasesImpl.value match { + val release = previousReleases.value match { case head :: tail if head.isPrerelease => tail .filterNot(_.isPrerelease) @@ -58,11 +58,11 @@ object TypelevelKernelPlugin extends AutoPlugin { } // latest tagged release, including pre-releases - private[sbt] lazy val currentPreReleaseImpl = Def.setting { - previousReleasesImpl.value.headOption.map(_.toString) + private[sbt] lazy val currentPreRelease: Def.Initialize[Option[String]] = Def.setting { + previousReleases.value.headOption.map(_.toString) } - private[sbt] lazy val previousReleasesImpl = Def.setting { + private[sbt] lazy val previousReleases: Def.Initialize[List[V]] = Def.setting { val currentVersion = V(version.value).map(_.copy(prerelease = None)) GitHelper.previousReleases(fromHead = true, strict = false).filter { v => currentVersion.forall(v.copy(prerelease = None) <= _) diff --git a/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala b/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala index 1abfc761..77525a8e 100644 --- a/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala +++ b/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala @@ -109,8 +109,8 @@ object TypelevelSitePlugin extends AutoPlugin { mdocVariables := { mdocVariables.value ++ Map( - "VERSION" -> currentReleaseImpl.value.getOrElse(version.value), - "PRERELEASE_VERSION" -> currentPreReleaseImpl.value.getOrElse(version.value), + "VERSION" -> currentRelease.value.getOrElse(version.value), + "PRERELEASE_VERSION" -> currentPreRelease.value.getOrElse(version.value), "SNAPSHOT_VERSION" -> version.value ) ++ tlSiteApiUrl.value.map("API_URL" -> _.toString).toMap @@ -128,7 +128,7 @@ object TypelevelSitePlugin extends AutoPlugin { scalaVersion.value, scalaBinaryVersion.value ) - version <- currentReleaseImpl.value + version <- currentRelease.value } yield { val o = moduleId.organization val n = cross(moduleId.name) diff --git a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala index a6f562b5..61733324 100644 --- a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala +++ b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala @@ -39,11 +39,12 @@ object TypelevelVersioningPlugin extends AutoPlugin { settingKey[Boolean]( "If true, an untagged commit is given a snapshot version, e.g. 0.4-00218f9-SNAPSHOT. If false, it is given a release version, e.g. 0.4-00218f9. (default: true)") - lazy val currentRelease = currentReleaseImpl + lazy val tlCurrentRelease = + settingKey[Option[String]]( + "The latest stable released version of your project, e.g. 0.2.0, 3.5.1. If applicable, this will be the version currently being released.") - lazy val currentPreRelease = currentPreReleaseImpl - - lazy val previousReleases = previousReleasesImpl + lazy val tlCurrentPreRelease = settingKey[Option[String]]( + "The latest pre-release (e.g. milestone, release candidate) of your project. If applicable, this will be the version currently being released.") } import autoImport._ @@ -130,7 +131,9 @@ object TypelevelVersioningPlugin extends AutoPlugin { if (isSnapshot.value) version += "-SNAPSHOT" version - } + }, + tlCurrentRelease := currentRelease.value, + tlCurrentPreRelease := currentPreRelease.value ) private val Description = """^.*-(\d+)-[a-zA-Z0-9]+$""".r From 085bdd150d75f940098e71eafae1de64d6275c04 Mon Sep 17 00:00:00 2001 From: Ben Plommer Date: Fri, 15 Jul 2022 12:30:06 +0100 Subject: [PATCH 06/10] Update site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala --- site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala b/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala index 77525a8e..947af5b7 100644 --- a/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala +++ b/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala @@ -75,7 +75,7 @@ object TypelevelSitePlugin extends AutoPlugin { import TypelevelGitHubPlugin._ override def requires = - MdocPlugin && LaikaPlugin && TypelevelGitHubPlugin && TypelevelVersioningPlugin && GenerativePlugin && NoPublishPlugin + MdocPlugin && LaikaPlugin && TypelevelGitHubPlugin && GenerativePlugin && NoPublishPlugin override def globalSettings = Seq( tlSiteApiModule := None From c58d30b035de98c4583bf1976c698dd1c9783dcf Mon Sep 17 00:00:00 2001 From: Ben Plommer Date: Fri, 15 Jul 2022 12:55:51 +0100 Subject: [PATCH 07/10] scalafix --- .../main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala | 3 ++- .../scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala index 6f927fce..8677df56 100644 --- a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala +++ b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala @@ -16,11 +16,12 @@ package org.typelevel.sbt +import org.typelevel.sbt.kernel.GitHelper +import org.typelevel.sbt.kernel.V import sbt._ import sbt.plugins.JvmPlugin import Keys._ -import org.typelevel.sbt.kernel.{GitHelper, V} object TypelevelKernelPlugin extends AutoPlugin { diff --git a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala index 61733324..54a6c65e 100644 --- a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala +++ b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala @@ -18,6 +18,7 @@ package org.typelevel.sbt import com.typesafe.sbt.GitPlugin import com.typesafe.sbt.SbtGit.git +import org.typelevel.sbt.TypelevelKernelPlugin.autoImport._ import org.typelevel.sbt.kernel.GitHelper import org.typelevel.sbt.kernel.V import sbt._ @@ -25,7 +26,6 @@ import sbt._ import scala.util.Try import Keys._ -import org.typelevel.sbt.TypelevelKernelPlugin.autoImport._ object TypelevelVersioningPlugin extends AutoPlugin { From 48522186bb5561ad68a06bb2f2e0212ce822cd0c Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Fri, 15 Jul 2022 23:27:50 +0000 Subject: [PATCH 08/10] Bikeshed setting names, descriptions Co-authored-by: Ben Plommer --- .../typelevel/sbt/TypelevelVersioningPlugin.scala | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala index 54a6c65e..beb1b9bc 100644 --- a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala +++ b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala @@ -39,12 +39,11 @@ object TypelevelVersioningPlugin extends AutoPlugin { settingKey[Boolean]( "If true, an untagged commit is given a snapshot version, e.g. 0.4-00218f9-SNAPSHOT. If false, it is given a release version, e.g. 0.4-00218f9. (default: true)") - lazy val tlCurrentRelease = - settingKey[Option[String]]( - "The latest stable released version of your project, e.g. 0.2.0, 3.5.1. If applicable, this will be the version currently being released.") + lazy val tlLatestVersion = settingKey[Option[String]]( + "The latest tagged version that is binary-compatible with the version in this build. The latest stable version is given first priority, otherwise falls back to the latest pre-release version (e.g. milestones/release candidates). If applicable, this will be the current tagged version.") - lazy val tlCurrentPreRelease = settingKey[Option[String]]( - "The latest pre-release (e.g. milestone, release candidate) of your project. If applicable, this will be the version currently being released.") + lazy val tlLatestPreReleaseVersion = settingKey[Option[String]]( + "The latest tagged version, including milestones and release candidates, that is binary-compatible with the version in this build. If applicable, this will be the current tagged version.") } import autoImport._ @@ -132,8 +131,8 @@ object TypelevelVersioningPlugin extends AutoPlugin { version }, - tlCurrentRelease := currentRelease.value, - tlCurrentPreRelease := currentPreRelease.value + tlLatestVersion := currentRelease.value, + tlLatestPreReleaseVersion := currentPreRelease.value ) private val Description = """^.*-(\d+)-[a-zA-Z0-9]+$""".r From 4e2eb8e0a6a363b4a42e5ffbdbb783d31cc0c9f7 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Fri, 15 Jul 2022 23:37:14 +0000 Subject: [PATCH 09/10] Refactoring --- .../typelevel/sbt/TypelevelKernelPlugin.scala | 59 ++++++++++--------- .../typelevel/sbt/TypelevelSitePlugin.scala | 1 + .../sbt/TypelevelVersioningPlugin.scala | 2 +- 3 files changed, 32 insertions(+), 30 deletions(-) diff --git a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala index 8677df56..0d2961de 100644 --- a/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala +++ b/kernel/src/main/scala/org/typelevel/sbt/TypelevelKernelPlugin.scala @@ -40,35 +40,6 @@ object TypelevelKernelPlugin extends AutoPlugin { } }) - 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) - // and there are no stable releases it is bincompatible with, - // then for all effective purposes it is the current release - - val release = previousReleases.value match { - case head :: tail if head.isPrerelease => - tail - .filterNot(_.isPrerelease) - .find(head.copy(prerelease = None).mustBeBinCompatWith(_)) - .orElse(Some(head)) - case releases => releases.headOption - } - - release.map(_.toString) - } - - // latest tagged release, including pre-releases - private[sbt] lazy val currentPreRelease: Def.Initialize[Option[String]] = Def.setting { - previousReleases.value.headOption.map(_.toString) - } - - private[sbt] lazy val previousReleases: Def.Initialize[List[V]] = Def.setting { - val currentVersion = V(version.value).map(_.copy(prerelease = None)) - GitHelper.previousReleases(fromHead = true, strict = false).filter { v => - currentVersion.forall(v.copy(prerelease = None) <= _) - } - } } import autoImport._ @@ -115,4 +86,34 @@ object TypelevelKernelPlugin extends AutoPlugin { } } + 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) + // and there are no stable releases it is bincompatible with, + // then for all effective purposes it is the current release + + val release = previousReleases.value match { + case head :: tail if head.isPrerelease => + tail + .filterNot(_.isPrerelease) + .find(head.copy(prerelease = None).mustBeBinCompatWith(_)) + .orElse(Some(head)) + case releases => releases.headOption + } + + release.map(_.toString) + } + + // latest tagged release, including pre-releases + private[sbt] lazy val currentPreRelease: Def.Initialize[Option[String]] = Def.setting { + previousReleases.value.headOption.map(_.toString) + } + + private[this] lazy val previousReleases: Def.Initialize[List[V]] = Def.setting { + val currentVersion = V(version.value).map(_.copy(prerelease = None)) + GitHelper.previousReleases(fromHead = true, strict = false).filter { v => + currentVersion.forall(v.copy(prerelease = None) <= _) + } + } + } diff --git a/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala b/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala index 947af5b7..456922ab 100644 --- a/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala +++ b/site/src/main/scala/org/typelevel/sbt/TypelevelSitePlugin.scala @@ -36,6 +36,7 @@ import MdocPlugin.autoImport._ import LaikaPlugin.autoImport._ import gha.GenerativePlugin import GenerativePlugin.autoImport._ +import TypelevelKernelPlugin._ import TypelevelKernelPlugin.autoImport._ object TypelevelSitePlugin extends AutoPlugin { diff --git a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala index beb1b9bc..e8d77f28 100644 --- a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala +++ b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala @@ -18,7 +18,7 @@ package org.typelevel.sbt import com.typesafe.sbt.GitPlugin import com.typesafe.sbt.SbtGit.git -import org.typelevel.sbt.TypelevelKernelPlugin.autoImport._ +import org.typelevel.sbt.TypelevelKernelPlugin._ import org.typelevel.sbt.kernel.GitHelper import org.typelevel.sbt.kernel.V import sbt._ From 91d747dd95bc1ab065c6e3fd4e747796be45834e Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Sat, 16 Jul 2022 00:21:51 +0000 Subject: [PATCH 10/10] Another attempt to clarify --- .../scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala index e8d77f28..aeb13a55 100644 --- a/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala +++ b/versioning/src/main/scala/org/typelevel/sbt/TypelevelVersioningPlugin.scala @@ -40,10 +40,10 @@ object TypelevelVersioningPlugin extends AutoPlugin { "If true, an untagged commit is given a snapshot version, e.g. 0.4-00218f9-SNAPSHOT. If false, it is given a release version, e.g. 0.4-00218f9. (default: true)") lazy val tlLatestVersion = settingKey[Option[String]]( - "The latest tagged version that is binary-compatible with the version in this build. The latest stable version is given first priority, otherwise falls back to the latest pre-release version (e.g. milestones/release candidates). If applicable, this will be the current tagged version.") + "The latest tagged version on this branch. Priority is given to the latest stable version, but if you have tagged a binary-breaking prelease version (such as a milestone or release candidate), that will be selected instead. If applicable, this will be the current tagged version.") lazy val tlLatestPreReleaseVersion = settingKey[Option[String]]( - "The latest tagged version, including milestones and release candidates, that is binary-compatible with the version in this build. If applicable, this will be the current tagged version.") + "The latest tagged version on this branch, including milestones and release candidates. If applicable, this will be the current tagged version.") } import autoImport._