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

        N)_classr   )selfr   r   s      #/usr/lib/python3.12/email/parser.py__init__zParser.__init__   s    *     c                     t        | j                  | j                        }|r|j                          |j	                  d      x}r%|j                  |       |j	                  d      x}r%|j                         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   _set_headersonlyreadfeedclose)r   fpheadersonly
feedparserdatas        r   parsezParser.parse)   sj      DKK@
'')ggdm#d#OOD! ggdm#d#!!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.parsestr8   s     zz(4.kzBBr   )NF)__name__
__module____qualname__r   r   r   r#    r   r   r   r      s    h 0"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.parseD   s    ||D"d++r   c                 0    t         j                  | |d      S r+   )r   r#   r!   s      r   r#   zHeaderParser.parsestrG   s    tT400r   NT)r%   r&   r'   r   r#   r(   r   r   r   r   C   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__M   s      d)b)r   c                     t        |dd      }	 | j                  j                  ||      |j                          S # |j                          w 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errors)r
   r1   r   detachr,   s      r   r   zBytesParser.parse_   s?     28IJ	;;$$R5IIKBIIKs	   < 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.
        ASCIIr6   )r8   )decoder1   r#   r!   s      r   
parsebyteszBytesParser.parsebytesn   s.     {{7+<{={{##D+66r   Nr$   )r%   r&   r'   r   r   r=   r(   r   r   r   r   K   s    *$	7r   r   c                       e Zd ZddZddZy)r   c                 2    t         j                  | |d      S NTr    )r   r   r,   s      r   r   zBytesHeaderParser.parse{   s      rt <<r   c                 2    t         j                  | |d      S r@   )r   r=   r!   s      r   r=   zBytesHeaderParser.parsebytes~   s    %%dDd%CCr   Nr.   )r%   r&   r'   r   r=   r(   r   r   r   r   z   s    =Dr   r   N)__doc____all__ior	   r
   email.feedparserr   r   email._policybaser   r   r   r   r   r(   r   r   <module>rG      sN   
 4, ' 8 &0C 0Cf16 1,7 ,7^D Dr   