+
+END
-$heading
+&print_html($left);
+print <<"END";
+ |
+
END
-print `$updatecmd`;
+&print_html($title);
-my($modulelist)=$query->param('module');
-$modulelist = `ls $cvsroot` unless defined $modulelist;
+print <<"END";
+$heading
+END
+print `$updatecmd >/dev/null 2>&1`;
+
my(@modules) = split (/\s+/, $modulelist);
foreach my $module (@modules) {
- print "";
- print "$module module | ";
+ print "\n\n";
+ print "\n$module module\n | \n\n";
print "\n";
my(@lines) = `$logcmd $module 2>&1`;
@@ -69,18 +100,65 @@ foreach my $module (@modules) {
else {
foreach my $line (@lines) {
- if ($line =~ /^([0-9]{4}-[0-9]{2}-[0-9]{2}.*?)([^\s]+)$/) {
- print "";
+ if ($line =~ /^([0-9]{4}-[0-9]{2}-[0-9]{2}.*?)\s+([^\s]+)\s+<([^\s]+)>$/) {
+ print "\n\n";
print HTML_encode($1);
- print "";
- print HTML_encode("by $2");
- print ""
+ print "\n";
+ print " commited by ";
+ print HTML_encode("$2");
+ print "\n\n"
}
+ elsif ($line =~ /^([0-9]{4}-[0-9]{2}-[0-9]{2}.*?)\s+([^\s]+)$/) {
+ print "\n\n";
+ print HTML_encode($1);
+ print "\n";
+ print " commited by ";
+ print HTML_encode("$2");
+ print "\n\n"
+ }
+ elsif($line =~ /(\S+) (\(\S+\))([,:])/ || $line =~ /(\S+) (\(\S+,\s+\S+\))([,:])/) {
+ my ($file, $rest, $ext) = ($1, $2, $3);
+ print "";
+ print "";
+ print HTML_encode($file);
+ print " ";
+ if($rest =~ /\((\S+)\.(\d+)(.*)\)/) {
+ my $start = $1;
+ my $end = $2;
+ my $other = $3;
+ my $newrev = "$start.$end";
+ my $oldrev;
+ if($end != 1) {
+ my $oldminver = $end-1;
+ $oldrev = "$start.$oldminver";
+ }
+ elsif($start =~ /^((\d+\.)+)(\d+)$/) {
+ $oldrev = $1;
+ # take trailing . off old revision
+ chop $oldrev;
+ }
+ if(defined $oldrev) {
+ my $diff = ".diff?r1=$oldrev&r2=$newrev";
+ print "(";
+ print HTML_encode("$start.$end");
+ print "";
+ print HTML_encode("$other)");
+ }
+ else {
+ print HTML_encode($rest);
+ }
+ }
+ else {
+ print HTML_encode($rest);
+ }
+ print HTML_encode($ext);
+ print " \n"
+ }
else {
chop $line;
print "";
print HTML_encode($line);
- print " "
+ print " \n"
}
}
}
@@ -89,8 +167,14 @@ foreach my $module (@modules) {
print " | \n\n";
}
+&print_html($bottom);
+
print <<"END";
+
+
+
+
@@ -111,4 +195,10 @@ sub HTML_encode ($){
$encoded =~ s/</g;
$encoded =~ s/>/>/g;
return $encoded;
+}
+
+# Print a file without escaping HTML: -
+sub print_html ($) {
+ my ($filename) = @_;
+ print `cat $filename 2>&1`;
}
|