HEX
Server: LiteSpeed
System: Linux srv146.niagahoster.com 4.18.0-553.30.1.lve.el8.x86_64 #1 SMP Tue Dec 3 01:21:19 UTC 2024 x86_64
User: kodi1989 (1633)
PHP: 8.1.34
Disabled: symlink,shell_exec,exec,popen,system,dl,passthru,escapeshellarg,escapeshellcmd,show_source,pcntl_exec
Upload Files
File: //opt/alt/python37/lib/python3.7/site-packages/packaging/__pycache__/metadata.cpython-37.pyc
B

��f��@s�ddlZddlZddlZddlZddlZddlZddlZddlmZm	Z	m
Z
mZmZm
Z
mZmZmZmZddlmZmZmZmZe�d�Zejdd�dkr�ddlmZmZn`ejr�ddlmZmZnHyddlmZmZWn2ek
�rGd	d
�d
�ZGdd�d�ZYnXye Wn&e!k
�r<Gd
d�de"�Z YnXe Z Gdd�de#�Z$Gdd�dedd�Z%dddddddddddd d!d"hZ&d#d$d%d&d'd(d)d*d+d,d-d.hZ'd/hZ(e)ee)d0�d1d2�Z*ee)e
e)e)fd0�d3d4�Z+ej,j-ee.e)fe)d5�d6d7�Z/ddd#dddd$dd8dddddd%d&d'd/d(d)d*d+d,d-d d!d.d"d9�Z0d:d;�e0�1�D�Z2ee.e)fee%e
e)ee)ffd0�d<d=�Z3e4�Z5d>d?d@dAdBdCgZ6edDZ7e8ddd"g�Z9GdEdF�dFee�Z:GdGdH�dH�Z;dS)I�N)
�Any�Callable�Dict�Generic�List�Optional�Tuple�Type�Union�cast�)�requirements�
specifiers�utils�version�T�)��)�Literal�	TypedDictc@seZdZdd�ZdS)rcOsdS)N�)�_args�_kwargsrr�C/opt/alt/python37/lib/python3.7/site-packages/packaging/metadata.py�__init_subclass__#szLiteral.__init_subclass__N)�__name__�
__module__�__qualname__rrrrrr"src@seZdZdd�ZdS)rcOsdS)Nr)rrrrrr'szTypedDict.__init_subclass__N)rrrrrrrrr&src@sJeZdZUdZeed<eeed<eeedd�dd�Zed�d	d
�Z	dS)�ExceptionGroupz�A minimal implementation of :external:exc:`ExceptionGroup` from Python 3.11.

        If :external:exc:`ExceptionGroup` is already defined by Python itself,
        that version is used instead.
        �message�
exceptionsN)r r!�returncCs||_||_dS)N)r r!)�selfr r!rrr�__init__9szExceptionGroup.__init__)r"cCs|jj�d|j�d|j�d�S)N�(z, �))�	__class__rr r!)r#rrr�__repr__=szExceptionGroup.__repr__)
rrr�__doc__�str�__annotations__r�	Exceptionr$r(rrrrr/s

rcs4eZdZUdZeed<eedd��fdd�Z�ZS)�InvalidMetadataz'A metadata field contains invalid data.�fieldN)r.r r"cs||_t��|�dS)N)r.�superr$)r#r.r )r'rrr$JszInvalidMetadata.__init__)rrrr)r*r+r$�
__classcell__rr)r'rr-Ds
r-c@s.eZdZUdZeed<eed<eed<eeed<eed<eed<eeed<eed	<eed
<eed<eed<eeed
<eed<eeed<eeed<eeed<eeed<eed<eed<eeed<eeed<eeed<eed<eeed<eeefed<eed<eeed<eeed<dS)�RawMetadataa�A dictionary of raw core metadata.

    Each field in core metadata maps to a key of this dictionary (when data is
    provided). The key is lower-case and underscores are used instead of dashes
    compared to the equivalent core metadata field. Any core metadata field that
    can be specified multiple times or can hold multiple values in a single
    field have a key with a plural name. See :class:`Metadata` whose attributes
    match the keys of this dictionary.

    Core metadata fields that can be specified multiple times are stored as a
    list or dict depending on which is appropriate for the field. Any fields
    which hold multiple values in a single field are stored as a list.

    �metadata_version�namer�	platforms�summary�description�keywords�	home_page�author�author_email�license�supported_platforms�download_url�classifiers�requires�provides�	obsoletes�
maintainer�maintainer_email�
requires_dist�
provides_dist�obsoletes_dist�requires_python�requires_external�project_urls�description_content_type�provides_extra�dynamicN)rrrr)r*r+rrrrrrr1Ss:
r1F)�totalr9r:r6rJr=r8r;rBrCr2r3rGr5rr>rLrArFr4r@rErKr?rDrHr<rI)�datar"cCsdd�|�d�D�S)zCSplit a string of comma-separate keyboards into a list of keywords.cSsg|]}|���qSr)�strip)�.0�krrr�
<listcomp>�sz#_parse_keywords.<locals>.<listcomp>�,)�split)rNrrr�_parse_keywords�srUc	Csji}x`|D]X}dd�|�dd�D�}|�dgtddt|���|\}}||krZtd��|||<q
W|S)	z?Parse a list of label/URL string pairings separated by a comma.cSsg|]}|���qSr)rO)rP�prrrrR�sz'_parse_project_urls.<locals>.<listcomp>rSr�rrz duplicate labels in project urls)rT�extend�max�len�KeyError)rN�urls�pair�parts�label�urlrrr�_parse_project_urls�s
ra)�msg�sourcer"cCsPt|t�r|��}|S|jdd�}y|�dd�Stk
rJtd��YnXdS)zGet the body of the message.T)�decode�utf8�strictzpayload in an invalid encodingN)�
isinstancer*�get_payloadrd�UnicodeDecodeError�
ValueError)rbrc�payload�bpayloadrrr�_get_payload�s
rmr7)r9zauthor-email�
classifierr6zdescription-content-typezdownload-urlrLz	home-pager7r;rBzmaintainer-emailzmetadata-versionr3rAzobsoletes-dist�platformzproject-urlr@z
provides-distzprovides-extrar?z
requires-distzrequires-externalzrequires-pythonr5zsupported-platformrcCsi|]\}}||�qSrr)rP�email�rawrrr�
<dictcomp>$srrcCs�i}i}t|t�r,tjjtjjd��|�}ntjjtjjd��	|�}�x�t
|���D�]�}|��}|�
|�png}g}d}x�|D]�}t|tjjtf�s�t�t|tjj��rg}	xXtj�|�D]H\}
}y|
�dd�Wntk
r�d}d}YnXd}|	�|
|f�q�W|�ttj�|	���q~|�|�q~W|�s<|||<qTt�|�}|dk�rZ|||<qT|tk�r�t|�dk�r�|d	||<qT|tk�r�|||<qT|d
k�r�t|�dk�r�t|d	�||<qT|dk�r�yt|�||<Wntk
�r�|||<YnXqT|||<qTWyt||�}
Wn6tk
�rJ|� dg��|j!t|t"�d
��Yn\X|
�r�d|k�r�t#t|�$d��}|� dg��%||
g�n"d|k�r�|d�|
�n|
|d<t#t&|�|fS)a
Parse a distribution's metadata stored as email headers (e.g. from ``METADATA``).

    This function returns a two-item tuple of dicts. The first dict is of
    recognized fields from the core metadata specification. Fields that can be
    parsed and translated into Python's built-in types are converted
    appropriately. All other fields are left as-is. Fields that are allowed to
    appear multiple times are stored as lists.

    The second dict contains all other fields from the metadata. This includes
    any unrecognized fields. It also includes any fields which are expected to
    be parsed into a built-in type but were not formatted appropriately. Finally,
    any fields that are expected to appear only once but are repeated are
    included in this dict.

    )�policyTrerf�latin1FNrrr7rIr6)rd)'rgr*rp�parser�Parserrs�compat32�parsestr�BytesParser�
