#
# filelist.py: method for determining which files to check
#
# Copyright (C) 2014 Red Hat, Inc.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published
# by the Free Software Foundation; either version 2.1 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with this program. If not, see .
#
# Author: David Shea
import os
import subprocess
def testfilelist(filterfunc=None):
"""A generator function for the list of file names to check.
If the check is run from a git work tree, the method returns a list
of files known to git. Otherwise, it returns a list of every file
beneath $top_srcdir.
top_srcdir must be set in the environment.
filterfunc, if provided, is a function that takes a filename as an
argument and returns True for files that should be included in the
file list. For example, something like lambda x: fnmatch(x, '*.py')
could be used to match only filenames that end in .py.
"""
if os.path.isdir(os.path.join(os.environ["top_srcdir"], ".git")):
output = subprocess.check_output(["git", "ls-files", "-c", os.environ["top_srcdir"]]).decode("utf-8")
filelist = output.split("\n")
else:
filelist = (os.path.join(path, testfile) \
for path, _dirs, files in os.walk(os.environ["top_srcdir"]) \
for testfile in files)
for f in filelist:
if not filterfunc or filterfunc(f):
yield f