Added and started using MaxLengthQueue.

This commit is contained in:
Jeremy Fincher 2003-04-09 18:12:38 +00:00
parent 67412da988
commit 79a1d351ad
3 changed files with 27 additions and 12 deletions

View File

@ -105,7 +105,10 @@ class Relay(callbacks.Privmsg):
def inFilter(self, irc, msg):
if not isinstance(irc, irclib.Irc):
irc = irc.getRealIrc()
self.ircstates[irc] = irc.state.copy()
try:
self.ircstates[irc].enqueue(irc.state.copy())
except KeyError:
self.ircstates[irc] = MaxLengthQueue(2, (irc.state.copy(),))
return msg
def startrelay(self, irc, msg, args):
@ -306,7 +309,7 @@ class Relay(callbacks.Privmsg):
else:
s = '%s/%s has quit.' % (msg.nick, network)
for channel in self.channels:
if msg.nick in self.ircstates[irc].channels[channel].users:
if msg.nick in self.ircstates[irc][1].channels[channel].users:
for otherIrc in self.ircs.itervalues():
if otherIrc != irc:
otherIrc.queueMsg(ircmsgs.privmsg(channel, s))

View File

@ -43,13 +43,15 @@ def ignore(*args, **kwargs):
pass
def catch(f, *args, **kwargs):
"""Catches all exceptions raises by f."""
try:
return f(*args, **kwargs)
except:
return None
class bool(int):
def __new__(self, val=0):
"""Just a holdover until 2.3 comes out with its wonderful new bool type."""
def __new__(cls, val=0):
# This constructor always returns an existing instance
if val:
return True
@ -93,6 +95,7 @@ True = int.__new__(bool, 1)
class set(object):
"""Just a holdover until 2.3 comes out with its wonderful new set type."""
__slots__ = ('d',)
def __init__(self, seq=()):
self.d = {}
@ -139,6 +142,7 @@ class set(object):
class queue(dict):
"""An FIFO Queue, O(1) for all operations."""
__slots__ = ('first', 'last')
def __init__(self, seq=()):
self.first = 0
@ -214,6 +218,15 @@ class queue(dict):
for (k, v) in d.iteritems():
dict.__setitem__(self, k, v)
class MaxLengthQueue(queue):
__slots__ = ('length',)
def __init__(length, *args):
self.length = length
queue.__init__(self, *args)
def enqueue(self, elt):
if len(self) > self.length:
self.dequeue()
class IterableMap(object):
"""Define .iteritems() in a class and subclass this to get the other iters.
@ -250,6 +263,7 @@ class IterableMap(object):
return False
def mktemp(suffix=''):
"""Gives a decent random string, suitable for a filename."""
import sha
import md5
import time
@ -266,12 +280,12 @@ def mktemp(suffix=''):
return sha.sha(s + str(time.time())).hexdigest() + suffix
def zipiter(*args):
length = len(args[0])
for arg in args:
if len(arg) < length:
length = len(arg)
for i in xrange(length):
yield tuple([arg[i] for arg in args])
args = map(iter, args)
while 1:
L = []
for arg in args:
L.append(arg.next())
yield tuple(L)
def reviter(L):
for i in xrange(len(L) - 1, -1, -1):

View File

@ -159,7 +159,7 @@ class IrcState(object):
self.reset()
def reset(self):
self.history = queue()
self.history = MaxLengthQueue(conf.maxHistory)
self.nicksToHostmasks = {}
self.channels = {}
@ -181,8 +181,6 @@ class IrcState(object):
def addMsg(self, irc, msg):
self.history.enqueue(msg)
if len(self.history) > conf.maxHistory:
self.history.dequeue()
if ircutils.isUserHostmask(msg.prefix) and not msg.command == 'NICK':
self.nicksToHostmasks[msg.nick] = msg.prefix
if msg.command == '352': # Response to a WHO command.