U AT^L!@sdZddlZddlZddlZddlZddlmZmZddlm Z ddddd d d d gZ e e d j ddZddZGdddeZeZdeed<ddZdd ZddZddZdd ZeedZdd ZeedZeedZddd ZdS) z Routines for manipulating RFC2047 encoded words. This is currently a package-private API, but will be considered for promotion to a public API if there is demand. N) ascii_lettersdigits)errorsdecode_qencode_qdecode_bencode_blen_qlen_bdecodeencodes=([a-fA-F0-9]{2})cCst|dS)N)bytesfromhexgroupr )mr,/usr/lib64/python3.8/email/_encoded_words.pyArcCs|dd}t|gfS)N_ )replace_q_byte_subber)encodedrrrrCs c@s,eZdZdededZddZdS) _QByteMaps-!*+/asciicCs.||jkrt|||<nd|||<||S)Nz={:02X})safechrformat)selfkeyrrr __missing__Ms z_QByteMap.__missing__N)__name__ __module__ __qualname__rr rrr"rrrrrIsr_ cCsddd|DS)Ncss|]}t|VqdSN) _q_byte_map.0xrrr Zszencode_q..)joinbstringrrrrYscCstdd|DS)Ncss|]}tt|VqdSr))lenr*r+rrrr.]szlen_q..)sumr0rrrr \scCst|d}|r ddd|nd}z&tj||dd|rDtgngfWStjk rztj|ddtgfWYStjk rz,tj|dddttgfWYYStjk r|tgfYYYSXYnXYnXdS)Ns===rT)validateFs==) r2base64Z b64decoderZInvalidBase64PaddingDefectbinasciiErrorZInvalidBase64CharactersDefectZInvalidBase64LengthDefect)rZpad_errZmissing_paddingrrrrds(   cCst|dS)Nr)r6Z b64encoder r0rrrrscCs&tt|d\}}|d|r dndS)Nr4r)divmodr2)r1Z groups_of_3Zleftoverrrrr s)qbc Cs|d\}}}}}|d\}}}|}|dd}t||\}}z||}Wnvtk r|t d |||d}YnBt k r|dd}|dkr|t d |YnX||||fS)aDecode encoded word and return (string, charset, lang, defects) tuple. An RFC 2047/2243 encoded word has the form: =?charset*lang?cte?encoded_string?= where '*lang' may be omitted but the other parts may not be. This function expects exactly such a string (that is, it does not check the syntax and may raise errors if the string is not well formed), and returns the encoded_string decoded first from its Content Transfer Encoding and then from the resulting bytes into unicode using the specified charset. If the cte-decoded string does not successfully decode using the specified character set, a defect is added to the defects list and the unknown octets are replaced by the unicode 'unknown' character \uFDFF. The specified charset and language are returned. The default for language, which is rarely if ever encountered, is the empty string. ?*rsurrogateescapez:Encoded word contains bytes not decodable using {} charset unknown-8bitzz=?{}{}?{}?{}?=)r _cte_encode_length _cte_encodersr)rJrHencodingrIr1ZqlenZblenrrrrr s    )rKNr()__doc__rer6r7 functoolsrJrrZemailr__all__partialcompilesubrrdictrr*ordrr rrr rDr rNrMr rrrrsL)   &+