Hi, Just pulled linux-2.6.git, and got this:
---- New branch: 3a6fd752a50af92765853879f4a11cc0cfcd0320 Tracked branch, applying changes... Merging 4d78b6c78ae6d87e4c1c8072f42efa716f04afb9 -> 3a6fd752a50af92765853879f4a11cc0cfcd0320 to a2755a80f40e5794ddc20e00f781af9d6320fafb... Enter commit message, terminated by ctrl-D on a separate line: Merge with 3a6fd752a50af92765853879f4a11cc0cfcd0320 ---- Weird thing was that I made no changes. Digging a bit deeper, I saw that .git/HEAD was a symlink to .git/heads/master, and the tracked branch was 'origin'. Due to the fact that Linus only have a .git/heads/master on his rsync, and this thus updated to the new sha1, but the 'origin' (and tracked) head is still pointing to an older sha1 caused this confusion. I replicated the linux tree via: ---- git init URL ---- So I had a look at gitinit.sh, which first creates the .git/heads/master and symlinks HEAD to it, then on seeing a URL was supplied, creates a .git/heads/origin, track it, but do *not* change the .git/HEAD symlink ... Is this intended? I see also that gittrack.sh do not update the HEAD symlink ... Is this also intended? I guess a solution is to either just use 'master', and do not do the 'origin' head, or to update the HEAD symlink. I however do not think this is very generic, especially if the remote repo do not call their main head 'master' - so it might be better to check what it have in .git/heads, and if only one, use that as the main and tracked head, else do nothing and tell the user to decide what head to track, etc. The last option however brings a problem or two. First, how do you do the multi-head thing? Maybe add a command 'git lsheads' (and while at it, also add 'git lstags'?)? Secondly, if there was more than one head, the local copy needs to be checked out ... don't know if 'git cancel' is the logical thing the user will think to do ('git clone' perhaps?) ... I think it might be a good time to start thinking and putting to text what commands is really needed, what they should be called, and how exactly they should behave before it gets much later in the game. Anyhow, suggestions/comments welcome. Thanks, -- Martin Schlemmer
signature.asc
Description: This is a digitally signed message part