1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
|
#!/bin/sh
## deken versioning scheme
# - we losely follow semver
# - releases should *always* have an even bugfix-number
# - during development, we use an odd bugfix-number
# files that contain the version number
# - ./developer/deken
# - ./deken-plugin.tcl
# - ./README.deken.pd
# - .git-ci/deken-test/README.deken.txt
version_script=".git-ci/git-version"
cd ${0%/*}/..
version=$1
version=${version#v}
if [ "x${version}" = "x" ]; then
echo "usage: $0 <version>" 1>&2
exit 1
fi
version_check() {
local bugfix
bugfix=$3
if [ -n "${bugfix}" ] && [ $((bugfix % 2)) -ne 0 ]; then
return 1
fi
return 0
}
if git diff --name-only | sed -e 's|^|CHANGED: |' | tee /dev/stderr | grep . >/dev/null; then
echo "the repository contains changes!" 1>&2
echo "commit or stash them, before releasing." 1>&2
exit 1
fi
if [ -x "${version_script}" ]; then
echo "setting version to ${version}"
${version_script} "${version}"
else
echo "version-script '${version_script}' missing"
exit 1
fi
if version_check $(echo $version | sed -e 's|[.-]| |g'); then
echo "committing changes and tagging release" 1>&2
git commit \
developer/deken deken-plugin.tcl \
README.deken.pd .git-ci/deken-test/README.deken.txt \
-m "Releasing v${version}" \
&& git tag -s -m "Released deken-v${version}" "v${version}"
else
echo "committing changes for development version" 1>&2
git commit \
developer/deken deken-plugin.tcl \
README.deken.pd .git-ci/deken-test/README.deken.txt \
-m "Bump dev-version to v${version}"
fi
|