| line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
|
1
|
|
|
|
|
|
|
package Bot::Cobalt::Plugin::Calc; |
|
2
|
|
|
|
|
|
|
$Bot::Cobalt::Plugin::Calc::VERSION = '0.004005'; |
|
3
|
1
|
|
|
1
|
|
13139
|
use strictures 2; |
|
|
1
|
|
|
|
|
1066
|
|
|
|
1
|
|
|
|
|
30
|
|
|
4
|
|
|
|
|
|
|
|
|
5
|
1
|
|
|
1
|
|
554
|
use List::Objects::WithUtils; |
|
|
1
|
|
|
|
|
615
|
|
|
|
1
|
|
|
|
|
4
|
|
|
6
|
|
|
|
|
|
|
|
|
7
|
1
|
|
|
1
|
|
55393
|
use Bot::Cobalt; |
|
|
1
|
|
|
|
|
1835
|
|
|
|
1
|
|
|
|
|
4
|
|
|
8
|
1
|
|
|
1
|
|
1062
|
use Bot::Cobalt::Common; |
|
|
1
|
|
|
|
|
103422
|
|
|
|
1
|
|
|
|
|
6
|
|
|
9
|
|
|
|
|
|
|
|
|
10
|
1
|
|
|
1
|
|
5552
|
use Bot::Cobalt::Plugin::Calc::Session; |
|
|
1
|
|
|
|
|
2
|
|
|
|
1
|
|
|
|
|
28
|
|
|
11
|
|
|
|
|
|
|
|
|
12
|
1
|
|
|
1
|
|
5
|
use POE; |
|
|
1
|
|
|
|
|
1
|
|
|
|
1
|
|
|
|
|
6
|
|
|
13
|
|
|
|
|
|
|
|
|
14
|
|
|
|
|
|
|
sub SESSID () { 0 } |
|
15
|
|
|
|
|
|
|
sub CALC () { 1 } |
|
16
|
|
|
|
|
|
|
|
|
17
|
|
|
|
|
|
|
sub new { |
|
18
|
1
|
|
|
1
|
0
|
52
|
bless [ |
|
19
|
|
|
|
|
|
|
undef, # SESSID |
|
20
|
|
|
|
|
|
|
Bot::Cobalt::Plugin::Calc::Session->new, # CALC |
|
21
|
|
|
|
|
|
|
], shift |
|
22
|
|
|
|
|
|
|
} |
|
23
|
|
|
|
|
|
|
|
|
24
|
|
|
|
|
|
|
sub Cobalt_register { |
|
25
|
0
|
|
|
0
|
0
|
|
my ($self, $core) = splice @_, 0, 2; |
|
26
|
|
|
|
|
|
|
|
|
27
|
0
|
|
|
|
|
|
my $sess = POE::Session->create( |
|
28
|
|
|
|
|
|
|
object_states => [ |
|
29
|
|
|
|
|
|
|
$self => +{ |
|
30
|
|
|
|
|
|
|
_start => 'px_start', |
|
31
|
|
|
|
|
|
|
issue_calc => 'px_issue_calc', |
|
32
|
|
|
|
|
|
|
calc_result => 'px_calc_result', |
|
33
|
|
|
|
|
|
|
calc_error => 'px_calc_error', |
|
34
|
|
|
|
|
|
|
}, |
|
35
|
|
|
|
|
|
|
], |
|
36
|
|
|
|
|
|
|
); |
|
37
|
0
|
|
|
|
|
|
$self->[SESSID] = $sess->ID; |
|
38
|
|
|
|
|
|
|
|
|
39
|
0
|
|
|
|
|
|
register( $self, SERVER => 'public_cmd_calc' ); |
|
40
|
0
|
|
|
|
|
|
logger->info("Loaded: calc"); |
|
41
|
0
|
|
|
|
|
|
PLUGIN_EAT_NONE |
|
42
|
|
|
|
|
|
|
} |
|
43
|
|
|
|
|
|
|
|
|
44
|
|
|
|
|
|
|
sub Cobalt_unregister { |
|
45
|
0
|
|
|
0
|
0
|
|
my ($self, $core) = splice @_, 0, 2; |
|
46
|
0
|
|
|
|
|
|
$poe_kernel->post( $self->[CALC]->session_id, 'shutdown' ); |
|
47
|
0
|
|
|
|
|
|
$poe_kernel->refcount_decrement( $self->[SESSID], 'Plugin loaded' ); |
|
48
|
0
|
|
|
|
|
|
logger->info("Unloaded"); |
|
49
|
0
|
|
|
|
|
|
PLUGIN_EAT_NONE |
|
50
|
|
|
|
|
|
|
} |
|
51
|
|
|
|
|
|
|
|
|
52
|
|
|
|
|
|
|
sub Bot_public_cmd_calc { |
|
53
|
0
|
|
|
0
|
0
|
|
my ($self, $core) = splice @_, 0, 2; |
|
54
|
0
|
|
|
|
|
|
my $msg = ${ $_[0] }; |
|
|
0
|
|
|
|
|
|
|
|
55
|
|
|
|
|
|
|
|
|
56
|
0
|
|
|
|
|
|
my $msgarr = $msg->message_array; |
|
57
|
0
|
|
|
|
|
|
my $calcstr = join ' ', @$msgarr; |
|
58
|
0
|
|
|
|
|
|
my $hints = hash( |
|
59
|
|
|
|
|
|
|
context => $msg->context, |
|
60
|
|
|
|
|
|
|
channel => $msg->channel, |
|
61
|
|
|
|
|
|
|
nick => $msg->src_nick, |
|
62
|
|
|
|
|
|
|
)->inflate; |
|
63
|
|
|
|
|
|
|
|
|
64
|
0
|
|
|
|
|
|
logger->debug("issue_calc '$calcstr'"); |
|
65
|
0
|
|
|
|
|
|
$poe_kernel->call( $self->[SESSID], issue_calc => $calcstr, $hints ); |
|
66
|
|
|
|
|
|
|
|
|
67
|
0
|
|
|
|
|
|
PLUGIN_EAT_NONE |
|
68
|
|
|
|
|
|
|
} |
|
69
|
|
|
|
|
|
|
|
|
70
|
|
|
|
|
|
|
|
|
71
|
|
|
|
|
|
|
sub px_start { |
|
72
|
0
|
|
|
0
|
0
|
|
my ($kernel, $self) = @_[KERNEL, OBJECT]; |
|
73
|
0
|
|
|
|
|
|
$kernel->refcount_increment( $_[SESSION]->ID, 'Plugin loaded' ); |
|
74
|
0
|
|
|
|
|
|
$self->[CALC]->start; |
|
75
|
|
|
|
|
|
|
} |
|
76
|
|
|
|
|
|
|
|
|
77
|
|
|
|
|
|
|
sub px_issue_calc { |
|
78
|
0
|
|
|
0
|
0
|
|
my ($kernel, $self) = @_[KERNEL, OBJECT]; |
|
79
|
0
|
|
|
|
|
|
logger->debug("got issue_calc, relaying to CALC"); |
|
80
|
0
|
|
|
|
|
|
$kernel->post( $self->[CALC]->session_id, calc => @_[ARG0, ARG1] ) |
|
81
|
|
|
|
|
|
|
} |
|
82
|
|
|
|
|
|
|
|
|
83
|
|
|
|
|
|
|
sub px_calc_result { |
|
84
|
0
|
|
|
0
|
0
|
|
my ($kernel, $self) = @_[KERNEL, OBJECT]; |
|
85
|
0
|
|
|
|
|
|
my ($result, $hints) = @_[ARG0, ARG1]; |
|
86
|
0
|
|
|
|
|
|
logger->debug("got calc_result"); |
|
87
|
0
|
|
|
|
|
|
broadcast( message => $hints->context, $hints->channel, |
|
88
|
|
|
|
|
|
|
$hints->nick . ": $result" |
|
89
|
|
|
|
|
|
|
); |
|
90
|
|
|
|
|
|
|
} |
|
91
|
|
|
|
|
|
|
|
|
92
|
|
|
|
|
|
|
sub px_calc_error { |
|
93
|
0
|
|
|
0
|
0
|
|
my ($kernel, $self) = @_[KERNEL, OBJECT]; |
|
94
|
0
|
|
|
|
|
|
my ($error, $hints) = @_[ARG0, ARG1]; |
|
95
|
|
|
|
|
|
|
# if this is a bad-args warn there's no hints hash - but then it's also a |
|
96
|
|
|
|
|
|
|
# bug and should warn() from ::Calc::Session |
|
97
|
0
|
0
|
|
|
|
|
return unless keys %$hints; |
|
98
|
|
|
|
|
|
|
|
|
99
|
0
|
|
|
|
|
|
broadcast( message => $hints->context, $hints->channel, |
|
100
|
|
|
|
|
|
|
$hints->nick . ": backend error: $error" |
|
101
|
|
|
|
|
|
|
); |
|
102
|
|
|
|
|
|
|
} |
|
103
|
|
|
|
|
|
|
|
|
104
|
|
|
|
|
|
|
|
|
105
|
|
|
|
|
|
|
1; |
|
106
|
|
|
|
|
|
|
__END__ |