diff options
author | Linus Torvalds <torvalds@g5.osdl.org> | 2005-07-08 18:23:06 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2005-07-08 18:23:06 -0700 |
commit | 918c05f1b653d24a03d5b29c576894ede63a6787 (patch) | |
tree | f1a442de27044f07d17a987b97f0f684dfb47a20 /git-tag-script | |
parent | Make "git resolve" take the merge message in $3 (diff) | |
download | tgif-918c05f1b653d24a03d5b29c576894ede63a6787.tar.xz |
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-x | git-tag-script | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/git-tag-script b/git-tag-script index 281d192814..442a243575 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 |