use Moose;
+use POE::Component::IRC::Common qw/irc_to_utf8/;
use POE::Session;
use POE::Component::IRC::Plugin::Logger;
use POE::Component::IRC::Plugin::BotTraffic;
use POE::Component::IRC::Plugin::NickReclaim;
use NDIRC::Dispatcher;
+use NDIRC::Context;
use IO::File;
+has disp => (
+ is => 'rw',
+ isa => 'Object',
+ lazy_build => 1
+);
+
# We registered for all events, this will produce some debug info.
sub _default {
my ($event, $args) = @_[ARG0 .. $#_];
Sort_by_date => 1,
Strip_color => 1,
Strip_formatting => 1,
+ Notices => 1,
));
$heap->{connector} = POE::Component::IRC::Plugin::Connector->new(
- servers => ['irc.netgamers.org', 'underworld.no.eu.netgamers.org'
- ,'firefly.no.eu.netgamers.org', 'underworld.ca.us.netgamers.org' ]
+ servers => [['irc.netgamers.org'], ['underworld.no.eu.netgamers.org']
+ ,['firefly.no.eu.netgamers.org'], ['underworld.ca.us.netgamers.org'] ]
);
$irc->plugin_add( 'Connector' => $heap->{connector} );
- $kernel->signal($session => 'USR2');
-
$irc->yield( register => 'all' );
$irc->yield( connect => { server => 'irc.netgamers.org' } );
$kernel->yield( 'refresh' );
}
+sub clear_constraint {
+ my $tc = shift;
+
+ while (1) {
+ if (ref $tc eq 'MooseX::Meta::TypeConstraint::Structured'){
+ for my $t (@{$tc->{type_constraints}}){
+ clear_constraint($t);
+ }
+
+ }
+ if (ref $tc eq 'Moose::Meta::TypeConstraint::Parameterized'){
+ clear_constraint($tc->{type_parameter});
+ }
+ last if ref $tc eq 'HASH';
+ last if ref $tc eq '';
+ if (defined $tc->{_type_constraint}){
+ $tc = $tc->{_type_constraint};
+ }elsif(defined $tc->{__type_constraint}){
+ $tc = $tc->{__type_constraint};
+ }else{
+ last;
+ }
+ }
+}
+
+sub clear_metains {
+ my $ins = shift;
+
+ for my $a (@{$ins->{attributes}}){
+ for my $m (@{$a->{associated_methods}}){
+ $m->{body} = undef;
+ }
+ clear_constraint($a->{isa});
+ }
+}
+
+sub clear_cycles {
+ my $c = shift;
+
+ for my $m (values %{$c->meta->{methods}}){
+ clear_constraint($m->{type_constraint});
+
+ my $ps = $m->{parsed_signature};
+ for my $p (@{$ps->{_positional_params}->{params}}){
+ clear_metains($p->{__MOP__}->{_meta_instance});
+ }
+
+ $m->{body} = undef;
+ }
+ clear_metains($c->meta->{_meta_instance});
+}
+
+
sub sig_usr2 {
- my $heap = $_[HEAP];
+ my $self = shift @_;
+ for my $c (values %{$self->disp->commands}){
+ clear_cycles($c);
+ }
+
+ $self->disp($self->_build_disp);
+}
+
+sub _build_disp {
+ my ($self) = @_;
my $disp = new NDIRC::Dispatcher;
if (my $commands = new IO::File 'commands'){
$disp->load(@commands);
}
- my $channels = new IO::File 'channels';
+ my $channels = new IO::File 'channels' or die $!;;
while (<$channels>){
my ($chan, @types) = split /\s+/;
say "$chan - @types";
$disp->add_channel($chan,\@types);
}
- $heap->{disp} = $disp;
+ return $disp;
}
sub sig_DIE {
}
sub irc_001 {
- my ($sender,$heap,$kernel) = @_[SENDER,HEAP,KERNEL];
+ my ($self,$sender,$kernel) = @_[OBJECT,SENDER,KERNEL];
# Since this is an irc_* event, we can get the component's object by
# accessing the heap of the sender. Then we register and connect to the
$irc->yield( mode => $irc->nick_name, '+ix');
# we join our channels
- $irc->yield( join => $_ ) for grep /^#/, keys %{$heap->{disp}->channels};
+ $irc->yield( join => $_ ) for grep /^#/, keys %{$self->disp->channels};
return;
}
sub irc_invite {
- my ($sender, $heap, $who, $channel) = @_[SENDER, HEAP, ARG0 .. ARG1];
+ my ($self,$sender, $who, $channel) = @_[OBJECT,SENDER, ARG0 .. ARG1];
my $irc = $sender->get_heap();
- $irc->yield( join => $_ ) for grep /^$channel$/i, keys %{$heap->{disp}->channels}
+ $irc->yield( join => $_ ) for grep /^$channel$/i, keys %{$self->disp->channels}
}
sub irc_public {
+ $_[ARG2] = irc_to_utf8 $_[ARG2];
}
sub irc_msg {
+ $_[ARG2] = irc_to_utf8 $_[ARG2];
}
sub refresh {
sub irc_join {
}
+sub parseCommand {
+ my ($self, $msg, $server, $nick, $address, $channel, $model) = @_;
+
+ return if $channel !~ /^#/ && $msg =~ /^~/;
+ $msg = ".$msg" if $channel !~ /^#/ && $msg =~ /^[^.!]/;
+
+ my ($p,$command,$args) = ($msg =~ /^([.!~])(\S+)(?: (.+))?/);
+
+ if ($msg =~ m{http://[\w.]+/.+?scan(_id|_grp)?=(\w+)}){
+ if (!$command || $command =~ m{^http://}){
+ ($p,$command,$args) = ('.','addscan',$msg);
+ }elsif($command ne 'addscan'){
+ $self->parseCommand (".addscan $msg", $server, $nick, $address, $channel, $model)
+ }
+ }
+
+ return 0 unless $self->disp->has_command($command,$channel);
+
+ my $reply_string;
+ given ($p){
+ when ('!'){
+ $reply_string = "privmsg $nick";
+ }
+ when ('~'){
+ $reply_string = "privmsg $channel";
+ }
+ default {
+ $reply_string = "notice $nick";
+ }
+ }
+
+ $address =~ s/.*@(.*)/$1/;
+ my $c = NDIRC::Context->new({
+ host => $address,
+ nick => $nick,
+ channel => $channel,
+ disp => $self->disp,
+ model => $model,
+ server => $server,
+ reply_string => $reply_string,
+ });
+
+ return $self->disp->run_command($c,$command,$args);
+}
+
1;