use strict;
use warnings;
+use File::Spec;
use HTML::Entities;
open (LOG, '<', "LOG");
-open (INDEX, '>','index.html');
open (LOG_HTML, '>', "log.html");
-print INDEX <<EOF;
-<html>
-<head>
- <link rel="stylesheet" href="build.css">
-</head>
-<body>
-EOF
-
print LOG_HTML <<EOF;
<html>
<head>
}
return %vars;
}
-
my (%vars) = read_vars ('VARS');
-print INDEX "<h2>Build Properties</h2>\n";
-print INDEX "<table>\n";
-print INDEX "<tr><th>Name</th><th>Value</th></tr>\n";
-foreach my $key (sort (keys (%vars))) {
- print INDEX "<tr>";
- print INDEX "<td>", encode_entities ($key), "</td>";
- print INDEX "<td>", encode_entities ($vars{$key}), "</td>";
- print INDEX "</tr>\n";
-}
-print INDEX "</table>\n";
my (@products);
my (@steps);
my ($new_page) = 0;
+my ($result) = "failure";
+my @dirstack;
while (<LOG>) {
my $ln = $.;
chomp;
if (/^\f$/) {
$new_page = 1;
+ @dirstack = ();
print LOG_HTML "</pre><hr><pre>\n";
next;
}
+ if (/Entering directory `(.*)'$/) {
+ push (@dirstack, $1);
+ } elsif (/Leaving directory `(.*)'$/) {
+ pop (@dirstack);
+ }
+
my $log_class;
if ($new_page) {
$new_page = 0;
$log_class = "step";
- if (my ($product) = /^Saving (.*)$/) {
+ if (my ($name, $product) = /^Saving(?:([^:]*):)?\s+(.*)$/) {
my $href = "$product/index.html";
$href = $product if ! -e $href;
my (%p);
+ $p{NAME} = $name if defined ($name);
$p{PRODUCT} = $product;
$p{HREF} = $href;
$p{LN} = $ln;
$s{LN} = $ln;
push (@steps, \%s);
}
+ $result = 'success' if $_ eq 'Success';
} else {
- if (my ($diagnostic) = /(error|warning):/) {
+ if (my ($diagnostic) = /(error|warning):/i) {
my (%d);
- $d{DIAGNOSTIC} = $diagnostic;
+ $d{DIAGNOSTIC} = lc ($diagnostic);
$d{MESSAGE} = $_;
$d{LN} = $ln;
+
+ if (@dirstack && (my ($file, $line) = /^([^\s:]+):(\d+):\s/)) {
+ $file = File::Spec->rel2abs ($file, $dirstack[$#dirstack]);
+ my (@path) = grep ($_ ne '' && $_ ne '.', split ('/', $file));
+ for (my $i = 0; $i < $#path; ) {
+ if ($path[$i + 1] eq '..') {
+ splice (@path, $i, 2);
+ } else {
+ $i++;
+ }
+ }
+
+ $d{LINE} = $line;
+ $d{FILE} = join ('/', @path);
+ }
push (@{$steps[$#steps]{CHILDREN}}, \%d);
$log_class = "$diagnostic";
}
}
+open (INDEX, '>','index.html');
+
+print INDEX <<EOF;
+<html>
+<head>
+ <link rel="stylesheet" href="build.css">
+</head>
+<body>
+EOF
+
+print INDEX "<h1>Build ", $vars{"build_number"}, ": $result</h1>\n";
+
+print INDEX "<h2>Build Properties</h2>\n";
+print INDEX "<table>\n";
+print INDEX "<tr><th>Name</th><th>Value</th></tr>\n";
+foreach my $key (sort (keys (%vars))) {
+ print INDEX "<tr>";
+ print INDEX "<td>", encode_entities ($key), "</td>";
+ print INDEX "<td>", encode_entities ($vars{$key}), "</td>";
+ print INDEX "</tr>\n";
+}
+print INDEX "</table>\n";
+
print INDEX "<h2>Build Products</h2>\n";
print INDEX "<ul>\n";
foreach my $p (@products) {
- print INDEX "<li><a href=\"", encode_entities ($p->{HREF}), "\">";
+ print INDEX "<li>";
+ print INDEX encode_entities ($p->{NAME}), ": " if defined ($p->{NAME});
+ print INDEX "<a href=\"", encode_entities ($p->{HREF}), "\">";
print INDEX encode_entities ($p->{PRODUCT});
print INDEX "</a></li>\n";
}
print INDEX "<p class=\"$c->{DIAGNOSTIC}\">";
print INDEX "<a href=\"log.html#$c->{LN}\">";
print INDEX encode_entities ($c->{MESSAGE});
- print INDEX "</a></p>\n";
+ print INDEX "</a>";
+ if (exists $c->{FILE}) {
+ print INDEX " in $c->{FILE}";
+ }
+ print INDEX "</p>\n";
} else {
print INDEX "<p>→ <a href=\"", encode_entities ($c->{HREF}), "\">";
print INDEX encode_entities ($c->{PRODUCT});
- print INDEX "</a></p>\n";
+ print INDEX "</a> ";
+ print INDEX log_link ($c->{LN});
+ print INDEX "</p>\n";
}
}
print INDEX "</li>\n";