parsebytes�	frozenset�keys�lower�get_all�header�Header�AssertionError�
decode_headerrdri�append�make_header�_EMAIL_TO_RAW_MAPPING�get�_STRING_FIELDSrZ�_LIST_FIELDSrUrar[rmrj�
setdefaultrh�bytesr�poprXr1)rNrq�unparsed�parsedr3�headers�valueZvalid_encoding�h�chunks�bin�encoding�raw_namerkZdescription_headerrrr�parse_email'sr
	











r�z1.0z1.1z1.2z2.1z2.2z2.3)z1.0z1.1z1.2z2.1z2.2z2.3c@s0eZdZUdZeed<eed<eed<dd�edd�d	d
�Zdedd�d
d�Zde	de
d�dd�Zd(eee
ed�dd�Zeed�dd�Zeed�dd�Zeejd�dd�Zeed�dd�Zeed�dd�Zeeeed�d d!�Zeeeejd�d"d#�Zeejd�d$d%�Zeeeej d�d&d'�Z!dS))�
_ValidatoravValidate a metadata field.

    All _process_*() methods correspond to a core metadata field. The method is
    called with the field's raw value. If the raw value is valid it is returned
    in its "enriched" form (e.g. ``version.Version`` for the ``Version`` field).
    If the raw value is invalid, :exc:`InvalidMetadata` is raised (with a cause
    as appropriate).
    r3r��addedz1.0)r�N)r�r"cCs
