summaryrefslogtreecommitdiff
path: root/git-tag-script
diff options
context:
space:
mode:
authorJunio C Hamano <junkio@cox.net>2005-07-25 22:18:35 (GMT)
committerJunio C Hamano <junkio@cox.net>2005-07-25 22:24:53 (GMT)
commit0fad0fdd4beadb2ff06af8d5a16d509cd8796ee4 (patch)
tree9e8d35cc421707fd243a41012b34a9769cc3c73f /git-tag-script
parent154d3d2dd2656c23ea04e9d1c6dd4e576a7af6de (diff)
downloadgit-0fad0fdd4beadb2ff06af8d5a16d509cd8796ee4.zip
git-0fad0fdd4beadb2ff06af8d5a16d509cd8796ee4.tar.gz
git-0fad0fdd4beadb2ff06af8d5a16d509cd8796ee4.tar.bz2
git-tag-script updates.
This adds -a (annotate only but not sign) option "A Large Angry SCM" <gitzilla@gmail.com> sent to the list, after fixing up the whitespace corruption in the patch, with some of my own fixes. Namely: * A new flag '-a' can be used to create an unsigned tag object; * The '-f' flag logic did not do the right thing; * When creating a signed tag, we did not check for GPG failure as we should; * Try to use the key for the tagger identity when signing the tag. Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'git-tag-script')
-rwxr-xr-xgit-tag-script32
1 files changed, 26 insertions, 6 deletions
diff --git a/git-tag-script b/git-tag-script
index c375a84..4917f99 100755
--- a/git-tag-script
+++ b/git-tag-script
@@ -3,17 +3,30 @@
. git-sh-setup-script || die "Not a git archive"
+usage () {
+ echo >&2 "Usage: git-tag-script [-a | -s] [-f] tagname"
+ exit 1
+}
+
+annotate=
signed=
force=
while case "$#" in 0) break ;; esac
do
case "$1" in
+ -a)
+ annotate=1
+ ;;
-s)
+ annotate=1
signed=1
;;
-f)
force=1
;;
+ -*)
+ usage
+ ;;
*)
break
;;
@@ -22,16 +35,19 @@ do
done
name="$1"
-[ "$name" ] || die "I need a tag-name"
-[ -e "$GIT_DIR/refs/tags/$name" ] &&
- [ "$force" ] || die "tag '$name' already exists"
+[ "$name" ] || usage
+if [ -e "$GIT_DIR/refs/tags/$name" -a -z "$force" ]; then
+ die "tag '$name' already exists"
+fi
shift
object=$(git-rev-parse --verify --revs-only --default HEAD "$@") || exit 1
type=$(git-cat-file -t $object) || exit 1
tagger=$(git-var GIT_COMMITTER_IDENT) || exit 1
-if [ "$signed" ]; then
+trap 'rm -f .tmp-tag* .tagmsg .editmsg' 0
+
+if [ "$annotate" ]; then
( echo "#"
echo "# Write a tag message"
echo "#" ) > .editmsg
@@ -43,9 +59,13 @@ if [ "$signed" ]; then
( echo -e "object $object\ntype $type\ntag $name\ntagger $tagger\n"; cat .tagmsg ) > .tmp-tag
rm -f .tmp-tag.asc .tagmsg
- gpg -bsa .tmp-tag && cat .tmp-tag.asc >> .tmp-tag
+ if [ "$signed" ]; then
+ me=$(expr "$tagger" : '\(.*>\)') &&
+ gpg -bsa -u "$me" .tmp-tag &&
+ cat .tmp-tag.asc >>.tmp-tag ||
+ die "failed to sign the tag with GPG."
+ fi
object=$(git-mktag < .tmp-tag)
- rm -f .tmp-tag .tmp-tag.sig
fi
mkdir -p "$GIT_DIR/refs/tags"