bug [ 1296004 ] MemoryError in httplib

This commit is contained in:
Georg Brandl 2005-09-29 20:16:07 +00:00
parent e677adc43a
commit 80ba8e8549
2 changed files with 10 additions and 4 deletions

View File

@ -153,6 +153,9 @@ HTTP_VERSION_NOT_SUPPORTED = 505
INSUFFICIENT_STORAGE = 507
NOT_EXTENDED = 510
# maximal amount of data to read at one time in _safe_read
MAXAMOUNT = 1048576
class HTTPMessage(mimetools.Message):
def addheader(self, key, value):
@ -541,14 +544,14 @@ class HTTPResponse:
reading. If the bytes are truly not available (due to EOF), then the
IncompleteRead exception can be used to detect the problem.
"""
s = ''
s = []
while amt > 0:
chunk = self.fp.read(amt)
chunk = self.fp.read(min(amt, MAXAMOUNT))
if not chunk:
raise IncompleteRead(s)
s += chunk
s.append(chunk)
amt -= len(chunk)
return s
return ''.join(s)
def getheader(self, name, default=None):
if self.msg is None:

View File

@ -242,6 +242,9 @@ Extension Modules
Library
-------
- Bug #1296004: httplib.py: Limit maximal amount of data read from the
socket to avoid a MemoryError on Windows.
- Patch #1166948: locale.py: Prefer LC_ALL, LC_CTYPE and LANG over LANGUAGE
to get the correct encoding.