Merged revisions 70430 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/trunk

........
  r70430 | mark.dickinson | 2009-03-17 18:01:03 +0000 (Tue, 17 Mar 2009) | 3 lines

  Fix bug in Decimal __format__ method that swapped left and right
  alignment.
........
This commit is contained in:
Mark Dickinson 2009-03-17 18:10:15 +00:00
parent 44c5481941
commit ad41634313
3 changed files with 11 additions and 2 deletions

View File

@ -5630,9 +5630,9 @@ def _format_align(body, spec_dict):
align = spec_dict['align'] align = spec_dict['align']
if align == '<': if align == '<':
result = padding + sign + body
elif align == '>':
result = sign + body + padding result = sign + body + padding
elif align == '>':
result = padding + sign + body
elif align == '=': elif align == '=':
result = sign + padding + body result = sign + padding + body
else: #align == '^' else: #align == '^'

View File

@ -693,6 +693,12 @@ class DecimalFormatTest(unittest.TestCase):
('.0g', '-sNaN', '-sNaN'), ('.0g', '-sNaN', '-sNaN'),
('', '1.00', '1.00'), ('', '1.00', '1.00'),
# check alignment
('<6', '123', '123 '),
('>6', '123', ' 123'),
('^6', '123', ' 123 '),
('=+6', '123', '+ 123'),
] ]
for fmt, d, result in test_values: for fmt, d, result in test_values:
self.assertEqual(format(Decimal(d), fmt), result) self.assertEqual(format(Decimal(d), fmt), result)

View File

@ -206,6 +206,9 @@ Core and Builtins
Library Library
------- -------
- Fix Decimal.__format__ bug that swapped the meanings of the '<' and
'>' alignment characters.
- Issue #1222: locale.format() bug when the thousands separator is a space - Issue #1222: locale.format() bug when the thousands separator is a space
character. character.