org.jetbrains.kotlin.build.BuildMetaInfo.kt Maven / Gradle / Ivy
/*
* Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.
* Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.
*/
package org.jetbrains.kotlin.build
import org.jetbrains.kotlin.cli.common.arguments.CommonCompilerArguments
import org.jetbrains.kotlin.config.*
abstract class BuildMetaInfo {
enum class CustomKeys {
LANGUAGE_VERSION_STRING, IS_EAP, METADATA_VERSION_STRING, PLUGIN_CLASSPATHS, API_VERSION_STRING
}
fun obtainReasonForRebuild(currentCompilerArgumentsMap: Map, previousCompilerArgsMap: Map): String? {
if (currentCompilerArgumentsMap.keys != previousCompilerArgsMap.keys) {
return "Compiler arguments version was changed"
}
val changedCompilerArguments = currentCompilerArgumentsMap.mapNotNull {
val key = it.key
val previousValue = previousCompilerArgsMap[it.key] ?: return@mapNotNull key
val currentValue = it.value
return@mapNotNull if (compareIsChanged(key, currentValue, previousValue)) key else null
}
if (changedCompilerArguments.isNotEmpty()) {
val rebuildReason = when (changedCompilerArguments.size) {
1 -> "One of compiler arguments was changed: "
else -> "Some compiler arguments were changed: "
} + changedCompilerArguments.joinToReadableString()
return rebuildReason
}
return null
}
private fun compareIsChanged(key: String, currentValue: String, previousValue: String): Boolean {
// check for specific key changes
checkIfPlatformSpecificCompilerArgumentWasChanged(key, currentValue, previousValue)?.let { comparisonResult ->
return comparisonResult
}
when (key) {
CustomKeys.LANGUAGE_VERSION_STRING.name ->
return LanguageVersion.fromVersionString(currentValue) != LanguageVersion.fromVersionString(previousValue)
CustomKeys.API_VERSION_STRING.name -> return ApiVersion.parse(currentValue) != ApiVersion.parse(previousValue)
CustomKeys.PLUGIN_CLASSPATHS.name -> return !PluginClasspathComparator(previousValue, currentValue).equals()
}
// check keys that are sensitive for true -> false change
if (key in argumentsListForSpecialCheck) {
return previousValue == "true" && currentValue != "true"
}
// compare all other change-sensitive values
if (previousValue != currentValue) {
return true
}
return false
}
open fun checkIfPlatformSpecificCompilerArgumentWasChanged(key: String, currentValue: String, previousValue: String): Boolean? {
return null
}
open fun createPropertiesMapFromCompilerArguments(args: CommonCompilerArguments): Map {
val resultMap = transformClassToPropertiesMap(args, excludedProperties).toMutableMap()
val languageVersion = args.languageVersion?.let { LanguageVersion.fromVersionString(it) }
?: LanguageVersion.LATEST_STABLE
val languageVersionSting = languageVersion.versionString
resultMap[CustomKeys.LANGUAGE_VERSION_STRING.name] = languageVersionSting
val isEAP = languageVersion.isPreRelease()
resultMap[CustomKeys.IS_EAP.name] = isEAP.toString()
val apiVersionString = args.apiVersion ?: languageVersionSting
resultMap[CustomKeys.API_VERSION_STRING.name] = apiVersionString
val pluginClasspath = PluginClasspath(args.pluginClasspaths).serialize()
resultMap[CustomKeys.PLUGIN_CLASSPATHS.name] = pluginClasspath
return resultMap
}
fun deserializeMapFromString(inputString: String): Map = inputString
.split("\n")
.filter(String::isNotBlank)
.associate { it.substringBefore("=") to it.substringAfter("=") }
private fun serializeMapToString(myList: Map) = myList.map { "${it.key}=${it.value}" }.joinToString("\n")
fun serializeArgsToString(args: CommonCompilerArguments) = serializeMapToString(createPropertiesMapFromCompilerArguments(args))
open val excludedProperties = listOf(
"languageVersion",
"apiVersion",
"pluginClasspaths",
"metadataVersion",
"dumpDirectory",
"dumpOnlyFqName",
"dumpPerf",
"errors",
"extraHelp",
"freeArgs",
"help",
"intellijPluginRoot",
"kotlinHome",
"listPhases",
"phasesToDump",
"phasesToDumpAfter",
"phasesToDumpBefore",
"profilePhases",
"renderInternalDiagnosticNames",
"reportOutputFiles",
"reportPerf",
"script",
"verbose",
"verbosePhases",
"version"
)
open val argumentsListForSpecialCheck = listOf(
"allowAnyScriptsInSourceRoots",
"allowKotlinPackage",
"allowResultReturnType",
"noCheckActual",
"skipMetadataVersionCheck",
"skipPrereleaseCheck",
"suppressVersionWarnings",
"suppressWarnings",
CustomKeys.IS_EAP.name
)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy