2018-03-05 19:34:23 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
2018-06-17 18:17:21 +01:00
|
|
|
# Merge commits from this branch are counted
|
|
|
|
DEVELOPBRANCH="yggdrasil-network/develop"
|
|
|
|
|
2018-12-17 10:34:26 +00:00
|
|
|
# Get the last tag that denotes moving to a major version number
|
2018-12-03 17:44:26 +00:00
|
|
|
TAG=$(git describe --abbrev=0 --tags --match="v[0-9]*\.[0-9]*\.0" 2>/dev/null)
|
2018-03-05 19:34:23 +00:00
|
|
|
|
2018-06-17 18:17:21 +01:00
|
|
|
# Get last merge to master
|
|
|
|
MERGE=$(git rev-list $TAG..master --grep "from $DEVELOPBRANCH" 2>/dev/null | head -n 1)
|
|
|
|
|
|
|
|
# Get the number of merges since the last merge to master
|
|
|
|
PATCH=$(git rev-list $TAG..master --count --merges --grep="from $DEVELOPBRANCH" 2>/dev/null)
|
2018-03-05 19:34:23 +00:00
|
|
|
|
2018-12-08 10:51:31 +00:00
|
|
|
# Decide whether we should prepend the version with "v" - the default is that
|
|
|
|
# we do because we use it in git tags, but we might not always need it
|
|
|
|
PREPEND="v"
|
2018-12-08 11:31:20 +00:00
|
|
|
if [ "$1" = "--bare" ]; then
|
2018-12-08 10:51:31 +00:00
|
|
|
PREPEND=""
|
|
|
|
fi
|
|
|
|
|
2018-03-05 20:06:38 +00:00
|
|
|
# If it fails then there's no last tag - go from the first commit
|
|
|
|
if [ $? != 0 ]; then
|
2018-06-17 18:17:21 +01:00
|
|
|
PATCH=$(git rev-list HEAD --count 2>/dev/null)
|
2018-03-05 19:34:23 +00:00
|
|
|
|
2018-12-07 22:17:09 +00:00
|
|
|
# Complain if the git history is not available
|
2018-12-07 22:03:57 +00:00
|
|
|
if [ $? != 0 ]; then
|
|
|
|
printf 'unknown'
|
2018-12-08 10:33:33 +00:00
|
|
|
exit 1
|
2018-12-07 22:03:57 +00:00
|
|
|
fi
|
|
|
|
|
2018-12-08 10:51:31 +00:00
|
|
|
printf '%s0.0.%d' "$PREPEND" "$PATCH"
|
2018-12-08 10:33:33 +00:00
|
|
|
exit 1
|
2018-03-05 19:34:23 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Split out into major, minor and patch numbers
|
2018-03-05 22:14:36 +00:00
|
|
|
MAJOR=$(echo $TAG | cut -c 2- | cut -d "." -f 1)
|
|
|
|
MINOR=$(echo $TAG | cut -c 2- | cut -d "." -f 2)
|
2018-03-05 19:34:23 +00:00
|
|
|
|
2018-06-17 18:17:21 +01:00
|
|
|
# Get the current checked out branch
|
|
|
|
BRANCH=$(git rev-parse --abbrev-ref HEAD)
|
|
|
|
|
2018-03-05 19:34:23 +00:00
|
|
|
# Output in the desired format
|
2018-12-03 17:49:03 +00:00
|
|
|
if [ $PATCH = 0 ]; then
|
2018-12-03 17:44:26 +00:00
|
|
|
if [ ! -z $FULL ]; then
|
2018-12-08 10:51:31 +00:00
|
|
|
printf '%s%d.%d.0' "$PREPEND" "$MAJOR" "$MINOR"
|
2018-12-03 17:44:26 +00:00
|
|
|
else
|
2018-12-08 10:51:31 +00:00
|
|
|
printf '%s%d.%d' "$PREPEND" "$MAJOR" "$MINOR"
|
2018-12-03 17:44:26 +00:00
|
|
|
fi
|
2018-03-05 22:14:36 +00:00
|
|
|
else
|
2018-12-08 10:51:31 +00:00
|
|
|
printf '%s%d.%d.%d' "$PREPEND" "$MAJOR" "$MINOR" "$PATCH"
|
2018-03-05 22:14:36 +00:00
|
|
|
fi
|
2018-06-17 18:17:21 +01:00
|
|
|
|
|
|
|
# Add the build tag on non-master branches
|
|
|
|
if [ $BRANCH != "master" ]; then
|
2018-12-17 10:34:26 +00:00
|
|
|
# Get the number of merges on the current branch since the last tag
|
|
|
|
BUILDTAG=$(git describe --abbrev=0 --tags --match="v[0-9]*\.[0-9]*\.[0-9]*" 2>/dev/null)
|
|
|
|
BUILD=$(git rev-list $BUILDTAG..HEAD --count --merges)
|
|
|
|
|
2018-06-17 18:17:21 +01:00
|
|
|
if [ $BUILD != 0 ]; then
|
|
|
|
printf -- "-%04d" "$BUILD"
|
|
|
|
fi
|
|
|
|
fi
|