HEX
Server: LiteSpeed
System: Linux us-phx-web1284.main-hosting.eu 4.18.0-553.109.1.lve.el8.x86_64 #1 SMP Thu Mar 5 20:23:46 UTC 2026 x86_64
User: u300739242 (300739242)
PHP: 8.2.30
Disabled: system, shell_exec, passthru, mysql_list_dbs, ini_alter, dl, symlink, link, chgrp, leak, popen, apache_child_terminate, virtual, mb_send_mail
Upload Files
File: //opt/alt/python37/lib/python3.7/site-packages/packaging/__pycache__/metadata.cpython-37.pyc
B

�P�e��@s�ddlZddlZddlZddlZddlZddlZddlZddlmZm	Z	m
Z
mZmZm
Z
mZmZmZmZddlmZmZmZmZe�d�Zejdd�dkr�ddlmZmZn`ejr�ddlmZmZnHyddlmZmZWn2ek
�rGd	d
�d
�ZGdd�d�ZYnXy
e j!Z!Wn&e"k
�r>Gd
d�de#�Z!YnXGdd�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�Z0ddd#dddd$dd8dddddd%d&d'd/d(d)d*d+d,d-d d!d.d"d9�Z1d:d;�e1�2�D�Z3ee/e*fee&e
e*ee*ffd0�d<d=�Z4e5�Z6d>d?d@dAdBdCgZ7edDZ8e9ddd"g�Z:GdEdF�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$GszInvalidMetadata.__init__)rrrr)r*r+r$�
__classcell__rr)r'rr-As
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+rrrrrrr1Ps:
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}y|j|j}WnLtk
rb|jtkr6d}n(|jtkrFg}n|jtkrVi}nds^t�YnXyt|d|j���}Wnt	k
r�Yn
X||�}|||j<y|j|j=Wntk
r�YnXt
t|�S)NrWFZ	_process_)�__dict__�_rawr3r[r�r��_DICT_FIELDSr��getattr�AttributeErrorrr)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_version sz$_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_version3s

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_typeCs$


z,_Validator._process_description_content_typecCsXxFttj|�D]6}|dkr,|�|�d���q|tkr|�|�d���qWtttj|��S)N>�metadata-versionr3rz" is not allowed as a dynamic fieldz is not a valid dynamic field)�mapr*r}r�r�r�)r#r�Z
dynamic_fieldrrr�_process_dynamiccsz_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_extrams
"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_python|s

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
eeed<e
�Ze
eeed<e
dd�Ze
eeed<e
�Ze
eed<e
�Ze
eed<e
dd�Ze
eed<e
�Ze
eeed<e
�Ze
eed<e
dd�Ze
eed<e
�Ze
eed<e
�Ze
eed<e
dd�Z e
eed<e
dd�Z!e
eed<e
�Z"e
eed<e
dd�Z#e
eeed <e
dd�Z$e
ee%j&ed!<e
dd�Z'e
e(j)ed"<e
dd�Z*e
eeed#<e
dd�Z+e
e,eefed$<e
dd�Z-e
ee.j/ed%<e
dd�Z0e
eeed&<e
dd�Z1e
eeed'<e
dd�Z2e
eeed(<e
dd�Z3e
eeed)<e
dd�Z4e
eeed*<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{�_REQUIRED_ATTRSr�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�g}t|�\}}|r^x:|D]2}|tkr2|�d�}n
d|��}|�t||��qW|r^td|��y|j||d�Stk
r�}z|�|j�td|�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�rXr!)	r�rNr�r!rqr�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)5rrrr)r1r+�classmethod�boolr�r
r�r*r�r�r2r�r3rr�r�rLrr4r<r5r6rJr7r8r=r9r:rBrCr;r>rDr
r�rGrr�rHrIrrKrr�rErFr?r@rArrrrr��sL
8r�)=�email.feedparserrpZemail.header�
email.message�email.parser�email.policy�sys�typingrrrrrrrr	r
rrWr
rrrr��TypeVarr�version_inforr�
TYPE_CHECKING�typing_extensions�ImportError�__builtins__rr�r,rjr-r1r�r�r�r*rUrar �Messager�rmr��itemsr�r��objectZ
_NOT_FOUNDr�r�r{r�r�r�rrrr�<module>s�0


E(,15