Jeff King <peff@xxxxxxxx> writes: > I hope this helps a little bit with Mark's confusion. But while writing > it, I really think it would be a simpler rule to say "if it's in > refs/heads/, then it's a branch" (which is similar to what Mark > suggested earlier). > > So "git checkout refs/heads/master" would be identical to "git checkout > master". That would require a code change, though. Sorry, but I do not get the logic behind such a change. Because you won't be breaking "git checkout frotz" that checks out the branch whose name is frotz (i.e. refs/heads/frotz) even when a tag frotz exists (i.e. refs/tags/frotz), the updated code cannot be "try to resolve the token given from the command line as-is, and if it is in refs/heads/ it is a branch switch, otherwise it is a detach at the commit". The updated code has to be "try to resolve the token appended to refs/heads and if it resolves, that is a branch switch. Otherwise if the token already begins with refs/heads/ then it also is a switch to the branch whose name is the token minus the leading refs/heads/, otherwise try to resolve it as-is and detach at that commit". The result changes behaviour for two classes of people. (1) People who have a branch whose name is refs/heads/frotz. Before they could switch to the branch by mechanically giving its name. Now they have to remember that such a branch with an unusual name needs to be fully spelled "git checkout refs/heads/refs/heads/frotz". (2) People who have scripts that gets a refname (or a list of refnames), and drive "git checkout" to either switch to the branch if that ref is a branch or detach at the commit if it isn't. Their script had to check if the ref begins with refs/heads/ and if so strip that before giving it to "git checkout", but with your change they do not have to. The former technically is a usability regression which I presume we do not care. The user with such a branch name is sick enough and deserve to be punished ;-) The latter might be improvement, but does it really matter? Such a script is already checking with refs/heads/ (and it is easy to codify in a script anyway), and with or without the change you suggest, it will check out the master branch when the ref is refs/heads/master and the script strips the leading refs/heads/. With the change, it also needs to delete the logic of stripping refs/heads/ to deal with (1) sanely. In addition, most likely such a script to check out a series of refs in an automated fashion is about autobuilding random set of commits, and it would probably be better off working on the HEAD detached at given commit, whether the incoming ref happens to be a branch ref or not. So I am still scratching my head, wondering what improvement from the end user's point of view you will be getting from such a change... -- 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