| line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
|
1
|
|
|
|
|
|
|
package POE::Component::Server::Twirc::LogAppender; |
|
2
|
|
|
|
|
|
|
|
|
3
|
2
|
|
|
2
|
|
8
|
use warnings; |
|
|
2
|
|
|
|
|
3
|
|
|
|
2
|
|
|
|
|
47
|
|
|
4
|
2
|
|
|
2
|
|
7
|
use strict; |
|
|
2
|
|
|
|
|
2
|
|
|
|
2
|
|
|
|
|
42
|
|
|
5
|
|
|
|
|
|
|
|
|
6
|
2
|
|
|
2
|
|
6
|
use base qw/Log::Log4perl::Appender/; |
|
|
2
|
|
|
|
|
3
|
|
|
|
2
|
|
|
|
|
450
|
|
|
7
|
|
|
|
|
|
|
|
|
8
|
|
|
|
|
|
|
sub new { |
|
9
|
0
|
|
|
0
|
1
|
|
my($class, @options) = @_; |
|
10
|
|
|
|
|
|
|
|
|
11
|
0
|
|
|
|
|
|
my $self = { |
|
12
|
|
|
|
|
|
|
name => 'twirc-logger', |
|
13
|
|
|
|
|
|
|
irc_channel => '&twirc-log', |
|
14
|
|
|
|
|
|
|
history => [], |
|
15
|
|
|
|
|
|
|
history_size => 50, |
|
16
|
|
|
|
|
|
|
@options, |
|
17
|
|
|
|
|
|
|
}; |
|
18
|
|
|
|
|
|
|
|
|
19
|
0
|
|
|
|
|
|
for ( qw/ircd irc_botname irc_channel/ ) { |
|
20
|
0
|
0
|
|
|
|
|
die "$_ required" unless defined $self->{$_}; |
|
21
|
|
|
|
|
|
|
} |
|
22
|
|
|
|
|
|
|
|
|
23
|
0
|
|
|
|
|
|
bless $self, $class; |
|
24
|
|
|
|
|
|
|
} |
|
25
|
|
|
|
|
|
|
|
|
26
|
|
|
|
|
|
|
sub log { |
|
27
|
0
|
|
|
0
|
0
|
|
my($self, %params) = @_; |
|
28
|
|
|
|
|
|
|
|
|
29
|
0
|
|
|
|
|
|
$self->{ircd}->yield(daemon_cmd_privmsg => |
|
30
|
|
|
|
|
|
|
$self->{irc_botname}, $self->{irc_channel}, $params{message}); |
|
31
|
|
|
|
|
|
|
|
|
32
|
0
|
|
|
|
|
|
push @{$self->{history}}, \%params; |
|
|
0
|
|
|
|
|
|
|
|
33
|
0
|
|
|
|
|
|
shift @{$self->{history}} while @{$self->{history}} > $self->{history_size}; |
|
|
0
|
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
34
|
|
|
|
|
|
|
} |
|
35
|
|
|
|
|
|
|
|
|
36
|
|
|
|
|
|
|
sub dump_history { |
|
37
|
0
|
|
|
0
|
0
|
|
my $self = shift; |
|
38
|
|
|
|
|
|
|
|
|
39
|
0
|
|
|
|
|
|
$self->{ircd}->yield(daemon_cmd_privmsg => |
|
40
|
|
|
|
|
|
|
$self->{irc_botname}, $self->{irc_channel}, $_->{message}) |
|
41
|
0
|
|
|
|
|
|
for @{$self->{history}}; |
|
42
|
|
|
|
|
|
|
} |
|
43
|
|
|
|
|
|
|
|
|
44
|
|
|
|
|
|
|
1; |