Kay Sievers 20 years ago
parent
commit
3f714537ae
  1. 103
      gitweb.pl

103
gitweb.pl

@ -109,7 +109,7 @@ print <<EOF;
div.head2 a:visited { color:#0000cc; } div.head2 a:visited { color:#0000cc; }
div.head2 a:hover { color:#880000; } div.head2 a:hover { color:#880000; }
div.head2 a:active { color:#880000; } div.head2 a:active { color:#880000; }
div.shortlog { padding:8px; background-color: #D9D8D1; font-weight:bold; } div.title { padding:8px; background-color: #D9D8D1; font-weight:bold; }
table { padding:0px; margin:0px; width:100%; } table { padding:0px; margin:0px; width:100%; }
tr { vertical-align:top; } tr { vertical-align:top; }
td { padding:8px; margin:0px; font-family: sans-serif; font-size: 12px; } td { padding:8px; margin:0px; font-family: sans-serif; font-size: 12px; }
@ -175,26 +175,16 @@ sub git_commit {
$co{'committer_time'} = $2; $co{'committer_time'} = $2;
$co{'committer_timezone'} = $3; $co{'committer_timezone'} = $3;
} elsif ($line =~ m/^author (.*>) ([0-9]+) (.*)$/) { } elsif ($line =~ m/^author (.*>) ([0-9]+) (.*)$/) {
$co{'$author'} = $1; $co{'author'} = $1;
$co{'$author_time'} = $2; $co{'author_time'} = $2;
$co{'$author_timezone'} = $3; $co{'author_timezone'} = $3;
} }
} }
my $shortlog = <$fd>; $co{'parents'} = \@parents;
chomp($shortlog); my (@comment) = map { chomp; $_ } <$fd>;
$co{'shortlog'} = escapeHTML($shortlog); $co{'comment'} = \@comment;
my $comment = $shortlog . "<br/>"; $co{'title'} = $comment[0];
while (my $line = <$fd>) {
chomp($line);
if ($line =~ m/signed-off-by:/i) {
$comment .= '<div class="signed_off">' . escapeHTML($line) . "<br/></div>\n";
} else {
$comment .= escapeHTML($line) . "<br/>\n";
}
}
$co{'comment'} = $comment;
close $fd; close $fd;

return %co; return %co;
} }


@ -354,45 +344,9 @@ if ($action eq "blob") {
my $time = $1; my $time = $1;
my $commit = $2; my $commit = $2;
my $parent = $3; my $parent = $3;
my @parents;
my ($author, $author_time, $author_timezone);
my ($committer, $committer_time, $committer_timezone);
my $tree;
my $comment;
my $shortlog;
open my $fd, "-|", "$gitbin/cat-file", "commit", $commit;
while (my $line = <$fd>) {
chomp($line);
last if $line eq "";
if ($line =~ m/^tree (.*)$/) {
$tree = $1;
} elsif ($line =~ m/^parent (.*)$/) {
push @parents, $1;
} elsif ($line =~ m/^committer (.*>) ([0-9]+) (.*)$/) {
$committer = $1;
$committer_time = $2;
$committer_timezone = $3;
} elsif ($line =~ m/^author (.*>) ([0-9]+) (.*)$/) {
$author = $1;
$author_time = $2;
$author_timezone = $3;
}
}
$shortlog = <$fd>;
chomp($shortlog);
$shortlog = escapeHTML($shortlog);
$comment = $shortlog . "<br/>";
while (my $line = <$fd>) {
chomp($line);
if ($line =~ m/signed-off-by:/i) {
$comment .= '<div class="signed_off">' . escapeHTML($line) . "<br/></div>\n";
} else {
$comment .= escapeHTML($line) . "<br/>\n";
}
}
close $fd;


my $age = time-$committer_time; my %co = git_commit($commit);
my $age = time - $co{'committer_time'};
my $age_string; my $age_string;
if ($age > 60*60*24*365*2) { if ($age > 60*60*24*365*2) {
$age_string = int $age/60/60/24/365; $age_string = int $age/60/60/24/365;
@ -424,20 +378,21 @@ if ($action eq "blob") {
} }
print "<tr>\n"; print "<tr>\n";
print "<td class=\"head1\">" . $age_string . "</td>\n"; print "<td class=\"head1\">" . $age_string . "</td>\n";
print "<td class=\"head1\">" . $cgi->a({-href => "$myself/$project/commit/$commit"}, $shortlog) . "</td>"; print "<td class=\"head1\">" . $cgi->a({-href => "$myself/$project/commit/$commit"}, $co{'title'}) . "</td>";
print "</tr>\n"; print "</tr>\n";
print "<tr>\n"; print "<tr>\n";
print "<td class=\"head3\">"; print "<td class=\"head3\">";
print $cgi->a({-href => "$myself/$project/commitdiff/$commit"}, "view diff") . "<br/>\n"; print $cgi->a({-href => "$myself/$project/commitdiff/$commit"}, "view diff") . "<br/>\n";
print $cgi->a({-href => "$myself/$project/commit/$commit"}, "view commit") . "<br/>\n"; print $cgi->a({-href => "$myself/$project/commit/$commit"}, "view commit") . "<br/>\n";
print $cgi->a({-href => "$myself/$project/tree/$tree"}, "view tree") . "<br/>\n"; print $cgi->a({-href => "$myself/$project/tree/$co{'tree'}"}, "view tree") . "<br/>\n";
print "</td>\n"; print "</td>\n";
print "<td class=\"head2\">\n"; print "<td class=\"head2\">\n";
print "author &nbsp; &nbsp;" . escapeHTML($author) . " [" . gmtime($author_time) . " " . $author_timezone . "]<br/>\n"; print "author &nbsp; &nbsp;" . escapeHTML($co{'author'}) . " [" . gmtime($co{'author_time'}) . " " . $co{'author_timezone'} . "]<br/>\n";
print "committer " . escapeHTML($committer) . " [" . gmtime($committer_time) . " " . $committer_timezone . "]<br/>\n"; print "committer " . escapeHTML($co{'committer'}) . " [" . gmtime($co{'committer_time'}) . " " . $co{'committer_timezone'} . "]<br/>\n";
print "commit &nbsp; &nbsp;$commit<br/>\n"; print "commit &nbsp; &nbsp;$commit<br/>\n";
print "tree &nbsp; &nbsp; &nbsp;$tree<br/>\n"; print "tree &nbsp; &nbsp; &nbsp;$co{'tree'}<br/>\n";
foreach my $par (@parents) { my $parents = $co{'parents'};
foreach my $par (@$parents) {
print "parent &nbsp; &nbsp;$par<br/>\n"; print "parent &nbsp; &nbsp;$par<br/>\n";
} }
print "</td>"; print "</td>";
@ -445,12 +400,20 @@ if ($action eq "blob") {
print "<tr>\n"; print "<tr>\n";
print "<td></td>\n"; print "<td></td>\n";
print "<td>\n"; print "<td>\n";
print "$comment<br/><br/>\n"; my $comment = $co{'comment'};
foreach my $line (@$comment) {
if ($line =~ m/signed-off-by:/i) {
print '<div class="signed_off">' . escapeHTML($line) . "<br/></div>\n";
} else {
print escapeHTML($line) . "<br/>\n";
}
}
print "<br/><br/>\n";
print "</td>"; print "</td>";
print "</tr>\n"; print "</tr>\n";
} elsif ($action eq "rss") { } elsif ($action eq "rss") {
last if ($i >= 12); last if ($i >= 12);
print "<item>\n\t<title>$age_string: $shortlog</title>\n"; print "<item>\n\t<title>$age_string: " . escapeHTML($co{'title'}) . "</title>\n";
print "\t<link> " . $cgi->url() . "/$project/commit/$commit</link>\n"; print "\t<link> " . $cgi->url() . "/$project/commit/$commit</link>\n";
print "</item>\n"; print "</item>\n";
} }
@ -471,8 +434,8 @@ if ($action eq "blob") {
$parent = $1; $parent = $1;
} }
} }
my $shortlog = <$fd>; my $title = <$fd>;
$shortlog = escapeHTML($shortlog); $title = escapeHTML($title);
close $fd; close $fd;


