add--interactive: handle EOF in prompt_yesno
The prompt_yesno function loops indefinitely waiting for a "y" or "n" response. But it doesn't handle EOF, meaning that we can end up in an infinite loop of reading EOF from stdin. One way to simulate that is with: echo e | GIT_EDITOR='echo corrupt >' git add -p Let's break out of the loop and propagate the undef to the caller. Without modifying the callers that effectively turns it into a "no" response. This is reasonable for both of the current callers, and it leaves room for any future caller to check for undef explicitly. Signed-off-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
1d73f8e86d
commit
d5addcf522
@ -1152,6 +1152,7 @@ sub prompt_yesno {
|
|||||||
while (1) {
|
while (1) {
|
||||||
print colored $prompt_color, $prompt;
|
print colored $prompt_color, $prompt;
|
||||||
my $line = prompt_single_character;
|
my $line = prompt_single_character;
|
||||||
|
return undef unless defined $line;
|
||||||
return 0 if $line =~ /^n/i;
|
return 0 if $line =~ /^n/i;
|
||||||
return 1 if $line =~ /^y/i;
|
return 1 if $line =~ /^y/i;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user