X-Git-Url: https://jfr.im/git/erebus.git/blobdiff_plain/b79721eec298caeaedf33fbfe401c8ada1876791..f717c85633876497545e003d2aa3041b5dd07f19:/modules/eval.py diff --git a/modules/eval.py b/modules/eval.py index 1c68b92..d2b82c8 100644 --- a/modules/eval.py +++ b/modules/eval.py @@ -6,8 +6,9 @@ modinfo = { 'author': 'Erebus Team', 'license': 'public domain', - 'compatible': [1], + 'compatible': [1,2], 'depends': [], + 'softdeps': ['help'], } # preamble @@ -22,9 +23,10 @@ import ctlmod def module(name): - return lib.parent.module(name) + return lib.mod(name) @lib.hook('eval', needchan=False, glevel=lib.MANAGER) +@lib.help("", "eval") @lib.argsGE(1) def cmd_eval(bot, user, chan, realtarget, *args): if chan is not None and realtarget == chan.name: replyto = chan @@ -36,6 +38,7 @@ def cmd_eval(bot, user, chan, realtarget, *args): @lib.hook('exec', needchan=False, glevel=lib.MANAGER) +@lib.help("", "exec") @lib.argsGE(1) def cmd_exec(bot, user, chan, realtarget, *args): if chan is not None and realtarget == chan.name: replyto = chan @@ -44,3 +47,8 @@ def cmd_exec(bot, user, chan, realtarget, *args): 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('exception', needchan=False, glevel=lib.OWNER) +@lib.help(None, "cause an exception") +def cmd_exception(*args, **kwargs): + raise Exception()