Karthik Nayak <[email protected]> writes:
> We check if given ref is the current branch in print_ref_list(). Move
> this check to print_ref_item() where it is checked right before
> printing.
This means that the '*' and the different color are coded in C, hence
it's not possible to mimick this using "git for-each-ref --format ...".
I do not consider this as blocking, but I think the ultimate goal should
be to allow this, so that all the goodies of "git branch" can be made
available to other ref-listing commands.
> --- a/builtin/branch.c
> +++ b/builtin/branch.c
> @@ -534,9 +534,9 @@ static char *get_head_description(void)
> }
>
> static void print_ref_item(struct ref_item *item, int maxwidth, int verbose,
> - int abbrev, int current, const char *remote_prefix)
> + int abbrev, int detached, const char *remote_prefix)
> {
> - char c;
> + char c = ' ';
> int color;
> struct strbuf out = STRBUF_INIT, name = STRBUF_INIT;
> const char *prefix = "";
> @@ -547,7 +547,11 @@ static void print_ref_item(struct ref_item *item, int
> maxwidth, int verbose,
>
> switch (item->kind) {
> case REF_LOCAL_BRANCH:
> - color = BRANCH_COLOR_LOCAL;
> + if (!detached && !strcmp(item->name, head)) {
> + color = BRANCH_COLOR_CURRENT;
> + c = '*';
> + } else
> + color = BRANCH_COLOR_LOCAL;
> break;
> case REF_REMOTE_BRANCH:
> color = BRANCH_COLOR_REMOTE;
> @@ -556,18 +560,13 @@ static void print_ref_item(struct ref_item *item, int
> maxwidth, int verbose,
> case REF_DETACHED_HEAD:
> color = BRANCH_COLOR_CURRENT;
> desc = get_head_description();
> + c = '*';
> break;
> default:
> color = BRANCH_COLOR_PLAIN;
> break;
> }
>
> - c = ' ';
> - if (current) {
> - c = '*';
> - color = BRANCH_COLOR_CURRENT;
> - }
I actually prefered the old way: current is a Boolean that says
semantically "this is the current branch", and the Boolean is turned
into presentation directives in a separate piece of code.
I'd write
char c;
int current = 0;
...
if (...)
current = 1;
...
case REF_DETACHED_HEAD:
current = 1;
...
and keep the last hunk.
(IOW, turn current from a parameter into a local variable)
--
Matthieu Moy
http://www-verimag.imag.fr/~moy/
--
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