2011-08-16 10:51:41 +02:00
|
|
|
#!/usr/bin/perl
|
|
|
|
|
|
|
|
use File::ReadBackwards;
|
|
|
|
|
|
|
|
if ($#ARGV ne 2){
|
|
|
|
print "not enough arguments\n";
|
|
|
|
exit 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
my $chan=$ARGV[1];
|
|
|
|
my $folder=$ARGV[0];
|
|
|
|
my $nick=$ARGV[2];
|
2012-01-11 09:15:06 +01:00
|
|
|
my $snick=$nick;
|
|
|
|
$snick=~s/\\/\\\\/g;
|
|
|
|
$snick=~s/\|/\\\|/g;
|
|
|
|
$snick=~s/\^/\\\^/g;
|
2011-08-16 10:51:41 +02:00
|
|
|
|
|
|
|
my @files;
|
|
|
|
|
|
|
|
push @files, `ls $folder/$chan.* | sort -r`;
|
|
|
|
|
|
|
|
foreach $file (@files) {
|
|
|
|
|
|
|
|
|
|
|
|
my $date=0;
|
|
|
|
my $lastaction;
|
|
|
|
my $line;
|
|
|
|
|
|
|
|
$file=~s/\n$//;
|
|
|
|
my $log = File::ReadBackwards->new($file) || die $!;
|
|
|
|
|
|
|
|
while ($line=$log->readline()){
|
|
|
|
# $line=$log->readline();
|
|
|
|
if ($date eq 0){
|
2012-01-11 09:15:06 +01:00
|
|
|
if ($line =~ m/^\[[0-9]{2}:[0-9]{2}(:[0-9]{2})?\]( Nick change:)? $snick /i && $line !~ m/joined #/ ) {
|
2011-08-16 10:51:41 +02:00
|
|
|
$date=1;
|
|
|
|
$lastaction=$line;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if ($line =~ m/^\[00:00(:00)?\] --- /){
|
|
|
|
($date=$line)=~s/^\[00:00(:00)?\] --- (.*)\n/$2/;
|
|
|
|
($time=$lastaction)=~s/(.*)\[([0-9]{2}:[0-9]{2}(:[0-9]{2})?)\](.*)\n/$2/;
|
2012-01-11 09:15:06 +01:00
|
|
|
$l=9+length($snick);
|
|
|
|
$k=12+length($snick);
|
2011-09-20 23:07:57 +02:00
|
|
|
if ($lastaction=~m/^.{$l}kicked/ || $lastaction=~m/.{$k}kicked/){
|
2012-01-11 09:15:06 +01:00
|
|
|
($by=$lastaction)=~s/^\[[0-9]{2}:[0-9]{2}(:[0-9]{2})?\] $snick kicked from #.* by //i;
|
2011-08-16 10:51:41 +02:00
|
|
|
($reason=$by)=~s/.*: (.*)\n/$1/;
|
|
|
|
$by=~s/:.*\n//i;
|
|
|
|
|
2011-08-30 15:29:37 +02:00
|
|
|
print "$nick was kicked by $by on $date at $time reason: $reason\n";
|
2012-01-11 09:15:06 +01:00
|
|
|
} elsif ($lastaction=~m/$snick \(.*\) left irc: /i){
|
|
|
|
($message=$lastaction)=~s/^.* $snick \(.*\) left irc: (.*)\n/$1/i;
|
2011-08-30 15:29:37 +02:00
|
|
|
print "$nick has quit on $date at $time saying: $message\n";
|
2011-09-20 23:07:57 +02:00
|
|
|
} elsif ($lastaction=~m/Nick change: $nick /i) {
|
2012-01-11 09:15:06 +01:00
|
|
|
($newnick=$lastaction)=~s/^.*Nick change: $snick -> (.*)\n/$1/i;
|
2011-09-20 23:07:57 +02:00
|
|
|
print "$nick changed his name to $newnick on $date at $time\n";
|
2011-08-16 10:51:41 +02:00
|
|
|
} else {
|
|
|
|
if ($lastaction=~m/\)\.$/) {
|
2012-01-11 09:15:06 +01:00
|
|
|
($message=$lastaction)=~s/^.* $snick \(.*\) left #[a-zA-Z0-9]* \((.*)\)\.\n/$1/i;
|
2011-08-30 15:29:37 +02:00
|
|
|
print "$nick has left on $date at $time saying: $message\n";
|
2011-08-16 10:51:41 +02:00
|
|
|
} else {
|
2011-08-30 15:29:37 +02:00
|
|
|
print "$nick has left on $date at $time\n";
|
2011-08-16 10:51:41 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
exit 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
print "I do not remember $nick\n";
|