summaryrefslogtreecommitdiffstats
path: root/scripts/check-version
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/check-version')
-rwxr-xr-xscripts/check-version95
1 files changed, 95 insertions, 0 deletions
diff --git a/scripts/check-version b/scripts/check-version
new file mode 100755
index 000000000..24f90af79
--- /dev/null
+++ b/scripts/check-version
@@ -0,0 +1,95 @@
+#!/bin/sh
+
+# $1 - version string
+# options:
+# -c colored grep (implies -d)
+# -d debug
+# -r release (exit status error; when called from Makefile)
+
+# To validate relevant files are up to date, you would run the script
+# from command line before tagging:
+#
+# $ scripts/check-version -cr <tag>
+
+set -eu
+#set -x
+
+# You would typically add/remove files to/from the list
+files="Documentation/user-manual.txt Makefile README ReleaseNotes.txt"
+
+whine() {
+ echo "$0: $*" >&2
+}
+
+croak() {
+ whine "$*"
+ exit 1
+}
+
+color=n
+debug=n
+release=n
+while getopts cdr opt; do
+ case $opt in
+ c)
+ color=y
+ debug=y
+ ;;
+ d)
+ debug=y
+ ;;
+ r)
+ release=y
+ ;;
+ *)
+ croak "invalid option"
+ ;;
+ esac
+done
+shift $(($OPTIND - 1))
+
+if [ $debug = y ]; then
+ opts=-n
+else
+ opts=-q
+fi
+[ $color = n ] || opts="${opts:+$opts }--color"
+
+v=${1:-}
+v=${v#v}
+case $v in
+ *-*)
+ # Ignore development versions
+ if [ $release = y ]; then
+ croak "'$v' not a release tag"
+ else
+ exit 0
+ fi
+ ;;
+ ''|*[!.0-9]*)
+ croak "invalid version string '$v'"
+ ;;
+esac
+whine "checking for version $v"
+
+saveIFS=$IFS
+IFS=.
+set -- $v
+IFS=$saveIFS
+v=
+while [ $# -gt 0 ]; do
+ v=${v:+$v\\.}$1
+ shift
+done
+
+sts=0
+for f in $files; do
+ grep -EH $opts \
+ -e "(VERSION=|[Ss]ubsurface[[:blank:]]+)?\<v?$v[.0-9]*\>" \
+ $f || {
+ [ $release != y ] || sts=1
+ whine "'$f' may need updating"
+ }
+done
+
+exit $sts