U
    ڲg\                     @   sj  d Z ddlZddlZddlmZ ddlmZ dddd	d
dddgZee	Z
G dd deZG dd deZG dd deZedejZdd ZeZG dd deZdd ZG dd deZeddfeddfeddfedd fed!d"fed#d"fed$d%fed&d'fed(d)fed*d+ff
Zed,dfed-dfed.d%fed$d%fed/dffZed0Zd1d2 Zd3d4 Zed5ejZd6d6d7d6d8ddd9Zd:d; ZG d<d deZ G d=d	 d	eZ!ed>ejZ"d?d@ Z#dAdB Z$G dCd
 d
eZ%G dDd deZ&G dEdF dFeZ'e'eeee'ee!dGdH e'e$e&edIZ(e(dJ e(dK< dLd Z)dS )Mz~
Implementation of a flexible versioning scheme providing support for PEP-440,
setuptools-compatible and semantic versioning.
    N   )string_typesparse_requirementNormalizedVersionNormalizedMatcherLegacyVersionLegacyMatcherSemanticVersionSemanticMatcherUnsupportedVersionError
get_schemec                   @   s   e Zd ZdZdS )r   zThis is an unsupported version.N)__name__
__module____qualname____doc__ r   r   3/tmp/pip-unpacked-wheel-mq592sfu/distlib/version.pyr      s   c                   @   sx   e Zd Zdd Zdd Zdd Zdd Zd	d
 Zdd Zdd Z	dd Z
dd Zdd Zdd Zdd Zedd ZdS )Versionc                 C   s@   |   | _}| | | _}t|ts,tt|dks<td S )Nr   )strip_stringparse_parts
isinstancetupleAssertionErrorlen)selfspartsr   r   r   __init__   s    zVersion.__init__c                 C   s   t dd S )Nzplease implement in a subclassNotImplementedErrorr   r   r   r   r   r   %   s    zVersion.parsec                 C   s$   t | t |kr td| |f d S )Nzcannot compare %r and %r)type	TypeErrorr   otherr   r   r   _check_compatible(   s    zVersion._check_compatiblec                 C   s   |  | | j|jkS Nr(   r   r&   r   r   r   __eq__,   s    
zVersion.__eq__c                 C   s   |  | S r)   r+   r&   r   r   r   __ne__0   s    zVersion.__ne__c                 C   s   |  | | j|jk S r)   r*   r&   r   r   r   __lt__3   s    
zVersion.__lt__c                 C   s   |  |p| | S r)   r.   r+   r&   r   r   r   __gt__7   s    zVersion.__gt__c                 C   s   |  |p| |S r)   r/   r&   r   r   r   __le__:   s    zVersion.__le__c                 C   s   |  |p| |S r)   )r0   r+   r&   r   r   r   __ge__=   s    zVersion.__ge__c                 C   s
   t | jS r)   )hashr   r   r   r   r   __hash__A   s    zVersion.__hash__c                 C   s   d| j j| jf S )Nz%s('%s')	__class__r   r   r4   r   r   r   __repr__D   s    zVersion.__repr__c                 C   s   | j S r)   r   r4   r   r   r   __str__G   s    zVersion.__str__c                 C   s   t dd S )NzPlease implement in subclasses.r!   r4   r   r   r   is_prereleaseJ   s    zVersion.is_prereleaseN)r   r   r   r    r   r(   r+   r-   r.   r0   r1   r2   r5   r8   r:   propertyr;   r   r   r   r   r      s   r   c                	   @   s   e Zd ZdZdd dd dd dd dd dd d	d d
d dZdd Zdd Zdd Zedd Z	dd Z
dd Zdd Zdd Zdd Zdd ZdS ) MatcherNc                 C   s   | |k S r)   r   vcpr   r   r   <lambda>T       zMatcher.<lambda>c                 C   s   | |kS r)   r   r>   r   r   r   rB   U   rC   c                 C   s   | |kp| |k S r)   r   r>   r   r   r   rB   V   rC   c                 C   s   | |kp| |kS r)   r   r>   r   r   r   rB   W   rC   c                 C   s   | |kS r)   r   r>   r   r   r   rB   X   rC   c                 C   s   | |kS r)   r   r>   r   r   r   rB   Y   rC   c                 C   s   | |kp| |kS r)   r   r>   r   r   r   rB   [   rC   c                 C   s   | |kS r)   r   r>   r   r   r   rB   \   rC   )<><=>======~=!=c                 C   s   t |S r)   r   r#   r   r   r   r   a   s    zMatcher.parse_requirementc                 C   s   | j d krtd|  | _}| |}|s:td| |j| _| j | _g }|jr|jD ]d\}}|	dr|dkrtd| |d d d }}|  | n|  |d }}|
|||f q^t|| _d S )	NzPlease specify a version classzNot valid: %rz.*)rH   rK   z#'.*' not allowed for %r constraintsTF)version_class
ValueErrorr   r   r   namelowerkeyconstraintsendswithappendr   r   )r   r   rZclistopZvnprefixr   r   r   r    d   s*    


