git-push: fix --tags and document it.

Previously 'git-push --tags dst', used information from
remotes/dst to determine which refs to push; this patch corrects
it, and also documents the --tags option.

Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
Junio C Hamano
2006-01-15 23:27:34 -08:00
parent fec9ebf16c
commit 42301e34a2
2 changed files with 22 additions and 14 deletions

View File

@ -1,6 +1,6 @@
#!/bin/sh
USAGE='[--all] [--force] <repository> [<refspec>...]'
USAGE='[--all] [--tags] [--force] <repository> [<refspec>...]'
. git-sh-setup
# Parse out parameters and then stop at remote, so that we can
@ -36,24 +36,27 @@ case "$#" in
echo "Where would you want to push today?"
usage ;;
esac
if test ",$has_all,$do_tags," = ",--all,yes,"
then
do_tags=
fi
. git-parse-remote
remote=$(get_remote_url "$@")
case "$has_all" in
--all) set x ;;
'') set x $(get_remote_refs_for_push "$@") ;;
esac
shift
case "$do_tags" in
yes)
set "$@" $(cd "$GIT_DIR/refs" && find tags -type f -print) ;;
case "$has_all" in
--all)
set x ;;
'')
case "$do_tags,$#" in
yes,1)
set x $(cd "$GIT_DIR/refs" && find tags -type f -print) ;;
yes,*)
set x $(cd "$GIT_DIR/refs" && find tags -type f -print) \
$(get_remote_refs_for_push "$@") ;;
,*)
set x $(get_remote_refs_for_push "$@") ;;
esac
esac
shift ;# away the initial 'x'
# Now we have explicit refs from the command line or from remotes/
# shorthand, or --tags. Falling back on the current branch if we still
# do not have any may be an alternative, but prevent mistakes for now.