On Mon, Feb 06, 2012 at 03:42:24PM +1100, Andrew Ardill wrote: > On 6 February 2012 15:30, Jeff King <peff@xxxxxxxx> wrote: > > > And perhaps in that case we should be discouraging them from calling it > > something besides master (because while master is mostly convention, > > there are a few magic spots in the code where it is treated specially, > > and departing from the convention for no good reason should be > > discouraged). > > What exactly are the areas where 'master' is treated specially? I > agree that people should be discouraged from needlessly abandoning > convention, however I think users should have the ability to name > their branches as they see fit. Fairly minor stuff. Between the top of my head and a quick grep: 1. Some transports (like git://) are incapable of communicating the destination of a remote's symbolic ref (they see only that HEAD points to some specific sha1). But things like "clone" want to know where the HEAD is pointing to set up the remotes/$origin/HEAD link. We can guess that if HEAD and some branch have the same sha1, that HEAD is pointing to that branch. But you might have two or more such branches pointing to the same spot. In this case, we prefer "master" over other branches. This code is in guess_remote_head. 2. When merging, if the current branch is named "master", the default merge message says "Merge branch foo". Otherwise, it says "Merge branch foo into bar". 3. It looks like the antique "branches" file format defaults to fetching "master" when no branch specifier is given. I doubt anyone is still using this file format these days. I was actually surprised how infrequently the term "master" comes up in a grep of the code. So while I wouldn't call my search exhaustive, I did inspect every match in the C code. > If I am forced to abandon code targeted at the 'master' naming > convention in order to use my desired naming convention, we should fix > that. Additionally, if I have to either manually set a branch name > with plumbing commands, or delete existing branches that are generated > automatically with no option not to generate them, we should improve > the porcelain to cover these cracks. > > In general, I think it plausible that in some use cases the term > 'master' might be misleading or inappropriate and users should not be > punished for that. I kind of agree that we shouldn't be unnecessarily restrictive. On the other hand, I am stretching to find the plausible reason that one would want to throw away the normal convention. Code aside, it simply introduces a slight communication barrier when talking with other git users, and for that reason should be something you don't do lightly. I don't recall seeing anybody complain seriously about it in the past six years of git's existence. -Peff -- 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