o
    j{                     @  s   d Z ddlmZ ddlZddlZddlZddlZddlZddlZddl	m
Z
mZ ddlmZmZmZ ddlmZ ddlmZ dd	lmZ erLdd
lmZ ede
dZdd Zd,ddZed-ddZed.ddZd/ddZ			d0d1d$d%Zd2d3d*d+ZdS )4zdistutils.spawn

Provides the 'spawn()' function, a front-end to various platform-
specific functions for launching another program in a sub-process.
    )annotationsN)MappingMutableSequence)TYPE_CHECKINGTypeVaroverload   )logDEBUG)DistutilsExecError)_ENV	_MappingT)boundc                 C  s   t r| S | d S )zE
    Render a subprocess command differently depending on DEBUG.
    r   r
   )cmd r   \/var/www/html/Deteccion_Ine/venv/lib/python3.10/site-packages/setuptools/_distutils/spawn.py_debug   s   r   env_MappingT | Nonereturn'_MappingT | dict[str, str | int] | Nonec                 C  sF   t  dkr| S ddlm}m} | }|r||ini }i t| |S )NDarwinr   )MACOSX_VERSION_VARget_macosx_target_ver)platformsystemutilr   r   _resolve)r   r   r   Z
target_verupdater   r   r   _inject_macos_ver$   s   r    Noneos._Environ[str]c                 C     d S Nr   r   r   r   r   r   /      r   c                 C  r#   r$   r   r%   r   r   r   r   1   r&   _MappingT | os._Environ[str]c                 C  s   | d u rt jS | S r$   )osenvironr%   r   r   r   r   3   s   TFr   /MutableSequence[bytes | str | os.PathLike[str]]search_pathboolverbose_ENV | Nonec              
   C  s   t t|  |rt| d }|dur|| d< ztj| t|d W dS  tyA } zt	dt
| d|jd  |d}~w tjy[ } zt	dt
| d|j |d}~ww )aN  Run another program, specified as a command list 'cmd', in a new process.

    'cmd' is just the argument list for the new process, ie.
    cmd[0] is the program to run and cmd[1:] are the rest of its arguments.
    There is no way to run a program with a name different from that of its
    executable.

    If 'search_path' is true (the default), the system's executable
    search path will be used to find the program; otherwise, cmd[0]
    must be the exact path to the executable.

    Raise DistutilsExecError if running the program fails in any way; just
    return on success.
    r   Nr%   zcommand z	 failed: z failed with exit code )r	   info
subprocesslist2cmdlineshutilwhich
check_callr    OSErrorr   r   argsCalledProcessError
returncode)r   r+   r-   r   
executableexcerrr   r   r   spawn7   s,   r=   r:   strpath
str | Nonec              	   C  s   t jdtdd tj| \}}tjdkr|dkr| d } tj| r%| S |du rJtj	
dd}|du rJztd}W n ttfyI   tj}Y nw |sNdS |tj}|D ]}tj|| }tj|ri|  S qVdS )	zTries to find 'executable' in the directories listed in 'path'.

    A string listing directories separated by 'os.pathsep'; defaults to
    os.environ['PATH'].  Returns the complete filename or None if not found.
    z+Use shutil.which instead of find_executable   )
stacklevelwin32z.exeNPATHCS_PATH)warningswarnDeprecationWarningr(   r?   splitextsysr   isfiler)   getconfstrAttributeError
ValueErrordefpathsplitpathsepjoin)r:   r?   _extpathspfr   r   r   find_executable^   s2   
rY   )r   r   r   r   )r   r!   r   r"   )r   r   r   r   )r   r   r   r'   )TFN)
r   r*   r+   r,   r-   r,   r   r.   r   r!   r$   )r:   r>   r?   r@   r   r@   )__doc__
__future__r   r(   r   r3   r1   rJ   rF   collections.abcr   r   typingr   r   r   _logr	   debugr   errorsr   r   r   r   r    r   r=   rY   r   r   r   r   <module>   s8    

'