pekko/project/Jdk9.scala

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

96 lines
4 KiB
Scala
Raw Permalink Normal View History

/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* license agreements; and to You under the Apache License, version 2.0:
*
* https://www.apache.org/licenses/LICENSE-2.0
*
2023-06-22 14:19:26 +01:00
* This file is part of the Apache Pekko project, which was derived from Akka.
*/
/*
2022-02-04 12:36:44 +01:00
* Copyright (C) 2017-2022 Lightbend Inc. <https://www.lightbend.com>
*/
import sbt.Keys._
import sbt._
object Jdk9 extends AutoPlugin {
import JdkOptions.JavaVersion._
// The version 21 is special for any Java versions >= 21
private val supportedJavaLTSVersions = List("21")
2024-01-22 07:15:16 +01:00
lazy val CompileJdk9 = config("CompileJdk9").extend(Compile)
2024-01-22 07:15:16 +01:00
lazy val TestJdk9 = config("TestJdk9").extend(Test).extend(CompileJdk9)
lazy val ScalaSourceDirectories: Seq[String] = getAdditionalSourceDirectoryNames("scala")
lazy val ScalaTestSourceDirectories: Seq[String] = getAdditionalSourceDirectoryNames("scala", isTest = true)
lazy val JavaSourceDirectories: Seq[String] = getAdditionalSourceDirectoryNames("java")
lazy val JavaTestSourceDirectories: Seq[String] = getAdditionalSourceDirectoryNames("java", isTest = true)
lazy val additionalSourceDirectories =
getAdditionalSourceDirectories(Compile, ScalaSourceDirectories ++ JavaSourceDirectories)
lazy val additionalTestSourceDirectories =
getAdditionalSourceDirectories(Test, ScalaTestSourceDirectories ++ JavaTestSourceDirectories)
private def getAdditionalSourceDirectoryNames(language: String, isTest: Boolean = false): Seq[String] = {
for {
version <- supportedJavaLTSVersions if version.toInt <= majorVersion
} yield {
if (isTest) {
s"$language-jdk$version-only"
} else {
s"$language-jdk-$version"
}
}
}
private def getAdditionalSourceDirectories(task: Configuration, sourceDirectoryNames: Seq[String]) = Def.setting {
for (sourceDirectoryName <- sourceDirectoryNames)
yield (task / sourceDirectory).value / sourceDirectoryName
}
2024-01-22 07:15:16 +01:00
lazy val compileJdk9Settings = Seq(
// following the scala-2.12, scala-sbt-1.0, ... convention
unmanagedSourceDirectories := additionalSourceDirectories.value,
scalacOptions := PekkoBuild.DefaultScalacOptions.value ++ Seq("-release", majorVersion.toString),
javacOptions := PekkoBuild.DefaultJavacOptions ++ Seq("--release", majorVersion.toString))
2024-01-22 07:15:16 +01:00
lazy val testJdk9Settings = Seq(
// following the scala-2.12, scala-sbt-1.0, ... convention
unmanagedSourceDirectories := additionalTestSourceDirectories.value,
scalacOptions := PekkoBuild.DefaultScalacOptions.value ++ Seq("-release", majorVersion.toString),
javacOptions := PekkoBuild.DefaultJavacOptions ++ Seq("--release", majorVersion.toString),
compile := compile.dependsOn(CompileJdk9 / compile).value,
classpathConfiguration := TestJdk9,
externalDependencyClasspath := (Test / externalDependencyClasspath).value)
2024-01-22 07:15:16 +01:00
lazy val compileSettings = Seq(
// It might have been more 'neat' to add the jdk9 products to the jar via packageBin/mappings, but that doesn't work with the OSGi plugin,
// so we add them to the fullClasspath instead.
// Compile / packageBin / mappings
// ++= (CompileJdk9 / products).value.flatMap(Path.allSubpaths),
2024-01-26 10:28:09 +08:00
// Since sbt-osgi upgrade to 0.9.5, the fullClasspath is no longer used on packaging when use sbt-osgi, so we have to
2024-01-26 10:15:24 +08:00
// add jdk9 products to dependencyClasspathAsJars instead.
// Compile / fullClasspath ++= (CompileJdk9 / exportedProducts).value)
Compile / dependencyClasspathAsJars ++= (CompileJdk9 / exportedProducts).value)
2024-01-22 07:15:16 +01:00
lazy val testSettings = Seq((Test / test) := {
(Test / test).value
(TestJdk9 / test).value
})
2024-01-22 07:15:16 +01:00
override lazy val trigger = noTrigger
override lazy val projectConfigurations = Seq(CompileJdk9)
override lazy val projectSettings =
inConfig(CompileJdk9)(Defaults.compileSettings) ++
inConfig(CompileJdk9)(compileJdk9Settings) ++
compileSettings ++
inConfig(TestJdk9)(Defaults.testSettings) ++
inConfig(TestJdk9)(testJdk9Settings) ++
testSettings
}