
    ,h}
                        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mZ d dl	m
Z
 erd dlmZ eeej                  e   f   Zded<    edeeej                  e   f   	      Zd
 ZddZddZej*                  d        Zy)    )annotationsN)TYPE_CHECKINGTypeVarUnion)unique_everseen)	TypeAliasr   StrPathStrPathT)boundc                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     R/var/www/html/Resume-Scraper/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_pythonpathr4   1   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	   r5   str)
__future__r   
contextlibr   r   typingr   r   r   more_itertoolsr   typing_extensionsr   r7   PathLiker	   __annotations__r
   r   r   r   contextmanagerr4    r   r   <module>rA      s    "  	 
 0 0 *+3C 001 1:U3C0@+@%AB((&F "7 "7r   