git.annexia.org
/
xavierbot.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Version 0.9: Use a nickserv password, and some fixes for OCaml 3.11.
[xavierbot.git]
/
xavierbot.pl.in
diff --git
a/xavierbot.pl.in
b/xavierbot.pl.in
index
8f01f0b
..
55ddae6
100755
(executable)
--- a/
xavierbot.pl.in
+++ b/
xavierbot.pl.in
@@
-1,11
+1,13
@@
-#!/usr/bin/perl -w
T
+#!/usr/bin/perl -w
# xavierbot : an OCaml interpreter IRC bot.
# By Richard W.M. Jones <rich@annexia.org>.
# This code is in the Public Domain.
# xavierbot : an OCaml interpreter IRC bot.
# By Richard W.M. Jones <rich@annexia.org>.
# This code is in the Public Domain.
-# $Id: xavierbot.pl.in,v 1.
7 2007/06/29 21:44:02
rjones Exp $
+# $Id: xavierbot.pl.in,v 1.
10 2010/04/04 19:38:40
rjones Exp $
use strict;
use POE qw(Component::IRC Wheel::Run);
use strict;
use POE qw(Component::IRC Wheel::Run);
+use Getopt::Long;
+use POE::Component::IRC::Plugin::NickServID;
#----------------------------------------------------------------------
# Start of configuration.
#----------------------------------------------------------------------
# Start of configuration.
@@
-13,13
+15,21
@@
use POE qw(Component::IRC Wheel::Run);
my $nick = "xavierbot";
my $ircname = "Xavierbot"; # Printable name.
my $server = "chat.freenode.net";
my $nick = "xavierbot";
my $ircname = "Xavierbot"; # Printable name.
my $server = "chat.freenode.net";
-#my $server = "devserv.devel.redhat.com";
my $port = 6667;
my $channel = "#ocaml";
my $port = 6667;
my $channel = "#ocaml";
+my $nickservpw = "123456"; # or undef
+
# End of configuration.
#----------------------------------------------------------------------
# End of configuration.
#----------------------------------------------------------------------
-# Current state.
+
+# Command line args can override configuration.
+GetOptions ("nick=s" => \$nick,
+ "ircname=s" => \$ircname,
+ "server=s" => \$server,
+ "port=i" => \$port,
+ "channel=s" => \$channel)
+ or die "$0: GetOptions: $!";
# Simple flood protection. This counts number of lines received from
# the toplevel, and is reset when we send a line. If this exceeds
# Simple flood protection. This counts number of lines received from
# the toplevel, and is reset when we send a line. If this exceeds
@@
-55,6
+65,11
@@
sub _start
port => $port,
) or die "POE::Component::IRC->spawn failed: $!";
port => $port,
) or die "POE::Component::IRC->spawn failed: $!";
+ $irc->plugin_add('NickServID',
+ POE::Component::IRC::Plugin::NickServID->new(
+ Password => $nickservpw,
+ ));
+
my $ocaml = start_toplevel ();
$kernel->sig(CHLD => qw(got_sigchld));
my $ocaml = start_toplevel ();
$kernel->sig(CHLD => qw(got_sigchld));
@@
-105,6
+120,11
@@
sub irc_public
$kernel->post ($sender => privmsg => $channel => $_)
foreach (@usage);
}
$kernel->post ($sender => privmsg => $channel => $_)
foreach (@usage);
}
+ elsif ($what =~ /^\s*xavierbot\b.*\brestart\b/) {
+ $sleeping = 0;
+ print STDOUT "got instruction to restart ...\n";
+ restart_toplevel ($heap->{ocaml});
+ }
elsif (!$sleeping) {
if (my ($stmt) = $what =~ m/^\s*([^\#].*;;)\s*$/) {
$heap->{ocaml}->put ("$stmt\n");
elsif (!$sleeping) {
if (my ($stmt) = $what =~ m/^\s*([^\#].*;;)\s*$/) {
$heap->{ocaml}->put ("$stmt\n");
@@
-121,11
+141,6
@@
sub irc_public
$kernel->post ($sender => privmsg => $channel =>
"xavierbot wakes up");
}
$kernel->post ($sender => privmsg => $channel =>
"xavierbot wakes up");
}
- elsif ($what =~ /^\s*xavierbot\b.*\brestart\b/) {
- $sleeping = 0;
- print STDOUT "got instruction to restart ...\n";
- restart_toplevel ($heap->{ocaml});
- }
}
undef;
}
}
undef;
}