Merge branch 'mjb.help' into mjb
This commit is contained in:
commit
47bb4bac49
18
Module.py
18
Module.py
|
@ -154,5 +154,23 @@ class Module(object):
|
|||
|
||||
print("looks like someone forgot to implement do!")
|
||||
|
||||
def help_description(self):
|
||||
"""Return a quick list of commands or other summary, should be
|
||||
less than two lines. If you want the module hidden from "!help",
|
||||
return None here"""
|
||||
return "No description available"
|
||||
|
||||
def help_summary(self):
|
||||
"""Return a command summary or longer description of this module.
|
||||
If this returns None, the summary will be
|
||||
"no help available for module foo"
|
||||
"""
|
||||
return None
|
||||
|
||||
def help_detail(self, command):
|
||||
"""Return detailed help for the given command. Return None if there
|
||||
is no suitable help available"""
|
||||
return None
|
||||
|
||||
# vi:tabstop=4:expandtab:autoindent
|
||||
# kate: indent-mode python;indent-width 4;replace-tabs on;
|
||||
|
|
|
@ -0,0 +1,122 @@
|
|||
"""
|
||||
Help - handle !help commands by interrogating modules for help text
|
||||
Copyright (C) 2011 Mike Bloy <mike@bloy.org>
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation, either version 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
"""
|
||||
|
||||
import re
|
||||
import sqlite3
|
||||
|
||||
from Module import Module
|
||||
|
||||
__author__ = "Mike Bloy <mike@bloy.org>"
|
||||
__date__ = "2011-01-08"
|
||||
|
||||
class Help(Module):
|
||||
|
||||
def __init__(self, irc, config, server):
|
||||
"""
|
||||
Upon creation, determine the save file location
|
||||
"""
|
||||
|
||||
Module.__init__(self, irc, config, server)
|
||||
|
||||
self.helpre = re.compile('^!help(\s+(\S+)(\s+(.+))?)?\s*$')
|
||||
|
||||
def do(self, connection, event, nick, userhost, what, admin_unlocked):
|
||||
"""look for !help and subcommands,
|
||||
and dispatch for further processing"""
|
||||
|
||||
match = self.helpre.search(what)
|
||||
if match:
|
||||
(module, key) = match.group(2,4)
|
||||
if (module == None):
|
||||
return self.handle_help_descriptions()
|
||||
elif (key == None):
|
||||
return self.handle_help_module(module)
|
||||
else:
|
||||
return self.handle_help_detail(module, key)
|
||||
|
||||
def handle_help_descriptions(self):
|
||||
"""print the general help"""
|
||||
message = "General Help:\n"
|
||||
for module in self.irc.modlist:
|
||||
description = module.help_description()
|
||||
if description:
|
||||
message += " %s - %s\n" % (module.__class__.__name__,
|
||||
description)
|
||||
return message
|
||||
|
||||
def handle_help_module(self, modname):
|
||||
"""handle the module level help processing"""
|
||||
module = self.find_module(modname)
|
||||
if module:
|
||||
helptext = module.help_summary()
|
||||
if helptext:
|
||||
return "%s - %s" % (modname, helptext)
|
||||
else:
|
||||
return "no help available for module %s" % (modname)
|
||||
else:
|
||||
return "no module named '%s' is loaded" % (modname)
|
||||
|
||||
def handle_help_detail(self, modname, key):
|
||||
"""handle the help detail message"""
|
||||
module = self.find_module(modname)
|
||||
if module:
|
||||
helptext = module.help_detail(key)
|
||||
if helptext:
|
||||
return "%s (%s) - %s" % (modname, key, helptext)
|
||||
else:
|
||||
return "no help available for module '%s', command '%s'" % (modname, key)
|
||||
else:
|
||||
return "no module named '%s' is loaded" % (modname)
|
||||
|
||||
return "asked for help on module %s detail %s" % (modname, key)
|
||||
|
||||
def find_module(self, modname):
|
||||
"""find a module in the server's list of loaded modules"""
|
||||
for module in self.irc.modlist:
|
||||
if modname == module.__class__.__name__:
|
||||
return module
|
||||
return None
|
||||
|
||||
def help_description(self):
|
||||
"""Return a quick list of commands or other summary, should be
|
||||
less than two lines. If you want the module hidden from "!help",
|
||||
return None here"""
|
||||
return "Display module and command help"
|
||||
|
||||
def help_summary(self):
|
||||
"""Return a command summary or longer description of this module.
|
||||
If this returns None, the summary will be
|
||||
"no help available for module foo"
|
||||
"""
|
||||
return """!help [module [detail]]
|
||||
type '!help Help module' or '!help Help detail' for more information"""
|
||||
|
||||
def help_detail(self, command):
|
||||
"""Return detailed help for the given command. Return None if there
|
||||
is no suitable help available"""
|
||||
if command == 'module':
|
||||
return """get a summary of a module's commands or function"""
|
||||
elif command == 'detail':
|
||||
return """get information on a specific module-defined detail"""
|
||||
else:
|
||||
return None
|
||||
|
||||
if __name__ == "__main__":
|
||||
print "Hello World"
|
||||
|
||||
# vi:tabstop=4:expandtab:autoindent
|
|
@ -166,5 +166,51 @@ class IrcAdmin(Module):
|
|||
|
||||
return ', '.join(self.irc.list_modules())
|
||||
|
||||
def help_description(self):
|
||||
"""Return a quick list of commands or other summary, should be
|
||||
less than two lines. If you want the module hidden from "!help",
|
||||
return None here"""
|
||||
return "Perform admin-related functions."
|
||||
|
||||
def help_summary(self):
|
||||
"""Return a command summary or longer description of this module.
|
||||
If this returns None, the summary will be
|
||||
"no help available for module foo"
|
||||
"""
|
||||
return """Bot admin commands (do '!help IrcAdmin [cmd] for details):
|
||||
!join, !part, !quit, !autojoin, !save, !nick, !load, !reload, !unload, !modules"""
|
||||
|
||||
def help_detail(self, command):
|
||||
"""Return detailed help for the given command. Return None if there
|
||||
is no suitable help available"""
|
||||
key = command.strip()
|
||||
if key[0] == '!':
|
||||
key = key[1:]
|
||||
words = key.split()
|
||||
if len(words) == 0:
|
||||
return None
|
||||
elif words[0] == 'join':
|
||||
return "!join [channel] - cause the bot to /join [channel]"
|
||||
elif words[0] == 'part':
|
||||
return "!part [channel] - cause the bot to /part from [channel]"
|
||||
elif words[0] == 'quit':
|
||||
return "!quit - cause the bot to save itself and quit"
|
||||
elif words[0] == 'autojoin':
|
||||
return "!autojoin [channel] - cause the bot to join [channel] on startup"
|
||||
elif words[0] == 'save':
|
||||
return "!save - cause the bot to save config data to the config file"
|
||||
elif words[0] == 'nick':
|
||||
return "!nick - cause the bot to change its nick"
|
||||
elif words[0] == 'load':
|
||||
return "!load - make the bot load a module dynamically"
|
||||
elif words[0] == 'reload':
|
||||
return "!reload - reload an already-loaded module"
|
||||
elif words[0] == 'unload':
|
||||
return "!unload - unload a loaded module, removing its functionality"
|
||||
elif words[0] == 'modules':
|
||||
return "!modules - list the currently loaded modules"
|
||||
else:
|
||||
return None
|
||||
|
||||
# vi:tabstop=4:expandtab:autoindent
|
||||
# kate: indent-mode python;indent-width 4;replace-tabs on;
|
||||
|
|
|
@ -18,6 +18,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|||
|
||||
import re
|
||||
import sqlite3
|
||||
import string
|
||||
|
||||
from Module import Module
|
||||
|
||||
|
@ -228,6 +229,43 @@ class Karma(Module):
|
|||
|
||||
return reply
|
||||
|
||||
def help_description(self):
|
||||
"""Return a quick list of commands or other summary, should be
|
||||
less than two lines. If you want the module hidden from "!help",
|
||||
return None here"""
|
||||
return "record karma and report on recorded karma"
|
||||
|
||||
def help_summary(self):
|
||||
"""Return a command summary or longer description of this module.
|
||||
If this returns None, the summary will be
|
||||
"no help available for module foo"
|
||||
"""
|
||||
return """Watches channels for words (or parenthesized phrases) followed by one of ++, --, +-, or -+, and records an increment, decrement, or combination of karma for the word or phrase, as well as the identity of the karma giver. Supports the following commands:
|
||||
!rank [item] - get the current karma value for item
|
||||
!karma stat [nick] - report on the karma-giving statistics of nick
|
||||
!karma report (highest|lowest) - report on the highest or lowest karma recipients
|
||||
!karma report (positive|negative) - report on the biggest optimists or pessimists"""
|
||||
|
||||
def help_detail(self, command):
|
||||
"""Return detailed help for the given command. Return None if there
|
||||
is no suitable help available"""
|
||||
key = command.strip()
|
||||
if key[0] == '!':
|
||||
key = key[1:]
|
||||
words = key.split()
|
||||
if len(words) == 0:
|
||||
return None
|
||||
elif words[0] == 'rank':
|
||||
return "!rank [item] - get the current karma value and rank of [item]"
|
||||
elif words[0] == 'karma':
|
||||
return """!karma stat [nick] - report on the positive, negative, and total karma given by [nick]
|
||||
!karma report highest - report on the top 5 karma recipients
|
||||
!karma report lowest - report on the bottom 5 karma recipients
|
||||
!karma report positive - report on the 5 most positive karma givers
|
||||
!karma report negative - report on the 5 most negative karma givers"""
|
||||
else:
|
||||
return None
|
||||
|
||||
if __name__ == "__main__":
|
||||
print "Hello World"
|
||||
|
||||
|
|
Loading…
Reference in New Issue