summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: fec9ebf)
raw | patch | inline | side by side (parent: fec9ebf)
author | Junio C Hamano <junkio@cox.net> | |
Mon, 16 Jan 2006 07:27:34 +0000 (23:27 -0800) | ||
committer | Junio C Hamano <junkio@cox.net> | |
Mon, 16 Jan 2006 07:59:12 +0000 (23:59 -0800) |
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>
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>
Documentation/git-push.txt | patch | blob | history | |
git-push.sh | patch | blob | history |
index 2254bac16e65e6a0a097b6fef80aed6e1d6887d4..365cfd4105870892306b6376de768b2f0d4b97a3 100644 (file)
SYNOPSIS
--------
-'git-push' [--all] [--force] <repository> <refspec>...
+'git-push' [--all] [--tags] [--force] <repository> <refspec>...
DESCRIPTION
-----------
Instead of naming each ref to push, specifies all refs
to be pushed.
+\--tags::
+ All refs under `$GIT_DIR/refs/tags` are pushed, in
+ addition to refspecs explicitly listed on the command
+ line.
+
-f, \--force::
Usually, the command refuses to update a local ref that is
not an ancestor of the remote ref used to overwrite it.
diff --git a/git-push.sh b/git-push.sh
index 136093bf138f57d45385c0d71344b4cd85c472d6..ce2ad71382fd8ceac29d366604afcbdba401472f 100755 (executable)
--- a/git-push.sh
+++ b/git-push.sh
#!/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
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