]> jfr.im git - erebus.git/blobdiff - modules/eval.py
update encoding
[erebus.git] / modules / eval.py
index 830600c3ebcd9338f51b8f5b1ec6bfd9751e8a59..00f37ebd71e592fbe07faf4f35bd7ded5a2b8ed9 100644 (file)
@@ -1,12 +1,15 @@
-# Erebus IRC bot - Author: John Runyon
+# Erebus IRC bot - Author: Erebus Team
+# vim: fileencoding=utf-8
 # !EVAL and !EXEC commands
+# This file is released into the public domain; see http://unlicense.org/
 
 # module info
 modinfo = {
-       'author': 'John Runyon (DimeCadmium)',
+       'author': 'Erebus Team',
        'license': 'public domain',
-       'compatible': [1],
+       'compatible': [0],
        'depends': [],
+       'softdeps': ['help'],
 }
 
 # preamble
@@ -17,17 +20,36 @@ modstop = lib.modstop
 
 # module code
 import sys
+import ctlmod
 
 
-@lib.hook('eval', lib.MANAGER)
-def cmd_eval(bot, user, chan, *args):
+def module(name):
+       return lib.mod(name)
+
+@lib.hook('eval', needchan=False, wantchan=True, glevel=lib.OWNER)
+@lib.help("<python>", "eval")
+@lib.argsGE(1)
+def cmd_eval(bot, user, chan, realtarget, *args):
+       if chan is not None: replyto = chan
+       else: replyto = user
+
        try: ret = eval(' '.join(args))
-       except: bot.msg(chan, "Error (%s): %s" % (sys.exc_info()[0], sys.exc_info()[1]))
-       else: bot.msg(chan, "Done: %r" % (ret))
+       except Exception: bot.msg(replyto, "Error: %s %s" % (sys.exc_info()[0], sys.exc_info()[1]))
+       else: bot.msg(replyto, "Done: %r" % (ret,))
+
+
+@lib.hook('exec', needchan=False, wantchan=True, glevel=lib.OWNER)
+@lib.help("<python>", "exec")
+@lib.argsGE(1)
+def cmd_exec(bot, user, chan, realtarget, *args):
+       if chan is not None: replyto = chan
+       else: replyto = user
 
+       try: exec(' '.join(args))
+       except Exception: bot.msg(replyto, "Error: %s %s" % (sys.exc_info()[0], sys.exc_info()[1]))
+       else: bot.msg(replyto, "Done.")
 
-@lib.hook('exec', lib.MANAGER)
-def cmd_exec(bot, user, chan, *args):
-       try: exec ' '.join(args)
-       except: bot.msg(chan, "Error: %s %s" % (sys.exc_info()[0], sys.exc_info()[1]))
-       else: bot.msg(chan, "Done.")
+@lib.hook('exception', needchan=False, glevel=lib.OWNER)
+@lib.help(None, "cause an exception")
+def cmd_exception(*args, **kwargs):
+       raise Exception()