diff options
author | Linus Torvalds <torvalds@g5.osdl.org> | 2005-07-23 15:21:22 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2005-07-23 15:21:22 -0700 |
commit | d727782eaf85d7bbf49e666776deadd3fee85715 (patch) | |
tree | d763af06625117ddff266e8bb0a2bb62e32a7d02 | |
parent | 1d8fa411e04130e175eae7a41e0918e4be7797a5 (diff) | |
download | git-d727782eaf85d7bbf49e666776deadd3fee85715.tar.gz |
Make "git tag" create both simple and signed tags
A simple tag is just a direct pointer to the object, while a signed tag
is a pointer to a "tag object" that has a pgp signature and points to
the object we tagged.
Use "git tag -s tagname" to create a signed tag.
The "-f" flag overwrites any previous tag of that name (useful if you
update a tag to point to a newer version for things like "latest" etc
tags that aren't necessarily static versions).
-rwxr-xr-x | git-tag-script | 50 |
1 files changed, 38 insertions, 12 deletions
diff --git a/git-tag-script b/git-tag-script index 4124f5494a..c375a840d3 100755 --- a/git-tag-script +++ b/git-tag-script @@ -2,25 +2,51 @@ # Copyright (c) 2005 Linus Torvalds . git-sh-setup-script || die "Not a git archive" + +signed= +force= +while case "$#" in 0) break ;; esac +do + case "$1" in + -s) + signed=1 + ;; + -f) + force=1 + ;; + *) + break + ;; + esac + shift +done + name="$1" [ "$name" ] || die "I need a tag-name" +[ -e "$GIT_DIR/refs/tags/$name" ] && + [ "$force" ] || die "tag '$name' already exists" +shift -object=${2:-$(cat "$GIT_DIR"/HEAD)} +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 -( echo "#" - echo "# Write a tag message" - echo "#" ) > .editmsg -${VISUAL:-${EDITOR:-vi}} .editmsg || exit +if [ "$signed" ]; then + ( echo "#" + echo "# Write a tag message" + echo "#" ) > .editmsg + ${VISUAL:-${EDITOR:-vi}} .editmsg || exit + + grep -v '^#' < .editmsg | git-stripspace > .tagmsg -grep -v '^#' < .editmsg | git-stripspace > .tagmsg + [ -s .tagmsg ] || exit -[ -s .tagmsg ] || exit + ( 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 + object=$(git-mktag < .tmp-tag) + rm -f .tmp-tag .tmp-tag.sig +fi -( 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 mkdir -p "$GIT_DIR/refs/tags" -git-mktag < .tmp-tag > "$GIT_DIR/refs/tags/$name" -#rm .tmp-tag .tmp-tag.sig +echo $object > "$GIT_DIR/refs/tags/$name" |