return func
return realhook
- def hook(self, cmd, needchan=True, glevel=ANYONE, clevel=PUBLIC):
+ def hook(self, cmd=None, needchan=True, glevel=ANYONE, clevel=PUBLIC):
+ _cmd = cmd #save this since it gets wiped out...
def realhook(func):
+ cmd = _cmd #...and restore it
+ if cmd is None:
+ cmd = func.__name__ # default to function name
+
func.needchan = needchan
func.reqglevel = glevel
func.reqclevel = clevel
return func(bot, user, chan, realtarget, *args)
else:
bot.msg(user, self.WRONGARGS)
+ checkargs.__name__ = func.__name__
return checkargs
return realhook
return func(bot, user, chan, realtarget, *args)
else:
bot.msg(user, self.WRONGARGS)
+ checkargs.__name__ = func.__name__
return checkargs
return realhook
+
+ def help(self, *args, **kwargs):
+ """help(syntax, shorthelp, longhelp, more lines longhelp, cmd=...?)
+ Example:
+ help("<user> <pass>", "login")
+ ^ Help will only be one line. Command name determined based on function name.
+ help("<user> <level>", "add a user", cmd=("adduser", "useradd"))
+ ^ Help will be listed under ADDUSER; USERADD will say "alias for adduser"
+ help(None, "do stuff", "This command is really complicated.")
+ ^ Command takes no args. Short description (in overall HELP listing) is "do stuff".
+ Long description (HELP <command>) will say "<command> - do stuff", newline, "This command is really complicated."
+ """
+ try:
+ self.mod('help').reghelp(*args, **kwargs)
+ except:
+ pass