2005-07-08 23:24:25 +02:00
|
|
|
#!/bin/sh
|
2005-10-29 06:16:33 +02:00
|
|
|
|
2006-01-16 08:27:34 +01:00
|
|
|
USAGE='[--all] [--tags] [--force] <repository> [<refspec>...]'
|
2005-12-13 23:30:31 +01:00
|
|
|
. git-sh-setup
|
2005-10-29 06:16:33 +02:00
|
|
|
|
2005-08-08 07:55:45 +02:00
|
|
|
# Parse out parameters and then stop at remote, so that we can
|
|
|
|
# translate it using .git/branches information
|
|
|
|
has_all=
|
|
|
|
has_force=
|
|
|
|
has_exec=
|
2006-03-26 04:27:15 +02:00
|
|
|
has_thin=--thin
|
2005-08-08 07:55:45 +02:00
|
|
|
remote=
|
git-push: avoid falling back on pushing "matching" refs.
The underlying "git send-pack remote.host:path" pushes all the
matching refs that both local and remote have, and "git push"
blindly inherits this property. Which probably was a mistake.
A typical cloned repository (e.g. a subsystem repository cloned
from Linus repository) has at least two branches, "master" to
keep the subsystem and "origin" that records tip of Linus
"master" when the repository was cloned. If this is the public
repository for the subsystem, then subsystem developers would
clone it, and then cloned ones have "master" and "origin". When
developers use this public subsystem repository as a shared
repository, pushing into it via "git push subsys:/path/name"
would try to push the matching refs, "master" and "origin", from
the developers' repositories. The "origin" in the public shared
repository does not have much relevance, yet pushing into
"origin" would cause "not a fast forward" checks to be
triggered. Arguably "git push subsys:/path/name master" would
work it around, but having them to say it explicitly to avoid
pushing into "origin" as well is bad.
This commit requires you to give at least one refspec to
git-push. You could "give" by either:
(1) Listing the refspec(s) explicitly on the command line.
E.g. "git push subsys:/path/name master".
(2) Using --all or --tags on the command line.
E.g. "git push --tags subsys:/path/name".
(3) Using a $GIT_DIR/remotes shorthand with 'Push: refspec'
line in it.
Unlike pull that can happen pretty much promiscuously, people
will push into the same set of a limited number of remote
repositories repeatedly over the life of the project, so it is
reasonable to assume they would want to keep a $GIT_DIR/remotes/
entry for those repositories even only to save typing the URL,
so keeping the default 'Push: refspec' line in such is a
sensible thing to do.
It was suggested to further fall back on pushing the current
branch, but this commit does not implement it. If developers
adopt topic branch workflow, pushing to public while on a topic
branch by mistake would expose the topic branch to the public
repository. Not falling back to the current branch prevents
that mistake from happening.
Signed-off-by: Junio C Hamano <junkio@cox.net>
2006-01-13 00:29:12 +01:00
|
|
|
do_tags=
|
2005-08-08 07:55:45 +02:00
|
|
|
|
|
|
|
while case "$#" in 0) break ;; esac
|
|
|
|
do
|
|
|
|
case "$1" in
|
|
|
|
--all)
|
|
|
|
has_all=--all ;;
|
git-push: avoid falling back on pushing "matching" refs.
The underlying "git send-pack remote.host:path" pushes all the
matching refs that both local and remote have, and "git push"
blindly inherits this property. Which probably was a mistake.
A typical cloned repository (e.g. a subsystem repository cloned
from Linus repository) has at least two branches, "master" to
keep the subsystem and "origin" that records tip of Linus
"master" when the repository was cloned. If this is the public
repository for the subsystem, then subsystem developers would
clone it, and then cloned ones have "master" and "origin". When
developers use this public subsystem repository as a shared
repository, pushing into it via "git push subsys:/path/name"
would try to push the matching refs, "master" and "origin", from
the developers' repositories. The "origin" in the public shared
repository does not have much relevance, yet pushing into
"origin" would cause "not a fast forward" checks to be
triggered. Arguably "git push subsys:/path/name master" would
work it around, but having them to say it explicitly to avoid
pushing into "origin" as well is bad.
This commit requires you to give at least one refspec to
git-push. You could "give" by either:
(1) Listing the refspec(s) explicitly on the command line.
E.g. "git push subsys:/path/name master".
(2) Using --all or --tags on the command line.
E.g. "git push --tags subsys:/path/name".
(3) Using a $GIT_DIR/remotes shorthand with 'Push: refspec'
line in it.
Unlike pull that can happen pretty much promiscuously, people
will push into the same set of a limited number of remote
repositories repeatedly over the life of the project, so it is
reasonable to assume they would want to keep a $GIT_DIR/remotes/
entry for those repositories even only to save typing the URL,
so keeping the default 'Push: refspec' line in such is a
sensible thing to do.
It was suggested to further fall back on pushing the current
branch, but this commit does not implement it. If developers
adopt topic branch workflow, pushing to public while on a topic
branch by mistake would expose the topic branch to the public
repository. Not falling back to the current branch prevents
that mistake from happening.
Signed-off-by: Junio C Hamano <junkio@cox.net>
2006-01-13 00:29:12 +01:00
|
|
|
--tags)
|
|
|
|
do_tags=yes ;;
|
2005-08-08 07:55:45 +02:00
|
|
|
--force)
|
|
|
|
has_force=--force ;;
|
|
|
|
--exec=*)
|
|
|
|
has_exec="$1" ;;
|
2006-02-20 09:09:41 +01:00
|
|
|
--thin)
|
2006-03-26 04:27:15 +02:00
|
|
|
;; # noop
|
|
|
|
--no-thin)
|
|
|
|
has_thin= ;;
|
2005-08-08 07:55:45 +02:00
|
|
|
-*)
|
2005-10-29 06:16:33 +02:00
|
|
|
usage ;;
|
2005-08-08 07:55:45 +02:00
|
|
|
*)
|
|
|
|
set x "$@"
|
|
|
|
shift
|
|
|
|
break ;;
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
2005-08-26 19:37:17 +02:00
|
|
|
case "$#" in
|
|
|
|
0)
|
2005-10-29 06:17:17 +02:00
|
|
|
echo "Where would you want to push today?"
|
|
|
|
usage ;;
|
2005-08-26 19:37:17 +02:00
|
|
|
esac
|
2005-08-08 07:55:45 +02:00
|
|
|
|
2005-09-08 02:26:23 +02:00
|
|
|
. git-parse-remote
|
2005-08-20 11:52:24 +02:00
|
|
|
remote=$(get_remote_url "$@")
|
2006-01-16 08:27:34 +01:00
|
|
|
|
2005-08-20 11:52:24 +02:00
|
|
|
case "$has_all" in
|
2006-01-16 08:27:34 +01:00
|
|
|
--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
|
2005-08-08 07:55:45 +02:00
|
|
|
esac
|
|
|
|
|
2006-01-16 08:27:34 +01:00
|
|
|
shift ;# away the initial 'x'
|
git-push: avoid falling back on pushing "matching" refs.
The underlying "git send-pack remote.host:path" pushes all the
matching refs that both local and remote have, and "git push"
blindly inherits this property. Which probably was a mistake.
A typical cloned repository (e.g. a subsystem repository cloned
from Linus repository) has at least two branches, "master" to
keep the subsystem and "origin" that records tip of Linus
"master" when the repository was cloned. If this is the public
repository for the subsystem, then subsystem developers would
clone it, and then cloned ones have "master" and "origin". When
developers use this public subsystem repository as a shared
repository, pushing into it via "git push subsys:/path/name"
would try to push the matching refs, "master" and "origin", from
the developers' repositories. The "origin" in the public shared
repository does not have much relevance, yet pushing into
"origin" would cause "not a fast forward" checks to be
triggered. Arguably "git push subsys:/path/name master" would
work it around, but having them to say it explicitly to avoid
pushing into "origin" as well is bad.
This commit requires you to give at least one refspec to
git-push. You could "give" by either:
(1) Listing the refspec(s) explicitly on the command line.
E.g. "git push subsys:/path/name master".
(2) Using --all or --tags on the command line.
E.g. "git push --tags subsys:/path/name".
(3) Using a $GIT_DIR/remotes shorthand with 'Push: refspec'
line in it.
Unlike pull that can happen pretty much promiscuously, people
will push into the same set of a limited number of remote
repositories repeatedly over the life of the project, so it is
reasonable to assume they would want to keep a $GIT_DIR/remotes/
entry for those repositories even only to save typing the URL,
so keeping the default 'Push: refspec' line in such is a
sensible thing to do.
It was suggested to further fall back on pushing the current
branch, but this commit does not implement it. If developers
adopt topic branch workflow, pushing to public while on a topic
branch by mistake would expose the topic branch to the public
repository. Not falling back to the current branch prevents
that mistake from happening.
Signed-off-by: Junio C Hamano <junkio@cox.net>
2006-01-13 00:29:12 +01:00
|
|
|
|
2006-01-21 21:36:12 +01:00
|
|
|
# $# 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.
|
git-push: avoid falling back on pushing "matching" refs.
The underlying "git send-pack remote.host:path" pushes all the
matching refs that both local and remote have, and "git push"
blindly inherits this property. Which probably was a mistake.
A typical cloned repository (e.g. a subsystem repository cloned
from Linus repository) has at least two branches, "master" to
keep the subsystem and "origin" that records tip of Linus
"master" when the repository was cloned. If this is the public
repository for the subsystem, then subsystem developers would
clone it, and then cloned ones have "master" and "origin". When
developers use this public subsystem repository as a shared
repository, pushing into it via "git push subsys:/path/name"
would try to push the matching refs, "master" and "origin", from
the developers' repositories. The "origin" in the public shared
repository does not have much relevance, yet pushing into
"origin" would cause "not a fast forward" checks to be
triggered. Arguably "git push subsys:/path/name master" would
work it around, but having them to say it explicitly to avoid
pushing into "origin" as well is bad.
This commit requires you to give at least one refspec to
git-push. You could "give" by either:
(1) Listing the refspec(s) explicitly on the command line.
E.g. "git push subsys:/path/name master".
(2) Using --all or --tags on the command line.
E.g. "git push --tags subsys:/path/name".
(3) Using a $GIT_DIR/remotes shorthand with 'Push: refspec'
line in it.
Unlike pull that can happen pretty much promiscuously, people
will push into the same set of a limited number of remote
repositories repeatedly over the life of the project, so it is
reasonable to assume they would want to keep a $GIT_DIR/remotes/
entry for those repositories even only to save typing the URL,
so keeping the default 'Push: refspec' line in such is a
sensible thing to do.
It was suggested to further fall back on pushing the current
branch, but this commit does not implement it. If developers
adopt topic branch workflow, pushing to public while on a topic
branch by mistake would expose the topic branch to the public
repository. Not falling back to the current branch prevents
that mistake from happening.
Signed-off-by: Junio C Hamano <junkio@cox.net>
2006-01-13 00:29:12 +01:00
|
|
|
|
2005-08-08 07:55:45 +02:00
|
|
|
case "$remote" in
|
2005-11-02 20:19:31 +01:00
|
|
|
git://*)
|
2005-10-29 06:16:33 +02:00
|
|
|
die "Cannot use READ-ONLY transport to push to $remote" ;;
|
|
|
|
rsync://*)
|
|
|
|
die "Pushing with rsync transport is deprecated" ;;
|
2005-08-08 07:55:45 +02:00
|
|
|
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
|
2006-02-20 09:09:41 +01:00
|
|
|
test "$has_thin" && set x "$has_thin" "$@" && shift
|
2005-08-08 07:55:45 +02:00
|
|
|
|
2005-11-02 20:19:31 +01:00
|
|
|
case "$remote" in
|
|
|
|
http://* | https://*)
|
|
|
|
exec git-http-push "$@";;
|
|
|
|
*)
|
|
|
|
exec git-send-pack "$@";;
|
|
|
|
esac
|