aboutsummaryrefslogtreecommitdiff
path: root/git-push.sh
diff options
context:
space:
mode:
authorJunio C Hamano <junkio@cox.net>2006-01-15 23:27:34 -0800
committerJunio C Hamano <junkio@cox.net>2006-01-15 23:59:12 -0800
commit42301e34a2736b091738d4ca6a23fd90bd1f1837 (patch)
tree6ac2b20f996afda0055f2d7d43fb4f47b8ee0361 /git-push.sh
parentfec9ebf16c948bcb4a8b88d0173ee63584bcde76 (diff)
downloadgit-42301e34a2736b091738d4ca6a23fd90bd1f1837.tar.gz
git-42301e34a2736b091738d4ca6a23fd90bd1f1837.tar.xz
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>
Diffstat (limited to 'git-push.sh')
-rwxr-xr-xgit-push.sh27
1 files changed, 15 insertions, 12 deletions
diff --git a/git-push.sh b/git-push.sh
index 136093bf1..ce2ad7138 100755
--- a/git-push.sh
+++ b/git-push.sh
@@ -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,23 +36,26 @@ 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 "$@") ;;
+--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
-case "$do_tags" in
-yes)
- set "$@" $(cd "$GIT_DIR/refs" && find tags -type f -print) ;;
-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