diff options
author | Raymond Hettinger <python@rcn.com> | 2008-06-16 01:42:40 +0000 |
---|---|---|
committer | Raymond Hettinger <python@rcn.com> | 2008-06-16 01:42:40 +0000 |
commit | 305480c9dcec736cba91db62062f75b5ceff9b60 (patch) | |
tree | 559504eba3446a11a6ad5d943a9d97f6f015783d | |
parent | a161f6070b455ac43aa4e414d7b64e6a80a37978 (diff) | |
download | cpython-git-305480c9dcec736cba91db62062f75b5ceff9b60.tar.gz |
Issue 3116: fix quadratic behavior in marshal.dumps().
-rw-r--r-- | Misc/NEWS | 2 | ||||
-rw-r--r-- | Python/marshal.c | 2 |
2 files changed, 3 insertions, 1 deletions
@@ -50,6 +50,8 @@ Core and Builtins Extension Modules ----------------- +- Issue #3116: marshal.dumps() had quadratic behavior for strings > 32Mb. + - Issue #2138: Add factorial() the math module. - The heapq module does comparisons using LT instead of LE. This diff --git a/Python/marshal.c b/Python/marshal.c index 6db46e4f63..140192f33b 100644 --- a/Python/marshal.c +++ b/Python/marshal.c @@ -67,7 +67,7 @@ w_more(int c, WFILE *p) size = PyString_Size(p->str); newsize = size + size + 1024; if (newsize > 32*1024*1024) { - newsize = size + 1024*1024; + newsize = size + (size >> 3); /* 12.5% overallocation */ } if (_PyString_Resize(&p->str, newsize) != 0) { p->ptr = p->end = NULL; |