]> granicus.if.org Git - python/commitdiff
Issue #22090: Fix '%' formatting for infinities and NaNs.
authorStefan Krah <skrah@bytereef.org>
Tue, 26 Aug 2014 18:46:49 +0000 (20:46 +0200)
committerStefan Krah <skrah@bytereef.org>
Tue, 26 Aug 2014 18:46:49 +0000 (20:46 +0200)
Lib/decimal.py
Lib/test/test_decimal.py
Modules/_decimal/libmpdec/io.c

index 5b984731b2107fe17caba4650ee91027bb04e65f..e11f1a0082ccfd0a714e06c1a5da276bbae4c425 100644 (file)
@@ -3769,6 +3769,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
index 8358ba6e41b2ee6179902bd0c909ce19b154deea..b4c8c3411e1684d031b1cca28f5a197e1ae6f2eb 100644 (file)
@@ -1057,6 +1057,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)
index b67324da94196ccabdc32a538b01006a94ce547f..a45a429dbf1d39f38b90496551deb77acb97ce30 100644 (file)
@@ -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;