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:
parent
bfc04bb9b8
commit
72bb989d6e
29
git-tag.sh
29
git-tag.sh
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user