Johannes Schindelin <[EMAIL PROTECTED]> writes: > I'd prefer $GIT_DIR/remotes/. And I propose another extension: Since the > files stored therein right now contain only one <remote> string, it should > be possible to add the default head(s) to the file.
That makes sense. Currently my arrangement is: $ cd .git/branches && grep . public-* public-master:http://www.kernel.org/pub/scm/git/git.git/ public-pu:http://www.kernel.org/pub/scm/git/git.git/#pu public-rc:http://www.kernel.org/pub/scm/git/git.git/#rc and in order to get the references on the public server to make sure people are seeing what I want them to see, I say: $ for h in master pu rc do echo $h git fetch public-$h git-rev-parse $h public-$h done Instead, I should be able to say: $ cat .git/remotes/public http://www.kernel.org/pub/scm/git/git.git/#pu:public-pu,rc:public-rc to mean that the following two are equivalent: $ git fetch public $ git fetch public pu:public-pu rc:public-rc that is, fetch pu there and store it in refs/heads/public-pu (same for rc). When I want to fetch only pu from there: $ git fetch public pu:public-pu or even $ git fetch public pu should work. If I happen to want to fetch pu one-shot but not want to update my local refs/heads/public-pu, then I should be able to say $ git fetch public pu: Another thing I need to worry about is that I would want to use this remotes information for pushing as well, but probably the reference mappings are different when fetching and pushing. With something like this: $ cat .git/remotes/ko kernel.org:/pub/scm/git/git.git/#master:ko-master,pu:ko-pu,rc:ko-rc $ git fetch ko rc I would fetch the remote ref "rc" and store it in refs/heads/ko-rc, which is fine, but after that I would do my work in the local repository, merge things up and update my local "rc" (not ko-rc, which to me is a "reference only" branch), and eventually when pushing I would want to store my "rc" (again not ko-rc) in "rc" over there. This means the reference mapping in these two shorthand notations should be flexible enough to allow me to do: $ git fetch ko rc ;# get rc from there store it under ko-rc here which is equivalent to $ git fetch ko rc:ko-rc and $ git push ko rc ;# push rc here to rc there which is equivalent to $ git push ko rc:rc Maybe its time to do a file format that is a bit more flexible. For example: $ cat .git/remotes/ko URL: kernel.org:/pub/scm/git/git.git/ Fetch-Reference: master:ko-master pu:ko-pu rc:ko-rc Push-Reference: master pu rc Note that I do not mean "Push-Reference" can not do the rename. I could have written "master:master" but I did not because I do _not_ want renaming push in this example. People who do not need different mappings for fetch/push should be able to say: $ cat .git/remotes/public URL: http://www.kernel.org/pub/scm/git/git.git/ Reference: pu:public-pu rc:public-rc Another thing I should mention is that Fetch-Reference mapping is <remote>:<local>, while Push-Reference is <local>:<remote>. This is only because I feel always using <src>:<dst> is easy to remember, is the way it works for the command line refs for git push already, and is the way I plan to enhance fetch to grok. My current thinking is Reference should take <remote>:<local> because fetching/pulling is probably more common than pushing, but I need to think a bit more about it. Johannes, sorry for doing my design work in an e-mail buffer to you ;-). - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html