o
    i                     @   s   d Z ddlmZ ddlmZ ddlmZ g dZddlZddlmZm	Z	 ddl
mZmZ dd	lmZ dd
lmZ G dd deZG dd deZG dd deZG dd deZdS )z-A parser of RFC 2822 and MIME email messages.    )unicode_literals)division)absolute_import)ParserHeaderParserBytesParserBytesHeaderParserN)StringIOTextIOWrapper)
FeedParserBytesFeedParser)Message)compat32c                   @   s,   e Zd ZefddZd	ddZd	ddZdS )
r   c                 K   s,   d|v r|d }|d= nt }|| _|| _dS )a  Parser of RFC 2822 and MIME email messages.

        Creates an in-memory object tree representing the email message, which
        can then be manipulated and turned over to a Generator to return the
        textual representation of the message.

        The string must be formatted as a block of RFC 2822 headers and header
        continuation lines, optionally preceded by a `Unix-from' header.  The
        header block is terminated either by the end of the string or by a
        blank line.

        _class is the class to instantiate for new message objects when they
        must be created.  This class must have a constructor that can take
        zero arguments.  Default is Message.Message.

        The policy keyword specifies a policy object that controls a number of
        aspects of the parser's operation.  The default policy maintains
        backward compatibility.

        policyN)r   _classr   )selfr   Z_3to2kwargsr    r   l/var/www/html/eduruby.in/lip-sync/lip-sync-env/lib/python3.10/site-packages/future/backports/email/parser.py__init__   s   
zParser.__init__Fc                 C   sB   t | j| jd}|r|  	 |d}|s	 | S || q)a\  Create a message structure from the data in a file.

        Reads all the data from the file and returns the root of the message
        structure.  Optional headersonly is a flag specifying whether to stop
        parsing after reading the headers or not.  The default is False,
        meaning it parses the entire contents of the file.
        )r   Ti    )r   r   r   _set_headersonlyreadfeedclose)r   fpheadersonly
feedparserdatar   r   r   parse/   s   

zParser.parsec                 C   s   | j t||dS )a-  Create a message structure from a string.

        Returns the root of the message structure.  Optional headersonly is a
        flag specifying whether to stop parsing after reading the headers or
        not.  The default is False, meaning it parses the entire contents of
        the file.
        r   )r   r	   r   textr   r   r   r   parsestrA   s   zParser.parsestrNF)__name__
__module____qualname__r   r   r   r!   r   r   r   r   r      s    
r   c                   @       e Zd ZdddZdddZdS )r   Tc                 C      t | |dS NT)r   r   r   r   r   r   r   r   r   N      zHeaderParser.parsec                 C   r'   r(   )r   r!   r   r   r   r   r!   Q   r*   zHeaderParser.parsestrNT)r#   r$   r%   r   r!   r   r   r   r   r   M       
r   c                   @   s(   e Zd Zdd Zd	ddZd	ddZdS )
r   c                 O   s   t |i || _dS )a  Parser of binary RFC 2822 and MIME email messages.

        Creates an in-memory object tree representing the email message, which
        can then be manipulated and turned over to a Generator to return the
        textual representation of the message.

        The input must be formatted as a block of RFC 2822 headers and header
        continuation lines, optionally preceded by a `Unix-from' header.  The
        header block is terminated either by the end of the input or by a
        blank line.

        _class is the class to instantiate for new message objects when they
        must be created.  This class must have a constructor that can take
        zero arguments.  Default is Message.Message.
        N)r   parser)r   argskwr   r   r   r   W   s   zBytesParser.__init__Fc                 C   sD   t |ddd}| | j||W  d   S 1 sw   Y  dS )ac  Create a message structure from the data in a binary file.

        Reads all the data from the file and returns the root of the message
        structure.  Optional headersonly is a flag specifying whether to stop
        parsing after reading the headers or not.  The default is False,
        meaning it parses the entire contents of the file.
        asciisurrogateescape)encodingerrorsN)r
   r-   r   r)   r   r   r   r   i   s   $zBytesParser.parsec                 C   s   |j ddd}| j||S )a2  Create a message structure from a byte string.

        Returns the root of the message structure.  Optional headersonly is a
        flag specifying whether to stop parsing after reading the headers or
        not.  The default is False, meaning it parses the entire contents of
        the file.
        ASCIIr1   )r3   )decoder-   r!   r   r   r   r   
parsebytesv   s   zBytesParser.parsebytesNr"   )r#   r$   r%   r   r   r6   r   r   r   r   r   U   s    
r   c                   @   r&   )r   Tc                 C      t j| |ddS NTr   )r   r   r)   r   r   r   r         zBytesHeaderParser.parsec                 C   r7   r8   )r   r6   r   r   r   r   r6      r9   zBytesHeaderParser.parsebytesNr+   )r#   r$   r%   r   r6   r   r   r   r   r      r,   r   )__doc__
__future__r   r   r   __all__warningsior	   r
   Z!future.backports.email.feedparserr   r   Zfuture.backports.email.messager   Z"future.backports.email._policybaser   objectr   r   r   r   r   r   r   r   <module>   s   9-