
    Fwg                         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e      Z G d de      Z G d de      Z G d de      Zy)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                   &    e Zd ZefdZddZddZy)r   c                 F    d|v r	|d   }|d= nt         }|| _        || _        y)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   _3to2kwargsr   s       T/var/www/horilla/myenv/lib/python3.12/site-packages/future/backports/email/parser.py__init__zParser.__init__   s0    * {"[-BFT\H]f    c                     t        | j                  | j                        }|r|j                          	 |j	                  d      }|s	 |j                         S |j                  |       6)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   _set_headersonlyreadfeedclose)r   fpheadersonly
feedparserdatas        r   parsezParser.parse/   s_      DKK@
'')774=D!! OOD!	 r   c                 :    | j                  t        |      |      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   s      r   parsestrzParser.parsestrA   s     zz(4.kzBBr   NF)__name__
__module____qualname__r   r   r"   r'    r   r   r   r      s    % 4"$Cr   r   c                       e Zd ZddZddZy)r   c                 0    t         j                  | |d      S NT)r   r"   r   r   r   s      r   r"   zHeaderParser.parseN   s    ||D"d++r   c                 0    t         j                  | |d      S r/   )r   r'   r%   s      r   r'   zHeaderParser.parsestrQ   s    tT400r   NT)r)   r*   r+   r"   r'   r,   r   r   r   r   M   s    ,1r   r   c                   "    e Zd Zd ZddZddZy)r   c                 $    t        |i || _        y)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kws      r   r   zBytesParser.__init__W   s      d)b)r   c                     t        |dd      }|5  | j                  j                  ||      cddd       S # 1 sw Y   yxY w)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   r5   r"   r0   s      r   r"   zBytesParser.parsei   s?     28IJ 	6;;$$R5	6 	6 	6s	   7A c                 `    |j                  dd      }| j                  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<   )decoder5   r'   r%   s      r   
parsebyteszBytesParser.parsebytesv   s.     {{7+<{={{##D+66r   Nr(   )r)   r*   r+   r   r"   r@   r,   r   r   r   r   U   s    *$
6	7r   r   c                       e Zd ZddZddZy)r	   c                 2    t         j                  | |d      S NTr$   )r   r"   r0   s      r   r"   zBytesHeaderParser.parse   s      rt <<r   c                 2    t         j                  | |d      S rC   )r   r@   r%   s      r   r@   zBytesHeaderParser.parsebytes   s    %%dDd%CCr   Nr2   )r)   r*   r+   r"   r@   r,   r   r   r	   r	      s    =Dr   r	   )__doc__
__future__r   r   r   __all__warningsior
   r   !future.backports.email.feedparserr   r   future.backports.email.messager   "future.backports.email._policybaser   objectr   r   r   r	   r,   r   r   <module>rN      s]   
 4 '  &
H  & I 2 75CV 5Cr16 1*7& *7ZD Dr   