Hi Junio, On Mon, 7 May 2018, Junio C Hamano wrote: > Jeff King <peff@xxxxxxxx> writes: > > > So really, I guess all I am arguing for is having GIT_COLOR_INV (or > > REVERSE) as a constant, and then teaching the code to combine it with > > the existing "new" color. It's perfectly OK to have: > > > > \x1b[7m\x1b[36m > > > > instead of: > > > > \x1b[7;36m > > > > It's two extra bytes, but I doubt anybody cares. > > I do not think two extra bytes will be missed, but it was not > immediately obvious to me how much flexibility or simplicity weu are > gaining by combining values from multiple configuration variables. > With a "letters on a new line is painted with ${new}, in addition, > the leading plus is further annotated with ${tbdiffNew}" (similarly > to "old") scheme, the user can take advantage of the fact that there > is no ${reset} between ${new} and ${tbdiffNew} and set tbdiffNew and > tbdiffOld to a same value (that does not change the color but > changes some other aspect of the appearance, like "reverse" or > "underline"). Since only pre-designed combination can be used (your > example works only because you chose to allow combination by > annotating the leading "+" with ${new}${tbdiffNew}), we'd need to > (1) establish a convention to paint things with similar meanings in > the same color, modifyable by individual command (e.g. you could say > anything new is by default green with "color.new=green", and then > "color.frotz.new=blink" "color.status.new=" "color.diff.new=blue" > would make frotz, status and diff subcommands to show new things in > blinking green, normal green, and blue), and (2) push the codebase > to adopt such color combination as a preferred design pattern if we > want the resulting system to be useful. > > I guess you are getting simpler configuration, which is a big plus, > but to make a truly useful combining convention, we'd need to > rethink and find a way to transition existing configurations to the > new world, which may not be feasible. I really do not like the sound of that much complexity. It strikes me as yet another instance of Yer Ain't Gonna Need It. In *particular* because nested diffs are a special thing: you *already* get overwhelmed with too much information, and adding colors to the fray won't help. What does help is to keep the colors, so that they can mean the same thing in inner vs outer diffs, but reverse foreground and background to make the outer diff "stick out more". Should my assessment be wrong, I think it'll still be relatively easy to add support for config settings, *then*, not before we know it is needed. Ciao, Dscho