Refactored how versions are auto-built to provide more normal versions
when building locally. Normal auto-detected versions will be based on the base version parsed from the most recent tag on the branch with a -SNAPSHOT appended. If the current commit is the tagged commit then it is used directly to preserve backwards compatibility... but really that should be a CI only option for most use-cases. A new includeBranchInVersion option was added to allow the old behavior of including the branch name in a munged version string for those wanting to keep their experimental branch builds separate from their normal master/version-branch builds.
This commit is contained in:
parent
124ef031d4
commit
5db3ac4fac
@ -8,6 +8,10 @@ jmeVersionName =
|
||||
# If true, the version name will contain the commit hash
|
||||
useCommitHashAsVersionName = false
|
||||
|
||||
# Set to true if a non-master branch name should be included in the automatically
|
||||
# generated version.
|
||||
includeBranchInVersion = false
|
||||
|
||||
# specify if JavaDoc should be built
|
||||
buildJavaDoc = true
|
||||
|
||||
|
118
version.gradle
118
version.gradle
@ -24,38 +24,107 @@ ext {
|
||||
|
||||
task configureVersionInfo {
|
||||
try {
|
||||
// Users can configure behavior by setting properties on the command
|
||||
// line:
|
||||
//
|
||||
// jmeVersionName:
|
||||
// If set this will override all automatic version detection.
|
||||
//
|
||||
// useCommitHashAsVersionName:
|
||||
// If there is no jmeVersionName set and the current commit has no
|
||||
// specific tag then setting this to 'true' will cause the version to
|
||||
// be the full commit ID.
|
||||
//
|
||||
// includeBranchInVersion:
|
||||
// Set to true if a non-master branch name should be included in the automatically
|
||||
// generated version.
|
||||
|
||||
def grgit = Grgit.open(project.file('.'))
|
||||
def head = grgit.head()
|
||||
jmeRevision = grgit.log(includes: [head]).size()
|
||||
jmeGitHash = head.id
|
||||
jmeShortGitHash = head.abbreviatedId
|
||||
jmeBranchName = grgit.branch.current.name
|
||||
jmeGitTag = grgit.tag.list().find { it.commit == head }
|
||||
|
||||
if(jmeVersionName==""){
|
||||
if (jmeGitTag != null) {
|
||||
jmeGitTag = jmeGitTag.name
|
||||
jmeFullVersion = jmeGitTag
|
||||
jmeVersionTag = ""
|
||||
if(jmeFullVersion.startsWith("v")&&Character.isDigit(jmeFullVersion.charAt(1))){
|
||||
jmeFullVersion=jmeFullVersion.substring(1);
|
||||
}
|
||||
} else {
|
||||
if(useCommitHashAsVersionName=="true"&&jmeGitHash!=null&&!jmeGitHash.equals("")){
|
||||
jmeFullVersion = jmeGitHash
|
||||
jmeVersionTag = ""
|
||||
}else{
|
||||
jmeFullVersion="${jmeVersion}-";
|
||||
if(jmeBranchName!="master")jmeFullVersion+="${jmeBranchName}-";
|
||||
jmeFullVersion+="SNAPSHOT"
|
||||
jmeVersionTag="SNAPSHOT"
|
||||
}
|
||||
}
|
||||
}else{
|
||||
jmeVersionTag=""
|
||||
jmeFullVersion=jmeVersionName
|
||||
// This code will find an exact-match tag if the current
|
||||
// commit is the same as the tag commit.
|
||||
jmeGitTag = grgit.tag.list().find { it.commit == head }
|
||||
def latestTag;
|
||||
if( jmeGitTag ) {
|
||||
// Just use the name. We keep jmeGitTag separate because there
|
||||
// is some logic that wants to know if this specific commit has
|
||||
// a tag versus 'whatever tag we are a child of'... which is what
|
||||
// 'latestTag' will be.
|
||||
jmeGitTag = jmeGitTag.name
|
||||
latestTag = jmeGitTag;
|
||||
} else {
|
||||
// Use describe to find the most recent tag. Unfortunately,
|
||||
// in this version of grgit, we don't have the 'always' options
|
||||
// so we can't make as many assumptions about the format of the
|
||||
// string.
|
||||
// If the commit is an exact match then it will return just the
|
||||
// tag name... else it will be tagName-commitCount-abbreviatedId
|
||||
// We'll use some groovy regex magic to get the tag either way.
|
||||
def describe = grgit.describe()
|
||||
def fullDescribe = (describe =~/(.*?)-(\d+)-g$jmeShortGitHash/)
|
||||
latestTag = fullDescribe ? fullDescribe[0][1] : describe
|
||||
println "Latest tag:" + latestTag
|
||||
}
|
||||
|
||||
// We could enhance this with some more regex if we wanted to sanity
|
||||
// check that it was formatted like our versions.
|
||||
def tagVersion = (latestTag =~/v?(.*)/)[0][1];
|
||||
// If the branch is not master then use the tag.
|
||||
if( jmeBranchName != "master" ) {
|
||||
jmeVersion = tagVersion
|
||||
}
|
||||
|
||||
// Parse out just the base version part. -SNAPSHOT versions
|
||||
// shouldn't really include our release suffixes
|
||||
def baseVersion = (tagVersion =~/(\d+\.\d+.\d+)/)
|
||||
baseVersion = baseVersion.size() > 0 ? baseVersion[0][0] : tagVersion
|
||||
|
||||
if( !jmeVersionName ) {
|
||||
// If there is a specific tag for the top commit then we always
|
||||
// use that.
|
||||
if( jmeGitTag ) {
|
||||
println "Using GIT tag as version"
|
||||
jmeFullVersion = tagVersion; // already cleaned up
|
||||
jmeVersionTag = "" // and no SNAPSHOT suffix for an exact version tag
|
||||
|
||||
// Note: this will not automatically add SNAPSHOT if the user has
|
||||
// local changes that they haven't committed. Technically, only
|
||||
// real CI builds should be using non-SNAPSHOT versions so we may
|
||||
// eventually want to change the script to always use -SNAPSHOT with
|
||||
// a CI option to turn it off.
|
||||
// We could also check the grgit.status for unstaged modified/removed files.
|
||||
// def unstaged = grgit.status().unstaged;
|
||||
// def modCount = unstaged.modified.size() + unstaged.removed.size()
|
||||
// ...but that seems like a wasteful check considering only official
|
||||
// version builds should not have a -SNAPSHOT.
|
||||
|
||||
} else if( useCommitHashAsVersionName == "true" && jmeGitHash ) {
|
||||
// The user has opted to use the hash... and we actually have
|
||||
// a hash.
|
||||
println "Using commit ID as version"
|
||||
jmeFullVersion = jmeGitHash;
|
||||
jmeVersionTag = ""
|
||||
} else {
|
||||
println "Auto-detecting version"
|
||||
jmeVersionTag = "SNAPSHOT"
|
||||
|
||||
if( includeBranchInVersion == "true" && jmeBranchName != "master" ) {
|
||||
jmeFullVersion = baseVersion + "-" + jmeBranchName + "-" + jmeVersionTag;
|
||||
} else {
|
||||
jmeFullVersion = baseVersion + "-" + jmeVersionTag;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
// Just use defaults
|
||||
println "Using user-defined version"
|
||||
jmeFullVersion=jmeVersionName
|
||||
jmeVersionTag = "SNAPSHOT"
|
||||
}
|
||||
|
||||
println("Revision: ${jmeRevision}")
|
||||
println("Hash: ${jmeGitHash}")
|
||||
@ -64,7 +133,8 @@ task configureVersionInfo {
|
||||
println("Build Date: ${jmeBuildDate}")
|
||||
println("Build Branch: ${jmeBranchName}")
|
||||
println("Use commit hash as version ${useCommitHashAsVersionName}")
|
||||
println("Build Tag: ${jmeVersionTag}")
|
||||
println("Base Version: ${baseVersion}")
|
||||
println("Build Suffix: ${jmeVersionTag}")
|
||||
println("Build Version: ${jmeFullVersion}")
|
||||
|
||||
} catch (ex) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user