Fix !help

This commit is contained in:
Némunaire 2012-11-04 14:04:49 +01:00
parent d58afa9419
commit 5afe5cb15a
2 changed files with 37 additions and 37 deletions

37
bot.py
View File

@ -413,7 +413,7 @@ class Bot:
msg.cmds[0] = msg.cmds[0][1:] msg.cmds[0] = msg.cmds[0][1:]
if msg.cmds[0] == "help": if msg.cmds[0] == "help":
return _help_msg(msg.sender) return _help_msg(msg.sender, self.modules, msg.cmds)
elif msg.cmds[0] == "more": elif msg.cmds[0] == "more":
if msg.channel == srv.nick: if msg.channel == srv.nick:
@ -556,6 +556,41 @@ class Bot:
def _ctcp_response(sndr, msg): def _ctcp_response(sndr, msg):
return response.Response(sndr, msg, ctcp=True) return response.Response(sndr, msg, ctcp=True)
def _help_msg(sndr, modules, cmd):
"""Parse and response to help messages"""
res = response.Response(sndr)
if len(cmd) > 1:
if cmd[1] in modules:
if len(cmd) > 2:
if hasattr(modules[cmd[1]], "HELP_cmd"):
res.append_message(modules[cmd[1]].HELP_cmd(cmd[2]))
else:
res.append_message("No help for command %s in module %s" % (cmd[2], cmd[1]))
elif hasattr(modules[cmd[1]], "help_full"):
res.append_message(modules[cmd[1]].help_full())
else:
res.append_message("No help for module %s" % cmd[1])
else:
res.append_message("No module named %s" % cmd[1])
else:
res.append_message("Pour me demander quelque chose, commencez "
"votre message par mon nom ; je réagis "
"également à certaine commandes commençant par"
" !. Pour plus d'informations, envoyez le "
"message \"!more\".")
res.append_message("Mon code source est libre, publié sous "
"licence AGPL (http://www.gnu.org/licenses/). "
"Vous pouvez le consulter, le dupliquer, "
"envoyer des rapports de bogues ou bien "
"contribuer au projet sur GitHub : "
"http://github.com/nemunaire/nemubot/")
res.append_message(title="Pour plus de détails sur un module, "
"envoyez \"!help nomdumodule\". Voici la liste"
" de tous les modules disponibles localement",
message=["\x03\x02%s\x03\x02 (%s)" % (im, modules[im].help_tiny ()) for im in modules if hasattr(modules[im], "help_tiny")])
return res
def hotswap(bak): def hotswap(bak):
return Bot(bak.servers, bak.modules, bak.modules_path) return Bot(bak.servers, bak.modules, bak.modules_path)

View File

@ -83,6 +83,7 @@ class MessageConsumer:
"""Create, parse and treat the message""" """Create, parse and treat the message"""
try: try:
msg = Message(self.raw, self.time, self.prvt) msg = Message(self.raw, self.time, self.prvt)
msg.server = self.srv.id
if msg.cmd == "PRIVMSG": if msg.cmd == "PRIVMSG":
msg.is_owner = (msg.nick == self.srv.owner) msg.is_owner = (msg.nick == self.srv.owner)
res = self.treat_in(context, msg) res = self.treat_in(context, msg)
@ -139,39 +140,3 @@ class Consumer(threading.Thread):
pass pass
finally: finally:
self.context.cnsr_thrd_size -= 2 self.context.cnsr_thrd_size -= 2
def _help_msg(modules, sndr, cmd):
"""Parse and response to help messages"""
res = response.Response(sndr)
if len(cmd) > 1:
if cmd[1] in modules:
if len(cmd) > 2:
if hasattr(modules[cmd[1]], "HELP_cmd"):
res.append_message(modules[cmd[1]].HELP_cmd(cmd[2]))
else:
res.append_message("No help for command %s in module %s" % (cmd[2], cmd[1]))
elif hasattr(modules[cmd[1]], "help_full"):
res.append_message(modules[cmd[1]].help_full())
else:
res.append_message("No help for module %s" % cmd[1])
else:
res.append_message("No module named %s" % cmd[1])
else:
res.append_message("Pour me demander quelque chose, commencez "
"votre message par mon nom ; je réagis "
"également à certaine commandes commençant par"
" !. Pour plus d'informations, envoyez le "
"message \"!more\".")
res.append_message("Mon code source est libre, publié sous "
"licence AGPL (http://www.gnu.org/licenses/). "
"Vous pouvez le consulter, le dupliquer, "
"envoyer des rapports de bogues ou bien "
"contribuer au projet sur GitHub : "
"http://github.com/nemunaire/nemubot/")
res.append_message(title="Pour plus de détails sur un module, "
"envoyez \"!help nomdumodule\". Voici la liste"
" de tous les modules disponibles localement",
message=["\x03\x02%s\x03\x02 (%s)" % (im, modules[im].help_tiny ()) for im in modules if hasattr(modules[im], "help_tiny")])
return res