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).
This commit is contained in:
parent
1d8fa411e0
commit
d727782eaf
@ -2,13 +2,36 @@
|
|||||||
# Copyright (c) 2005 Linus Torvalds
|
# Copyright (c) 2005 Linus Torvalds
|
||||||
|
|
||||||
. git-sh-setup-script || die "Not a git archive"
|
. 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="$1"
|
||||||
[ "$name" ] || die "I need a tag-name"
|
[ "$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
|
type=$(git-cat-file -t $object) || exit 1
|
||||||
tagger=$(git-var GIT_COMMITTER_IDENT) || exit 1
|
tagger=$(git-var GIT_COMMITTER_IDENT) || exit 1
|
||||||
|
|
||||||
|
if [ "$signed" ]; then
|
||||||
( echo "#"
|
( echo "#"
|
||||||
echo "# Write a tag message"
|
echo "# Write a tag message"
|
||||||
echo "#" ) > .editmsg
|
echo "#" ) > .editmsg
|
||||||
@ -21,6 +44,9 @@ grep -v '^#' < .editmsg | git-stripspace > .tagmsg
|
|||||||
( echo -e "object $object\ntype $type\ntag $name\ntagger $tagger\n"; cat .tagmsg ) > .tmp-tag
|
( echo -e "object $object\ntype $type\ntag $name\ntagger $tagger\n"; cat .tagmsg ) > .tmp-tag
|
||||||
rm -f .tmp-tag.asc .tagmsg
|
rm -f .tmp-tag.asc .tagmsg
|
||||||
gpg -bsa .tmp-tag && cat .tmp-tag.asc >> .tmp-tag
|
gpg -bsa .tmp-tag && cat .tmp-tag.asc >> .tmp-tag
|
||||||
|
object=$(git-mktag < .tmp-tag)
|
||||||
|
rm -f .tmp-tag .tmp-tag.sig
|
||||||
|
fi
|
||||||
|
|
||||||
mkdir -p "$GIT_DIR/refs/tags"
|
mkdir -p "$GIT_DIR/refs/tags"
|
||||||
git-mktag < .tmp-tag > "$GIT_DIR/refs/tags/$name"
|
echo $object > "$GIT_DIR/refs/tags/$name"
|
||||||
#rm .tmp-tag .tmp-tag.sig
|
|
||||||
|
Loading…
Reference in New Issue
Block a user