diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2013-10-03 19:29:36 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2013-10-03 19:29:36 (GMT) |
commit | 7d36e2fc5c4bc6e80beced40b6299eac39cefb0e (patch) | |
tree | 649f208a8292e8150fb75beb1673fb2617c15671 | |
parent | bf14dccc4d685174ea96647389ffa69c64cb310f (diff) | |
download | cpython-7d36e2fc5c4bc6e80beced40b6299eac39cefb0e.zip cpython-7d36e2fc5c4bc6e80beced40b6299eac39cefb0e.tar.gz cpython-7d36e2fc5c4bc6e80beced40b6299eac39cefb0e.tar.bz2 |
Remove builtin "caching" in pprint
-rw-r--r-- | Lib/pprint.py | 50 |
1 files changed, 22 insertions, 28 deletions
diff --git a/Lib/pprint.py b/Lib/pprint.py index 6155fb2..3be9c36 100644 --- a/Lib/pprint.py +++ b/Lib/pprint.py @@ -42,12 +42,6 @@ from io import StringIO as _StringIO __all__ = ["pprint","pformat","isreadable","isrecursive","saferepr", "PrettyPrinter"] -# cache these for faster access: -_commajoin = ", ".join -_id = id -_len = len -_type = type - def pprint(object, stream=None, indent=1, width=80, depth=None, *, compact=False): @@ -96,8 +90,8 @@ class _safe_key: rv = NotImplemented if rv is NotImplemented: - rv = (str(_type(self.obj)), _id(self.obj)) < \ - (str(_type(other.obj)), _id(other.obj)) + rv = (str(type(self.obj)), id(self.obj)) < \ + (str(type(other.obj)), id(other.obj)) return rv def _safe_tuple(t): @@ -159,16 +153,16 @@ class PrettyPrinter: def _format(self, object, stream, indent, allowance, context, level): level = level + 1 - objid = _id(object) + objid = id(object) if objid in context: stream.write(_recursion(object)) self._recursive = True self._readable = False return rep = self._repr(object, context, level - 1) - typ = _type(object) + typ = type(object) max_width = self._width - 1 - indent - allowance - sepLines = _len(rep) > max_width + sepLines = len(rep) > max_width write = stream.write if sepLines: @@ -177,7 +171,7 @@ class PrettyPrinter: write('{') if self._indent_per_level > 1: write((self._indent_per_level - 1) * ' ') - length = _len(object) + length = len(object) if length: context[objid] = 1 indent = indent + self._indent_per_level @@ -189,13 +183,13 @@ class PrettyPrinter: rep = self._repr(key, context, level) write(rep) write(': ') - self._format(ent, stream, indent + _len(rep) + 2, + self._format(ent, stream, indent + len(rep) + 2, allowance + 1, context, level) if length > 1: for key, ent in items[1:]: rep = self._repr(key, context, level) write(',\n%s%s: ' % (' '*indent, rep)) - self._format(ent, stream, indent + _len(rep) + 2, + self._format(ent, stream, indent + len(rep) + 2, allowance + 1, context, level) indent = indent - self._indent_per_level del context[objid] @@ -207,7 +201,7 @@ class PrettyPrinter: (issubclass(typ, set) and r is set.__repr__) or (issubclass(typ, frozenset) and r is frozenset.__repr__) ): - length = _len(object) + length = len(object) if issubclass(typ, list): write('[') endchar = ']' @@ -225,7 +219,7 @@ class PrettyPrinter: write(typ.__name__) write('({') endchar = '})' - indent += _len(typ.__name__) + 1 + indent += len(typ.__name__) + 1 object = sorted(object, key=_safe_key) if self._indent_per_level > 1: write((self._indent_per_level - 1) * ' ') @@ -240,7 +234,7 @@ class PrettyPrinter: write(endchar) return - if issubclass(typ, str) and _len(object) > 0 and r is str.__repr__: + if issubclass(typ, str) and len(object) > 0 and r is str.__repr__: def _str_parts(s): """ Return a list of string literals comprising the repr() @@ -249,16 +243,16 @@ class PrettyPrinter: lines = s.splitlines(True) for i, line in enumerate(lines): rep = repr(line) - if _len(rep) <= max_width: + if len(rep) <= max_width: yield rep else: # A list of alternating (non-space, space) strings parts = re.split(r'(\s+)', line) + [''] current = '' - for i in range(0, _len(parts), 2): + for i in range(0, len(parts), 2): part = parts[i] + parts[i+1] candidate = current + part - if _len(repr(candidate)) > max_width: + if len(repr(candidate)) > max_width: if current: yield repr(current) current = part @@ -281,7 +275,7 @@ class PrettyPrinter: for ent in items: if self._compact: rep = self._repr(ent, context, level) - w = _len(rep) + 2 + w = len(rep) + 2 if width < w: width = max_width if delim: @@ -316,7 +310,7 @@ class PrettyPrinter: # Return triple (repr_string, isreadable, isrecursive). def _safe_repr(object, context, maxlevels, level): - typ = _type(object) + typ = type(object) if typ is str: if 'locale' not in _sys.modules: return repr(object), True, False @@ -340,7 +334,7 @@ def _safe_repr(object, context, maxlevels, level): if issubclass(typ, dict) and r is dict.__repr__: if not object: return "{}", True, False - objid = _id(object) + objid = id(object) if maxlevels and level >= maxlevels: return "{...}", False, objid in context if objid in context: @@ -361,7 +355,7 @@ def _safe_repr(object, context, maxlevels, level): if krecur or vrecur: recursive = True del context[objid] - return "{%s}" % _commajoin(components), readable, recursive + return "{%s}" % ", ".join(components), readable, recursive if (issubclass(typ, list) and r is list.__repr__) or \ (issubclass(typ, tuple) and r is tuple.__repr__): @@ -369,13 +363,13 @@ def _safe_repr(object, context, maxlevels, level): if not object: return "[]", True, False format = "[%s]" - elif _len(object) == 1: + elif len(object) == 1: format = "(%s,)" else: if not object: return "()", True, False format = "(%s)" - objid = _id(object) + objid = id(object) if maxlevels and level >= maxlevels: return format % "...", False, objid in context if objid in context: @@ -394,7 +388,7 @@ def _safe_repr(object, context, maxlevels, level): if orecur: recursive = True del context[objid] - return format % _commajoin(components), readable, recursive + return format % ", ".join(components), readable, recursive rep = repr(object) return rep, (rep and not rep.startswith('<')), False @@ -402,7 +396,7 @@ def _safe_repr(object, context, maxlevels, level): def _recursion(object): return ("<Recursion on %s with id=%s>" - % (_type(object).__name__, _id(object))) + % (type(object).__name__, id(object))) def _perfcheck(object=None): |