Commit 00859c05 authored by Barry Warsaw's avatar Barry Warsaw

__format(): Applied SF patch #482003 by Skip to fix multiline dict

output.

Patch includes additional test case test_basic_line_wrap().

This patch is a candidate for Python 2.1.2.
parent 3072ecdc
...@@ -158,7 +158,7 @@ class PrettyPrinter: ...@@ -158,7 +158,7 @@ class PrettyPrinter:
if length > 1: if length > 1:
for key, ent in items[1:]: for key, ent in items[1:]:
rep = self.__repr(key, context, level) rep = self.__repr(key, context, level)
write(',\n%s: %s' % (' '*indent, rep)) 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) allowance + 1, context, level)
indent = indent - self.__indent_per_level indent = indent - self.__indent_per_level
......
...@@ -77,6 +77,25 @@ class QueryTestCase(unittest.TestCase): ...@@ -77,6 +77,25 @@ class QueryTestCase(unittest.TestCase):
(native, got, function)) (native, got, function))
def test_basic_line_wrap(self):
"""verify basic line-wrapping operation"""
o = {'RPM_cal': 0,
'RPM_cal2': 48059,
'Speed_cal': 0,
'controldesk_runtime_us': 0,
'main_code_runtime_us': 0,
'read_io_runtime_us': 0,
'write_io_runtime_us': 43690}
exp = """\
{'RPM_cal': 0,
'RPM_cal2': 48059,
'Speed_cal': 0,
'controldesk_runtime_us': 0,
'main_code_runtime_us': 0,
'read_io_runtime_us': 0,
'write_io_runtime_us': 43690}"""
self.assertEqual(pprint.pformat(o), exp)
def test_main(): def test_main():
test_support.run_unittest(QueryTestCase) test_support.run_unittest(QueryTestCase)
......
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