Psyduck - 可達鴨 之 鴨力山大2


Server : LiteSpeed
System : Linux premium217.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User : alloknri ( 880)
PHP Version : 8.1.34
Disable Function : NONE
Directory :  /lib64/python3.8/email/__pycache__/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //lib64/python3.8/email/__pycache__/generator.cpython-38.pyc
U

e5d�N�@s�dZdddgZddlZddlZddlZddlZddlmZddlm	Z	m
Z
ddlmZd	Z
d
Ze�d�Ze�dej�ZGd
d�d�ZGdd�de�ZdZGdd�de�Zeeejd��ZdeZejZdS)z:Classes to generate plain text from a message object tree.�	Generator�DecodedGenerator�BytesGenerator�N)�deepcopy)�StringIO�BytesIO)�_has_surrogates�_�
z
\r\n|\r|\nz^From c@s�eZdZdZd'dd�dd�Zdd�Zd(d	d
�Zdd�Zd
d�Zdd�Z	dd�Z
dd�Zdd�Zdd�Z
dd�ZeZdd�Zdd�Zdd �Zd!d"�Zed)d#d$��Zed%d&��ZdS)*rz�Generates output from a Message object tree.

    This basic generator writes the message to the given file object as plain
    text.
    N��policycCs6|dkr|dkrdn|j}||_||_||_||_dS)a�Create the generator for message flattening.

        outfp is the output file-like object for writing the message to.  It
        must have a write() method.

        Optional mangle_from_ is a flag that, when True (the default if policy
        is not set), escapes From_ lines in the body of the message by putting
        a `>' in front of them.

        Optional maxheaderlen specifies the longest length for a non-continued
        header.  When a header line is longer (in characters, with tabs
        expanded to 8 spaces) than maxheaderlen, the header will split as
        defined in the Header class.  Set maxheaderlen to zero to disable
        header wrapping.  The default is 78, as recommended (but not required)
        by RFC 2822.

        The policy keyword specifies a policy object that controls a number of
        aspects of the generator's operation.  If no policy is specified,
        the policy associated with the Message object passed to the
        flatten method is used.

        NT)�mangle_from_�_fp�
_mangle_from_�maxheaderlenr)�self�outfpr
rr�r�'/usr/lib64/python3.8/email/generator.py�__init__$szGenerator.__init__cCs|j�|�dS�N)r�write�r�srrrrDszGenerator.writeFcCs�|jdkr|jn|j}|dk	r*|j|d�}|jdk	rB|j|jd�}|j|_|�|j�|_d|_|�|j�|_|j}|j}zL||_||_|r�|�	�}|s�dt
�t
�
��}|�||j�|�
|�W5||_||_XdS)a�Print the message object tree rooted at msg to the output file
        specified when the Generator instance was created.

        unixfrom is a flag that forces the printing of a Unix From_ delimiter
        before the first object in the message tree.  If the original message
        has no From_ delimiter, a `standard' one is crafted.  By default, this
        is False to inhibit the printing of any From_ delimiter.

        Note that for subobjects, no From_ line is printed.

        linesep specifies the characters used to indicate a new line in
        the output.  The default value is determined by the policy specified
        when the Generator instance was created or, if none was specified,
        from the policy associated with the msg.

        N)�linesep�Zmax_line_length�zFrom nobody )r�clonerr�_NL�_encode�_encoded_NLZ_EMPTY�_encoded_EMPTYZget_unixfrom�time�ctimer�_write)r�msg�unixfromrrZold_gen_policyZold_msg_policyZufromrrr�flattenHs,
zGenerator.flattencCs|j||jd|jd�S)z1Clone this generator with the exact same options.Nr)�	__class__rr)r�fprrrrys
�zGenerator.clonecCst�Sr)r�rrrr�_new_buffer�szGenerator._new_buffercCs|Srrrrrrr�szGenerator._encodecCsT|sdSt�|�}|dd�D]}|�|�|�|j�q|drP|�|d�dS)N���)�NLCRE�splitrr)r�lines�linerrr�_write_lines�s

