X-Git-Url: http://git.shiar.net/git-grep-footer.git/blobdiff_plain/d98fc39f894e88b4416e899c073480ee90b4b085..8fe9f6baac5b1fde96dfb345f1b3676cd3894c0b:/git-grep-footer diff --git a/git-grep-footer b/git-grep-footer index 0c26549..2e42b4a 100755 --- a/git-grep-footer +++ b/git-grep-footer @@ -23,12 +23,12 @@ GetOptions(\my %opt, local $| = 1; local $/ = "\0"; -my $HEADERMATCH = qr/ [a-z]+ (?: (?:-\w+)+ | \ by ) /ix; +my $HEADERMATCH = qr/ [a-z]+ (?: (?:-\w+)+ | \ by ) | cc | reference /ix; my (%headercount, @headercache); while (readline) { - s/(.+)\n//m; + s/^([0-9a-f]{4,40})\n//m and my $hash = $1; # strip commit seperator @@ -40,12 +40,12 @@ while (readline) { # if invalid, assume it's latin1 $_ = decode(cp1252 => $_) if $@; - my $prefix = 0; my %attr; BLOCK: for (reverse split /\n\n/) { my @headers; + my $prefix = 0; LINE: for (split /\n/) { @@ -85,7 +85,7 @@ while (readline) { }{<...>}imsx; } when (['var', 'vars', '']) { - when ($header[0] =~ /[ _-] (?: by | to ) $/imsx) { + when ($header[0] =~ /[ _-] (?: by | to ) $ | ^cc$/imsx) { $header[1] = undef; } for ($header[1]) { @@ -118,11 +118,13 @@ while (readline) { next BLOCK if not @headers; if ($opt{debug} and $prefix) { - say "infix junk in commit $hash"; + say sprintf ': invalid lines in %s (%s)', $hash // 'block', $prefix; } for (@headers) { my $line = $_->[2] // join(': ', @$_); + $line =~ s/^/$hash / if defined $hash; + if (defined $opt{min} or $opt{max}) { my $counter = \$headercount{ $_->[0] }->{ $_->[1] // '' }; my $excess = $$counter++ - ($opt{min} // 0); @@ -161,6 +163,7 @@ a common convention to list custom metadata such as C and C. Sections are identified by at least one leading keyword containing a dash +(or exceptionally recognised) followed by a colon. =head1 OPTIONS