X-Git-Url: https://jfr.im/git/erebus.git/blobdiff_plain/839d2b358368b12c685ad30e6e6a534179dd0478..90b64dc01090c9a9920c42af24e9d69cb2c0cec4:/modlib.py diff --git a/modlib.py b/modlib.py index 743e36d..4c349c0 100644 --- a/modlib.py +++ b/modlib.py @@ -15,8 +15,8 @@ class error(object): class modlib(object): # default (global) access levels MANAGER = 100 - ADMIN = 90 - STAFF = 80 + ADMIN = 75 + STAFF = 50 AUTHED = 0 ANYONE = -1 @@ -28,8 +28,12 @@ class modlib(object): KNOWN = -3 PUBLIC = -2 #anyone (use glevel to control auth-needed) + # messages + WRONGARGS = "Wrong number of arguments." + def __init__(self, name): self.hooks = {} + self.numhooks = {} self.parent = None self.name = name @@ -38,9 +42,23 @@ class modlib(object): self.parent = parent for cmd, func in self.hooks.iteritems(): self.parent.hook(cmd, func) + for num, func in self.numhooks.iteritems(): + self.parent.hooknum(num, func) + return True def modstop(self, parent): for cmd, func in self.hooks.iteritems(): self.parent.unhook(cmd, func) + for num, func in self.numhooks.iteritems(): + self.parent.unhooknum(num, func) + return True + + def hooknum(self, num): + def realhook(func): + self.numhooks[num] = func + if self.parent is not None: + self.parent.hooknum(num, func) + return func + return realhook def hook(self, cmd, needchan=True, glevel=ANYONE, clevel=PUBLIC): def realhook(func): @@ -53,3 +71,23 @@ class modlib(object): self.parent.hook(cmd, func) return func return realhook + + def argsEQ(self, num): + def realhook(func): + def checkargs(bot, user, chan, realtarget, *args): + if len(args) == num: + return func(bot, user, chan, realtarget, *args) + else: + bot.msg(user, self.WRONGARGS) + return checkargs + return realhook + + def argsGE(self, num): + def realhook(func): + def checkargs(bot, user, chan, realtarget, *args): + if len(args) >= num: + return func(bot, user, chan, realtarget, *args) + else: + bot.msg(user, self.WRONGARGS) + return checkargs + return realhook