1 # This file is part of Acrobat.
3 # Acrobat is free software; you can redistribute it and/or modify
4 # it under the terms of the GNU General Public License as published
5 # by the Free Software Foundation; either version 2 of the License,
6 # or (at your option) any later version.
8 # Acrobat is distributed in the hope that it will be useful,
9 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # GNU General Public License for more details.
13 # You should have received a copy of the GNU General Public License
14 # along with Acrobat; if not, write to the Free Software
15 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
18 # Andrew Walkingshaw <andrew@lexical.org.uk>
19 # Peter Corbett <ptc24@cam.ac.uk>
20 # Matthew Vernon <matthew@debian.org>
21 # Stephen Early <steve@greenend.org.uk>
23 # Acrobat configuration file
25 # The following definitions are required to be present in this module:
31 # Also a function called "command"; see later.
33 # Everything else in this file is configuration-specific.
35 # Most command implementations are stored in a separate module.
38 # This fishpond is shared between trouts and flirts. It doesn't have to be;
39 # you can define as many ponds as you like.
50 # load a file full of flirts or trouts
53 f = open(filename, "r")
54 r = [l.strip() for l in f.readlines() if l.find("%s") != -1]
57 r = [ "doesn't know what to do about %s." ]
60 # (troutlist,selftroutmsg,DoSmsg,notargetmsg,nofishmsg,fishpond,selftroutprob)
63 ' (at the instigation of %s)',
64 "Sorry, but %s is being a spoilsport.",
65 "Who do you wish me to trout?",
66 "Fish stocks exhausted.",
72 ' (but %s is their secret admirer)',
73 "Sorry, but %s made me take Holy Orders.",
74 "Who do you wish me to flirt with?",
75 "My libido is over-used!",
79 # Hacky command to output the current fishpond state
80 def fishq(bot, cmd, nick, conn, public,f):
81 from irclib import irc_lower
82 if not public and irc_lower(nick) == irc_lower(bot.owner):
83 state=("Fishpond state: cur_fish=%d, max_fish=%d, nofish_time=%d, "
84 +"fish_time_inc=%d, fish_inc=%d, DoS=%d, Boring_Git=%s, "
85 +"quotatime=%d")%(f.cur_fish,f.max_fish,f.nofish_time,
86 f.fish_time_inc,f.fish_inc,f.DoS,f.Boring_Git,
88 bot.automsg(public,nick,state)
90 # Karma implementation
92 karmafilename = "karmadump"
95 f = open(karmafilename, "r")
96 karmadb = cPickle.load(f)
101 def karma(cmd, amount):
102 thing=cmd.split()[0][:-2].lower()
103 if karmadb.has_key(thing):
104 karmadb[thing] += amount
106 karmadb[thing] = amount
109 f = open(karmafilename, "w")
110 cPickle.dump(karmadb, f)
113 sys.stderr.write("Problems dumping karma: probably lost :(")
115 # When the bot exits we should save the karma db
116 def quit(bot,cmd,nick,conn,public):
118 c.quitq(bot,cmd,nick,conn,public)
119 def reload(bot,cmd,nick,conn,public):
121 c.reloadq(bot,cmd,nick,conn,public)
123 # Command processing: whenever something is said that the bot can hear,
124 # "command" is invoked and must decide what to do. This configuration
125 # defines a couple of special cases (for karma) but is otherwise driven
126 # by a dictionary of commands.
128 commands = {"karma": (c.karmaq,karmadb),
129 "karmalist": (c.listkeysq,karmadb),
130 "karmadel": (c.karmadelq,karmadb),
131 "info": (c.infoq,karmadb),
132 "trout": (c.troutq,troutcfg),
133 "fish": (fishq,fish),
134 "flirt": (c.troutq,flirtcfg),
135 "quiet": (c.nofishq,fish),
142 # disconnect and hop annoy people
143 # "disconnect": c.disconnq,
144 # "hop": c.disconnq }
145 commands["list"]=(c.listkeysq,commands)
147 triggers = ("!", "~") # what character should the bot be invoked by:
148 # eg !trout, ~trout etc.
150 def command(bot, cmd, nick, conn, public):
153 if public and cmd[0] in triggers:
158 command = cmd.split()[0]
162 if command.endswith("++"):
165 if command.endswith("--"):
168 if ours and command.lower() in commands.keys():
171 e(bot,cmd,nick,conn,public)
173 e[0](bot,cmd,nick,conn,public,*e[1:])