zGenerator._write_linescCs�|j}z"d|_|��|_}|�|�W5||_|j}|`X|r�t|�}|�d�dkrd|d|d<n|�d|d�|�d|d�t|dd�}|dkr�|�|�n||�|j�	|�
��dS)N�content-transfer-encodingr�Content-Transfer-Encoding�content-type��_write_headers)r�
_munge_cter+�	_dispatchr�getZreplace_header�getattrr6r�getvalue)rr%ZoldfpZ	munge_cteZsfp�methrrrr$�s&zGenerator._writecCst|��}|��}t�||f��dd�}t|d|d�}|dkrh|�dd�}t|d|d�}|dkrh|j}||�dS)N�-r	Z_handle_)�get_content_maintype�get_content_subtype�
UNDERSCORE�join�replacer:�
_writeBody)rr%�main�subZspecificr<Zgenericrrrr8�szGenerator._dispatchcCs6|��D]\}}|�|j�||��q|�|j�dSr)�	raw_itemsrrZfoldr�rr%�h�vrrrr6�szGenerator._write_headerscCs�|��}|dkrdSt|t�s.tdt|���t|j�r~|�d�}|dk	r~t|�}|d=|�	||�|��}|d|df|_
|jr�t�
d|�}|�|�dS)Nzstring payload expected: %s�charsetr2r4�>From )�get_payload�
isinstance�str�	TypeError�typer�_payloadZ	get_paramrZset_payloadr7r�fcrerEr1)rr%�payloadrJrrr�_handle_text�s$


�zGenerator._handle_textcCs�g}|��}|dkrg}n(t|t�r2|�|�dSt|t�sB|g}|D]6}|��}|�|�}|j|d|jd�|�	|�
��qF|��}|s�|j�
|�}|�|�}|�|�|jdk	r�|jr�t�d|j�}	n|j}	|�|	�|�|j�|�d||j�|�r|j�|�d��|D],}
|�|jd||j�|j�|
��q|�|jd|d|j�|jdk	�r�|j�r�t�d|j�}n|j}|�|�dS)NF�r&rrKz--r)rLrMrNr�listr+rr'r�appendr;Zget_boundaryr rA�_make_boundaryZset_boundary�preamblerrRrEr1r�pop�epilogue)rr%ZmsgtextsZsubparts�partr�g�boundaryZalltextrYZ	body_partr[rrr�_handle_multipartsJ







zGenerator._handle_multipartcCs0|j}|jdd�|_z|�|�W5||_XdS)Nrr)rrr_)rr%�prrr�_handle_multipart_signed<s
z"Generator._handle_multipart_signedcCs�g}|��D]t}|��}|�|�}|j|d|jd�|��}|�|j�}|rv|d|jkrv|�	|j�
|dd���q|�	|�q|j�|j�
|��dS)NFrUr,)
rLr+rr'rr;r.r r!rWrArr)rr%Zblocksr\rr]�textr/rrr�_handle_message_delivery_statusGs
z)Generator._handle_message_delivery_statuscCs^|��}|�|�}|j}t|t�rD|j|�d�d|jd�|��}n
|�	|�}|j
�|�dS)NrFrU)r+rrQrMrVr'rLrr;rrr)rr%rr]rSrrr�_handle_message\s




zGenerator._handle_messagecCsvt�tj�}dt|d}|dkr(|S|}d}|�dt�|�dtj�}|�	|�sXqr|dt
|�}|d7}q0|S)Nz===============z==rz^--z(--)?$�.r5)�randomZ	randrange�sys�maxsize�_fmt�_compile_re�re�escape�	MULTILINE�searchrN)�clsrb�tokenr^�bZcounterZcrerrrrXus

zGenerator._make_boundarycCst�||�Sr)rk�compile�ror�flagsrrrrj�szGenerator._compile_re)NN)FN)N)�__name__�
__module__�__qualname__�__doc__rrr'rr+rr1r$r8r6rTrCr_rarcrd�classmethodrXrjrrrrrs.	� 
1'
:csPeZdZdZdd�Zdd�Zdd�Zdd	�Z�fd
d�ZeZ	e
dd
��Z�ZS)ra�Generates a bytes version of a Message object tree.

    Functionally identical to the base Generator except that the output is
    bytes and not string.  When surrogates were used in the input to encode
    bytes, these are decoded back to bytes for output.  If the policy has
    cte_type set to 7bit, then the message is transformed such that the
    non-ASCII bytes are properly content transfer encoded, using the charset
    unknown-8bit.

    The outfp object must accept bytes in its write method.
    cCs|j�|�dd��dS)N�ascii�surrogateescape)rr�encoderrrrr�szBytesGenerator.writecCst�Sr)rr*rrrr+�szBytesGenerator._new_buffercCs
