diff options
author | Stefan Krah <skrah@bytereef.org> | 2014-08-26 18:47:32 (GMT) |
---|---|---|
committer | Stefan Krah <skrah@bytereef.org> | 2014-08-26 18:47:32 (GMT) |
commit | 9ea83cff473a8dea3fa4c34e0036c3de3e09b77e (patch) | |
tree | 20f2e96d0b19c4f633273ff6e5ee3204fa4985bc | |
parent | e863739e61996f5bf48a14b2fe69a95d23fe45e0 (diff) | |
parent | 298131a44896a4fec1ea829814ad52409d59aba5 (diff) | |
download | cpython-9ea83cff473a8dea3fa4c34e0036c3de3e09b77e.zip cpython-9ea83cff473a8dea3fa4c34e0036c3de3e09b77e.tar.gz cpython-9ea83cff473a8dea3fa4c34e0036c3de3e09b77e.tar.bz2 |
Merge 3.4.
-rw-r--r-- | Lib/decimal.py | 2 | ||||
-rw-r--r-- | Lib/test/test_decimal.py | 5 | ||||
-rw-r--r-- | Modules/_decimal/libmpdec/io.c | 11 |
3 files changed, 14 insertions, 4 deletions
diff --git a/Lib/decimal.py b/Lib/decimal.py index 6d0b34c..44d4406 100644 --- a/Lib/decimal.py +++ b/Lib/decimal.py @@ -3759,6 +3759,8 @@ class Decimal(object): if self._is_special: sign = _format_sign(self._sign, spec) body = str(self.copy_abs()) + if spec['type'] == '%': + body += '%' return _format_align(sign, body, spec) # a type of None defaults to 'g' or 'G', depending on context diff --git a/Lib/test/test_decimal.py b/Lib/test/test_decimal.py index f8bb7eb..be60887 100644 --- a/Lib/test/test_decimal.py +++ b/Lib/test/test_decimal.py @@ -1058,6 +1058,11 @@ class FormatTest(unittest.TestCase): # issue 6850 ('a=-7.0', '0.12345', 'aaaa0.1'), + + # issue 22090 + ('<^+15.20%', 'inf', '<<+Infinity%<<<'), + ('\x07>,%', 'sNaN1234567', 'sNaN1234567%'), + ('=10.10%', 'NaN123', ' NaN123%'), ] for fmt, d, result in test_values: self.assertEqual(format(Decimal(d), fmt), result) diff --git a/Modules/_decimal/libmpdec/io.c b/Modules/_decimal/libmpdec/io.c index b67324d..a45a429 100644 --- a/Modules/_decimal/libmpdec/io.c +++ b/Modules/_decimal/libmpdec/io.c @@ -446,7 +446,7 @@ _mpd_to_string(char **result, const mpd_t *dec, int flags, mpd_ssize_t dplace) if (mpd_isspecial(dec)) { - mem = sizeof "-Infinity"; + mem = sizeof "-Infinity%"; if (mpd_isnan(dec) && dec->len > 0) { /* diagnostic code */ mem += dec->digits; @@ -609,10 +609,10 @@ _mpd_to_string(char **result, const mpd_t *dec, int flags, mpd_ssize_t dplace) *cp++ = (flags&MPD_FMT_UPPER) ? 'E' : 'e'; cp = exp_to_string(cp, ldigits-dplace); } + } - if (flags&MPD_FMT_PERCENT) { - *cp++ = '%'; - } + if (flags&MPD_FMT_PERCENT) { + *cp++ = '%'; } assert(cp < decstring+mem); @@ -1260,6 +1260,9 @@ mpd_qformat_spec(const mpd_t *dec, const mpd_spec_t *spec, stackspec.align = '>'; spec = &stackspec; } + if (type == '%') { + flags |= MPD_FMT_PERCENT; + } } else { uint32_t workstatus = 0; |