mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-01-11 12:42:34 +01:00
Make Owner.defaultplugin more robust in it's error detection.
This commit is contained in:
parent
b9598abfb8
commit
45b534fa03
18
src/Owner.py
18
src/Owner.py
@ -175,7 +175,7 @@ class LogErrorHandler(logging.Handler):
|
|||||||
else:
|
else:
|
||||||
s = record.msg
|
s = record.msg
|
||||||
# Send to the owner dudes.
|
# Send to the owner dudes.
|
||||||
|
|
||||||
|
|
||||||
class Owner(privmsgs.CapabilityCheckingPrivmsg):
|
class Owner(privmsgs.CapabilityCheckingPrivmsg):
|
||||||
# This plugin must be first; its priority must be lowest; otherwise odd
|
# This plugin must be first; its priority must be lowest; otherwise odd
|
||||||
@ -363,7 +363,7 @@ class Owner(privmsgs.CapabilityCheckingPrivmsg):
|
|||||||
irc.error('You must give your bot the --allow-eval option for '
|
irc.error('You must give your bot the --allow-eval option for '
|
||||||
'this command to be enabled.')
|
'this command to be enabled.')
|
||||||
_exec = eval
|
_exec = eval
|
||||||
|
|
||||||
def announce(self, irc, msg, args):
|
def announce(self, irc, msg, args):
|
||||||
"""<text>
|
"""<text>
|
||||||
|
|
||||||
@ -377,7 +377,7 @@ class Owner(privmsgs.CapabilityCheckingPrivmsg):
|
|||||||
c = ircdb.channels.getChannel(channel)
|
c = ircdb.channels.getChannel(channel)
|
||||||
if not c.lobotomized:
|
if not c.lobotomized:
|
||||||
irc.queueMsg(ircmsgs.privmsg(channel, text))
|
irc.queueMsg(ircmsgs.privmsg(channel, text))
|
||||||
|
|
||||||
def defaultplugin(self, irc, msg, args):
|
def defaultplugin(self, irc, msg, args):
|
||||||
"""[--remove] <command> [<plugin>]
|
"""[--remove] <command> [<plugin>]
|
||||||
|
|
||||||
@ -393,9 +393,17 @@ class Owner(privmsgs.CapabilityCheckingPrivmsg):
|
|||||||
(command, plugin) = privmsgs.getArgs(rest, optional=1)
|
(command, plugin) = privmsgs.getArgs(rest, optional=1)
|
||||||
command = callbacks.canonicalName(command)
|
command = callbacks.canonicalName(command)
|
||||||
cbs = callbacks.findCallbackForCommand(irc, command)
|
cbs = callbacks.findCallbackForCommand(irc, command)
|
||||||
|
def isDispatcher(cb):
|
||||||
|
name = callbacks.canonicalName(getattr(cb, 'name')())
|
||||||
|
return getattr(cb, name).isDispatcher
|
||||||
|
# Ensure someone isn't trying to use a plugin for their command
|
||||||
|
cbs = [cb for cb in cbs if not isDispatcher(cb)]
|
||||||
if remove:
|
if remove:
|
||||||
conf.supybot.commands.defaultPlugins.unregister(command)
|
try:
|
||||||
irc.replySuccess()
|
conf.supybot.commands.defaultPlugins.unregister(command)
|
||||||
|
irc.replySuccess()
|
||||||
|
except registry.NonExistentRegistryEntry:
|
||||||
|
raise callbacks.ArgumentError
|
||||||
elif not cbs:
|
elif not cbs:
|
||||||
irc.error('That\'s not a valid command.')
|
irc.error('That\'s not a valid command.')
|
||||||
return
|
return
|
||||||
|
Loading…
Reference in New Issue
Block a user