git-tag: Fix "can't shift that many".

This stop git-tag from emitting a "shift: can't shift that many"
error, when listing tags.

[jc: with further fixups from Sam Vilain merged in; it passes
 the tests under dash now]

Signed-off-by: Alexandre Vassalotti <alexandre@peadrop.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Alexandre Vassalotti 2007-06-28 12:56:57 -04:00 committed by Junio C Hamano
parent bfc04bb9b8
commit 72bb989d6e

View File

@ -19,28 +19,40 @@ do
case "$1" in case "$1" in
-a) -a)
annotate=1 annotate=1
shift
;; ;;
-s) -s)
annotate=1 annotate=1
signed=1 signed=1
shift
;; ;;
-f) -f)
force=1 force=1
shift
;; ;;
-n) -n)
case $2 in case "$#,$2" in
-*) LINES=1 # no argument 1,* | *,-*)
LINES=1 # no argument
;; ;;
*) shift *) shift
LINES=$(expr "$1" : '\([0-9]*\)') LINES=$(expr "$1" : '\([0-9]*\)')
[ -z "$LINES" ] && LINES=1 # 1 line is default when -n is used [ -z "$LINES" ] && LINES=1 # 1 line is default when -n is used
;; ;;
esac esac
shift
;; ;;
-l) -l)
list=1 list=1
shift shift
PATTERN="$1" # select tags by shell pattern, not re case $# in
0) PATTERN=
;;
*)
PATTERN="$1" # select tags by shell pattern, not re
shift
;;
esac
git rev-parse --symbolic --tags | sort | git rev-parse --symbolic --tags | sort |
while read TAG while read TAG
do do
@ -74,7 +86,9 @@ do
if test "$#" = "0"; then if test "$#" = "0"; then
die "error: option -m needs an argument" die "error: option -m needs an argument"
else else
message="$1"
message_given=1 message_given=1
shift
fi fi
;; ;;
-F) -F)
@ -85,13 +99,19 @@ do
else else
message="$(cat "$1")" message="$(cat "$1")"
message_given=1 message_given=1
shift
fi fi
;; ;;
-u) -u)
annotate=1 annotate=1
signed=1 signed=1
shift shift
username="$1" if test "$#" = "0"; then
die "error: option -u needs an argument"
else
username="$1"
shift
fi
;; ;;
-d) -d)
shift shift
@ -126,7 +146,6 @@ do
break break
;; ;;
esac esac
shift
done done
[ -n "$list" ] && exit 0 [ -n "$list" ] && exit 0