aboutsummaryrefslogtreecommitdiffstats
path: root/bin/dumpdb
diff options
context:
space:
mode:
authorTokio Kikuchi <tkikuchi@is.kochi-u.ac.jp>2007-09-17 14:51:10 +0900
committerTokio Kikuchi <tkikuchi@is.kochi-u.ac.jp>2007-09-17 14:51:10 +0900
commitba98caf52c18dea4ea244c092617677bdbb01015 (patch)
treedfef0b88cd422691382c9ad4351889c5cf9cc195 /bin/dumpdb
parent22ef9f160de887fe1e4eaa53b1b0613673e3c345 (diff)
parent06622797ea56104b960932c992d6719c5a6251ca (diff)
downloadmailman2-ba98caf52c18dea4ea244c092617677bdbb01015.tar.gz
mailman2-ba98caf52c18dea4ea244c092617677bdbb01015.tar.xz
mailman2-ba98caf52c18dea4ea244c092617677bdbb01015.zip
merge from launchpad
Diffstat (limited to 'bin/dumpdb')
-rw-r--r--bin/dumpdb63
1 files changed, 30 insertions, 33 deletions
diff --git a/bin/dumpdb b/bin/dumpdb
index 0bde09b8..c8e42462 100644
--- a/bin/dumpdb
+++ b/bin/dumpdb
@@ -1,6 +1,6 @@
#! @PYTHON@
#
-# Copyright (C) 1998-2005 by the Free Software Foundation, Inc.
+# Copyright (C) 1998-2007 by the Free Software Foundation, Inc.
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
@@ -45,16 +45,15 @@ Python pickle. In either case, if you want to override the default assumption
-- or if the file ends in neither suffix -- use the -p or -m flags.
"""
-import os
import sys
import getopt
import pprint
-from cPickle import load
+import cPickle
+import marshal
from types import StringType
import paths
# Import this /after/ paths so that the sys.path is properly hacked
-from email.Generator import Generator
from Mailman.i18n import _
PROGRAM = sys.argv[0]
@@ -121,37 +120,35 @@ def main():
# Handle dbs
pp = pprint.PrettyPrinter(indent=4)
if filetype == 1:
- # BAW: this probably doesn't work if there are mixed types of .db
- # files (i.e. some marshals, some bdbs).
- d = DumperSwitchboard().read(filename)
- if doprint:
- pp.pprint(d)
- return d
+ load = marshal.load
+ typename = 'marshal'
else:
- fp = open(filename)
- m = []
- try:
- cnt = 1
- if doprint:
- print _('[----- start pickle file -----]')
- while True:
- try:
- obj = load(fp)
- except EOFError:
- if doprint:
- print _('[----- end pickle file -----]')
- break
+ load = cPickle.load
+ typename = 'pickle'
+ fp = open(filename)
+ m = []
+ try:
+ cnt = 1
+ if doprint:
+ print _('[----- start %(typename)s file -----]')
+ while True:
+ try:
+ obj = load(fp)
+ except EOFError:
if doprint:
- print _('<----- start object %(cnt)s ----->')
- if isinstance(obj, StringType):
- print obj
- else:
- pp.pprint(obj)
- cnt += 1
- m.append(obj)
- finally:
- fp.close()
- return m
+ print _('[----- end %(typename)s file -----]')
+ break
+ if doprint:
+ print _('<----- start object %(cnt)s ----->')
+ if isinstance(obj, StringType):
+ print obj
+ else:
+ pp.pprint(obj)
+ cnt += 1
+ m.append(obj)
+ finally:
+ fp.close()
+ return m