New submission from Bob Glickstein :
Passing both a value for i and decode=True to
email.message.Message.get_payload(), when self is a multipart, returns None
when it should return a string. The reason is that an is_multipart() test is
done on self when it should instead be done on the selected payload part.
Here's a patch that fixes this:
--- /usr/lib64/python2.7/email/message.py 2011-10-26 18:40:36.0
-0700
+++ /home/bobg/tmp/message.py 2012-05-07 06:34:28.579401481 -0700
@@ -192,9 +192,9 @@
else:
payload = self._payload[i]
if decode:
-if self.is_multipart():
+if payload.is_multipart():
return None
-cte = self.get('content-transfer-encoding', '').lower()
+cte = payload.get('content-transfer-encoding', '').lower()
if cte == 'quoted-printable':
return utils._qdecode(payload)
elif cte == 'base64':
--
components: Library (Lib)
messages: 160144
nosy: Bob.Glickstein
priority: normal
severity: normal
status: open
title: get_payload(n, True) returns None
type: behavior
versions: Python 2.7
___
Python tracker
<http://bugs.python.org/issue14740>
___
___
Python-bugs-list mailing list
Unsubscribe:
http://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com