diff options
author | Junio C Hamano <gitster@pobox.com> | 2007-07-02 04:00:08 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2007-07-03 05:57:45 +0200 |
commit | 098e711e6c0d123dff2f38d6b804ec632ad7dd78 (patch) | |
tree | 8eff204173270918a0fd53a7b6c589708941a22e /remote.c | |
parent | Merge branch 'maint' (diff) | |
download | git-098e711e6c0d123dff2f38d6b804ec632ad7dd78.tar.xz git-098e711e6c0d123dff2f38d6b804ec632ad7dd78.zip |
"git-push $URL" without refspecs pushes only matching branches
When "git push" is run without any refspec (neither on the
command line nor in the config), we used to push "matching refs"
in the sense that anything under refs/ hierarchy that exist on
both ends were updated. This used to be a sane default for
publishing your repository to another back when we did not have
refs/remotes/ hierarchy, but it does not make much sense these
days.
This changes the semantics to push only "matching branches".
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'remote.c')
-rw-r--r-- | remote.c | 7 |
1 files changed, 7 insertions, 0 deletions
@@ -544,6 +544,13 @@ int match_refs(struct ref *src, struct ref *dst, struct ref ***dst_tail, if (!pat) continue; } + else if (prefixcmp(src->name, "refs/heads/")) + /* + * "matching refs"; traditionally we pushed everything + * including refs outside refs/heads/ hierarchy, but + * that does not make much sense these days. + */ + continue; if (pat) { const char *dst_side = pat->dst ? pat->dst : pat->src; |