zMatcher.__init__c                 C   sx   t |tr| |}| jD ]X\}}}| j|}t |trDt| |}|s`d|| jjf }t	|||||s dS qdS )z
        Check if the provided version matches the constraints.

        :param version: The version to match against this instance.
        :type version: String or :class:`Version` instance.
        z%r not implemented for %sFT)
r   r   rM   r   
_operatorsgetgetattrr7   r   r"   )r   versionoperator
constraintrW   fmsgr   r   r   match   s    




zMatcher.matchc                 C   s6   d }t | jdkr2| jd d dkr2| jd d }|S )Nr   r   )rH   rI   )r   r   )r   resultr   r   r   exact_version   s     zMatcher.exact_versionc                 C   s0   t | t |ks| j|jkr,td| |f d S )Nzcannot compare %s and %s)r$   rO   r%   r&   r   r   r   r(      s    zMatcher._check_compatiblec                 C   s"   |  | | j|jko | j|jkS r)   )r(   rQ   r   r&   r   r   r   r+      s    
zMatcher.__eq__c                 C   s   |  | S r)   r,   r&   r   r   r   r-      s    zMatcher.__ne__c                 C   s   t | jt | j S r)   )r3   rQ   r   r4   r   r   r   r5      s    zMatcher.__hash__c                 C   s   d| j j| jf S )Nz%s(%r)r6   r4   r   r   r   r8      s    zMatcher.__repr__c                 C   s   | j S r)   r9   r4   r   r   r   r:      s    zMatcher.__str__)r   r   r   rM   rX   r   r    r`   r<   rb   r(   r+   r-   r5   r8   r:   r   r   r   r   r=   O   s*   
r=   z^v?(\d+!)?(\d+(\.\d+)*)((a|alpha|b|beta|c|rc|pre|preview)(\d+)?)?(\.(post|r|rev)(\d+)?)?([._-]?(dev)(\d+)?)?(\+([a-zA-Z\d]+(\.[a-zA-Z\d]+)?))?$c                 C   s  |   } t| }|s"td|  | }tdd |d dD }t|dkrl|d dkrl|d d }qF|d szd}nt|d d d }|dd	 }|d
d }|dd }|d }|dkrd}n.|d d kr|d df}n|d t|d f}|dkrd}n0|d d kr"|d df}n|d t|d f}|dkrFd}n0|d d krb|d df}n|d t|d f}|d krd}nHg }	|dD ]0}
|
	 rdt|
f}
nd|
f}
|	
|
 qt|	}|s|s|rd}nd}|sd}|sd}||||||fS )NzNot a valid version: %sc                 s   s   | ]}t |V  qd S r)   int.0r?   r   r   r   	<genexpr>   s     z_pep_440_key.<locals>.<genexpr>r   .r            	   
         )NNr   )ari   )z)_)final)r   PEP440_VERSION_REr`   r   groupsr   splitr   rd   isdigitrT   )r   mrv   numsepochprepostdevlocalr   partr   r   r   _pep_440_key   s`    




