-
-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #4103 from pypa/feature/distutils-sync
Sync latest distutils
- Loading branch information
Showing
21 changed files
with
273 additions
and
176 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
Merged with pypa/distutils@7a04cbda0fc714. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,72 @@ | ||
"""Timestamp comparison of files and groups of files.""" | ||
|
||
import functools | ||
import os.path | ||
|
||
from .errors import DistutilsFileError | ||
from .py39compat import zip_strict | ||
from ._functools import splat | ||
|
||
|
||
def _newer(source, target): | ||
return not os.path.exists(target) or ( | ||
os.path.getmtime(source) > os.path.getmtime(target) | ||
) | ||
|
||
|
||
def newer(source, target): | ||
""" | ||
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. | ||
""" | ||
if not os.path.exists(source): | ||
raise DistutilsFileError("file '%s' does not exist" % os.path.abspath(source)) | ||
|
||
return _newer(source, target) | ||
|
||
|
||
def newer_pairwise(sources, targets, newer=newer): | ||
""" | ||
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()'. | ||
""" | ||
newer_pairs = filter(splat(newer), zip_strict(sources, targets)) | ||
return tuple(map(list, zip(*newer_pairs))) or ([], []) | ||
|
||
|
||
def newer_group(sources, target, missing='error'): | ||
""" | ||
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. | ||
""" | ||
|
||
def missing_as_newer(source): | ||
return missing == 'newer' and not os.path.exists(source) | ||
|
||
ignored = os.path.exists if missing == 'ignore' else None | ||
return any( | ||
missing_as_newer(source) or _newer(source, target) | ||
for source in filter(ignored, sources) | ||
) | ||
|
||
|
||
newer_pairwise_group = functools.partial(newer_pairwise, newer=newer_group) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,96 +1,14 @@ | ||
"""distutils.dep_util | ||
import warnings | ||
|
||
Utility functions for simple, timestamp-based dependency of files | ||
and groups of files; also, function based entirely on such | ||
timestamp dependency analysis.""" | ||
from . import _modified | ||
|
||
import os | ||
from .errors import DistutilsFileError | ||
|
||
|
||
def newer(source, target): | ||
"""Return true if 'source' exists and is more recently modified than | ||
'target', or if 'source' exists and 'target' doesn't. Return false if | ||
both exist and 'target' is the same age or younger than 'source'. | ||
Raise DistutilsFileError if 'source' does not exist. | ||
""" | ||
if not os.path.exists(source): | ||
raise DistutilsFileError("file '%s' does not exist" % os.path.abspath(source)) | ||
if not os.path.exists(target): | ||
return 1 | ||
|
||
from stat import ST_MTIME | ||
|
||
mtime1 = os.stat(source)[ST_MTIME] | ||
mtime2 = os.stat(target)[ST_MTIME] | ||
|
||
return mtime1 > mtime2 | ||
|
||
|
||
# newer () | ||
|
||
|
||
def newer_pairwise(sources, targets): | ||
"""Walk two filename lists in parallel, testing if each source is newer | ||
than its corresponding target. Return a pair of lists (sources, | ||
targets) where source is newer than target, according to the semantics | ||
of 'newer()'. | ||
""" | ||
if len(sources) != len(targets): | ||
raise ValueError("'sources' and 'targets' must be same length") | ||
|
||
# build a pair of lists (sources, targets) where source is newer | ||
n_sources = [] | ||
n_targets = [] | ||
for i in range(len(sources)): | ||
if newer(sources[i], targets[i]): | ||
n_sources.append(sources[i]) | ||
n_targets.append(targets[i]) | ||
|
||
return (n_sources, n_targets) | ||
|
||
|
||
# newer_pairwise () | ||
|
||
|
||
def newer_group(sources, target, missing='error'): | ||
"""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 what we do when a source file is missing; the | ||
default ("error") is to blow up with an OSError from inside 'stat()'; | ||
if it is "ignore", we silently drop any missing source files; if it is | ||
"newer", any missing source files make us assume that 'target' is | ||
out-of-date (this is handy in "dry-run" mode: it'll make you pretend to | ||
carry out commands that wouldn't work because inputs are missing, but | ||
that doesn't matter because you're not actually going to run the | ||
commands). | ||
""" | ||
# If the target doesn't even exist, then it's definitely out-of-date. | ||
if not os.path.exists(target): | ||
return 1 | ||
|
||
# Otherwise we have to find out the hard way: if *any* source file | ||
# is more recent than 'target', then 'target' is out-of-date and | ||
# we can immediately return true. If we fall through to the end | ||
# of the loop, then 'target' is up-to-date and we return false. | ||
from stat import ST_MTIME | ||
|
||
target_mtime = os.stat(target)[ST_MTIME] | ||
for source in sources: | ||
if not os.path.exists(source): | ||
if missing == 'error': # blow up when we stat() the file | ||
pass | ||
elif missing == 'ignore': # missing source dropped from | ||
continue # target's dependency list | ||
elif missing == 'newer': # missing source means target is | ||
return 1 # out-of-date | ||
|
||
source_mtime = os.stat(source)[ST_MTIME] | ||
if source_mtime > target_mtime: | ||
return 1 | ||
else: | ||
return 0 | ||
|
||
|
||
# newer_group () | ||
def __getattr__(name): | ||
if name not in ['newer', 'newer_group', 'newer_pairwise']: | ||
raise AttributeError(name) | ||
warnings.warn( | ||
"dep_util is Deprecated. Use functions from setuptools instead.", | ||
DeprecationWarning, | ||
stacklevel=2, | ||
) | ||
return getattr(_modified, name) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.