diff options
| author | R David Murray <rdmurray@bitdance.com> | 2013-03-20 22:12:14 -0400 |
|---|---|---|
| committer | R David Murray <rdmurray@bitdance.com> | 2013-03-20 22:12:14 -0400 |
| commit | 4f9e787189db3d142c18d45c2757f07c0ea8413e (patch) | |
| tree | a283eb5ef2027fbd090f079001dd03090782ce40 /Python/pystrtod.c | |
| parent | 7ddb402f873b3a7242d4f129060073971f4ef536 (diff) | |
| parent | 5a798963eadb3caa3261326f6bb6925d127ffb5b (diff) | |
| download | cpython-4f9e787189db3d142c18d45c2757f07c0ea8413e.tar.gz | |
Merge: #5712: Preemptively fix some other possible timing issues.
Diffstat (limited to 'Python/pystrtod.c')
| -rw-r--r-- | Python/pystrtod.c | 41 |
1 files changed, 40 insertions, 1 deletions
diff --git a/Python/pystrtod.c b/Python/pystrtod.c index 75e3032fb7..4ab8f08d22 100644 --- a/Python/pystrtod.c +++ b/Python/pystrtod.c @@ -22,6 +22,43 @@ case_insensitive_match(const char *s, const char *t) the successfully parsed portion of the string. On failure, return -1.0 and set *endptr to point to the start of the string. */ +#ifndef PY_NO_SHORT_FLOAT_REPR + +double +_Py_parse_inf_or_nan(const char *p, char **endptr) +{ + double retval; + const char *s; + int negate = 0; + + s = p; + if (*s == '-') { + negate = 1; + s++; + } + else if (*s == '+') { + s++; + } + if (case_insensitive_match(s, "inf")) { + s += 3; + if (case_insensitive_match(s, "inity")) + s += 5; + retval = _Py_dg_infinity(negate); + } + else if (case_insensitive_match(s, "nan")) { + s += 3; + retval = _Py_dg_stdnan(negate); + } + else { + s = p; + retval = -1.0; + } + *endptr = (char *)s; + return retval; +} + +#else + double _Py_parse_inf_or_nan(const char *p, char **endptr) { @@ -57,6 +94,8 @@ _Py_parse_inf_or_nan(const char *p, char **endptr) return retval; } +#endif + /** * _PyOS_ascii_strtod: * @nptr: the string to convert to a numeric value. @@ -954,7 +993,7 @@ format_float_short(double d, char format_code, /* shouldn't get here: Gay's code should always return something starting with a digit, an 'I', or 'N' */ strncpy(p, "ERR", 3); - p += 3; + /* p += 3; */ assert(0); } goto exit; |
