Merge branch 'jk/status-read-branch-name-fix'
[git] / contrib / examples / git-verify-tag.sh
1 #!/bin/sh
2
3 USAGE='<tag>'
4 SUBDIRECTORY_OK='Yes'
5 . git-sh-setup
6
7 verbose=
8 while test $# != 0
9 do
10         case "$1" in
11         -v|--v|--ve|--ver|--verb|--verbo|--verbos|--verbose)
12                 verbose=t ;;
13         *)
14                 break ;;
15         esac
16         shift
17 done
18
19 if [ "$#" != "1" ]
20 then
21         usage
22 fi
23
24 type="$(git cat-file -t "$1" 2>/dev/null)" ||
25         die "$1: no such object."
26
27 test "$type" = tag ||
28         die "$1: cannot verify a non-tag object of type $type."
29
30 case "$verbose" in
31 t)
32         git cat-file -p "$1" |
33         sed -n -e '/^-----BEGIN PGP SIGNATURE-----/q' -e p
34         ;;
35 esac
36
37 trap 'rm -f "$GIT_DIR/.tmp-vtag"' 0
38
39 git cat-file tag "$1" >"$GIT_DIR/.tmp-vtag" || exit 1
40 sed -n -e '
41         /^-----BEGIN PGP SIGNATURE-----$/q
42         p
43 ' <"$GIT_DIR/.tmp-vtag" |
44 gpg --verify "$GIT_DIR/.tmp-vtag" - || exit 1
45 rm -f "$GIT_DIR/.tmp-vtag"