From dd6637e332fcc2dc27a3c4387a78a21f8bd5de1c Mon Sep 17 00:00:00 2001 From: Tomasz Godzik Date: Thu, 12 Oct 2023 12:25:18 +0200 Subject: [PATCH] refactor: Extract adjustScalacReleaseOptions method --- backend/src/main/scala/bloop/Compiler.scala | 55 ++++++++++++++------- 1 file changed, 37 insertions(+), 18 deletions(-) diff --git a/backend/src/main/scala/bloop/Compiler.scala b/backend/src/main/scala/bloop/Compiler.scala index b15db508cd..03f643e8c6 100644 --- a/backend/src/main/scala/bloop/Compiler.scala +++ b/backend/src/main/scala/bloop/Compiler.scala @@ -604,54 +604,73 @@ object Compiler { } } - private def getCompilationOptions( - inputs: CompileInputs, - logger: Logger, - newClassesDir: Path - ): CompileOptions = { - // Sources are all files - val sources = inputs.sources.map(path => converter.toVirtualFile(path.underlying)) - val classpath = inputs.classpath.map(path => converter.toVirtualFile(path.underlying)) - def existsReleaseSetting = inputs.scalacOptions.exists(opt => + /** + * Bloop runs Scala compilation in the same process as the main server, + * so the compilation process will use the same JDK that Bloop is using. + * That's why we must ensure that produce class files will be compliant with expected JDK version + * and compilation errors will show up when using wrong JDK API. + */ + private def adjustScalacReleaseOptions( + scalacOptions: Array[String], + javacBin: Option[AbsolutePath], + logger: Logger + ): Array[String] = { + def existsReleaseSetting = scalacOptions.exists(opt => opt.startsWith("-release") || opt.startsWith("--release") || opt.startsWith("-java-output-version") ) - def sameHome = inputs.javacBin match { + def sameHome = javacBin match { case Some(bin) => bin.getParent.getParent == JavaRuntime.home case None => false } - val scalacOptions = inputs.javacBin.flatMap(binary => + javacBin.flatMap(binary => // /bin/java JavaRuntime.getJavaVersionFromJavaHome(binary.getParent.getParent) ) match { - case None => inputs.scalacOptions - case Some(_) if existsReleaseSetting || sameHome => inputs.scalacOptions + case None => scalacOptions + case Some(_) if existsReleaseSetting || sameHome => scalacOptions case Some(version) => try { val numVer = if (version.startsWith("1.8")) 8 else version.takeWhile(_.isDigit).toInt val bloopNumVer = JavaRuntime.version.takeWhile(_.isDigit).toInt if (bloopNumVer > numVer) { - inputs.scalacOptions ++ List("-release", numVer.toString()) + scalacOptions ++ List("-release", numVer.toString()) } else { logger.warn( s"Bloop is runing with ${JavaRuntime.version} but your code requires $version to compile, " + "this might cause some compilation issues when using JDK API unsupported by the Bloop's current JVM version" ) - inputs.scalacOptions + scalacOptions } } catch { case NonFatal(_) => - inputs.scalacOptions + scalacOptions } } + } + + private def getCompilationOptions( + inputs: CompileInputs, + logger: Logger, + newClassesDir: Path + ): CompileOptions = { + // Sources are all files + val sources = inputs.sources.map(path => converter.toVirtualFile(path.underlying)) + val classpath = inputs.classpath.map(path => converter.toVirtualFile(path.underlying)) + + val scalacOptions = adjustScalacReleaseOptions( + scalacOptions = inputs.scalacOptions, + javacBin = inputs.javacBin, + logger = logger + ) val optionsWithoutFatalWarnings = scalacOptions.filter(_ != "-Xfatal-warnings") - val isFatalWarningsEnabled = scalacOptions.length != optionsWithoutFatalWarnings.length + val areFatalWarningsEnabled = scalacOptions.length != optionsWithoutFatalWarnings.length // Enable fatal warnings in the reporter if they are enabled in the build - if (isFatalWarningsEnabled) + if (areFatalWarningsEnabled) inputs.reporter.enableFatalWarnings() CompileOptions