]> jfr.im git - erebus.git/blobdiff - modules/eval.py
Added !MODLOAD, !MODUNLOAD, !MODRELOAD
[erebus.git] / modules / eval.py
index 830600c3ebcd9338f51b8f5b1ec6bfd9751e8a59..159635fb3f99eb248c4f43eff1330af424e455ed 100644 (file)
@@ -19,15 +19,23 @@ modstop = lib.modstop
 import sys
 
 
-@lib.hook('eval', lib.MANAGER)
-def cmd_eval(bot, user, chan, *args):
+@lib.hook('eval', needchan=False, glevel=lib.MANAGER)
+@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: 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, glevel=lib.MANAGER)
+@lib.argsGE(1)
+def cmd_exec(bot, user, chan, realtarget, *args):
+       if chan is not None: replyto = chan
+       else: replyto = user
 
-@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.")
+       except: bot.msg(replyto, "Error: %s %s" % (sys.exc_info()[0], sys.exc_info()[1]))
+       else: bot.msg(replyto, "Done.")