||_dS)N)r�)r#r�rrrr$�sz_Validator.__init__�Metadata)�_ownerr3r"cCs||_t||_dS)N)r3�_RAW_TO_EMAIL_MAPPINGr�)r#r�r3rrr�__set_name__�sz_Validator.__set_name__)�instancer�r"cCs�|j}|j�|j�}|jtks&|dk	rZyt|d|j���}Wntk
rPYn
X||�}|||j<y|j|j=Wntk
r�YnXtt	|�S)NZ	_process_)
�__dict__�_rawr�r3�_REQUIRED_ATTRS�getattr�AttributeErrorr[rr)r#r�r��cacher��	converterrrr�__get__�s
z_Validator.__get__)rb�causer"cCs&t|j|�dt|j�i��}||_|S)Nr.)r-r��
format_map�repr�	__cause__)r#rbr��excrrr�_invalid_metadatasz_Validator._invalid_metadata)r�r"cCs"|tkr|�|�d���tt|�S)Nz  is not a valid metadata version)�_VALID_METADATA_VERSIONSr�r�_MetadataVersion)r#r�rrr�_process_metadata_versionsz$_Validator._process_metadata_versionc
Csb|s|�d��ytj|dd�Wn8tjk
rX}z|j|�d�|d��Wdd}~XYnX|SdS)Nz{field} is a required fieldT)�validatez is invalid for {field})r�)r�r�canonicalize_name�InvalidName)r#r�r�rrr�
_process_name$s
"z_Validator._process_namec
CsV|s|�d��y
t�|�Stjk
rP}z|j|�d�|d��Wdd}~XYnXdS)Nz{field} is a required fieldz is invalid for {field})r�)r��version_module�parse�InvalidVersion)r#r�r�rrr�_process_version1s

z_Validator._process_versioncCsd|kr|�d��|S)z%Check the field contains no newlines.�
z{field} must be a single line)r�)r#r�rrr�_process_summary;s
z_Validator._process_summaryc	Cs�dddh}tj��}||d<|����|dj}}||ksH||��krb|�dt|��d|����|�dd�}|dkr�|�d	t|�����d
dh}|�dd
�}|dkr�||kr�|�d
t|��d|����|S)Nz
text/plainz
text/x-rstz
text/markdownzcontent-typez{field} must be one of z, not �charsetzUTF-8z0{field} can only specify the UTF-8 charset, not ZGFMZ
CommonMark�variantz(valid Markdown variants for {field} are )	rpr �EmailMessage�get_content_typer}�paramsr��listr�)	r#r�Z
content_typesr �content_type�
parametersr�Zmarkdown_variantsr�rrr�!_process_description_content_typeAs$


z,_Validator._process_description_content_typecCsXxFttj|�D]6}|dkr,|�|�d���q|tkr|�|�d���qWtttj|��S)N>r�metadata-versionr3z" is not allowed as a dynamic fieldz is not a valid dynamic field)�mapr*r}r�r�r�)r#r�Z
dynamic_fieldrrr�_process_dynamicasz_Validator._process_dynamicc
Cslg}y&x |D]}|�tj|dd��qWWn8tjk
rb}z|j|�d�|d��Wdd}~XYnX|SdS)NT)r�z is invalid for {field})r�)r�rr�r�r�)r#r�Znormalized_namesr3r�rrr�_process_provides_extraks
"z"_Validator._process_provides_extrac
CsHy
t�|�Stjk
rB}z|j|�d�|d��Wdd}~XYnXdS)Nz is invalid for {field})r�)r�SpecifierSet�InvalidSpecifierr�)r#r�r�rrr�_process_requires_pythonzs

