Add / command in add --patch

This command allows the user to skip hunks that don't match the specified
regex.

Signed-off-by: William Pursell <bill.pursell@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
William Pursell 2008-11-27 04:07:57 +00:00 committed by Junio C Hamano
parent 57886bc7fb
commit dd971cc9d6

View File

@ -801,6 +801,7 @@ n - do not stage this hunk
a - stage this and all the remaining hunks in the file a - stage this and all the remaining hunks in the file
d - do not stage this hunk nor any of the remaining hunks in the file d - do not stage this hunk nor any of the remaining hunks in the file
g - select a hunk to go to g - select a hunk to go to
/ - search for a hunk matching the given regex
j - leave this hunk undecided, see next undecided hunk j - leave this hunk undecided, see next undecided hunk
J - leave this hunk undecided, see next hunk J - leave this hunk undecided, see next hunk
k - leave this hunk undecided, see previous undecided hunk k - leave this hunk undecided, see previous undecided hunk
@ -964,7 +965,7 @@ sub patch_update_file {
for (@{$hunk[$ix]{DISPLAY}}) { for (@{$hunk[$ix]{DISPLAY}}) {
print; print;
} }
print colored $prompt_color, "Stage this hunk [y,n,a,d$other,?]? "; print colored $prompt_color, "Stage this hunk [y,n,a,d,/$other,?]? ";
my $line = <STDIN>; my $line = <STDIN>;
if ($line) { if ($line) {
if ($line =~ /^y/i) { if ($line =~ /^y/i) {
@ -1013,6 +1014,31 @@ sub patch_update_file {
} }
next; next;
} }
elsif ($line =~ m|^/(.*)|) {
my $search_string;
eval {
$search_string = qr{$1}m;
};
if ($@) {
my ($err,$exp) = ($@, $1);
$err =~ s/ at .*git-add--interactive line \d+, <STDIN> line \d+.*$//;
print STDERR "Malformed search regexp $exp: $err\n";
next;
}
my $iy = $ix;
while (1) {
my $text = join ("", @{$hunk[$iy]{TEXT}});
last if ($text =~ $search_string);
$iy++;
$iy = 0 if ($iy >= $num);
if ($ix == $iy) {
print STDERR "No hunk matches the given pattern\n";
last;
}
}
$ix = $iy;
next;
}
elsif ($other =~ /K/ && $line =~ /^K/) { elsif ($other =~ /K/ && $line =~ /^K/) {
$ix--; $ix--;
next; next;