[Zope-Checkins] CVS: Zope/utilities/ZODBTools - zodbload.py:1.2.2.4
Jim Fulton
jim at zope.com
Fri Oct 3 13:02:31 EDT 2003
Update of /cvs-repository/Zope/utilities/ZODBTools
In directory cvs.zope.org:/tmp/cvs-serv6665
Modified Files:
Tag: Zope-2_7-branch
zodbload.py
Log Message:
Added more ways to specify messages to be read from the mailbox file.
See the doc string.
=== Zope/utilities/ZODBTools/zodbload.py 1.2.2.3 => 1.2.2.4 ===
--- Zope/utilities/ZODBTools/zodbload.py:1.2.2.3 Thu Oct 2 15:37:05 2003
+++ Zope/utilities/ZODBTools/zodbload.py Fri Oct 3 13:02:31 2003
@@ -88,6 +88,30 @@
Specify the mailbox for getting input data.
+ There is a (lame) syntax for providing options within the
+ filename. The filename may be followed by up to 3 integers,
+ min, max, and start:
+
+ -mbox 'foo.mbox 0 100 10000'
+
+ The messages from min to max will be read from the mailbox.
+ They will be assigned message numbers starting with start.
+ So, in the example above, we read the first hundred messages
+ and assign thgem message numbers starting with 10001.
+
+ The maxmum can be given as a negative number, in which case, it
+ specifies the number of messages to read.
+
+ The start defaults to the minimum. The following two options:
+
+ -mbox 'foo.mbox 300 400 300'
+
+ and
+
+ -mbox 'foo.mbox 300 -100'
+
+ are equivalent
+
$Id$
"""
@@ -124,28 +148,40 @@
def __init__(self, filename):
if ' ' in filename:
- filename, min, max = filename.split()
+ filename = filename.split()
+ if len(filename) < 4:
+ filename += [0, 0, -1][-(4-len(filename)):]
+ filename, min, max, start = filename
min = int(min)
max = int(max)
+ start = int(start)
+
+ if start < 0:
+ start = min
+
+ if max < 0:
+ # negative max is treated as a count
+ self._max = start - max
+ elif max > 0:
+ self._max = start + max - min
+ else:
+ self._max = 0
+
else:
- min = max = 0
+ self._max = 0
+ min = start = 0
- if filename.endswith('.bz2'):
- f = os.popen("bunzip2 <"+filename, 'r')
- filename = filename[-4:]
- else:
- f = open(filename)
+ f = open(filename)
self._mbox = mb = mailbox.UnixMailbox(f)
- self.number = min
+ self.number = start
while min:
mb.next()
min -= 1
self._lock = threading.Lock()
self.__name__ = os.path.splitext(os.path.split(filename)[1])[0]
- self._max = max
def next(self):
self._lock.acquire()
More information about the Zope-Checkins
mailing list