z#_Validator._process_requires_pythonc
Cshg}y"x|D]}|�t�|��qWWn8tjk
r^}z|j|�d�|d��Wdd}~XYnX|SdS)Nz is invalid for {field})r�)r�r
�Requirement�InvalidRequirementr�)r#r��reqs�reqr�rrr�_process_requires_dist�s
&z!_Validator._process_requires_dist)N)"rrrr)r*r+r�r$r�r	rr�rr,r-r�r�r�r��Versionr�r�r�rr�r�NormalizedNamer�rr�r�r
r�r�rrrrr��s*



 
r�c@s>eZdZUdZeed<edd�eedd�dd��Zedd�e	e
efedd�dd	��Ze
�Ze
eed
<e
�Ze
eed<e
�Ze
ejed<e
d
d�Ze
eeeed<e
�Ze
eeeed<e
dd�Ze
eeeed<e
�Ze
eeed<e
�Ze
eeed<e
dd�Ze
eeed<e
�Ze
eeeed<e
�Ze
eeed<e
dd�Ze
eeed<e
�Ze
eeed<e
�Z e
eeed<e
dd�Z!e
eeed<e
dd�Z"e
eeed<e
�Z#e
eeed<e
dd�Z$e
eeeed <e
dd�Z%e
eee&j'ed!<e
dd�Z(e
ee)j*ed"<e
dd�Z+e
eeeed#<e
dd�Z,e
ee-eefed$<e
dd�Z.e
eee/j0ed%<e
dd�Z1e
eeeed&<e
dd�Z2e
eeeed'<e
dd�Z3e
eeeed(<e
dd�Z4e
eeeed)<e
dd�Z5e
eeeed*<d+S),r�aJRepresentation of distribution metadata.

    Compared to :class:`RawMetadata`, this class provides objects representing
    metadata fields instead of only using built-in types. Any invalid metadata
    will cause :exc:`InvalidMetadata` to be raised (with a
    :py:attr:`~BaseException.__cause__` attribute as appropriate).
    r�T)r�)rNr�r"cCsN|�}|��|_|�rJg}y|j}t�|�}Wn0tk
r^}z|�|�d}Wdd}~XYnXt|j�tB}|dh8}x�|D]�}	y�|r�y|j	|	j
}
Wn0tk
r�t|	d|	���}|�|�w~YnXt�|
�}||kr�t|	}
t|
d�}|�|�w~t
||	�Wq~tk
�r4}z|�|�Wdd}~XYq~Xq~W|�rJtd|��|S)z�Create an instance from :class:`RawMetadata`.

        If *validate* is true, all metadata will be validated. All exceptions
        related to validation will be gathered and raised as an :class:`ExceptionGroup`.
        Nr2zunrecognized field: zW{field} introduced in metadata version {field_metadata_version}, not {metadata_version}zinvalid metadata)�copyr�r2r��indexr-r�r{r�r�r�r[r�r�r)�clsrNr�Zinsr!r2Zmetadata_ageZmetadata_version_excZfields_to_check�keyZfield_metadata_versionr�Z	field_ager.rrr�from_raw�sH





 
zMetadata.from_rawc	
Cs�t|�\}}|r^g}x:|D]2}|tkr2|�d�}n
d|��}|�t||��qW|r^td|��y|j||d�Stk
r�}ztd|j�d�Wdd}~XYnXdS)z�Parse metadata from email headers.

        If *validate* is true, the metadata will be validated. All exceptions
        related to validation will be gathered and raised as an :class:`ExceptionGroup`.
        z has invalid datazunrecognized field: r�)r�zinvalid or unparsed metadataN)r�r�r�r-rr�r!)	r�rNr�rqr�r!Zunparsed_keyr Z	exc_grouprrr�
from_email�s 	


zMetadata.from_emailr2r3rz2.2)r�rLr4z1.1r<r5r6z2.1rJr7r8r=r9r:z1.2rBrCr;r>rDrGrHrIrKrErFr?r@rAN)6rrrr)r1r+�classmethod�boolr�r
r�r*r�r�r2r�r3rr�r�rLrrr4r<r5r6rJr7r8r=r9r:rBrCr;r>rDr
r�rGrr�rHrIrrKrr�rErFr?r@rArrrrr��sP
8"r�)<�email.feedparserrpZemail.header�
email.message�email.parser�email.policy�sys�typingrrrrrrrr	r
rrWr
rrrr��TypeVarr�version_inforr�
TYPE_CHECKINGZtyping_extensions�ImportErrorr�	NameErrorr,rjr-r1r�r�Z_DICT_FIELDSr*rUrar �Messager�rmr��itemsr�r��objectZ
_NOT_FOUNDr�r�r{r�r�r�rrrr�<module>s�0

E(,10