grep -O: Do not pass color sequences as filenames to pager
With a .gitconfig like this: [color] ui = auto [color "grep"] filename = magenta if stdout is a terminal, the grep machinery will output the color sequence \e[36m before each filename in its output. In the case of "git grep -O foo", output is argv for the pager. Disable color when calling the grep machinery in this case. Signed-off-by: Nazri Ramliy <ayiehere@gmail.com> Signed-off-by: Jonathan Nieder <jrnieder@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
0c72cead84
commit
e7b082a411
@ -125,6 +125,21 @@ test_expect_success 'modified file' '
|
||||
test_cmp empty out
|
||||
'
|
||||
|
||||
test_config() {
|
||||
git config "$1" "$2" &&
|
||||
test_when_finished "git config --unset $1"
|
||||
}
|
||||
|
||||
test_expect_success 'copes with color settings' '
|
||||
rm -f actual &&
|
||||
echo grep.h >expect &&
|
||||
test_config color.grep always &&
|
||||
test_config color.grep.filename yellow &&
|
||||
test_config color.grep.separator green &&
|
||||
git grep -O'\''printf "%s\n" >actual'\'' GREP_AND &&
|
||||
test_cmp expect actual
|
||||
'
|
||||
|
||||
test_expect_success 'run from subdir' '
|
||||
rm -f actual &&
|
||||
echo grep.c >expect &&
|
||||
|
Reference in New Issue
Block a user