Jeff King <peff@xxxxxxxx> writes: > On Thu, Feb 07, 2013 at 09:44:59PM +0530, Ramkumar Ramachandra wrote: > >> This has been annoying me for a really long time, but I never really >> got around to scratching this particular itch. I have a very common >> scenario where I fork a project on GitHub. I have two configured >> remotes: origin which points to "git://upstream" and mine which points >> to "ssh://mine". By default, I always want to pull `master` from >> origin and push to mine. > > Same here. Even without GitHub, working on git.git I treat Junio as my > "origin", but push to a publishing point. The "you fetch from and push to the same place" semantics that associates a branch to a single remote was primarily done for people coming from CVS/SVN background [*1*]. I think the triangle arrangement where you want to have "this is where I fetch from and integrate with, and that is where I publish" is more common among the Git users these days. How best to express the triangle is somewhat tricky, but I think it is sensible to say you have "origin" that points to your upstream (i.e. me), and "peff" that points to your publishing point, in other words, make it explicit that the user deals with two remotes. Then have push.default name the remote "peff", so that "git push" goes to that remote by default (and have "git fetch/pull" go to "origin). You will have two sets of remote tracking branches (one from "origin" that your push will never pretend to have fetched immediately after finishing, the other from "peff" that keeps track of what you pushed the last time). Of course, some people may have "I use this and that branches to interact with upstream X while I use these other branches to interacct with upstream Y, and all of them push to different places", and supporting that may need complex per branch "On this branch fetch from and integrate with remote X, and push to remote Z" settings, but as you said, "I fetch from and integrate with X, and result is pushed out to Y" should be the most common, and it would be desirable to have a simple way to express it with just a single new configuration variable. [Footnote] *1* It also happens to work reasonably well for people like Linus and I with the "I pull from random places, I locally integrate and I publish the results" workflow, because we are trained to think that it is not just being lazy but simply meaningless to say "git pull" without saying "fetch and integrate _what_ and from _whom_", and that is only because we do not have a fixed upstream. Linus and I would practically never fetch from "origin", i.e. from ourselves. -- 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