X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=git-tag-script;h=4917f99576ef91266a63a12899f16de6589ea226;hb=0b124bb4bf8eafae8a4eae9c1fc44bf63da2e62e;hp=233491bc633aaa21337bfb5ba1b01369d0ea6d89;hpb=65f0d0ee4627dd0f0468ceded38677076d78feb5;p=git.git diff --git a/git-tag-script b/git-tag-script index 233491bc..4917f995 100755 --- a/git-tag-script +++ b/git-tag-script @@ -1,8 +1,72 @@ #!/bin/sh -object=${2:-$(cat .git/HEAD)} -type=$(cat-file -t $object) || exit 1 -( echo -e "object $object\ntype $type\ntag $1\n"; cat ) > .tmp-tag -rm -f .tmp-tag.asc -gpg -bsa .tmp-tag && cat .tmp-tag.asc >> .tmp-tag -git-mktag < .tmp-tag -#rm .tmp-tag .tmp-tag.sig +# Copyright (c) 2005 Linus Torvalds + +. 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 + ;; + esac + shift +done + +name="$1" +[ "$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 + +trap 'rm -f .tmp-tag* .tagmsg .editmsg' 0 + +if [ "$annotate" ]; then + ( 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\ntagger $tagger\n"; cat .tagmsg ) > .tmp-tag + rm -f .tmp-tag.asc .tagmsg + 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) +fi + +mkdir -p "$GIT_DIR/refs/tags" +echo $object > "$GIT_DIR/refs/tags/$name"