3 ^&c @sddZddddddddd d g Zd d lZd d lmZmZmZdZdZdZ dde dDZ e d d Z e d d Z x,dejdejdD]Zeee e<qWde ed<xdD]Zeee e<qWddZddZddZddZd,dd Zd!d Zd"d Zd-d$dZe d d Zxd%D]Zeeee<qWd&efd'dZefd(dZeZeZd)d*Zd+dZ d S).aFQuoted-printable content transfer encoding per RFCs 2045-2047. This module handles the content transfer encoding method defined in RFC 2045 to encode US ASCII-like 8-bit data called `quoted-printable'. It is used to safely encode text that is in a character set similar to the 7-bit US ASCII character set, but that includes some 8-bit characters that are normally not allowed in email bodies or headers. Quoted-printable is very space-inefficient for encoding binary files; use the email.base64mime module for that instead. This module provides an interface to encode and decode both headers and bodies with quoted-printable encoding. RFC 2045 defines a method for including character set information in an `encoded-word' in a header. This method is commonly used for 8-bit real names in To:/From:/Cc: etc. fields, as well as Subject: lines. This module does not do the line wrapping or end-of-line character conversion necessary for proper internationalized headers; it only does dumb encoding and decoding. To deal with the various line wrapping issues, use the email.header module. body_decode body_encode body_lengthdecode decodestring header_decode header_encode header_lengthquoteunquoteN) ascii_lettersdigits hexdigits Z cCsg|] }d|qS)z=%02X).0crr(/usr/lib64/python3.6/email/quoprimime.py 7sris-!*+/Zascii_ s_ !"#$%&'()*+,-./0123456789:;<>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~ cCt|t|kS)z>Return True if the octet should be escaped with header quopri.)chr_QUOPRI_HEADER_MAPoctetrrr header_checkJrcCr)z^z header_length..ZsumZ bytearrayrrrrTs cCr )zReturn a body quoted-printable encoding length. :param bytearray: An array of bytes (a.k.a. octets). :return: The length in bytes of the byte array when it is encoded with quoted-printable for bodies. csr!r")r#rr$rrrr%hr&zbody_length..r'r(rrrrascCsft|tst|}|s&|j|jnn^|d|kr||dtkr||dtkr|t|||d7}|d7}n||7}|d7}||kr>||7}q>WqW|d dkr|j|r|dd }|S) z_Decode a quoted-printable string. Lines are separated with eol, which defaults to \n. rr r5r)r6r.rNr*r*)r8Zrstripr#r r Zendswith)r4r:Zdecodedr;ZiZnrrrrrs8   ,  cCs|jd}t|S)zCTurn a match in the form =AB to the ASCII character with value 0xabr )Zgroupr )Zmatchr,rrr_unquote_matchs r<cCs |jdd}tjdt|tjdS)aDecode a string encoded with RFC 2045 MIME header `Q' encoding. This function does not parse a full MIME header value encoded with quoted-printable (like =?iso-8859-1?q?Hello_World?=) -- please use the high level email.header class for that functionality. rrz=[a-fA-F0-9]{2})Zflags)ZreplacereZsubr<ZASCIIr/rrrr#s )r)r2)!Z__doc__Z__all__r=Zstringr r r r9ZNLZ EMPTYSTRINGZranger0rrZencoderrr1rrrrr-r rrr7rrrrr<rrrrrZsP         O 0