summaryrefslogtreecommitdiff
path: root/git-tag-script
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@g5.osdl.org>2005-07-09 01:23:06 (GMT)
committerLinus Torvalds <torvalds@g5.osdl.org>2005-07-09 01:23:06 (GMT)
commit918c05f1b653d24a03d5b29c576894ede63a6787 (patch)
treef1a442de27044f07d17a987b97f0f684dfb47a20 /git-tag-script
parent3ba513c32e7b9102187d94d1c43f33d9559fb334 (diff)
downloadgit-918c05f1b653d24a03d5b29c576894ede63a6787.zip
git-918c05f1b653d24a03d5b29c576894ede63a6787.tar.gz
git-918c05f1b653d24a03d5b29c576894ede63a6787.tar.bz2
Make "git tag" more user-friendly
Instead of having to cut-and-paste the result, write it to the tag directory directly. Also, start an editor for the tag message, rather than just reading it from stdin.
Diffstat (limited to 'git-tag-script')
-rwxr-xr-xgit-tag-script20
1 files changed, 16 insertions, 4 deletions
diff --git a/git-tag-script b/git-tag-script
index 281d192..442a243 100755
--- a/git-tag-script
+++ b/git-tag-script
@@ -1,12 +1,24 @@
#!/bin/sh
# Copyright (c) 2005 Linus Torvalds
-: ${GIT_DIR=.git}
+. git-sh-setup-script || die "Not a git archive"
+name="$1"
+[ "$name" ] || die "I need a tag-name"
object=${2:-$(cat "$GIT_DIR"/HEAD)}
type=$(git-cat-file -t $object) || exit 1
-( echo -e "object $object\ntype $type\ntag $1\n"; cat ) > .tmp-tag
-rm -f .tmp-tag.asc
+
+( echo "#"
+ echo "# Write a tag message"
+ echo "#" ) > .editmsg
+${VISUAL:-${EDITOR:-vi}} .editmsg || exit
+
+grep -v '^#' < .editmsg | git-stripspace > .tagmsg
+
+[ -s .tagmsg ] || exit
+
+( echo -e "object $object\ntype $type\ntag $name\n"; cat .tagmsg ) > .tmp-tag
+rm -f .tmp-tag.asc .tagmsg
gpg -bsa .tmp-tag && cat .tmp-tag.asc >> .tmp-tag
-git-mktag < .tmp-tag
+git-mktag < .tmp-tag > "$GIT_DIR/refs/tags/$name"
#rm .tmp-tag .tmp-tag.sig