diff options
author | Barry Warsaw <barry@python.org> | 2007-08-30 14:28:55 (GMT) |
---|---|---|
committer | Barry Warsaw <barry@python.org> | 2007-08-30 14:28:55 (GMT) |
commit | 2cc1f6d95b11f017f04921ea33a5cfc369e32e97 (patch) | |
tree | 0af4321c600f82fed75258c753ac71e1ed6588f0 /Lib/email/base64mime.py | |
parent | 5a23cc5a01458c74f8c849f41c2aea0151716668 (diff) | |
download | cpython-2cc1f6d95b11f017f04921ea33a5cfc369e32e97.zip cpython-2cc1f6d95b11f017f04921ea33a5cfc369e32e97.tar.gz cpython-2cc1f6d95b11f017f04921ea33a5cfc369e32e97.tar.bz2 |
More email package related repairs. This fixes smtplib's import and use of
email.base64mime, but test_smtplib still has failures for me. They are
timeout errors so think they're more related to my current wacky network setup
than bugs remaining in the code related to the email package.
This also r57693 that got clobbered with the sandbox sync, and fixes a couple
of other minor problems that cropped up. I will kill the sandbox branch next.
The email package now has 11F/11E.
Diffstat (limited to 'Lib/email/base64mime.py')
-rw-r--r-- | Lib/email/base64mime.py | 20 |
1 files changed, 7 insertions, 13 deletions
diff --git a/Lib/email/base64mime.py b/Lib/email/base64mime.py index 0035b79..369bf10 100644 --- a/Lib/email/base64mime.py +++ b/Lib/email/base64mime.py @@ -101,25 +101,19 @@ def body_encode(s, maxlinelen=76, eol=NL): -def decode(s, convert_eols=False): +def decode(string): """Decode a raw base64 string, returning a bytes object. - If convert_eols is set to a string value, all canonical email linefeeds, - e.g. "\\r\\n", in the decoded text will be converted to the value of - convert_eols. os.linesep is a good choice for convert_eols if you are - decoding a text attachment. - This function does not parse a full MIME header value encoded with base64 (like =?iso-8895-1?b?bmloISBuaWgh?=) -- please use the high level email.Header class for that functionality. """ - if not s: - return s - - dec = a2b_base64(s) - if convert_eols: - return dec.replace(CRLF, convert_eols) - return dec + if not string: + return bytes() + elif isinstance(string, str): + return a2b_base64(string.encode('raw-unicode-escape')) + else: + return a2b_base64(s) # For convenience and backwards compatibility w/ standard base64 module |