Your IP : 216.73.216.12
o
S�g��@sxdZgd�ZddlmZmZddlmZmZddlm Z Gdd�d�Z
Gdd �d e
�ZGd
d�d�ZGdd
�d
e�Z
dS)z-A parser of RFC 2822 and MIME email messages.)�Parser�HeaderParser�BytesParser�BytesHeaderParser�
FeedParser�BytesFeedParser�)�StringIO�
TextIOWrapper)rr)�compat32c@s0eZdZd
ed�dd�Zddd�Zddd �ZdS)rN��policycCs||_||_dS)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�3/opt/alt/python310/lib64/python3.10/email/parser.py�__init__s
zParser.__init__FcCsBt|j|jd�}|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.
rTi )rr
rZ_set_headersonly�readZfeed�close)r�fp�headersonlyZ
feedparser�datarrr�parse)s
��zParser.parsecCs|jt|�|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)rr�r�textrrrr�parsestr;szParser.parsestr)N�F)�__name__�
__module__�__qualname__r
rrrrrrrrs
rc@� eZdZddd�Zddd�ZdS)rTcC�t�||d�S�NT)rr�rrrrrrrH�zHeaderParser.parsecCr!r")rrrrrrrKr$zHeaderParser.parsestrN�T)rrrrrrrrrrG�
rc@s(eZdZdd�Zd dd�Zd dd�ZdS)
rcOst|i|��|_dS)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�kwrrrrQszBytesParser.__init__FcCs2t|ddd�}z|j�||�W|��S|��w)acCreate 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 r'r�detachr#rrrrcszBytesParser.parsecCs|jddd�}|j�||�S)a2Create 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'rrrrr�
parsebytesrszBytesParser.parsebytesNr)rrrrrr1rrrrrOs
rc@r )rTcC�tj||dd�S�NTr)rrr#rrrr�zBytesHeaderParser.parsecCr2r3)rr1rrrrr1�r4zBytesHeaderParser.parsebytesNr%)rrrrr1rrrrr~r&rN)�__doc__�__all__�iorr Zemail.feedparserrrZemail._policybaser
rrrrrrrr�<module>s7/
?>