U
    ;rc                     @   s   d Z ddddddgZddlmZmZ dd	lmZmZ dd
lm	Z	 G dd dZ
G dd de
ZG dd dZG dd deZdS )z-A parser of RFC 2822 and MIME email messages.ParserHeaderParserBytesParserBytesHeaderParser
FeedParserBytesFeedParser    )StringIOTextIOWrapper)r   r   )compat32c                   @   s0   e Zd Zd
edddZdddZddd	ZdS )r   Npolicyc                C   s   || _ || _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.

        N)_classr   )selfr   r    r   "/usr/lib/python3.8/email/parser.py__init__   s    zParser.__init__Fc                 C   s@   t | j| jd}|r|  |d}|s,q8|| q| S )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   i    )r   r   r   Z_set_headersonlyreadZfeedclose)r   fpheadersonlyZ
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   parsestr;   s    zParser.parsestr)N)F)F)__name__
__module____qualname__r
   r   r   r   r   r   r   r   r      s   
c                   @   s    e Zd ZdddZdddZdS )	r   Tc                 C   s   t | |dS NT)r   r   r   r   r   r   r   r   r   H   s    zHeaderParser.parsec                 C   s   t | |dS r   )r   r   r   r   r   r   r   K   s    zHeaderParser.parsestrN)T)T)r   r   r   r   r   r   r   r   r   r   G   s   
c                   @   s(   e Zd Zdd Zd	ddZd
ddZdS )r   c                 O   s   t ||| _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   Q   s    zBytesParser.__init__Fc                 C   s0   t |ddd}z| j||W S |  X 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	   detachr!   r   r    r   r   r   r   c   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.
        ASCIIr%   )r'   )decoder!   r   r   r   r   r   
parsebytesr   s    zBytesParser.parsebytesN)F)F)r   r   r   r   r   r+   r   r   r   r   r   O   s   
c                   @   s    e Zd ZdddZdddZdS )	r   Tc                 C   s   t j| |ddS NTr   )r   r   r    r   r   r   r      s    zBytesHeaderParser.parsec                 C   s   t j| |ddS r,   )r   r+   r   r   r   r   r+      s    zBytesHeaderParser.parsebytesN)T)T)r   r   r   r   r+   r   r   r   r   r   ~   s   
N)__doc____all__ior   r	   Zemail.feedparserr   r   Zemail._policybaser
   r   r   r   r   r   r   r   r   <module>   s    7/