X-Git-Url: https://git.notmuchmail.org/git?a=blobdiff_plain;f=devel%2Frelease-checks.sh;h=d6410add85d057d00b145c259b86d562b3d49056;hb=4b14ccf0d66f52d4777c928a67cd55de9d3e748a;hp=d2bbc6a06d077f7f57c6bab8713fc6f30e55bf02;hpb=1407901cba742b12931e54765eff819c02aa6764;p=notmuch diff --git a/devel/release-checks.sh b/devel/release-checks.sh index d2bbc6a0..d6410add 100755 --- a/devel/release-checks.sh +++ b/devel/release-checks.sh @@ -13,6 +13,8 @@ fi set -o posix set -o pipefail # bash feature +readonly DEFAULT_IFS="$IFS" # Note: In this particular case quotes are needed. + # Avoid locale-specific differences in output of executed commands LANG=C LC_ALL=C; export LANG LC_ALL @@ -20,8 +22,10 @@ readonly PV_FILE='bindings/python/notmuch/version.py' # Using array here turned out to be unnecessarily complicated emsgs='' +emsg_count=0 append_emsg () { + emsg_count=$((emsg_count + 1)) emsgs="${emsgs:+$emsgs\n} $1" } @@ -73,6 +77,38 @@ case $VERSION in *) verfail "'$VERSION' is a single number" ;; esac +_set_version_components () +{ + VERSION_MAJOR=$1 + VERSION_MINOR=$2 + VERSION_MICRO=${3:-0} # set to 0 in case $3 is unset or "null" (string) +} + +IFS=. +_set_version_components $VERSION +IFS=$DEFAULT_IFS + +echo -n "Checking that libnotmuch version macros match $VERSION... " +NOTMUCH_MAJOR_VERSION=broken +NOTMUCH_MINOR_VERSION=broken +NOTMUCH_MICRO_VERSION=broken +eval `awk 'NF == 3 && $1 == "#define" && $2 ~ /^NOTMUCH_[A-Z]+_VERSION$/ \ + && $3 ~ /^[0-9]+$/ { print $2 "=" $3 }' lib/notmuch.h` + +check_version_component () +{ + eval local v1=\$VERSION_$1 + eval local v2=\$NOTMUCH_$1_VERSION + if [ $v1 != $v2 ] + then append_emsg "NOTMUCH_$1_VERSION is defined as '$v2' in lib/notmuch.h instead of '$v1'" + fi +} + +old_emsg_count=$emsg_count +check_version_component MAJOR +check_version_component MINOR +check_version_component MICRO +[ $old_emsg_count = $emsg_count ] && echo Yes. || echo No. echo -n "Checking that this is Debian package for notmuch... " read deb_notmuch deb_version rest < debian/changelog @@ -104,6 +140,20 @@ else append_emsg "Version '$py_version' is not '$VERSION' in $PV_FILE" fi +echo -n "Checking that NEWS header is tidy... " +if [ "`exec sed 's/./=/g; 1q' NEWS`" = "`exec sed '1d; 2q' NEWS`" ] +then + echo Yes. +else + echo No. + if [ "`exec sed '1d; s/=//g; 2q' NEWS`" != '' ] + then + append_emsg "Line 2 in NEWS file is not all '=':s" + else + append_emsg "Line 2 in NEWS file does not have the same length as line 1" + fi +fi + echo -n "Checking that this is Notmuch NEWS... " read news_notmuch news_version news_date < NEWS if [ "$news_notmuch" = "Notmuch" ]