X-Git-Url: https://jfr.im/git/erebus.git/blobdiff_plain/e5a241469daa56cf798340a25526ef59a79bd700..5f42c250f797d8cf1bca89d431134764d97c63fd:/modules/eval.py diff --git a/modules/eval.py b/modules/eval.py index 8293879..d9ff4e4 100644 --- a/modules/eval.py +++ b/modules/eval.py @@ -20,25 +20,27 @@ modstop = lib.modstop import sys import ctlmod + +def module(name): + return lib.mod(name) + @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 + if chan is not None and realtarget == chan.name: replyto = chan else: replyto = user try: ret = eval(' '.join(args)) - except SystemExit: raise - except: bot.msg(replyto, "Error (%s): %s" % (sys.exc_info()[0], sys.exc_info()[1])) + 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, glevel=lib.MANAGER) @lib.argsGE(1) def cmd_exec(bot, user, chan, realtarget, *args): - if chan is not None: replyto = chan + if chan is not None and realtarget == chan.name: replyto = chan else: replyto = user try: exec ' '.join(args) - except SystemExit: raise - except: bot.msg(replyto, "Error: %s %s" % (sys.exc_info()[0], sys.exc_info()[1])) + except Exception: bot.msg(replyto, "Error: %s %s" % (sys.exc_info()[0], sys.exc_info()[1])) else: bot.msg(replyto, "Done.")