mirror of
				https://github.com/python/cpython.git
				synced 2025-10-24 23:46:23 +00:00 
			
		
		
		
	 8b2af27dae
			
		
	
	
		8b2af27dae
		
	
	
	
	
		
			
			MIMEApplication() requires a bytes object for its _data, so fix the tests. We no longer need utils._identity() or utils._bdecode(). The former isn't used anywhere AFAICT (where's "make test's" lint? <wink>) and the latter is a kludge that is eliminated by base64.b64encode(). Current status: 5F/5E
		
			
				
	
	
		
			75 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Copyright (C) 2001-2006 Python Software Foundation
 | ||
| # Author: Barry Warsaw
 | ||
| # Contact: email-sig@python.org
 | ||
| 
 | ||
| """Encodings and related functions."""
 | ||
| 
 | ||
| __all__ = [
 | ||
|     'encode_7or8bit',
 | ||
|     'encode_base64',
 | ||
|     'encode_noop',
 | ||
|     'encode_quopri',
 | ||
|     ]
 | ||
| 
 | ||
| 
 | ||
| from base64 import b64encode as _bencode
 | ||
| from quopri import encodestring as _encodestring
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| def _qencode(s):
 | ||
|     enc = _encodestring(s, quotetabs=True)
 | ||
|     # Must encode spaces, which quopri.encodestring() doesn't do
 | ||
|     return enc.replace(' ', '=20')
 | ||
| 
 | ||
| 
 | ||
| def encode_base64(msg):
 | ||
|     """Encode the message's payload in Base64.
 | ||
| 
 | ||
|     Also, add an appropriate Content-Transfer-Encoding header.
 | ||
|     """
 | ||
|     orig = msg.get_payload()
 | ||
|     encdata = _bencode(orig)
 | ||
|     msg.set_payload(encdata)
 | ||
|     msg['Content-Transfer-Encoding'] = 'base64'
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| def encode_quopri(msg):
 | ||
|     """Encode the message's payload in quoted-printable.
 | ||
| 
 | ||
|     Also, add an appropriate Content-Transfer-Encoding header.
 | ||
|     """
 | ||
|     orig = msg.get_payload()
 | ||
|     encdata = _qencode(orig)
 | ||
|     msg.set_payload(encdata)
 | ||
|     msg['Content-Transfer-Encoding'] = 'quoted-printable'
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| def encode_7or8bit(msg):
 | ||
|     """Set the Content-Transfer-Encoding header to 7bit or 8bit."""
 | ||
|     orig = msg.get_payload()
 | ||
|     if orig is None:
 | ||
|         # There's no payload.  For backwards compatibility we use 7bit
 | ||
|         msg['Content-Transfer-Encoding'] = '7bit'
 | ||
|         return
 | ||
|     # We play a trick to make this go fast.  If encoding to ASCII succeeds, we
 | ||
|     # know the data must be 7bit, otherwise treat it as 8bit.
 | ||
|     try:
 | ||
|         orig.encode('ascii')
 | ||
|     except UnicodeError:
 | ||
|         # iso-2022-* is non-ASCII but still 7-bit
 | ||
|         charset = msg.get_charset()
 | ||
|         output_cset = charset and charset.output_charset
 | ||
|         if output_cset and output_cset.lower().startswith('iso-2202-'):
 | ||
|             msg['Content-Transfer-Encoding'] = '7bit'
 | ||
|         else:
 | ||
|             msg['Content-Transfer-Encoding'] = '8bit'
 | ||
|     else:
 | ||
|         msg['Content-Transfer-Encoding'] = '7bit'
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| def encode_noop(msg):
 | ||
|     """Do nothing."""
 |