o
    LK&h                     @  s   d Z ddlmZ ddlZddlZddlmZmZ ddl	m
Z
mZ ddlmZ ddlmZ dd	lmZ ed
ddZedddZdd Zd%ddZefd&ddZ	d'd(d"d#Zejeed$ZdS ))z2Timestamp comparison of files and groups of files.    )annotationsN)CallableIterable)LiteralTypeVar)splat   )
zip_strict)DistutilsFileError	_SourcesT3str | bytes | os.PathLike[str] | os.PathLike[bytes])bound	_TargetsTc                 C  s&   t j| pt j| t j|kS N)ospathexistsgetmtimesourcetarget r   R/var/www/html/venv/lib/python3.10/site-packages/setuptools/_distutils/_modified.py_newer   s   r   r   r   returnboolc                 C  s.   t j| stdt j| dt| |S )z
    Is source modified more recently than target.

    Returns True if 'source' is modified more recently than
    'target' or if 'target' does not exist.

    Raises DistutilsFileError if 'source' does not exist.
    zfile z does not exist)r   r   r   r
   abspathr   r   r   r   r   newer   s   
r   sourcesIterable[_SourcesT]targetsIterable[_TargetsT]&Callable[[_SourcesT, _TargetsT], bool]'tuple[list[_SourcesT], list[_TargetsT]]c                 C  s.   t t|t| |}tttt| pg g fS )a1  
    Filter filenames where sources are newer than targets.

    Walk two filename iterables in parallel, testing if each source is newer
    than its corresponding target.  Returns a pair of lists (sources,
    targets) where source is newer than target, according to the semantics
    of 'newer()'.
    )filterr   r	   tuplemaplistzip)r   r    r   newer_pairsr   r   r   newer_pairwise/   s   r*   error=Iterable[str | bytes | os.PathLike[str] | os.PathLike[bytes]]missing#Literal['error', 'ignore', 'newer']c                   sL    fdd dkrt jjnd}t j p%tfddt|| D S )a  
    Is target out-of-date with respect to any file in sources.

    Return True if 'target' is out-of-date with respect to any file
    listed in 'sources'. In other words, if 'target' exists and is newer
    than every file in 'sources', return False; otherwise return True.
    ``missing`` controls how to handle a missing source file:

    - error (default): allow the ``stat()`` call to fail.
    - ignore: silently disregard any missing source files.
    - newer: treat missing source files as "target out of date". This
      mode is handy in "dry-run" mode: it will pretend to carry out
      commands that wouldn't work because inputs are missing, but
      that doesn't matter because dry-run won't run the commands.
    c                   s    dko
t j|  S )Nr   )r   r   r   )r   )r-   r   r   missing_as_newerU   s   z%newer_group.<locals>.missing_as_newerignoreNc                 3  s"    | ]} |pt |V  qd S r   )r   ).0r   )r/   r   r   r   	<genexpr>Y   s
    
znewer_group.<locals>.<genexpr>)r   r   r   anyr$   )r   r   r-   ignoredr   )r-   r/   r   r   newer_group@   s
   r5   )r   )r   r   r   r   r   r   )r   r   r    r!   r   r"   r   r#   )r+   )r   r,   r   r   r-   r.   r   r   )__doc__
__future__r   	functoolsos.pathr   collections.abcr   r   typingr   r   jaraco.functoolsr   compat.py39r	   errorsr
   r   r   r   r   r*   r5   partialnewer_pairwise_groupr   r   r   r   <module>   s,    
