colored diff: diff.color = auto fix
Even if the standard output is connected to a tty, do not colorize the diff if we are talking to a dumb terminal when diff.color configuration variable is set to "auto". Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
parent
6bdca89057
commit
a0c2089c1d
10
diff.c
10
diff.c
@ -110,8 +110,14 @@ int git_diff_config(const char *var, const char *value)
|
|||||||
if (!strcmp(var, "diff.color")) {
|
if (!strcmp(var, "diff.color")) {
|
||||||
if (!value)
|
if (!value)
|
||||||
diff_use_color_default = 1; /* bool */
|
diff_use_color_default = 1; /* bool */
|
||||||
else if (!strcasecmp(value, "auto"))
|
else if (!strcasecmp(value, "auto")) {
|
||||||
diff_use_color_default = isatty(1);
|
diff_use_color_default = 0;
|
||||||
|
if (isatty(1)) {
|
||||||
|
char *term = getenv("TERM");
|
||||||
|
if (term && strcmp(term, "dumb"))
|
||||||
|
diff_use_color_default = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
else if (!strcasecmp(value, "never"))
|
else if (!strcasecmp(value, "never"))
|
||||||
diff_use_color_default = 0;
|
diff_use_color_default = 0;
|
||||||
else if (!strcasecmp(value, "always"))
|
else if (!strcasecmp(value, "always"))
|
||||||
|
Loading…
Reference in New Issue
Block a user