Commit 5a8828ce authored by Fred Drake's avatar Fred Drake

_safe_repr(): Make the context parameter required; ok since it's only for

	internal use.  Make sure the maxlevels and level parameters get
	passed to recursive invocations.
parent 661a14d0
...@@ -153,16 +153,13 @@ class PrettyPrinter: ...@@ -153,16 +153,13 @@ class PrettyPrinter:
return _safe_repr(object, context, self.__depth, level) return _safe_repr(object, context, self.__depth, level)
def _safe_repr(object, context=None, maxlevels=None, level=0): def _safe_repr(object, context, maxlevels=None, level=0):
level = level + 1 level = level + 1
typ = type(object) typ = type(object)
if not (typ in (DictType, ListType, TupleType) and object): if not (typ in (DictType, ListType, TupleType) and object):
return `object` return `object`
if context is None: if context.has_key(id(object)):
context = {} return `_Recursion(object)`
else:
if context.has_key(id(object)):
return `_Recursion(object)`
objid = id(object) objid = id(object)
context[objid] = 1 context[objid] = 1
if typ is DictType: if typ is DictType:
...@@ -171,19 +168,21 @@ def _safe_repr(object, context=None, maxlevels=None, level=0): ...@@ -171,19 +168,21 @@ def _safe_repr(object, context=None, maxlevels=None, level=0):
else: else:
items = object.items() items = object.items()
k, v = items[0] k, v = items[0]
s = "{%s: %s" % (_safe_repr(k, context), _safe_repr(v, context)) s = "{%s: %s" % (_safe_repr(k, context, maxlevels, level),
_safe_repr(v, context, maxlevels, level))
for k, v in items[1:]: for k, v in items[1:]:
s = "%s, %s: %s" \ s = "%s, %s: %s" \
% (s, _safe_repr(k, context), _safe_repr(v, context)) % (s, _safe_repr(k, context, maxlevels, level),
_safe_repr(v, context, maxlevels, level))
s = s + "}" s = s + "}"
else: else:
s, term = (typ is ListType) and ('[', ']') or ('(', ')') s, term = (typ is ListType) and ('[', ']') or ('(', ')')
if maxlevels and level >= maxlevels: if maxlevels and level >= maxlevels:
s = s + "..." s = s + "..."
else: else:
s = s + _safe_repr(object[0], context) s = s + _safe_repr(object[0], context, maxlevels, level)
for ent in object[1:]: for ent in object[1:]:
s = "%s, %s" % (s, _safe_repr(ent, context)) s = "%s, %s" % (s, _safe_repr(ent, context, maxlevels, level))
s = s + term s = s + term
del context[objid] del context[objid]
return s return s
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment