Santi Béjar <sbejar@xxxxxxxxx> writes: > It allows to separate when you fetch from when you merge. So, a "git pull" > can be: > > $ git fetch > $ git pull --local There was something that has been disturbing me in your patches (this one, and the previous "remote=." one) and I could not tell what it was. I think I know what it is now. Let me outline my understanding of the workflow these two changes would help. You have an upstream repository that has more than one branches you are interested in, say "master" and "next". And you work on top of both of them, so you have two branches of your own that correspond to them. So you organize your remote section perhaps like this: [remote."origin"] url = git://git.k.o/.../git.git/ fetch = refs/heads/master:refs/remotes/origin/master fetch = refs/heads/next:refs/remotes/origin/next fetch = +refs/heads/pu:refs/remotes/origin/pu [branch."master"] remote = origin merge = refs/heads/master [branch."next"] remote = origin merge = refs/heads/next That is, your refs/heads/master corresponds to upstream's master branch and your next corresponds to upstream's next branch. When you are on your "master" you would merge changes made to upstream's master into it with "git pull". By the way, could you add descriptions on remote.* to Documentation/config.txt? After doing a "git pull" while on your "master" and finishing working on your "master", you might switch to your "next". At that point, if you want to merge upstream changes without re-fetching, you can do either of the following: git pull . remotes/origin/next git pull --local (the former can be "git pull" if "branch.next.remote=."). I think this is the point of your two patches, and in that sense, the --local one makes "branch.remote=." patch unnecessary. While these save typing on "git pull", two things bother me. * the tool is not helping you decide if you can get away without re-fetching. you need to remember that (1) you fetched from the upstream to update "master" recently _and_ (2) because of your [remote."origin"] configuration your remotes/origin/next was updated while you pulled into your "master". * while the workflow assumes that one local branch is tied closely to one remote branch (in this example, tracked under remotes/origin), the rest of the tools do not take advantage of that assumption to help you decide what to do next. For example, if each of your local branch is tied closely to one remote branch, you should be able to "git fetch" to update the tracking branches and then ask: - what changes are in remote that I haven't merged? - what happens when I pull --local right now? - what changes if any are in mine alone missing from remote? - can I push to remote right now (i.e. would it fast-forward)? - how fresh is the tracking branch that corresponds to my current branch? Right now, these require you to spell out the name of the tracking branch. Assuming you are on your "next" branch: git log ..remotes/origin/next git log remotes/origin/next.. git log remotes/origin/next...next [*1*] git show-branch remotes/origin/next next tail -n 1 .git/logs/remotes/origin/next would be the ways to ask the above questions (and the last one is unreadable unless you can do strptime in your head). Maybe we can introduce a new extended SHA-1 notation to mean "the tracking branch this branch usually merges from". Then we can say: git log ..^ git log ^.. git log ^... git show-branch ^ next I am not sure '^' is syntactically viable, but hopefully you get the idea. [*1*] While three-dots symmetric difference is a nice addition made recently, I often find it irritating that the output does not tell which branch each of the commit is reachable from, and end up running show-branch, which does. Would anybody have a clever idea to fix this cleanly? - 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