open $fd, "-|", "$gitbin/diff-tree", "-r", $parent, $hash; open $fd, "-|", "$gitbin/diff-tree", "-r", $parent, $hash;
@ -482,7 +445,7 @@ if ($action eq "blob") {
git_header_html(); git_header_html();
print "<div class=\"head2\">\n"; print "<div class=\"head2\">\n";
print "view " . $cgi->a({-href => "$myself/$project/commitdiff/$hash"}, "diff") . "</div><br/><br/>\n"; print "view " . $cgi->a({-href => "$myself/$project/commitdiff/$hash"}, "diff") . "</div><br/><br/>\n";
print "<div class=\"shortlog\">$shortlog<br/></div>\n"; print "<div class=\"title\">$title<br/></div>\n";
print "<pre>\n"; print "<pre>\n";
foreach my $line (@difftree) { foreach my $line (@difftree) {
# '*100644->100644 blob 9f91a116d91926df3ba936a80f020a6ab1084d2b->bb90a0c3a91eb52020d0db0e8b4f94d30e02d596 net/ipv4/route.c' # '*100644->100644 blob 9f91a116d91926df3ba936a80f020a6ab1084d2b->bb90a0c3a91eb52020d0db0e8b4f94d30e02d596 net/ipv4/route.c'
@ -527,8 +490,8 @@ if ($action eq "blob") {
$parent = $1; $parent = $1;
} }
} }
my $shortlog = <$fd>; my $title = <$fd>;
$shortlog = escapeHTML($shortlog); $title = escapeHTML($title);
close $fd; close $fd;


open $fd, "-|", "$gitbin/diff-tree", "-r", $parent, $hash; open $fd, "-|", "$gitbin/diff-tree", "-r", $parent, $hash;
@ -538,7 +501,7 @@ if ($action eq "blob") {
git_header_html(); git_header_html();
print "<div class=\"head2\">\n"; print "<div class=\"head2\">\n";
print "view " . $cgi->a({-href => "$myself/$project/commit/$hash"}, "commit") . "</div><br/><br/>\n"; print "view " . $cgi->a({-href => "$myself/$project/commit/$hash"}, "commit") . "</div><br/><br/>\n";
print "<div class=\"shortlog\">$shortlog<br/></div>\n"; print "<div class=\"title\">$title<br/></div>\n";
print "<pre>\n"; print "<pre>\n";
foreach my $line (@difftree) { foreach my $line (@difftree) {
# '*100644->100644 blob 8e5f9bbdf4de94a1bc4b4da8cb06677ce0a57716->8da3a306d0c0c070d87048d14a033df02f40a154 Makefile' # '*100644->100644 blob 8e5f9bbdf4de94a1bc4b4da8cb06677ce0a57716->8da3a306d0c0c070d87048d14a033df02f40a154 Makefile'

Loading…
Cancel
Save