Junio C Hamano wrote: > William Pursell <bill.pursell@xxxxxxxxx> writes: > >>> How well does substr() work with utf-8 and other multi-byte encodings >>> these days, I have to wonder... >> Hopefully, it works well. > > "Hopefully" is the last word I'd like to hear from submitters. It would > be either "I do not know" or "I studied the topic and I know the code works". Right. From what I can tell (30 minutes of research, and I am by no means an expert), perl 5.8 will handle this just fine with no changes to the code as long as one of the environment variables LANGUAGE, LC_ALL, LC_TYPE, or LANG contains either 'UTF-8' or 'UTF8'. With that setting, all file handles will be opened in UTF8 mode, so the git diff-files pipe should be parsed appropriately. I think this is not an issue except with older Perl. > By the way, I noticed that you are sending your patches with: > > Content-Type: text/plain; charset=ISO-8859-1; format=flowed > > Please don't. format=flawed tends to destroy whitespaces (I fixed them up > by hand for the ones I parked in 'pu'). Thanks for pointing that out. Settings changed. I do appreciate you taking the time to essentially hold my hand through this process, and hope that I'm not causing you too much extra work. > I would say "$line =~ /^[-+].*\w/" (i.e. match any +/- line that contains > a word letter) would be sufficient, and it would be much easier to read. > > As you append the entire $line to $summary, there is no need to capture > with (). Done. > > I think "$i ||= 0" is more customary. > Also changed. >From 2d191d7170948246007cbde5afb28eeb666b3427 Mon Sep 17 00:00:00 2001 From: William Pursell <bill.pursell@xxxxxxxxx> Date: Thu, 4 Dec 2008 10:00:24 +0000 Subject: [PATCH 1/2] Add subroutine to display one-line summary of hunks. This commit implements a rather simple-minded mechanism to display a one-line summary of the hunks in an array ref. The display consists of the line numbers and the first changed line, truncated to 80 characters. 20 lines are displayed at a time, and the index of the first undisplayed line is returned, allowing the caller to display more if desired. (The 20 and 80 should be made configurable.) Signed-off-by: William Pursell <bill.pursell@xxxxxxxxx> --- changes from v1: do not print '@@' characters in summary pad line numbers in summary to 20 chars to help alignment only accept diff lines with a non-space, non-bracket character ensure a newline appears on a trimmed line changes from v2: accept any line with a word char (instead of insisting on non-bracket) use "$i || = 0" instead of "$i = 0 if not $i" git-add--interactive.perl | 41 +++++++++++++++++++++++++++++++++++++++++ 1 files changed, 41 insertions(+), 0 deletions(-) diff --git a/git-add--interactive.perl b/git-add--interactive.perl index b0223c3..eb11132 100755 --- a/git-add--interactive.perl +++ b/git-add--interactive.perl @@ -836,6 +836,47 @@ sub patch_update_cmd { } } +# Generate a one line summary of a hunk. +sub summarize_hunk { + my $rhunk = shift; + my $summary = $rhunk->{TEXT}[0]; + + # Keep the line numbers, discard extra context. + $summary =~ s/@@(.*?)@@.*/$1 /s; + $summary .= " " x (20 - length $summary); + + # Add some user context. + for my $line (@{$rhunk->{TEXT}}) { + if ($line =~ m/^[+-].*\w/) { + $summary .= $line; + last; + } + } + + chomp $summary; + return substr($summary, 0, 80) . "\n"; +} + + +# Print a one-line summary of each hunk in the array ref in +# the first argument, starting wih the index in the 2nd. +sub display_hunks { + my ($hunks, $i) = @_; + my $ctr = 0; + $i ||= 0; + for (; $i < @$hunks && $ctr < 20; $i++, $ctr++) { + my $status = " "; + if (defined $hunks->[$i]{USE}) { + $status = $hunks->[$i]{USE} ? "+" : "-"; + } + printf "%s%2d: %s", + $status, + $i + 1, + summarize_hunk($hunks->[$i]); + } + return $i; +} + sub patch_update_file { my ($ix, $num); my $path = shift; -- 1.6.1.rc1.37.g83daf.dirty -- William Pursell -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html