|�d�S�Nrz)r|rrrrr�szBytesGenerator._encodecCs8|��D]\}}|j�|j�||��q|�|j�dSr)rFrrrZfold_binaryrrGrrrr6�szBytesGenerator._write_headerscs\|jdkrdSt|j�rH|jjdksH|jr:t�d|j�|_|�|j�ntt	|��
|�dS)NZ7bitrK)rQrrZcte_typerrRrEr1�superrrT)rr%�r(rrrT�s
zBytesGenerator._handle_textcCst�|�d�|�Sr})rkrrr|rsrrrrj�szBytesGenerator._compile_re)
rurvrwrxrr+rr6rTrCryrj�
__classcell__rrrrr�s
zD[Non-text (%(type)s) part of message omitted, filename %(filename)s]c@s(eZdZdZddd�dd�Zdd�ZdS)	rz�Generates a text representation of a message.

    Like the Generator base class, except that non-text parts are substituted
    with a format string representing the part.
    NrcCs.tj|||||d�|dkr$t|_n||_dS)a�Like Generator.__init__() except that an additional optional
        argument is allowed.

        Walks through all subparts of a message.  If the subpart is of main
        type `text', then it prints the decoded payload of the subpart.

        Otherwise, fmt is a format string that is used instead of the message
        payload.  fmt is expanded with the following keywords (in
        %(keyword)s format):

        type       : Full MIME type of the non-text part
        maintype   : Main MIME type of the non-text part
        subtype    : Sub-MIME type of the non-text part
        filename   : Filename of the non-text part
        description: Description associated with the non-text part
        encoding   : Content transfer encoding of the non-text part

        The default value for fmt is None, meaning

        [Non-text (%(type)s) part of message omitted, filename %(filename)s]
        rN)rr�_FMTri)rrr
rZfmtrrrrr�s�zDecodedGenerator.__init__cCs�|��D]v}|��}|dkr2t|jdd�|d�q|dkr<qt|j|��|��|��|�d�|�dd�|�d	d
�d�|d�qdS)NrbF)�decode)�fileZ	multipartz
[no filename]zContent-Descriptionz[no description]r3z
[no encoding])rP�maintypeZsubtype�filenameZdescription�encoding)	�walkr>�printrLriZget_content_typer?�get_filenamer9)rr%r\r�rrrr8�s(���	�zDecodedGenerator._dispatch)NNN)rurvrwrxrr8rrrrr�s
�r5z%%0%dd)rx�__all__rkrgr"rf�copyr�iorrZemail.utilsrr@�NLrrr-rmrRrrr�r�len�reprrhZ_widthrirXrrrr�<module>s*

t3;
Name
Size
Permissions
Options
__init__.cpython-38.opt-1.pyc
1.653 KB
-rw-r--r--
__init__.cpython-38.opt-2.pyc
1.043 KB
-rw-r--r--
__init__.cpython-38.pyc
1.653 KB
-rw-r--r--
_encoded_words.cpython-38.opt-1.pyc
5.555 KB
-rw-r--r--
_encoded_words.cpython-38.opt-2.pyc
3.713 KB
-rw-r--r--
_encoded_words.cpython-38.pyc
5.555 KB
-rw-r--r--
_header_value_parser.cpython-38.opt-1.pyc
78.015 KB
-rw-r--r--
_header_value_parser.cpython-38.opt-2.pyc
61.538 KB
-rw-r--r--
_header_value_parser.cpython-38.pyc
78.062 KB
-rw-r--r--
_parseaddr.cpython-38.opt-1.pyc
12.178 KB
-rw-r--r--
_parseaddr.cpython-38.opt-2.pyc
9.287 KB
-rw-r--r--
_parseaddr.cpython-38.pyc
12.178 KB
-rw-r--r--
_policybase.cpython-38.opt-1.pyc
14.465 KB
-rw-r--r--
_policybase.cpython-38.opt-2.pyc
5.844 KB
-rw-r--r--
_policybase.cpython-38.pyc
14.465 KB
-rw-r--r--
base64mime.cpython-38.opt-1.pyc
3.161 KB
-rw-r--r--
base64mime.cpython-38.opt-2.pyc
1.426 KB
-rw-r--r--
base64mime.cpython-38.pyc
3.161 KB
-rw-r--r--
charset.cpython-38.opt-1.pyc
11.156 KB
-rw-r--r--
charset.cpython-38.opt-2.pyc
4.976 KB
-rw-r--r--
charset.cpython-38.pyc
11.192 KB
-rw-r--r--
contentmanager.cpython-38.opt-1.pyc
7.19 KB
-rw-r--r--
contentmanager.cpython-38.opt-2.pyc
7.19 KB
-rw-r--r--
contentmanager.cpython-38.pyc
7.19 KB
-rw-r--r--
encoders.cpython-38.opt-1.pyc
1.576 KB
-rw-r--r--
encoders.cpython-38.opt-2.pyc
1.233 KB
-rw-r--r--
encoders.cpython-38.pyc
1.576 KB
-rw-r--r--
errors.cpython-38.opt-1.pyc
5.769 KB
-rw-r--r--
errors.cpython-38.opt-2.pyc
4.37 KB
-rw-r--r--
errors.cpython-38.pyc
5.769 KB
-rw-r--r--
feedparser.cpython-38.opt-1.pyc
10.246 KB
-rw-r--r--
feedparser.cpython-38.opt-2.pyc
8.622 KB
-rw-r--r--
feedparser.cpython-38.pyc
10.395 KB
-rw-r--r--
generator.cpython-38.opt-1.pyc
12.232 KB
-rw-r--r--
generator.cpython-38.opt-2.pyc
8.62 KB
-rw-r--r--
generator.cpython-38.pyc
12.232 KB
-rw-r--r--
header.cpython-38.opt-1.pyc
16.056 KB
-rw-r--r--
header.cpython-38.opt-2.pyc
10.563 KB
-rw-r--r--
header.cpython-38.pyc
16.056 KB
-rw-r--r--
headerregistry.cpython-38.opt-1.pyc
21.479 KB
-rw-r--r--
headerregistry.cpython-38.opt-2.pyc
15.851 KB
-rw-r--r--
headerregistry.cpython-38.pyc
21.529 KB
-rw-r--r--
iterators.cpython-38.opt-1.pyc
1.877 KB
-rw-r--r--
iterators.cpython-38.opt-2.pyc
1.271 KB
-rw-r--r--
iterators.cpython-38.pyc
1.877 KB
-rw-r--r--
message.cpython-38.opt-1.pyc
36.992 KB
-rw-r--r--
message.cpython-38.opt-2.pyc
20.818 KB
-rw-r--r--
message.cpython-38.pyc
36.992 KB
-rw-r--r--
parser.cpython-38.opt-1.pyc
5.59 KB
-rw-r--r--
parser.cpython-38.opt-2.pyc
2.643 KB
-rw-r--r--
parser.cpython-38.pyc
5.59 KB
-rw-r--r--
policy.cpython-38.opt-1.pyc
9.434 KB
-rw-r--r--
policy.cpython-38.opt-2.pyc
3.364 KB
-rw-r--r--
policy.cpython-38.pyc
9.434 KB
-rw-r--r--
quoprimime.cpython-38.opt-1.pyc
7.5 KB
-rw-r--r--
quoprimime.cpython-38.opt-2.pyc
4.108 KB
-rw-r--r--
quoprimime.cpython-38.pyc
7.5 KB
-rw-r--r--
utils.cpython-38.opt-1.pyc
9.32 KB
-rw-r--r--
utils.cpython-38.opt-2.pyc
6.074 KB
-rw-r--r--
utils.cpython-38.pyc
9.32 KB
-rw-r--r--