aboutsummaryrefslogtreecommitdiff
path: root/share
diff options
context:
space:
mode:
authorWladimir J. van der Laan <laanwj@gmail.com>2014-04-16 12:03:59 +0200
committerWladimir J. van der Laan <laanwj@gmail.com>2014-04-16 12:04:00 +0200
commit31853a1517c4ccf15a784380411f9d5de20d3ec1 (patch)
tree6e3c302e70bc8ce063d473448ae40895aa62f7da /share
parent74dd52a9fc13851a6ec847da985388a6bfb70be7 (diff)
parent3d20cd5f61fff33fe5fffd6efddf2c942c8dd2f9 (diff)
Merge pull request #4049
3d20cd5 VERSION obtained from source instead of the previous git tag. (Warren Togami)
Diffstat (limited to 'share')
-rwxr-xr-xshare/genbuild.sh14
1 files changed, 12 insertions, 2 deletions
diff --git a/share/genbuild.sh b/share/genbuild.sh
index afa4b4ccb9..6890a6eba0 100755
--- a/share/genbuild.sh
+++ b/share/genbuild.sh
@@ -14,13 +14,21 @@ else
fi
DESC=""
+SUFFIX=""
LAST_COMMIT_DATE=""
if [ -e "$(which git)" -a -d ".git" ]; then
# clean 'dirty' status of touched files that haven't been modified
git diff >/dev/null 2>/dev/null
- # get a string like "v0.6.0-66-g59887e8-dirty"
- DESC="$(git describe --dirty 2>/dev/null)"
+ # if latest commit is tagged and not dirty, then override using the tag name
+ RAWDESC=$(git describe --abbrev=0 2>/dev/null)
+ if [ "$(git rev-parse HEAD)" = "$(git rev-list -1 $RAWDESC)" ]; then
+ git diff-index --quiet HEAD -- && DESC=$RAWDESC
+ fi
+
+ # otherwise generate suffix from git, i.e. string like "59887e8-dirty"
+ SUFFIX=$(git rev-parse --short HEAD)
+ git diff-index --quiet HEAD -- || SUFFIX="$SUFFIX-dirty"
# get a string like "2012-04-10 16:27:19 +0200"
LAST_COMMIT_DATE="$(git log -n 1 --format="%ci")"
@@ -28,6 +36,8 @@ fi
if [ -n "$DESC" ]; then
NEWINFO="#define BUILD_DESC \"$DESC\""
+elif [ -n "$SUFFIX" ]; then
+ NEWINFO="#define BUILD_SUFFIX $SUFFIX"
else
NEWINFO="// No build information available"
fi