r   c                   @   s6   e Zd ZdZdd ZedddddgZed	d
 ZdS )r   aI  A rational version.

    Good:
        1.2         # equivalent to "1.2.0"
        1.2.0
        1.2a1
        1.2.3a2
        1.2.3b1
        1.2.3c1
        1.2.3.4
        TODO: fill this out

    Bad:
        1           # minimum two numbers
        1.2a        # release level must have a release serial
        1.2.3b
    c                 C   s<   t |}t|}| }tdd |d dD | _|S )Nc                 s   s   | ]}t |V  qd S r)   rc   re   r   r   r   rg     s     z*NormalizedVersion.parse.<locals>.<genexpr>r   rh   )_normalized_keyru   r`   rv   r   rw   _release_clause)r   r   ra   ry   rv   r   r   r   r     s
    
zNormalizedVersion.parserq   br@   rcr~   c                    s   t  fdd jD S )Nc                 3   s    | ]}|r|d   j kV  qdS )r   N)PREREL_TAGS)rf   tr4   r   r   rg   !  s      z2NormalizedVersion.is_prerelease.<locals>.<genexpr>)anyr   r4   r   r4   r   r;     s    zNormalizedVersion.is_prereleaseN)	r   r   r   r   r   setr   r<   r;   r   r   r   r   r      s
   c                 C   s>   t | } t |}| |krdS | |s*dS t|}| | dkS )NTFrh   )str
startswithr   )xynr   r   r   _match_prefix$  s    
r   c                	   @   sn   e Zd ZeZddddddddd	Zd
d Zdd Zdd Zdd Z	dd Z
dd Zdd Zdd Zdd ZdS )r   _match_compatible	_match_lt	_match_gt	_match_le	_match_ge	_match_eq_match_arbitrary	_match_ne)rJ   rD   rE   rF   rG   rH   rI   rK   c                 C   sV   |rd|ko|j d }n|j d  o,|j d }|rN|jddd }| |}||fS )N+ri   r   r   )r   r   rw   rM   )r   r[   r]   rW   Zstrip_localr   r   r   r   _adjust_local>  s    
zNormalizedMatcher._adjust_localc                 C   sD   |  |||\}}||krdS |j}ddd |D }t|| S )NFrh   c                 S   s   g | ]}t |qS r   r   rf   ir   r   r   
<listcomp>Q  s     z/NormalizedMatcher._match_lt.<locals>.<listcomp>r   r   joinr   r   r[   r]   rW   Zrelease_clausepfxr   r   r   r   L  s    zNormalizedMatcher._match_ltc                 C   sD   |  |||\}}||krdS |j}ddd |D }t|| S )NFrh   c                 S   s   g | ]}t |qS r   r   r   r   r   r   r   Y  s     z/NormalizedMatcher._match_gt.<locals>.<listcomp>r   r   r   r   r   r   T  s    zNormalizedMatcher._match_gtc                 C   s   |  |||\}}||kS r)   r   r   r[   r]   rW   r   r   r   r   \  s    zNormalizedMatcher._match_lec                 C   s   |  |||\}}||kS r)   r   r   r   r   r   r   `  s    zNormalizedMatcher._match_gec                 C   s.   |  |||\}}|s ||k}n
t||}|S r)   r   r   r   r[   r]   rW   ra   r   r   r   r   d  s
    

zNormalizedMatcher._match_eqc                 C   s   t |t |kS r)   r   r   r   r   r   r   l  s    z"NormalizedMatcher._match_arbitraryc                 C   s0   |  |||\}}|s ||k}nt|| }|S r)   r   r   r   r   r   r   o  s
    
zNormalizedMatcher._match_nec                 C   sf   |  |||\}}||krdS ||k r*dS |j}t|dkrH|d d }ddd |D }t||S )NTFr   ri   rh   c                 S   s   g | ]}t |qS r   r   r   r   r   r   r     s     z7NormalizedMatcher._match_compatible.<locals>.<listcomp>)r   r   r   r   r   r   r   r   r   r   w  s    z#NormalizedMatcher._match_compatibleN)r   r   r   r   rM   rX   r   r   r   r   r   r   r   r   r   r   r   r   r   r   /  s&   z[.+-]$ z^[.](\d)z0.\1z^[.-]z
^\((.*)\)$\1z^v(ersion)?\s*(\d+)z\2z^r(ev)?\s*(\d+)z[.]{2,}rh   z\b(alfa|apha)\balphaz\b(pre-alpha|prealpha)\bz	pre.alphaz	\(beta\)$betaz
^[:~._+-]+z
[,*")([\]]z[~:+_ -]z\.$z(\d+(\.\d+)*)c                 C   sL  |    }tD ]\}}|||}q|s.d}t|}|sFd}|}n| d d}dd |D }t|dk r~|	d qft|dkr||
 d }n8ddd |dd D ||
 d  }|dd }dd	d |D }|  }|rtD ]\}}|||}q|s|}nd
|kr*dnd}|| | }t|sHd}|S )z
    Try to suggest a semantic form for a version for which
    _suggest_normalized_version couldn't come up with anything.
    z0.0.0r   rh   c                 S   s   g | ]}t |qS r   rc   r   r   r   r   r     s     z-_suggest_semantic_version.<locals>.<listcomp>   Nc                 S   s   g | ]}t |qS r   r   r   r   r   r   r     s     c                 S   s   g | ]}t |qS r   r   r   r   r   r   r     s     r~   -r   )r   rP   _REPLACEMENTSsub_NUMERIC_PREFIXr`   rv   rw   r   rT   endr   _SUFFIX_REPLACEMENTS	is_semver)r   ra   patreplry   rW   suffixsepr   r   r   _suggest_semantic_version  s:    
,
r   c                 C   sh  zt |  | W S  tk
r"   Y nX |  }dD ]\}}|||}q0tdd|}tdd|}tdd|}tdd	|}td
d|}|dr|dd }tdd|}tdd|}tdd|}tdd|}tdd|}tdd|}tdd|}tdd|}tdd|}tdd|}tdd |}zt | W n tk
rb   d}Y nX |S )!a  Suggest a normalized version close to the given version string.

    If you have a version string that isn't rational (i.e. NormalizedVersion
    doesn't like it) then you might be able to get an equivalent (or close)
    rational version from this function.

    This does a number of simple normalizations to the given string, based
    on observation of versions currently in use on PyPI. Given a dump of
    those version during PyCon 2009, 4287 of them:
    - 2312 (53.93%) match NormalizedVersion without change
      with the automatic suggestion
    - 3474 (81.04%) match when using this suggestion method

    @param s {str} An irrational version string.
    @returns A rational version string, or None, if couldn't determine one.
    ))z-alpharq   )z-betar   )r   rq   )r   r   )r   r@   )z-finalr   )z-prer@   )z-releaser   )z.releaser   )z-stabler   )r   rh   )rs   rh   ) r   )z.finalr   )rt   r   zpre$Zpre0zdev$Zdev0z([abc]|rc)[\-\.](\d+)$z\1\2z[\-\.](dev)[\-\.]?r?(\d+)$z.\1\2z[.~]?([abc])\.?r   r?   r   Nz\b0+(\d+)(?!\d)z(\d+[abc])$z\g<1>0z\.?(dev-r|dev\.r)\.?(\d+)$z.dev\2z-(a|b|c)(\d+)$z[\.\-](dev|devel)$z.dev0z(?![\.\-])dev$z(final|stable)$r   z\.?(r|-|-r)\.?(\d+)$z.post\2z\.?(dev|git|bzr)\.?(\d+)$z\.?(pre|preview|-c)(\d+)$zc\g<2>zp(\d+)$z.post\1)r   r   rP   replacerer   r   )r   rsorigr   r   r   r   _suggest_normalized_version  s>    
	
r   z([a-z]+|\d+|[\.-])r@   zfinal-@)r|   previewr   r   r~   r   rh   c                 C   sr   dd }g }|| D ]T}| dr^|dk rD|rD|d dkrD|  q*|r^|d dkr^|  qD|| qt|S )Nc                 S   st   g }t |  D ]R}t||}|rd|d d   krBdkrRn n|d}nd| }|| q|d |S )N0r   9   **final)_VERSION_PARTrw   rP   _VERSION_REPLACErY   zfillrT   )r   ra   rA   r   r   r   	get_partsM  s     
z_legacy_key.<locals>.get_partsr   r   ri   z*final-00000000)r   poprT   r   )r   r   ra   rA   r   r   r   _legacy_keyL  s    


r   c                   @   s    e Zd Zdd Zedd ZdS )r   c                 C   s   t |S r)   )r   r#   r   r   r   r   g  s    zLegacyVersion.parsec                 C   s8   d}| j D ](}t|tr
|dr
|dk r
d} q4q
|S )NFr   r   T)r   r   r   r   )r   ra   r   r   r   r   r;   j  s    
zLegacyVersion.is_prereleaseNr   r   r   r   r<   r;   r   r   r   r   r   f  s   c                   @   s4   e Zd ZeZeejZded< e	dZ
dd ZdS )r	   r   rJ   z^(\d+(\.\d+)*)c                 C   s`   ||k rdS | j t|}|s2td|| dS | d }d|krV|ddd }t||S )NFzACannot compute compatible match for version %s  and constraint %sTr   rh   r   )
numeric_rer`   r   loggerwarningrv   rsplitr   )r   r[   r]   rW   ry   r   r   r   r   r   }  s     zLegacyMatcher._match_compatibleN)r   r   r   r   rM   dictr=   rX   r   compiler   r   r   r   r   r   r	   u  s
   

zN^(\d+)\.(\d+)\.(\d+)(-[a-z0-9]+(\.[a-z0-9-]+)*)?(\+[a-z0-9]+(\.[a-z0-9-]+)*)?$c                 C   s
   t | S r)   )
_SEMVER_REr`   )r   r   r   r   r     s    r   c           	      C   sn   dd }t | }|st| | }dd |d d D \}}}||d d||d d }}|||f||fS )	Nc                 S   s8   | d kr|f}n$| dd   d}tdd |D }|S )Nr   rh   c                 S   s"   g | ]}|  r|d n|qS )r   )rx   r   )rf   rA   r   r   r   r     s     z5_semantic_key.<locals>.make_tuple.<locals>.<listcomp>)rw   r   )r   Zabsentra   r   r   r   r   
make_tuple  s
    z!_semantic_key.<locals>.make_tuplec                 S   s   g | ]}t |qS r   rc   r   r   r   r   r     s     z!_semantic_key.<locals>.<listcomp>r   |   r   )r   r   rv   )	r   r   ry   rv   majorminorpatchr|   buildr   r   r   _semantic_key  s    
