Commit 052969a6 authored by Guido van Rossum's avatar Guido van Rossum

Don't use calculations on values gotten from tell(). Also use a

slightly different way to test for the existence of unread.
parent 897b9f0b
......@@ -125,7 +125,14 @@ class Message:
self.status = ''
headerseen = ""
firstline = 1
startofline = unread = tell = None
if hasattr(self.fp, 'unread'):
unread = self.fp.unread
elif self.seekable:
tell = self.fp.tell
while 1:
if tell:
startofline = tell()
line = self.fp.readline()
if not line:
self.status = 'EOF in headers'
......@@ -160,10 +167,10 @@ class Message:
else:
self.status = 'Non-header line where header expected'
# Try to undo the read.
if hasattr(self.fp, 'unread'):
self.fp.unread(line)
elif self.seekable:
self.fp.seek(-len(line), 1)
if unread:
unread(line)
elif tell:
self.fp.seek(startofline)
else:
self.status = self.status + '; bad seek'
break
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment