Fixed a bug in the handling of the msg keyword argument in IrcMsg.

This commit is contained in:
Jeremy Fincher 2003-09-17 07:53:11 +00:00
parent e02589c204
commit 288f6179d6
2 changed files with 29 additions and 14 deletions

View File

@ -77,25 +77,14 @@ class IrcMsg(object):
__slots__ = ('args', 'command', 'host', 'nick', 'prefix', 'user', __slots__ = ('args', 'command', 'host', 'nick', 'prefix', 'user',
'_hash', '_str', '_repr', '_len') '_hash', '_str', '_repr', '_len')
def __init__(self, s='', command='', args=None, prefix='', msg=None): def __init__(self, s='', command='', args=None, prefix='', msg=None):
assert not (msg and s), 'Ircmsg.__init__ cannot accept both s and msg'
if not s and not command and not msg: if not s and not command and not msg:
raise ValueError, 'IRC messages require a command.' raise ValueError, 'IRC messages require a command.'
self._str = None self._str = None
self._repr = None self._repr = None
self._hash = None self._hash = None
self._len = None self._len = None
if msg is not None: if s:
self.prefix = msg.prefix
self.command = msg.command
self.args = tuple(msg.args)
if command: # Must be using command=, args=, prefix= form.
self.prefix = prefix
self.command = command
if args is not None:
assert all(ircutils.isValidArgument, args)
self.args = tuple(args)
else:
self.args = ()
elif s: # Must be using a string.
self._str = s self._str = s
if s[0] == ':': if s[0] == ':':
self.prefix, s = s[1:].split(None, 1) self.prefix, s = s[1:].split(None, 1)
@ -108,11 +97,30 @@ class IrcMsg(object):
else: else:
self.args = s.split() self.args = s.split()
self.command = self.args.pop(0) self.command = self.args.pop(0)
else:
if msg is not None:
if prefix:
self.prefix = prefix
else:
self.prefix = msg.prefix
if command:
self.command = command
else:
self.command = msg.command
if args:
self.args = args
else:
self.args = msg.args
else:
self.prefix = prefix
self.command = command
assert all(ircutils.isValidArgument, args)
self.args = args
self.args = tuple(self.args)
if ircutils.isUserHostmask(self.prefix): if ircutils.isUserHostmask(self.prefix):
(self.nick,self.user,self.host)=ircutils.splitHostmask(self.prefix) (self.nick,self.user,self.host)=ircutils.splitHostmask(self.prefix)
else: else:
(self.nick, self.user, self.host) = (self.prefix,)*3 (self.nick, self.user, self.host) = (self.prefix,)*3
self.args = tuple(self.args)
def __str__(self): def __str__(self):
if self._str is not None: if self._str is not None:

View File

@ -104,6 +104,13 @@ class IrcMsgTestCase(unittest.TestCase):
zeroes += 1 zeroes += 1
self.failIf(zeroes > (len(msgs)/10), 'Too many zero hashes.') self.failIf(zeroes > (len(msgs)/10), 'Too many zero hashes.')
def testMsgKeywordHandledProperly(self):
msg = ircmsgs.notice('foo', 'bar')
msg2 = ircmsgs.IrcMsg(msg=msg, command='PRIVMSG')
self.assertEqual(msg2.command, 'PRIVMSG')
self.assertEqual(msg2.args, msg.args)
class FunctionsTestCase(unittest.TestCase): class FunctionsTestCase(unittest.TestCase):
def testIsAction(self): def testIsAction(self):
L = [':jemfinch!~jfincher@ts26-2.homenet.ohio-state.edu PRIVMSG' L = [':jemfinch!~jfincher@ts26-2.homenet.ohio-state.edu PRIVMSG'