r   c                   @   s    e Zd Zdd Zedd ZdS )r
   c                 C   s   t |S r)   )r   r#   r   r   r   r     s    zSemanticVersion.parsec                 C   s   | j d d dkS )Nr   r   r   )r   r4   r   r   r   r;     s    zSemanticVersion.is_prereleaseNr   r   r   r   r   r
     s   c                   @   s   e Zd ZeZdS )r   N)r   r   r   r
   rM   r   r   r   r   r     s   c                   @   s6   e Zd ZdddZdd Zdd Zdd	 Zd
d ZdS )VersionSchemeNc                 C   s   || _ || _|| _d S r)   )rQ   matcher	suggester)r   rQ   r   r   r   r   r   r      s    zVersionScheme.__init__c                 C   s2   z| j | d}W n tk
r,   d}Y nX |S NTF)r   rM   r   r   r   ra   r   r   r   is_valid_version  s    
zVersionScheme.is_valid_versionc                 C   s0   z|  | d}W n tk
r*   d}Y nX |S r   )r   r   r   r   r   r   is_valid_matcher  s    

zVersionScheme.is_valid_matcherc                 C   s$   | dr|dd }| d| S )z:
        Used for processing some metadata fields
        ,Nri   zdummy_name (%s))rS   r   r#   r   r   r   is_valid_constraint_list  s    
z&VersionScheme.is_valid_constraint_listc                 C   s   | j d krd }n
|  |}|S r)   )r   r   r   r   r   suggest  s    

zVersionScheme.suggest)N)r   r   r   r    r   r   r   r   r   r   r   r   r     s
   
	r   c                 C   s   |S r)   r   r#   r   r   r   rB     rC   rB   )
normalizedlegacyZsemanticr   defaultc                 C   s   | t krtd|  t |  S )Nzunknown scheme name: %r)_SCHEMESrN   )rO   r   r   r   r     s    )*r   loggingr   compatr   utilr   __all__	getLoggerr   r   rN   r   objectr   r=   r   Iru   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r	   r   r   r   r
   r   r   r   r   r   r   r   r   <module>   s      
1dE$X
.s	(