
    |g
                       U d dl mZ d dlZd dlZd dlZd dlmZmZ erd dlm	Z	 d dl
mZ ej                  dk\  reeej                  e   f   Zded<   neeej                  f   Zded<   d	 Zdd
ZddZej(                  d        Zy)    )annotationsN)TYPE_CHECKINGUnion)	TypeAlias)unique_everseen)   	   r   StrPathc                p    t         j                  j                  |       }t        j                  |d       y)z1Ensure that the parent directory of `path` existsT)exist_okN)ospathdirnamemakedirs)r   r   s     M/var/www/html/pythonbot/venv/lib/python3.12/site-packages/setuptools/_path.pyensure_directoryr      s"    ggood#GKK$'    c                0    t        |       t        |      k(  S )a  Differs from os.path.samefile because it does not require paths to exist.
    Purely string based (no comparison between i-nodes).
    >>> same_path("a/b", "./a/b")
    True
    >>> same_path("a/b", "a/./b")
    True
    >>> same_path("a/b", "././a/b")
    True
    >>> same_path("a/b", "./a/b/c/..")
    True
    >>> same_path("a/b", "../a/b/c")
    False
    >>> same_path("a", "a/b")
    False
    )normpath)p1p2s     r   	same_pathr      s      B<8B<''r   c                   t         j                  dk(  rt        j                  j	                  |       n| }t        j                  j                  t        j                  j                  t        j                  j                  |                  S )z2Normalize a file/dir name for comparison purposes.cygwin)sysplatformr   r   abspathnormcaserealpathr   )filenamefiles     r   r   r   -   sV     ),(@277??8$hD77BGG,,RWW-=-=d-CDEEr   c              #  h  K   t               }t        j                  j                  d|      }t        j                  j                  dd      }	 t        j                  j                  t        |             }t        d||g      }t        j                  j                  |      }|r|t        j                  d<   d ||u r!t        j                  j                  dd       y|t        j                  d<   y# ||u r!t        j                  j                  dd       w |t        j                  d<   w xY ww)a  
    Add the indicated paths to the head of the PYTHONPATH environment
    variable so that subprocesses will also see the packages at
    these paths.

    Do this in a context that restores the value on exit.

    >>> getfixture('monkeypatch').setenv('PYTHONPATH', 'anything')
    >>> with paths_on_pythonpath(['foo', 'bar']):
    ...     assert 'foo' in os.environ['PYTHONPATH']
    ...     assert 'anything' in os.environ['PYTHONPATH']
    >>> os.environ['PYTHONPATH']
    'anything'

    >>> getfixture('monkeypatch').delenv('PYTHONPATH')
    >>> with paths_on_pythonpath(['foo', 'bar']):
    ...     assert 'foo' in os.environ['PYTHONPATH']
    >>> os.environ.get('PYTHONPATH')
    
PYTHONPATH N)	objectr   environgetpathsepjoinr   filterpop)pathsnothingorig_pythonpathcurrent_pythonpathprefixto_joinnew_paths          r   paths_on_pythonpathr3   4   s     * hGjjnn\7;Ob97!78(:;<::??7+'/BJJ|$g%JJNN<.'6BJJ|$ g%JJNN<.'6BJJ|$s   AD2A.C5 <9D25:D//D2)r   r
   r   r
   returnbool)r    r
   r4   str)
__future__r   
contextlibr   r   typingr   r   typing_extensionsr   more_itertoolsr   version_infor6   PathLiker
   __annotations__r   r   r   contextmanagerr3    r   r   <module>rA      s    "  	 
 '+ +vsBKK$445GY5sBKK/0GY0((&F "7 "7r   