X-Git-Url: https://jfr.im/git/erebus.git/blobdiff_plain/931c88a4c3ec73d24c53baa4e8464bcb2e51b3b6..485a2596f5ecdbb1e6f3070fbf055a499b3408dc:/modules/eval.py?ds=sidebyside diff --git a/modules/eval.py b/modules/eval.py index 830600c..6e19282 100644 --- a/modules/eval.py +++ b/modules/eval.py @@ -18,16 +18,23 @@ modstop = lib.modstop # module code import sys +@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 -@lib.hook('eval', lib.MANAGER) -def cmd_eval(bot, user, chan, *args): 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', lib.MANAGER) -def cmd_exec(bot, user, chan, *args): +@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 + 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.")