o
    [h                     @   sv   d Z ddlZddlmZmZmZmZ ddlmZ ddl	m
Z
mZ ddl	mZ ddlmZ ddlmZ G dd	 d	ZdS )
z`Represents a wheel file and provides access to the various parts of the
name that have meaning.
    N)DictIterableListOptionalTag)BuildTagparse_wheel_filename)InvalidWheelFilename)
deprecatedc                   @   s   e Zd ZdZedejZdeddfddZ	e
defdd	Zdee fd
dZdee defddZdee deeef defddZdee defddZdS )WheelzA wheel filez^(?P<namever>(?P<name>[^\s-]+?)-(?P<ver>[^\s-]*?))
        ((-(?P<build>\d[^-]*?))?-(?P<pyver>[^\s-]+?)-(?P<abi>[^\s-]+?)-(?P<plat>[^\s-]+?)
        \.whl|\.dist-info)$filenamereturnNc              
      s  || _ |  d | _zt|}|\| _}| _| _t|| _W d S  ty } zb| j	|}|s5t
|jd d td|d|jd  ddddd |d	d
d| _|dd
d| _|dd}|dd |ddt fdd|D | _W Y d }~d S d }~ww )Nr   zWheel filename zU is not correctly normalised. Future versions of pip will raise the following error:
z

zvto rename the wheel to use a correctly normalised name (this may require updating the version in the project metadata)z25.3i2  )reasonreplacementgone_inissuename_-verpyver.abiplatc                 3   s2    | ]} D ]}D ]
}t |||d V  q
qqdS ))interpreterr   platformNr   ).0pyr   r   abisplats /home/ubuntu/experiments/live_experiments/Pythonexperiments/Otree/venv/lib/python3.10/site-packages/pip/_internal/models/wheel.py	<genexpr>D   s    z!Wheel.__init__.<locals>.<genexpr>)r   
_build_tagr	   r   	file_tagsstrversion_PackagingInvalidWheelFilenamelegacy_wheel_file_rematchr
   argsr   groupreplacesplit	frozenset)selfr   
wheel_info_versionelegacy_wheel_info
pyversionsr"   r   r#   __init__   s:   zWheel.__init__c                 C   sx   | j d ur| j S | j| j}|d usJ d|d}td|}|d us*J d| }t|d |d f| _ | j S )Nz!guaranteed by filename validationbuildz^(\d+)(.*)$r      )r%   r*   r+   r   r-   regroupsint)r1   r5   	build_tagr+   build_tag_groupsr"   r"   r#   r=   K   s   

zWheel.build_tagc                 C   s   t dd | jD S )z4Return the wheel's tags as a sorted list of strings.c                 s   s    | ]}t |V  qd S N)r'   r   tagr"   r"   r#   r$   ]   s    z0Wheel.get_formatted_file_tags.<locals>.<genexpr>)sortedr&   r1   r"   r"   r#   get_formatted_file_tags[   s   zWheel.get_formatted_file_tagstagsc                    s2   zt  fddt|D W S  ty   t w )a  Return the lowest index that one of the wheel's file_tag combinations
        achieves in the given list of supported tags.

        For example, if there are 8 supported tags and one of the file tags
        is first in the list, then return 0.

        :param tags: the PEP 425 tags to check the wheel against, in order
            with most preferred first.

        :raises ValueError: If none of the wheel's file tags match one of
            the supported tags.
        c                 3   s"    | ]\}}| j v r|V  qd S r?   )r&   )r   itrC   r"   r#   r$   m   s     z*Wheel.support_index_min.<locals>.<genexpr>)next	enumerateStopIteration
ValueErrorr1   rE   r"   rC   r#   support_index_min_   s
   zWheel.support_index_mintag_to_priorityc                    s   t  fdd| jD S )a  Return the priority of the most preferred tag that one of the wheel's file
        tag combinations achieves in the given list of supported tags using the given
        tag_to_priority mapping, where lower priorities are more-preferred.

        This is used in place of support_index_min in some cases in order to avoid
        an expensive linear scan of a large list of tags.

        :param tags: the PEP 425 tags to check the wheel against.
        :param tag_to_priority: a mapping from tag to priority of that tag, where
            lower is more preferred.

        :raises ValueError: If none of the wheel's file tags match one of
            the supported tags.
        c                 3   s     | ]}| v r | V  qd S r?   r"   r@   rN   r"   r#   r$      s    z0Wheel.find_most_preferred_tag.<locals>.<genexpr>)minr&   )r1   rE   rN   r"   rO   r#   find_most_preferred_tagq   s   zWheel.find_most_preferred_tagc                 C   s   | j | S )zReturn whether the wheel is compatible with one of the given tags.

        :param tags: the PEP 425 tags to check the wheel against.
        )r&   
isdisjointrL   r"   r"   r#   	supported   s   zWheel.supported)__name__
__module____qualname____doc__r:   compileVERBOSEr*   r'   r7   propertyr   r=   r   rD   r   r<   rM   r   rQ   r   boolrS   r"   r"   r"   r#   r      s&    /

r   )rW   r:   typingr   r   r   r   Zpip._vendor.packaging.tagsr   Zpip._vendor.packaging.utilsr   r	   r
   r)   pip._internal.exceptionspip._internal.utils.deprecationr   r   r"   r"   r"   r#   <module>   s    