2001-02-28 19:00:26 -05:00
|
|
|
#!/usr/bin/perl
|
|
|
|
|
2009-11-08 04:24:11 -05:00
|
|
|
# $OpenBSD: portslogger,v 1.15 2009/11/08 09:24:11 espie Exp $
|
2001-02-28 19:00:26 -05:00
|
|
|
# Copyright (c) 2001 Marc Espie. All rights reserved.
|
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions
|
|
|
|
# are met:
|
|
|
|
# 1. Redistributions of code must retain the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer.
|
|
|
|
# 2. Neither the name of OpenBSD nor the names of its contributors
|
|
|
|
# may be used to endorse or promote products derived from this software
|
|
|
|
# without specific prior written permission.
|
|
|
|
#
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY ITS AUTHOR AND THE OpenBSD project ``AS IS'' AND
|
|
|
|
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
# SUCH DAMAGE.
|
|
|
|
|
|
|
|
# This critter recognizes context switch changes in the ports tree
|
|
|
|
# and logs its output accordingly, as a kind of `super-tee'
|
|
|
|
|
2001-07-19 08:29:09 -04:00
|
|
|
{
|
|
|
|
package Logger;
|
|
|
|
@ISA=qw(IO::File);
|
|
|
|
|
2001-02-28 19:00:26 -05:00
|
|
|
use File::Path;
|
2001-07-19 08:29:09 -04:00
|
|
|
use IO::File;
|
|
|
|
use File::Temp qw/tempfile/;
|
2001-02-28 19:00:26 -05:00
|
|
|
|
2001-07-19 08:29:09 -04:00
|
|
|
our $directory;
|
|
|
|
our %temps;
|
2001-02-28 19:00:26 -05:00
|
|
|
|
|
|
|
|
2001-07-19 08:29:09 -04:00
|
|
|
sub setdir
|
|
|
|
{
|
|
|
|
$directory = shift;
|
|
|
|
mkpath $directory;
|
|
|
|
die "No logging directory" unless -d $directory;
|
|
|
|
}
|
2001-02-28 19:00:26 -05:00
|
|
|
|
2001-07-19 08:29:09 -04:00
|
|
|
sub new
|
|
|
|
{
|
|
|
|
my $class = shift;
|
|
|
|
my $name = shift;
|
|
|
|
$name = "$directory/$name.log";
|
|
|
|
my $self = IO::File::new($class, $name, '>>');
|
|
|
|
if (!$self) {
|
|
|
|
if (defined $temps{$name}) {
|
|
|
|
$self = IO::File::new($class, $temps{$name}, '>>');
|
|
|
|
} else {
|
|
|
|
($self, $temps{$name}) = tempfile(SUFFIX => '.log') or
|
|
|
|
die "Can't create any logfile";
|
|
|
|
print STDERR "*** Couldn't open $name, \n";
|
|
|
|
print STDERR "*** using ".$temps{$name}." instead\n";
|
|
|
|
bless $self, $class;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$self->print("+++ ", `date`);
|
|
|
|
$self->autoflush(1);
|
|
|
|
return $self;
|
2001-02-28 19:00:26 -05:00
|
|
|
}
|
|
|
|
|
2001-07-19 08:29:09 -04:00
|
|
|
sub close
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
print $self "--- ", `date`;
|
|
|
|
$self->SUPER::close();
|
|
|
|
}
|
|
|
|
|
|
|
|
sub DESTROY
|
|
|
|
{
|
|
|
|
my $self = shift;
|
|
|
|
$self->close();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-11-08 04:24:11 -05:00
|
|
|
use Getopt::Std;
|
|
|
|
|
|
|
|
our $opt_s;
|
|
|
|
|
|
|
|
getopts('s');
|
|
|
|
|
2001-11-11 07:57:25 -05:00
|
|
|
if (@ARGV < 1) {
|
2001-11-11 07:38:57 -05:00
|
|
|
print STDERR "Usage: $0 directory\n";
|
|
|
|
exit 1;
|
|
|
|
}
|
|
|
|
|
2001-07-19 08:29:09 -04:00
|
|
|
Logger::setdir(shift);
|
|
|
|
|
|
|
|
my $logfile = undef;
|
|
|
|
my $ncontext = undef;
|
|
|
|
|
|
|
|
my $context;
|
|
|
|
|
2001-02-28 19:00:26 -05:00
|
|
|
while (<>) {
|
2009-11-08 04:24:11 -05:00
|
|
|
print unless $opt_s;
|
|
|
|
s/\cM+$//;
|
|
|
|
# zap fetch & pkg_add progress bar
|
|
|
|
s/^.*\cM//;
|
2005-01-07 19:05:16 -05:00
|
|
|
if (m/^\=\=\=\>\s+
|
|
|
|
(?:
|
|
|
|
(?: Extracting|
|
|
|
|
Applying\ distribution\ patches|
|
|
|
|
Patching|
|
|
|
|
Configuring|
|
|
|
|
Building|
|
|
|
|
Faking\ installation|
|
|
|
|
Building\ package|
|
|
|
|
Deinstalling|
|
|
|
|
Cleaning|
|
|
|
|
Dist\ cleaning|
|
|
|
|
Checking\ files|
|
|
|
|
Regression\ check|
|
|
|
|
Updating\ plist|
|
|
|
|
Updating|
|
|
|
|
Registering\ installation)\s+for\s+(.*)|
|
|
|
|
Returning\ to\ build\ of\s+(.*)|
|
|
|
|
Installing\s+(.*?)\s+from)
|
|
|
|
/ox) {
|
2001-07-26 10:53:53 -04:00
|
|
|
$ncontext = "$1$2$3"; # XXX only one alternative matches
|
2001-07-19 08:29:09 -04:00
|
|
|
chomp $ncontext;
|
2002-04-24 17:35:33 -04:00
|
|
|
# register to `master' context.
|
|
|
|
$ncontext=$1 if $ncontext =~ m/^.*\[(.*?)\]$/;
|
2001-07-19 08:29:09 -04:00
|
|
|
if ($ncontext ne $context) {
|
|
|
|
$context = $ncontext;
|
|
|
|
$logfile = new Logger $context;
|
2001-02-28 19:00:26 -05:00
|
|
|
}
|
2007-08-25 03:56:04 -04:00
|
|
|
} elsif (m/^\=\=\=\> Exiting\s+(.*)\s+with an error$/) {
|
2009-11-08 04:24:11 -05:00
|
|
|
undef $context;
|
2001-02-28 19:00:26 -05:00
|
|
|
}
|
2001-07-19 08:29:09 -04:00
|
|
|
unless (defined $context) {
|
|
|
|
$context = default;
|
|
|
|
$logfile = new Logger 'default';
|
2001-02-28 19:00:26 -05:00
|
|
|
}
|
2001-07-19 08:29:09 -04:00
|
|
|
$logfile->print($_);
|
2001-02-28 19:00:26 -05:00
|
|
|
}
|
|
|
|
|