2020-03-09 16:44:40 +03:00
|
|
|
import sbt._
|
2020-07-10 13:57:42 +03:00
|
|
|
import sbt.internal.util.ManagedLogger
|
2020-03-09 16:44:40 +03:00
|
|
|
|
|
|
|
import scala.sys.process._
|
|
|
|
|
|
|
|
object BuildInfo {
|
2020-09-09 16:37:26 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Writes build-time information to a Scala object that can be used by the
|
|
|
|
* components.
|
|
|
|
*
|
|
|
|
* If the `ENSO_RELEASE_MODE` environment variable is set to `true`, will set
|
|
|
|
* an `isRelease` flag to true. This flag can be used to disable
|
|
|
|
* development-specific features.
|
|
|
|
*
|
|
|
|
* @param file location where to write the Scala code
|
|
|
|
* @param log a logger instance for diagnostics
|
|
|
|
* @param ensoVersion Enso version
|
|
|
|
* @param scalacVersion Scala compiler version used in the project
|
|
|
|
* @param graalVersion GraalVM version used in the project
|
|
|
|
* @return sequence of modified files
|
|
|
|
*/
|
2020-03-09 16:44:40 +03:00
|
|
|
def writeBuildInfoFile(
|
|
|
|
file: File,
|
2020-07-10 13:57:42 +03:00
|
|
|
log: ManagedLogger,
|
2020-03-09 16:44:40 +03:00
|
|
|
ensoVersion: String,
|
|
|
|
scalacVersion: String,
|
|
|
|
graalVersion: String
|
|
|
|
): Seq[File] = {
|
2020-09-09 16:37:26 +03:00
|
|
|
val gitInfo = getGitInformation(log).getOrElse(fallbackGitInformation)
|
|
|
|
val isRelease = isReleaseMode
|
2020-03-09 16:44:40 +03:00
|
|
|
val fileContents =
|
|
|
|
s"""
|
|
|
|
|package buildinfo
|
|
|
|
|
|
|
|
|
|object Info {
|
|
|
|
|
|
|
|
|
| // Versions
|
|
|
|
| val ensoVersion = "$ensoVersion"
|
|
|
|
| val scalacVersion = "$scalacVersion"
|
|
|
|
| val graalVersion = "$graalVersion"
|
|
|
|
|
|
|
|
|
| // Git Info
|
2020-09-09 16:37:26 +03:00
|
|
|
| val commit = "${gitInfo.commitHash}"
|
2020-07-27 13:45:19 +03:00
|
|
|
| val ref = "${gitInfo.ref}"
|
|
|
|
| val isDirty = ${gitInfo.isDirty}
|
|
|
|
| val latestCommitDate = "${gitInfo.latestCommitDate}"
|
2020-09-09 16:37:26 +03:00
|
|
|
|
|
|
|
|
| // Release mode, set to true if the environment variable
|
|
|
|
| // `ENSO_RELEASE_MODE` is set to `true` at build time.
|
|
|
|
| val isRelease = $isRelease
|
2020-03-09 16:44:40 +03:00
|
|
|
|}
|
|
|
|
|""".stripMargin
|
|
|
|
IO.write(file, fileContents)
|
2020-07-10 13:57:42 +03:00
|
|
|
log.debug("Build info updated.")
|
2020-03-09 16:44:40 +03:00
|
|
|
Seq(file)
|
|
|
|
}
|
2020-07-27 13:45:19 +03:00
|
|
|
|
2020-09-09 16:37:26 +03:00
|
|
|
private def isReleaseMode: Boolean =
|
|
|
|
if (sys.env.get("ENSO_RELEASE_MODE").contains("true")) true else false
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Information regarding the Git repository that was used in the build.
|
|
|
|
*
|
|
|
|
* @param ref if available, name of the branch that was checked out; if a
|
|
|
|
* branch is not available, but the current commit is tagged, name
|
|
|
|
* of that tag is used, otherwise falls back to `HEAD`
|
|
|
|
* @param commitHash hash of the currently checked out commit
|
|
|
|
* @param isDirty indicates if there are any uncommitted changes
|
|
|
|
* @param latestCommitDate date of the current commit
|
|
|
|
*/
|
2020-07-27 13:45:19 +03:00
|
|
|
private case class GitInformation(
|
|
|
|
ref: String,
|
2020-09-09 16:37:26 +03:00
|
|
|
commitHash: String,
|
2020-07-27 13:45:19 +03:00
|
|
|
isDirty: Boolean,
|
|
|
|
latestCommitDate: String
|
|
|
|
)
|
2020-09-09 16:37:26 +03:00
|
|
|
|
2020-07-27 13:45:19 +03:00
|
|
|
private def getGitInformation(log: ManagedLogger): Option[GitInformation] =
|
|
|
|
try {
|
|
|
|
val hash = ("git rev-parse HEAD" !!).trim
|
|
|
|
val ref =
|
|
|
|
try {
|
|
|
|
val branchCommand = "git symbolic-ref -q --short HEAD"
|
|
|
|
val tagCommand = "git describe --tags --exact-match"
|
|
|
|
val refCommand =
|
|
|
|
branchCommand #|| tagCommand
|
|
|
|
(refCommand !!).trim
|
|
|
|
} catch {
|
|
|
|
case e: Exception =>
|
|
|
|
log.warn(
|
|
|
|
"Cannot get name of git branch/tag, defaulting to \"HEAD\". " +
|
|
|
|
s"(Caused by: $e)"
|
|
|
|
)
|
|
|
|
"HEAD"
|
|
|
|
}
|
|
|
|
val isDirty = !("git status --porcelain" !!).trim.isEmpty
|
|
|
|
val latestCommitDate = ("git log HEAD -1 --format=%cd" !!).trim
|
2020-09-09 16:37:26 +03:00
|
|
|
Some(
|
|
|
|
GitInformation(
|
|
|
|
ref = ref,
|
|
|
|
commitHash = hash,
|
|
|
|
isDirty = isDirty,
|
|
|
|
latestCommitDate = latestCommitDate
|
|
|
|
)
|
|
|
|
)
|
2020-07-27 13:45:19 +03:00
|
|
|
} catch {
|
|
|
|
case e: Exception =>
|
|
|
|
log.warn(
|
|
|
|
"Could not get any git information. The build will proceed but it " +
|
|
|
|
s"will not contain the git metadata. (Caused by: $e)"
|
|
|
|
)
|
|
|
|
None
|
|
|
|
}
|
2020-09-09 16:37:26 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Fallback instance of [[GitInformation]] that can be used if the build is
|
|
|
|
* outside of a repository or the git information cannot be obtained for
|
|
|
|
* other reasons.
|
|
|
|
*/
|
2020-07-27 13:45:19 +03:00
|
|
|
private def fallbackGitInformation: GitInformation =
|
|
|
|
GitInformation(
|
|
|
|
"<built outside of a git repository>",
|
|
|
|
"<built outside of a git repository>",
|
|
|
|
isDirty = false,
|
|
|
|
"<built outside of a git repository>"
|
|
|
|
)
|
2020-03-09 16:44:40 +03:00
|
|
|
}
|