Fix shellcheck and use anotated tag
This commit is contained in:
parent
bf3bf6aa24
commit
8718d66556
53
bump-tag
53
bump-tag
|
@ -2,55 +2,56 @@
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
test -f cosmos.conf && . ./cosmos.conf
|
|
||||||
|
|
||||||
echo "Fetching any updates from server:"
|
echo "Fetching any updates from server:"
|
||||||
git pull
|
git pull
|
||||||
echo ""
|
echo ""
|
||||||
|
|
||||||
if [ "x$1" = "x" ]; then
|
if [[ -z ${1} ]]; then
|
||||||
deftag=`basename $PWD`
|
deftag=$(basename "${PWD}")
|
||||||
else
|
else
|
||||||
deftag="$1"
|
deftag="${1}"
|
||||||
fi
|
fi
|
||||||
tagpfx=${tag:="$deftag"}
|
tagpfx=${tag:="${deftag}"}
|
||||||
|
|
||||||
last_tag=`git tag -l "${tagpfx}-*"|sort|tail -1`
|
last_tag=$(git tag -l "${tagpfx}-*" | sort | tail -1)
|
||||||
|
|
||||||
echo "Verifying last tag $last_tag:"
|
echo "Verifying last tag ${last_tag}:"
|
||||||
(git tag -v $last_tag | grep ^gpg:) || true
|
(git tag -v "${last_tag}" | grep ^gpg:) || true
|
||||||
# again to not mask exit status of git with grep
|
# again to not mask exit status of git with grep
|
||||||
git tag -v $last_tag > /dev/null 2>&1
|
git tag -v "${last_tag}" >/dev/null 2>&1
|
||||||
echo ""
|
echo ""
|
||||||
|
|
||||||
echo "Differences between tag $last_tag and what you are about to sign:"
|
echo "Differences between tag ${last_tag} and what you are about to sign:"
|
||||||
PAGER=cat git diff --color $last_tag..main
|
env PAGER=cat git diff --color "${last_tag}..main"
|
||||||
|
|
||||||
iter=1
|
iter=1
|
||||||
ok=
|
ok=
|
||||||
while test -z "$ok"; do
|
while test -z "$ok"; do
|
||||||
this_tag=$(date +${tagpfx}-%Y-%m-%d-v`printf "%02d" $iter`)
|
this_tag=$(date "+${tagpfx}-%Y-%m-%d-v$(printf "%02d" ${iter})")
|
||||||
iter=`expr $iter + 1`
|
iter=$(( iter + 1))
|
||||||
case `(echo $this_tag; echo $last_tag) | sort | tail -1` in
|
case $( (
|
||||||
$last_tag)
|
echo "${this_tag}"
|
||||||
;;
|
echo "${last_tag}"
|
||||||
$this_tag)
|
) | sort | tail -1) in
|
||||||
ok=yes
|
"${last_tag}") ;;
|
||||||
;;
|
|
||||||
esac
|
"${this_tag}")
|
||||||
|
ok=yes
|
||||||
|
;;
|
||||||
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ "$deftag" != "$tagpfx" ]; then
|
if [ "${deftag}" != "${tagpfx}" ]; then
|
||||||
echo -e "Using new tag \e[94m$this_tag\e[0m according to pattern in cosmos.conf"
|
echo -e "Using new tag \e[94m${this_tag}\e[0m according to pattern in cosmos.conf"
|
||||||
else
|
else
|
||||||
echo -e "Using new tag \e[94m$this_tag\e[0m"
|
echo -e "Using new tag \e[94m${this_tag}\e[0m"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -e "\e[1mONLY SIGN IF YOU APPROVE OF VERIFICATION AND DIFF ABOVE\e[0m"
|
echo -e "\e[1mONLY SIGN IF YOU APPROVE OF VERIFICATION AND DIFF ABOVE\e[0m"
|
||||||
|
|
||||||
# GITTAGEXTRA is for putting things like "-u 2117364A"
|
# GITTAGEXTRA is for putting things like "-u 2117364A"
|
||||||
|
# shellcheck disable=SC2086
|
||||||
git tag $GITTAGEXTRA -m bump. -s $this_tag
|
git tag ${GITTAGEXTRA} -a "${this_tag}" -m bump. -s "${this_tag}"
|
||||||
|
|
||||||
git push
|
git push
|
||||||
git push --tags
|
git push --tags
|
||||||
|
|
Loading…
Reference in a new issue