Commit 9a577c98 authored by Jason R. Coombs's avatar Jason R. Coombs

Issue #12285: Replace implementation of findall with implementation from Setuptools 7ce820d524db.

parent c073f121
...@@ -6,6 +6,7 @@ and building lists of files. ...@@ -6,6 +6,7 @@ and building lists of files.
import os, re import os, re
import fnmatch import fnmatch
import functools
from distutils.util import convert_path from distutils.util import convert_path
from distutils.errors import DistutilsTemplateError, DistutilsInternalError from distutils.errors import DistutilsTemplateError, DistutilsInternalError
from distutils import log from distutils import log
...@@ -242,35 +243,28 @@ class FileList: ...@@ -242,35 +243,28 @@ class FileList:
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
# Utility functions # Utility functions
def _find_all_simple(path):
"""
Find all files under 'path'
"""
results = (
os.path.join(base, file)
for base, dirs, files in os.walk(path, followlinks=True)
for file in files
)
return filter(os.path.isfile, results)
def findall(dir=os.curdir): def findall(dir=os.curdir):
"""Find all files under 'dir' and return the list of full filenames
(relative to 'dir').
""" """
from stat import ST_MODE, S_ISREG, S_ISDIR, S_ISLNK Find all files under 'dir' and return the list of full filenames.
Unless dir is '.', return full filenames with dir prepended.
list = [] """
stack = [dir] files = _find_all_simple(dir)
pop = stack.pop if dir == os.curdir:
push = stack.append make_rel = functools.partial(os.path.relpath, start=dir)
files = map(make_rel, files)
while stack: return list(files)
dir = pop()
names = os.listdir(dir)
for name in names:
if dir != os.curdir: # avoid the dreaded "./" syndrome
fullname = os.path.join(dir, name)
else:
fullname = name
# Avoid excess stat calls -- just one will do, thank you!
stat = os.stat(fullname)
mode = stat[ST_MODE]
if S_ISREG(mode):
list.append(fullname)
elif S_ISDIR(mode) and not S_ISLNK(mode):
push(fullname)
return list
def glob_to_re(pattern): def glob_to_re(pattern):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment