Am 03.05.2011 00:04, schrieb Junio C Hamano: > Renà Scharfe <rene.scharfe@xxxxxxxxxxxxxx> writes: > >> Aggregating the set of matching characters and passing them back >> during expression evaluation can be more efficient, yes, as it would >> avoid calling regexec() on the printed lines again only to find out >> what to color. But I wouldn't call it easy. E.g. how to return the >> set of matching characters in the following case? >> >> $ git grep --color -e foo --and -e bar > > I would naÃvely expect each of the "grep_expr" in the parsed grep tree to > have not just a one-bit "hit", but rm_so/rm_eo pair, but as I said, I was > asleep while "coloring the parts that matched" discussion was in progress > ;-) That's true, but each one represents a single contiguous run of characters to color. But I meant to say that returning non-contiguous ranges, as you can get in the --and example above, is not that easy. To me. Hmm, if one just wants to color the parts that triggered a match it gets a lot easier. Each pattern just needs to remember the last matching offsets and then show_line can walk the expression tree to find out what needs coloring. Not sure about the details, though. :) > But > >> Also GNU grep doesn't only color the first sufficient match. >> E.g. this will color both b and d: >> >> $ echo abcde | grep --color -e b -e d > > that is probably a useful thing to have. Obviously, my suggestion should > optimize away the match with 'd' to begin with, so keeping rm_so/rm_eo > pair would not help painting d at all. Worse yet, I would expect that > > $ echo abcdeabcde | grep --color -e b -e d > > would need to paint all occurrences for such a purpose, so obviously you > would need an extra pass to find all potential hits. Ugly and makes me > personally wonder if it is really worth it, but the user is explicitly > asking for --color and is prepared to pay the price, so it probably is Ok. The performance impact is low as long as there are lots more lines that don't match than matching ones. Which should be a given for most uses of grep. I always miss hit coloring if I have to use an environment that doesn't provide , similarly to syntax highlighting, so I do think it's worth it, for me at least. Renà -- 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