8e76c79f4a
This reverts 9e9b26751a
commit partially.
When no refspec is specified on the command line and there is no
default refspec to push specified in remotes/ file, just let
send-pack to do its default "matching refs" updates.
Thanks to Greg KH for complaining.
Signed-off-by: Junio C Hamano <junkio@cox.net>
82 lines
1.6 KiB
Bash
Executable File
82 lines
1.6 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
USAGE='[--all] [--tags] [--force] <repository> [<refspec>...]'
|
|
. git-sh-setup
|
|
|
|
# Parse out parameters and then stop at remote, so that we can
|
|
# translate it using .git/branches information
|
|
has_all=
|
|
has_force=
|
|
has_exec=
|
|
remote=
|
|
do_tags=
|
|
|
|
while case "$#" in 0) break ;; esac
|
|
do
|
|
case "$1" in
|
|
--all)
|
|
has_all=--all ;;
|
|
--tags)
|
|
do_tags=yes ;;
|
|
--force)
|
|
has_force=--force ;;
|
|
--exec=*)
|
|
has_exec="$1" ;;
|
|
-*)
|
|
usage ;;
|
|
*)
|
|
set x "$@"
|
|
shift
|
|
break ;;
|
|
esac
|
|
shift
|
|
done
|
|
case "$#" in
|
|
0)
|
|
echo "Where would you want to push today?"
|
|
usage ;;
|
|
esac
|
|
|
|
. git-parse-remote
|
|
remote=$(get_remote_url "$@")
|
|
|
|
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'
|
|
|
|
# $# is now 0 if there was no explicit refspec on the command line
|
|
# and there was no defalt refspec to push from remotes/ file.
|
|
# we will let git-send-pack to do its "matching refs" thing.
|
|
|
|
case "$remote" in
|
|
git://*)
|
|
die "Cannot use READ-ONLY transport to push to $remote" ;;
|
|
rsync://*)
|
|
die "Pushing with rsync transport is deprecated" ;;
|
|
esac
|
|
|
|
set x "$remote" "$@"; shift
|
|
test "$has_all" && set x "$has_all" "$@" && shift
|
|
test "$has_force" && set x "$has_force" "$@" && shift
|
|
test "$has_exec" && set x "$has_exec" "$@" && shift
|
|
|
|
case "$remote" in
|
|
http://* | https://*)
|
|
exec git-http-push "$@";;
|
|
*)
|
|
exec git-send-pack "$@";;
|
|
esac
|