Fixed empty types.

This commit is contained in:
Jeremy Fincher 2004-10-15 11:18:55 +00:00
parent ec75306a37
commit edc1e70648
2 changed files with 33 additions and 22 deletions

View File

@ -108,7 +108,7 @@ def urlSnarfer(f):
def newf(self, irc, msg, match, *L, **kwargs): def newf(self, irc, msg, match, *L, **kwargs):
url = match.group(0) url = match.group(0)
channel = msg.args[0] channel = msg.args[0]
if not ircutils.isChannel(channel): if not irc.isChannel(channel):
return return
if ircdb.channels.getChannel(channel).lobotomized: if ircdb.channels.getChannel(channel).lobotomized:
self.log.info('Not snarfing in %s: lobotomized.', channel) self.log.info('Not snarfing in %s: lobotomized.', channel)
@ -234,7 +234,7 @@ def getHaveOp(irc, msg, args, state, action='do that'):
irc.error('I need to be opped to %s.' % action, Raise=True) irc.error('I need to be opped to %s.' % action, Raise=True)
def validChannel(irc, msg, args, state): def validChannel(irc, msg, args, state):
if ircutils.isChannel(args[0]): if irc.isChannel(args[0]):
# XXX Check maxlength in irc.state.supported. # XXX Check maxlength in irc.state.supported.
state.args.append(args.pop(0)) state.args.append(args.pop(0))
else: else:
@ -317,9 +317,9 @@ def getSeenNick(irc, msg, args, state, errmsg=None):
def getChannel(irc, msg, args, state): def getChannel(irc, msg, args, state):
if args and ircutils.isChannel(args[0]): if args and irc.isChannel(args[0]):
channel = args.pop(0) channel = args.pop(0)
elif ircutils.isChannel(msg.args[0]): elif irc.isChannel(msg.args[0]):
channel = msg.args[0] channel = msg.args[0]
else: else:
state.log.debug('Raising ArgumentError because there is no channel.') state.log.debug('Raising ArgumentError because there is no channel.')
@ -333,9 +333,17 @@ def inChannel(irc, msg, args, state):
if state.channel not in irc.state.channels: if state.channel not in irc.state.channels:
irc.error('I\'m not in %s.' % state.channel, Raise=True) irc.error('I\'m not in %s.' % state.channel, Raise=True)
def onlyInChannel(irc, msg, args, state):
if not (irc.isChannel(msg.args[0]) and msg.args[0] in irc.state.channels):
irc.error('This command may only be given in a channel that I am in.',
Raise=True)
else:
state.channel = msg.args[0]
state.args.append(state.channel)
def callerInChannel(irc, msg, args, state): def callerInChannel(irc, msg, args, state):
channel = args[0] channel = args[0]
if ircutils.isChannel(channel): if irc.isChannel(channel):
if channel in irc.state.channels: if channel in irc.state.channels:
if msg.nick in irc.state.channels[channel].users: if msg.nick in irc.state.channels[channel].users:
state.args.append(args.pop(0)) state.args.append(args.pop(0))
@ -379,11 +387,11 @@ def getSomethingNoSpaces(irc, msg, args, state, *L):
getSomething(irc, msg, args, state, p=p, *L) getSomething(irc, msg, args, state, p=p, *L)
def private(irc, msg, args, state): def private(irc, msg, args, state):
if ircutils.isChannel(msg.args[0]): if irc.isChannel(msg.args[0]):
irc.errorRequiresPrivacy(Raise=True) irc.errorRequiresPrivacy(Raise=True)
def public(irc, msg, args, state, errmsg=None): def public(irc, msg, args, state, errmsg=None):
if not ircutils.isChannel(msg.args[0]): if not irc.isChannel(msg.args[0]):
if errmsg is None: if errmsg is None:
errmsg = 'This message must be sent in a channel.' errmsg = 'This message must be sent in a channel.'
irc.error(errmsg, Raise=True) irc.error(errmsg, Raise=True)
@ -468,6 +476,7 @@ wrappers = ircutils.IrcDict({
'seenNick': getSeenNick, 'seenNick': getSeenNick,
'channel': getChannel, 'channel': getChannel,
'inChannel': inChannel, 'inChannel': inChannel,
'onlyInChannel': onlyInChannel,
'callerInChannel': callerInChannel, 'callerInChannel': callerInChannel,
'plugin': getPlugin, 'plugin': getPlugin,
'boolean': getBoolean, 'boolean': getBoolean,
@ -678,11 +687,10 @@ class Spec(object):
utils.mapinto(contextify, self.types) utils.mapinto(contextify, self.types)
def __call__(self, irc, msg, args, stateAttrs={}): def __call__(self, irc, msg, args, stateAttrs={}):
if self.types: state = self._state(self.types[:], stateAttrs)
state = self._state(self.types[:], stateAttrs) while state.types:
while state.types: context = state.types.pop(0)
context = state.types.pop(0) context(irc, msg, args, state)
context(irc, msg, args, state)
if args and not self.allowExtra: if args and not self.allowExtra:
log.debug('args and not self.allowExtra: %r', args) log.debug('args and not self.allowExtra: %r', args)
raise callbacks.ArgumentError raise callbacks.ArgumentError

View File

@ -30,20 +30,20 @@
from testsupport import * from testsupport import *
from supybot.commands import * from supybot.commands import *
import supybot.irclib as irclib
import supybot.ircmsgs as ircmsgs import supybot.ircmsgs as ircmsgs
import supybot.callbacks as callbacks import supybot.callbacks as callbacks
class CommandsTestCase(SupyTestCase): class CommandsTestCase(SupyTestCase):
msg = ircmsgs.privmsg('test', 'foo') def assertState(self, spec, given, expected, target='test', **kwargs):
class irc: msg = ircmsgs.privmsg(target, 'foo')
nick = 'test' realIrc = getTestIrc()
def error(self, s): realIrc.nick = 'test'
raise self.failureException, s realIrc.state.supported['chantypes'] = '#'
def assertState(self, spec, given, expected, **kwargs): irc = callbacks.SimpleProxy(realIrc, msg)
irc = callbacks.SimpleProxy(self.irc(), self.msg)
myspec = Spec(spec, **kwargs) myspec = Spec(spec, **kwargs)
state = myspec(irc, self.msg, given) state = myspec(irc, msg, given)
self.assertEqual(state.args, expected, self.assertEqual(state.args, expected,
'Expected %r, got %r' % (expected, state.args)) 'Expected %r, got %r' % (expected, state.args))
@ -95,7 +95,10 @@ class CommandsTestCase(SupyTestCase):
self.assertState(spec, ['1', '2', '3'], [[1, 2, 3]]) self.assertState(spec, ['1', '2', '3'], [[1, 2, 3]])
self.assertRaises(callbacks.Error, self.assertRaises(callbacks.Error,
self.assertState, spec, [], ['asdf']) self.assertState, spec, [], ['asdf'])
def testChannelRespectsNetwork(self):
spec = ['channel', 'text']
self.assertState(spec, ['#foo', '+s'], ['#foo', '+s'])
self.assertState(spec, ['+s'], ['#foo', '+s'], target='#foo')
# vim:set shiftwidth=4 tabstop=8 expandtab textwidth=78: # vim:set shiftwidth=4 tabstop=8 expandtab textwidth=78: