From 3fe4ae7dcf7074e64884ade0f256492b97317380 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Thu, 16 May 2024 03:27:10 +0000 Subject: [PATCH 1/2] Support checking Java formatting --- .../org/typelevel/sbt/TypelevelCiPlugin.scala | 53 ++++++++++--------- docs/customization.md | 1 + 2 files changed, 29 insertions(+), 25 deletions(-) diff --git a/ci/src/main/scala/org/typelevel/sbt/TypelevelCiPlugin.scala b/ci/src/main/scala/org/typelevel/sbt/TypelevelCiPlugin.scala index 25732a03..d4ba79d6 100644 --- a/ci/src/main/scala/org/typelevel/sbt/TypelevelCiPlugin.scala +++ b/ci/src/main/scala/org/typelevel/sbt/TypelevelCiPlugin.scala @@ -37,6 +37,8 @@ object TypelevelCiPlugin extends AutoPlugin { settingKey[Boolean]("Whether to do header check in CI (default: false)") lazy val tlCiScalafmtCheck = settingKey[Boolean]("Whether to do scalafmt check in CI (default: false)") + lazy val tlCiJavafmtCheck = + settingKey[Boolean]("Whether to do javafmt check in CI (default: false)") lazy val tlCiScalafixCheck = settingKey[Boolean]("Whether to do scalafix check in CI (default: false)") lazy val tlCiMimaBinaryIssueCheck = @@ -57,6 +59,7 @@ object TypelevelCiPlugin extends AutoPlugin { override def buildSettings = Seq( tlCiHeaderCheck := false, tlCiScalafmtCheck := false, + tlCiJavafmtCheck := false, tlCiScalafixCheck := false, tlCiMimaBinaryIssueCheck := false, tlCiDocCheck := false, @@ -68,32 +71,32 @@ object TypelevelCiPlugin extends AutoPlugin { githubWorkflowPublishTargetBranches := Seq(), githubWorkflowBuild := { - val style = (tlCiHeaderCheck.value, tlCiScalafmtCheck.value) match { - case (true, true) => // headers + formatting - List( - WorkflowStep.Sbt( - List("headerCheckAll", "scalafmtCheckAll", "project /", "scalafmtSbtCheck"), - name = Some("Check headers and formatting"), - cond = Some(primaryAxisCond.value) - ) - ) - case (true, false) => // headers - List( - WorkflowStep.Sbt( - List("headerCheckAll"), - name = Some("Check headers"), - cond = Some(primaryAxisCond.value) - ) - ) - case (false, true) => // formatting - List( - WorkflowStep.Sbt( - List("scalafmtCheckAll", "project /", "scalafmtSbtCheck"), - name = Some("Check formatting"), - cond = Some(primaryAxisCond.value) - ) + val style = { + val headers = List("headerCheckAll").filter(_ => tlCiHeaderCheck.value) + + val scalafmt = List( + "scalafmtCheckAll", + "project /", + "scalafmtSbtCheck" + ).filter(_ => tlCiScalafmtCheck.value) + + val javafmt = List("javafmtCheckAll").filter(_ => tlCiJavafmtCheck.value) + + val formatting = javafmt ++ scalafmt + + val headersFormatting = headers ++ formatting + + val names = + List("headers").filter(_ => headers.nonEmpty) ++ List("formatting").filter(_ => + formatting.nonEmpty) + + List( + WorkflowStep.Sbt( + headers ++ formatting, + name = Some(s"Check ${names.mkString(" and ")}"), + cond = Some(primaryAxisCond.value) ) - case (false, false) => Nil // nada + ).filter(_ => headersFormatting.nonEmpty) } val test = List( diff --git a/docs/customization.md b/docs/customization.md index 2eac19b9..952bcd62 100644 --- a/docs/customization.md +++ b/docs/customization.md @@ -62,6 +62,7 @@ Both plugins are documented in [**sbt-typelevel-github-actions**](gha.md). - `tlCiHeaderCheck` (setting): Whether to do header check in CI (default: `false`). - `tlCiScalafmtCheck` (setting): Whether to do scalafmt check in CI (default: `false`). +- `tlCiJavafmtCheck` (setting): Whether to do javafmt check in CI (default: `false`). - `tlCiScalafixCheck` (setting): Whether to do scalafix check in CI (default: `false`). - `tlCiMimaBinaryIssueCheck` (setting): Whether to do MiMa binary issues check in CI (default: `false`). - `tlCiDocCheck` (setting): Whether to build API docs in CI (default: `false`). From 7754484af2cfa7a8503af7a4220c24be9bf3a5e1 Mon Sep 17 00:00:00 2001 From: Arman Bilge Date: Thu, 16 May 2024 20:25:49 +0000 Subject: [PATCH 2/2] Add `javafmtAll` to `prePR` --- core/src/main/scala/org/typelevel/sbt/TypelevelPlugin.scala | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/core/src/main/scala/org/typelevel/sbt/TypelevelPlugin.scala b/core/src/main/scala/org/typelevel/sbt/TypelevelPlugin.scala index dc69871b..72f5421b 100644 --- a/core/src/main/scala/org/typelevel/sbt/TypelevelPlugin.scala +++ b/core/src/main/scala/org/typelevel/sbt/TypelevelPlugin.scala @@ -79,12 +79,14 @@ object TypelevelPlugin extends AutoPlugin { GlobalScope / tlCommandAliases ++= { val header = tlCiHeaderCheck.value val scalafmt = tlCiScalafmtCheck.value + val javafmt = tlCiJavafmtCheck.value val scalafix = tlCiScalafixCheck.value val prePR = List("project /", "githubWorkflowGenerate") ++ List("+headerCreateAll").filter(_ => header) ++ List("+scalafixAll").filter(_ => scalafix) ++ - List("+scalafmtAll", "scalafmtSbt").filter(_ => scalafmt) + List("+scalafmtAll", "scalafmtSbt").filter(_ => scalafmt) ++ + List("javafmtAll").filter(_ => javafmt) val botHook = List("githubWorkflowGenerate") ++ List("+headerCreateAll").filter(_ => header) ++