Fixed the bug that caused "reply reply" to be necessary instead of just "reply".

This commit is contained in:
Jeremy Fincher 2005-05-23 11:23:53 +00:00
parent aeaad9056c
commit a1992b55ec
2 changed files with 26 additions and 2 deletions

View File

@ -705,7 +705,14 @@ class NestedCommandsIrcProxy(ReplyIrcProxy):
cbs = [cb for (cb, L) in cbs if L == maxL] cbs = [cb for (cb, L) in cbs if L == maxL]
if len(maxL) == 1: if len(maxL) == 1:
# Special case: one arg determines the callback. In this case, we # Special case: one arg determines the callback. In this case, we
# have to check defaultPlugins. # have to check, in order:
# 1. Whether the arg is the same as the name of a callback. This
# callback would then win.
for cb in cbs:
if cb.canonicalName() == maxL[0]:
return (maxL, [cb])
# 2. Whether a defaultplugin is defined.
defaultPlugins = conf.supybot.commands.defaultPlugins defaultPlugins = conf.supybot.commands.defaultPlugins
try: try:
defaultPlugin = defaultPlugins.get(maxL[0])() defaultPlugin = defaultPlugins.get(maxL[0])()
@ -719,7 +726,9 @@ class NestedCommandsIrcProxy(ReplyIrcProxy):
# actually have that command. # actually have that command.
return (maxL, [cb]) return (maxL, [cb])
except registry.NonExistentRegistryEntry: except registry.NonExistentRegistryEntry:
pass # No default plugin defined. pass
# 3. Whether an importantPlugin is one of the responses.
important = defaultPlugins.importantPlugins() important = defaultPlugins.importantPlugins()
important = map(canonicalName, important) important = map(canonicalName, important)
importants = [] importants = []

View File

@ -261,6 +261,21 @@ class FunctionsTestCase(SupyTestCase):
self.assertEqual(callbacks.tokenize('bar [baz]'), ['bar', ['baz']]) self.assertEqual(callbacks.tokenize('bar [baz]'), ['bar', ['baz']])
class AmbiguityTestCase(PluginTestCase):
plugins = ('Misc',) # Something so it doesn't complain.
class Foo(callbacks.Plugin):
def bar(self, irc, msg, args):
irc.reply('foo.bar')
class Bar(callbacks.Plugin):
def bar(self, irc, msg, args):
irc.reply('bar.bar')
def testAmbiguityWithCommandSameNameAsPlugin(self):
self.irc.addCallback(self.Foo(self.irc))
self.assertResponse('bar', 'foo.bar')
self.irc.addCallback(self.Bar(self.irc))
self.assertResponse('bar', 'bar.bar')
class PrivmsgTestCase(ChannelPluginTestCase): class PrivmsgTestCase(ChannelPluginTestCase):
plugins = ('Utilities', 'Misc',) plugins = ('Utilities', 'Misc',)
conf.allowEval = True conf.allowEval = True