On Mon, Sep 07, 2009 at 12:53:18AM -0700, Junio C Hamano wrote: > Josh Triplett <josh@xxxxxxxxxxxxxxxx> writes: > > This configuration option allows systematically rewriting fetch-only > > URLs to push-capable URLs when used with push. For instance: > > > > [url "ssh://example.org/"] > > pushInsteadOf = "git://example.org/" > > > > This will allow clones of "git://example.org/path/to/repo" to > > subsequently push to "ssh://example.org/path/to/repo", without manually > > configuring pushurl for that remote. > > Nice. Thanks. > > @@ -435,12 +449,13 @@ static void alias_all_urls(void) > > for (i = 0; i < remotes_nr; i++) { > > if (!remotes[i]) > > continue; > > - for (j = 0; j < remotes[i]->url_nr; j++) { > > - remotes[i]->url[j] = alias_url(remotes[i]->url[j], &rewrites); > > - } > > for (j = 0; j < remotes[i]->pushurl_nr; j++) { > > remotes[i]->pushurl[j] = alias_url(remotes[i]->pushurl[j], &rewrites); > > } > > + for (j = 0; j < remotes[i]->url_nr; j++) { > > + remotes[i]->url[j] = alias_url(remotes[i]->url[j], &rewrites); > > + add_pushurl_alias(remotes[i], remotes[i]->url[j]); > > + } > > Even if you have URL but not pushURL, now you get a corresponding pushURL > for free by just adding pushinsteadof mapping that covers the URL without > having to configue pushURL for each of them. Yes, exactly. > What happens if you already had a pair of concrete url and pushurl defined > for one of your repositories (say git://git.kernel.org/pub/scm/git/git.git > for fetch, ssh://x.kernel.org/pub/scm/git/git.git for push) at a site, and > then upon seeing this new feature, added a pushinsteadof pattern that also > covers the URL side of that pair (e.g. everything in git://git.kernel.org/ > is mapped to x.kernel.org:/ namespsace)? > > Do you end up pushing to both (e.g. ssh://x.kernel.org/pub/scm/git/git.git > and x.kernel.org:/pub/scm/git/git.git), or in such a case, the pushURL you > gave explicitly prevents the pushinsteadof to give unexpected duplicates? You get a duplicate: ~$ grep -B1 steadOf .gitconfig [url "ssh://joshtriplett.org/"] pushInsteadOf="git://joshtriplett.org/" ~$ grep -B1 url .git/config [remote "origin"] url = git://joshtriplett.org/git/home.git pushurl = ssh://joshtriplett.org/git/home.git ~$ ~/src/git/git push Everything up-to-date Everything up-to-date Initially, that behavior seemed pretty reasonable to me; nothing else in the remotes handling attempts to remove duplicates, and they seem harmless enough and easily resolved by removing one or the other. Now that I think about it, though, an explicit pushurl should definitely disable pushInsteadOf's implicit pushurls. If you explicitly configure a *different* pushurl for a remote, you may not *want* the default pushurl that corresponds to your url. For instance, consider what would happen if you configure url to point to the main public repository and pushurl to point to a private repository. In this case, you definitely don't want "git push" to helpfully push to the public repository as well; if you do, you can easily enough add a second pushurl for that. I can easily change the patch to make an explicit pushurl disable pushInsteadOf. Expect v2 shortly. - Josh Triplett -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html