summaryrefslogtreecommitdiff
path: root/Objects/stringobject.c
diff options
context:
space:
mode:
authorMarc-André Lemburg <mal@egenix.com>2002-12-29 19:44:06 +0000
committerMarc-André Lemburg <mal@egenix.com>2002-12-29 19:44:06 +0000
commit6029bcc9d6e03a0c1e3e56293e0b4532e1dc75fe (patch)
treed9e365cc28ed409fe3cdd717546c2e731b631024 /Objects/stringobject.c
parent1053590589f2675071400c9d2d1df1bd33a3b95c (diff)
downloadcpython-6029bcc9d6e03a0c1e3e56293e0b4532e1dc75fe.tar.gz
Patch for bug #659709: bogus computation of float length
Python 2.2.x backport candidate. (This bug has been around since Python 1.6.)
Diffstat (limited to 'Objects/stringobject.c')
-rw-r--r--Objects/stringobject.c22
1 files changed, 16 insertions, 6 deletions
diff --git a/Objects/stringobject.c b/Objects/stringobject.c
index 1e42856729..748592ea50 100644
--- a/Objects/stringobject.c
+++ b/Objects/stringobject.c
@@ -3361,21 +3361,31 @@ formatfloat(char *buf, size_t buflen, int flags,
prec = 6;
if (type == 'f' && fabs(x)/1e25 >= 1e25)
type = 'g';
- PyOS_snprintf(fmt, sizeof(fmt), "%%%s.%d%c",
- (flags&F_ALT) ? "#" : "",
- prec, type);
- /* worst case length calc to ensure no buffer overrun:
+ /* Worst case length calc to ensure no buffer overrun:
+
+ 'g' formats:
fmt = %#.<prec>g
buf = '-' + [0-9]*prec + '.' + 'e+' + (longest exp
for any double rep.)
len = 1 + prec + 1 + 2 + 5 = 9 + prec
+
+ 'f' formats:
+ buf = '-' + [0-9]*x + '.' + [0-9]*prec (with x < 50)
+ len = 1 + 50 + 1 + prec = 52 + prec
+
If prec=0 the effective precision is 1 (the leading digit is
- always given), therefore increase by one to 10+prec. */
- if (buflen <= (size_t)10 + (size_t)prec) {
+ always given), therefore increase the length by one.
+
+ */
+ if ((type == 'g' && buflen <= (size_t)10 + (size_t)prec) ||
+ (type == 'f' && buflen <= (size_t)53 + (size_t)prec)) {
PyErr_SetString(PyExc_OverflowError,
"formatted float is too long (precision too large?)");
return -1;
}
+ PyOS_snprintf(fmt, sizeof(fmt), "%%%s.%d%c",
+ (flags&F_ALT) ? "#" : "",
+ prec, type);
PyOS_snprintf(buf, buflen, fmt, x);
return strlen(buf);
}