Code

gitweb: Filter out commit ID from @difftree in git_commit and git_commitdiff
authorJakub Narebski <jnareb@gmail.com>
Tue, 24 Oct 2006 11:54:49 +0000 (13:54 +0200)
committerJunio C Hamano <junkio@cox.net>
Wed, 25 Oct 2006 04:23:41 +0000 (21:23 -0700)
Filter out commit ID output that git-diff-tree adds when called with
only one <tree-ish> (not only for --stdin) in git_commit and
git_commitdiff.

This also works with older git versions, which doesn't have
--no-commit-id option to git-diff-tree.

Signed-off-by: Jakub Narebski <jnareb@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>
gitweb/gitweb.perl

index 5f0a13426445e28601f6e6f06c87f0347549d8e0..2bc14b2c2ab012ed23a28229262b0092bfd658dc 100755 (executable)
@@ -3115,6 +3115,9 @@ sub git_commit {
        my @difftree = map { chomp; $_ } <$fd>;
        close $fd or die_error(undef, "Reading git-diff-tree failed");
 
+       # filter out commit ID output
+       @difftree = grep(!/^[0-9a-fA-F]{40}$/, @difftree);
+
        # non-textual hash id's can be cached
        my $expires;
        if ($hash =~ m/^[0-9a-fA-F]{40}$/) {
@@ -3391,7 +3394,9 @@ sub git_commitdiff {
                while (chomp(my $line = <$fd>)) {
                        # empty line ends raw part of diff-tree output
                        last unless $line;
-                       push @difftree, $line;
+                       # filter out commit ID output
+                       push @difftree, $line
+                               unless $line =~ m/^[0-9a-fA-F]{40}$/;
                }
 
        } elsif ($format eq 'plain') {