|
|
@ -731,14 +731,17 @@ sub parse_diff_header { |
|
|
|
|
|
|
|
|
|
|
|
my $head = { TEXT => [], DISPLAY => [], TYPE => 'header' }; |
|
|
|
my $head = { TEXT => [], DISPLAY => [], TYPE => 'header' }; |
|
|
|
my $mode = { TEXT => [], DISPLAY => [], TYPE => 'mode' }; |
|
|
|
my $mode = { TEXT => [], DISPLAY => [], TYPE => 'mode' }; |
|
|
|
|
|
|
|
my $deletion = { TEXT => [], DISPLAY => [], TYPE => 'deletion' }; |
|
|
|
|
|
|
|
|
|
|
|
for (my $i = 0; $i < @{$src->{TEXT}}; $i++) { |
|
|
|
for (my $i = 0; $i < @{$src->{TEXT}}; $i++) { |
|
|
|
my $dest = $src->{TEXT}->[$i] =~ /^(old|new) mode (\d+)$/ ? |
|
|
|
my $dest = |
|
|
|
$mode : $head; |
|
|
|
$src->{TEXT}->[$i] =~ /^(old|new) mode (\d+)$/ ? $mode : |
|
|
|
|
|
|
|
$src->{TEXT}->[$i] =~ /^deleted file/ ? $deletion : |
|
|
|
|
|
|
|
$head; |
|
|
|
push @{$dest->{TEXT}}, $src->{TEXT}->[$i]; |
|
|
|
push @{$dest->{TEXT}}, $src->{TEXT}->[$i]; |
|
|
|
push @{$dest->{DISPLAY}}, $src->{DISPLAY}->[$i]; |
|
|
|
push @{$dest->{DISPLAY}}, $src->{DISPLAY}->[$i]; |
|
|
|
} |
|
|
|
} |
|
|
|
return ($head, $mode); |
|
|
|
return ($head, $mode, $deletion); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
sub hunk_splittable { |
|
|
|
sub hunk_splittable { |
|
|
@ -1206,7 +1209,7 @@ sub patch_update_file { |
|
|
|
my ($ix, $num); |
|
|
|
my ($ix, $num); |
|
|
|
my $path = shift; |
|
|
|
my $path = shift; |
|
|
|
my ($head, @hunk) = parse_diff($path); |
|
|
|
my ($head, @hunk) = parse_diff($path); |
|
|
|
($head, my $mode) = parse_diff_header($head); |
|
|
|
($head, my $mode, my $deletion) = parse_diff_header($head); |
|
|
|
for (@{$head->{DISPLAY}}) { |
|
|
|
for (@{$head->{DISPLAY}}) { |
|
|
|
print; |
|
|
|
print; |
|
|
|
} |
|
|
|
} |
|
|
@ -1214,6 +1217,9 @@ sub patch_update_file { |
|
|
|
if (@{$mode->{TEXT}}) { |
|
|
|
if (@{$mode->{TEXT}}) { |
|
|
|
unshift @hunk, $mode; |
|
|
|
unshift @hunk, $mode; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
if (@{$deletion->{TEXT}} && !@hunk) { |
|
|
|
|
|
|
|
@hunk = ($deletion); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
$num = scalar @hunk; |
|
|
|
$num = scalar @hunk; |
|
|
|
$ix = 0; |
|
|
|
$ix = 0; |
|
|
@ -1267,7 +1273,9 @@ sub patch_update_file { |
|
|
|
print; |
|
|
|
print; |
|
|
|
} |
|
|
|
} |
|
|
|
print colored $prompt_color, $patch_mode_flavour{VERB}, |
|
|
|
print colored $prompt_color, $patch_mode_flavour{VERB}, |
|
|
|
($hunk[$ix]{TYPE} eq 'mode' ? ' mode change' : ' this hunk'), |
|
|
|
($hunk[$ix]{TYPE} eq 'mode' ? ' mode change' : |
|
|
|
|
|
|
|
$hunk[$ix]{TYPE} eq 'deletion' ? ' deletion' : |
|
|
|
|
|
|
|
' this hunk'), |
|
|
|
$patch_mode_flavour{TARGET}, |
|
|
|
$patch_mode_flavour{TARGET}, |
|
|
|
" [y,n,q,a,d,/$other,?]? "; |
|
|
|
" [y,n,q,a,d,/$other,?]? "; |
|
|
|
my $line = prompt_single_character; |
|
|
|
my $line = prompt_single_character; |
|
|
|