Re: [PATCH] Support specific color for a specific remote branches

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Aug 08, 2011 at 02:31:39PM -0700, Junio C Hamano wrote:

> But in real-life, it is entirely plausible that people with multiple
> integration branches are taking advantage of the simplicity of the old
> layout, i.e.
> 
>     [remote "origin"]
>     	fetch = refs/heads/master:refs/heads/origin
>         fetch = refs/heads/next:refs/heads/next
>         fetch = refs/heads/maint:refs/heads/maint
>         fetch = +refs/heads/pu:refs/heads/pu
>
> [...]
>
> Now, for these repositories, is "next" a local branch or a remote one? I
> have a feeling that it might be easier to understand if we label anything
> that you can update with "checkout && commit" a local one for the purpose
> of "branch -r" listing; IOW, the current "git branch -r" classification
> would match this use pattern better, even though refs/heads/next _is_ an
> RHS of a rule to follow others.

Agreed, that really muddies the idea of what is a "remote branch" and
what is not. I think there is a sense among users that "local branches"
and "remote branches" are mutually exclusive sets, even though by some
definitions they may not be (i.e., if you define the former by where in
the refs/ hierarchy they exist, and the latter by being the RHS of a
remote fetch refspec).

> In that sense, I would be entirely happy if the configuration variable
> used in this series were branch.<namepattern>.color and let you specify
> 
> 	[branch "refs/heads"] color = yellow
>         [branch "refs/remotes/origin"] color = purple
>         [branch "refs/remotes/nitfol"] color = cyan

There are two issues I see with that:

  1. Until now, "branch" sections like this have always been about local
     branches.  What are the rules for defining something like
     "branch.refs/remotes/origin/foo.merge"? Knowing how the code works,
     it is easy to say it is a noop, as we will never look at it. But I
     wonder how it looks from the perspective if a recent git user.

  2. Until now, "branch" sections specify full refs, not subsets or
     wildcard patterns. What does "branch.refs/heads.merge" mean?
     A noop? A wildcard with slightly lesser precedence than
     "branch.refs/heads/foo.merge"?

If we are going to go this route, I think it is really about introducing
properties not on branches, but on subsets of the ref namespace. So
might say:

  [ref "refs/heads/*"] color = yellow

which says "whenever you are dealing with this part of the refs
namespace, my preferred color is yellow". And "git branch" happens to
respect that (and we could just as easily have a "%(refcolor)" marker in
git-for-each-ref).

I know the difference is subtle, but I just think it removes entirely
the question about what is a branch and what is not. Furthermore, it
naturally extends to other commands (e.g., you could color subsets of
the tag namespace differently), to more complex layouts (e.g., if we
end up moving fetched tags into the refs/remotes namespace eventually),
and to other properties besides color (though I haven't though up any
applications).

> It becomes complicated (and for no good reason, in my opinion; see the
> "next" example above) if you try to tie this with remote.<name> hierarchy,
> as it obviously becomes illogical not to use the "RHS of a fetch refspec"
> logic when we are talking about remote.<name>.

We've been discussing the coloring issue here. But the other thread I
pointed out was about asking "which fetched branches do we have locally
for this remote?".  Which is a very reasonable thing to ask, and which
don't do a good job of answering right now. And I think it has to
do the "RHS of a fetch refspec thing".

Right now you can do "git remote show". But:

  1. It's very heavyweight. It shows you way more than you want in most
     cases, and it touches the network by default (there is a "-n"
     option, but touching the network by default makes it pretty
     un-git).

  2. It's not as easily discoverable as "git branch -r". It's not
     unreasonable for users to mentally go through the sequence:

       a. "git branch" shows me branches

       b. oh, it has an "-r" option for remotes

       c. how do I limit to one remote?

I'm not sure what the right solution is. Going from 2b to 2c is a very
natural thing for a user to want to do. But it means jumping from one
definition of "remote" (i.e., everything under "refs/remotes") to
another (the config defined by remote "foo"). In the default config,
that is a natural jump, as they are semantically connected. But they
don't have to be.

-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


[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]