summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2013-10-02 08:43:30 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2013-10-02 08:43:30 (GMT)
commit092bd388ced26650cf0a5a4838a87f7ca8a9ea97 (patch)
tree8e01d43c091b4e0469c837434a465e03d91a22b8
parent75f65e368e04c6242c103d3139571b8aaad8b4be (diff)
parent51844384f4b225d214e122edd8af65c75e50a150 (diff)
downloadcpython-092bd388ced26650cf0a5a4838a87f7ca8a9ea97.zip
cpython-092bd388ced26650cf0a5a4838a87f7ca8a9ea97.tar.gz
cpython-092bd388ced26650cf0a5a4838a87f7ca8a9ea97.tar.bz2
Issue #19137: The pprint module now correctly formats instances of set and
frozenset subclasses.
-rw-r--r--Lib/pprint.py28
-rw-r--r--Lib/test/test_pprint.py79
-rw-r--r--Misc/NEWS3
3 files changed, 83 insertions, 27 deletions
diff --git a/Lib/pprint.py b/Lib/pprint.py
index 1f98f5c..f4bc59b 100644
--- a/Lib/pprint.py
+++ b/Lib/pprint.py
@@ -203,24 +203,22 @@ class PrettyPrinter:
if issubclass(typ, list):
write('[')
endchar = ']'
- elif issubclass(typ, set):
- if not length:
- write('set()')
- return
- write('{')
- endchar = '}'
- object = sorted(object, key=_safe_key)
- elif issubclass(typ, frozenset):
+ elif issubclass(typ, tuple):
+ write('(')
+ endchar = ')'
+ else:
if not length:
- write('frozenset()')
+ write(rep)
return
- write('frozenset({')
- endchar = '})'
+ if typ is set:
+ write('{')
+ endchar = '}'
+ else:
+ write(typ.__name__)
+ write('({')
+ endchar = '})'
+ indent += len(typ.__name__) + 1
object = sorted(object, key=_safe_key)
- indent += 10
- else:
- write('(')
- endchar = ')'
if self._indent_per_level > 1:
write((self._indent_per_level - 1) * ' ')
if length:
diff --git a/Lib/test/test_pprint.py b/Lib/test/test_pprint.py
index bf136de..5a2050f 100644
--- a/Lib/test/test_pprint.py
+++ b/Lib/test/test_pprint.py
@@ -23,6 +23,20 @@ class tuple3(tuple):
def __repr__(self):
return tuple.__repr__(self)
+class set2(set):
+ pass
+
+class set3(set):
+ def __repr__(self):
+ return set.__repr__(self)
+
+class frozenset2(frozenset):
+ pass
+
+class frozenset3(frozenset):
+ def __repr__(self):
+ return frozenset.__repr__(self)
+
class dict2(dict):
pass
@@ -117,22 +131,24 @@ class QueryTestCase(unittest.TestCase):
for simple in (0, 0, 0+0j, 0.0, "", b"",
(), tuple2(), tuple3(),
[], list2(), list3(),
+ set(), set2(), set3(),
+ frozenset(), frozenset2(), frozenset3(),
{}, dict2(), dict3(),
self.assertTrue, pprint,
-6, -6, -6-6j, -1.5, "x", b"x", (3,), [3], {3: 6},
(1,2), [3,4], {5: 6},
tuple2((1,2)), tuple3((1,2)), tuple3(range(100)),
[3,4], list2([3,4]), list3([3,4]), list3(range(100)),
+ set({7}), set2({7}), set3({7}),
+ frozenset({8}), frozenset2({8}), frozenset3({8}),
dict2({5: 6}), dict3({5: 6}),
range(10, -11, -1)
):
native = repr(simple)
- for function in "pformat", "saferepr":
- f = getattr(pprint, function)
- got = f(simple)
- self.assertEqual(native, got,
- "expected %s got %s from pprint.%s" %
- (native, got, function))
+ self.assertEqual(pprint.pformat(simple), native)
+ self.assertEqual(pprint.pformat(simple, width=1, indent=0)
+ .replace('\n', ' '), native)
+ self.assertEqual(pprint.saferepr(simple), native)
def test_basic_line_wrap(self):
# verify basic line-wrapping operation
@@ -221,10 +237,54 @@ class QueryTestCase(unittest.TestCase):
others.should.not.be: like.this}"""
self.assertEqual(DottedPrettyPrinter().pformat(o), exp)
+ def test_set_reprs(self):
+ self.assertEqual(pprint.pformat(set()), 'set()')
+ self.assertEqual(pprint.pformat(set(range(3))), '{0, 1, 2}')
+ self.assertEqual(pprint.pformat(set(range(7)), width=20), '''\
+{0,
+ 1,
+ 2,
+ 3,
+ 4,
+ 5,
+ 6}''')
+ self.assertEqual(pprint.pformat(set2(range(7)), width=20), '''\
+set2({0,
+ 1,
+ 2,
+ 3,
+ 4,
+ 5,
+ 6})''')
+ self.assertEqual(pprint.pformat(set3(range(7)), width=20),
+ 'set3({0, 1, 2, 3, 4, 5, 6})')
+
+ self.assertEqual(pprint.pformat(frozenset()), 'frozenset()')
+ self.assertEqual(pprint.pformat(frozenset(range(3))),
+ 'frozenset({0, 1, 2})')
+ self.assertEqual(pprint.pformat(frozenset(range(7)), width=20), '''\
+frozenset({0,
+ 1,
+ 2,
+ 3,
+ 4,
+ 5,
+ 6})''')
+ self.assertEqual(pprint.pformat(frozenset2(range(7)), width=20), '''\
+frozenset2({0,
+ 1,
+ 2,
+ 3,
+ 4,
+ 5,
+ 6})''')
+ self.assertEqual(pprint.pformat(frozenset3(range(7)), width=20),
+ 'frozenset3({0, 1, 2, 3, 4, 5, 6})')
+
@unittest.expectedFailure
#See http://bugs.python.org/issue13907
@test.support.cpython_only
- def test_set_reprs(self):
+ def test_set_of_sets_reprs(self):
# This test creates a complex arrangement of frozensets and
# compares the pretty-printed repr against a string hard-coded in
# the test. The hard-coded repr depends on the sort order of
@@ -247,11 +307,6 @@ class QueryTestCase(unittest.TestCase):
# algorithm cause the test to fail when it should pass.
# XXX Or changes to the dictionary implmentation...
- self.assertEqual(pprint.pformat(set()), 'set()')
- self.assertEqual(pprint.pformat(set(range(3))), '{0, 1, 2}')
- self.assertEqual(pprint.pformat(frozenset()), 'frozenset()')
-
- self.assertEqual(pprint.pformat(frozenset(range(3))), 'frozenset({0, 1, 2})')
cube_repr_tgt = """\
{frozenset(): frozenset({frozenset({2}), frozenset({0}), frozenset({1})}),
frozenset({0}): frozenset({frozenset(),
diff --git a/Misc/NEWS b/Misc/NEWS
index b2030a8..f3a6e1a 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -13,6 +13,9 @@ Core and Builtins
Library
-------
+- Issue #19137: The pprint module now correctly formats instances of set and
+ frozenset subclasses.
+
- Issue #10042: functools.total_ordering now correctly handles
NotImplemented being returned by the underlying comparison function (Patch
by Katie Miller)