yggdrasil-go/contrib/semver/version.sh

47 lines
1.2 KiB
Bash
Raw Normal View History

2018-03-05 22:34:23 +03:00
#!/bin/sh
# Merge commits from this branch are counted
DEVELOPBRANCH="yggdrasil-network/develop"
2018-03-05 22:34:23 +03:00
# Get the last tag
TAG=$(git describe --abbrev=0 --tags --match="v[0-9]*\.[0-9]*" 2>/dev/null)
2018-03-05 22:34:23 +03: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 22:34:23 +03:00
2018-03-05 23:06:38 +03:00
# If it fails then there's no last tag - go from the first commit
if [ $? != 0 ]; then
PATCH=$(git rev-list HEAD --count 2>/dev/null)
2018-03-05 22:34:23 +03:00
printf 'v0.0.%d' "$PATCH"
2018-03-05 22:34:23 +03:00
exit -1
fi
# Get the number of merges on the current branch since the last tag
BUILD=$(git rev-list $TAG..HEAD --count --merges)
2018-03-05 22:34:23 +03:00
# Split out into major, minor and patch numbers
MAJOR=$(echo $TAG | cut -c 2- | cut -d "." -f 1)
MINOR=$(echo $TAG | cut -c 2- | cut -d "." -f 2)
2018-03-05 22:34:23 +03:00
# Get the current checked out branch
BRANCH=$(git rev-parse --abbrev-ref HEAD)
2018-03-05 22:34:23 +03:00
# Output in the desired format
if [ $PATCH = 0 ]; then
printf 'v%d.%d' "$MAJOR" "$MINOR"
else
printf 'v%d.%d.%d' "$MAJOR" "$MINOR" "$PATCH"
fi
# Add the build tag on non-master branches
if [ $BRANCH != "master" ]; then
if [ $BUILD != 0 ]; then
printf -- "-%04d" "$BUILD"
fi
fi