2018-06-07 15:50:31 +02:00
|
|
|
#!/usr/bin/env python3
|
2019-04-06 15:08:09 +02:00
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
2018-06-07 15:50:31 +02:00
|
|
|
|
2020-07-01 15:11:08 +02:00
|
|
|
"""Write subfolder list to a file
|
2018-06-07 15:50:31 +02:00
|
|
|
|
2020-07-01 15:11:08 +02:00
|
|
|
This script will walk the specified directory and write the file specified with
|
|
|
|
the list of all sub-directories found. If the output file already exists, the
|
|
|
|
file will only be updated in case sub-directories have been added or removed
|
|
|
|
since the previous invocation.
|
2020-04-22 08:06:07 +02:00
|
|
|
|
2020-07-01 15:11:08 +02:00
|
|
|
"""
|
2018-06-07 15:50:31 +02:00
|
|
|
|
2020-07-01 15:11:08 +02:00
|
|
|
import os
|
|
|
|
import argparse
|
2018-06-07 15:50:31 +02:00
|
|
|
|
|
|
|
|
2020-07-01 15:11:08 +02:00
|
|
|
def parse_args():
|
|
|
|
"""Parse command line arguments and options"""
|
2018-06-07 15:50:31 +02:00
|
|
|
parser = argparse.ArgumentParser(
|
2020-07-01 15:11:08 +02:00
|
|
|
description=__doc__,
|
2023-01-04 17:08:36 +01:00
|
|
|
formatter_class=argparse.RawDescriptionHelpFormatter,
|
|
|
|
allow_abbrev=False)
|
2018-06-07 15:50:31 +02:00
|
|
|
|
|
|
|
parser.add_argument('-d', '--directory', required=True,
|
|
|
|
help='Directory to walk for sub-directory discovery')
|
2018-06-14 22:27:17 +02:00
|
|
|
parser.add_argument('-c', '--create-links', required=False,
|
2020-04-22 08:06:07 +02:00
|
|
|
help='Create links for each directory found in \
|
|
|
|
directory given')
|
2018-06-07 15:50:31 +02:00
|
|
|
parser.add_argument('-o', '--out-file', required=True,
|
2020-04-22 08:06:07 +02:00
|
|
|
help='File to write containing a list of all \
|
|
|
|
directories found')
|
2018-06-07 15:50:31 +02:00
|
|
|
parser.add_argument('-t', '--trigger-file', required=False,
|
|
|
|
help='Trigger file to be be touched to re-run CMake')
|
|
|
|
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
2020-07-01 15:11:08 +02:00
|
|
|
return args
|
|
|
|
|
|
|
|
|
|
|
|
def get_subfolder_list(directory, create_links=None):
|
|
|
|
"""Return subfolder list of a directory"""
|
2018-06-07 15:50:31 +02:00
|
|
|
dirlist = []
|
2020-07-01 15:11:08 +02:00
|
|
|
|
|
|
|
if create_links is not None:
|
|
|
|
if not os.path.exists(create_links):
|
|
|
|
os.makedirs(create_links)
|
2020-04-22 08:06:07 +02:00
|
|
|
symbase = os.path.basename(directory)
|
2020-07-01 15:11:08 +02:00
|
|
|
symlink = create_links + os.path.sep + symbase
|
2018-06-14 22:27:17 +02:00
|
|
|
if not os.path.exists(symlink):
|
|
|
|
os.symlink(directory, symlink)
|
2020-07-01 15:11:08 +02:00
|
|
|
dirlist.append(symlink)
|
2018-06-14 22:27:17 +02:00
|
|
|
else:
|
2020-07-01 15:11:08 +02:00
|
|
|
dirlist.append(directory)
|
|
|
|
|
|
|
|
for root, dirs, _ in os.walk(directory, topdown=True):
|
2019-02-16 03:56:57 +01:00
|
|
|
dirs.sort()
|
2018-06-07 15:50:31 +02:00
|
|
|
for subdir in dirs:
|
2020-07-01 15:11:08 +02:00
|
|
|
if create_links is not None:
|
2020-04-22 08:06:07 +02:00
|
|
|
targetdirectory = os.path.join(root, subdir)
|
|
|
|
reldir = os.path.relpath(targetdirectory, directory)
|
|
|
|
linkname = symbase + '_' + reldir.replace(os.path.sep, '_')
|
2020-07-01 15:11:08 +02:00
|
|
|
symlink = create_links + os.path.sep + linkname
|
2018-06-14 22:27:17 +02:00
|
|
|
if not os.path.exists(symlink):
|
2020-04-22 08:06:07 +02:00
|
|
|
os.symlink(targetdirectory, symlink)
|
2020-07-01 15:11:08 +02:00
|
|
|
dirlist.append(symlink)
|
2018-06-14 22:27:17 +02:00
|
|
|
else:
|
2020-07-01 15:11:08 +02:00
|
|
|
dirlist.append(os.path.join(root, subdir))
|
|
|
|
|
|
|
|
return dirlist
|
|
|
|
|
2018-06-07 15:50:31 +02:00
|
|
|
|
2020-07-01 15:11:08 +02:00
|
|
|
def gen_out_file(out_file, dirs):
|
|
|
|
"""Generate file with the list of directories
|
2018-06-07 15:50:31 +02:00
|
|
|
|
2020-07-01 15:11:08 +02:00
|
|
|
File won't be updated if it already exists and has the same content
|
2018-06-07 15:50:31 +02:00
|
|
|
|
2020-07-01 15:11:08 +02:00
|
|
|
"""
|
|
|
|
dirs_nl = "\n".join(dirs) + "\n"
|
|
|
|
|
|
|
|
if os.path.exists(out_file):
|
|
|
|
with open(out_file, 'r', encoding="utf-8") as out_file_fo:
|
|
|
|
out_file_dirs = out_file_fo.read()
|
|
|
|
|
|
|
|
if out_file_dirs == dirs_nl:
|
|
|
|
return
|
|
|
|
|
|
|
|
with open(out_file, 'w', encoding="utf-8") as out_file_fo:
|
|
|
|
out_file_fo.writelines(dirs_nl)
|
|
|
|
|
|
|
|
|
|
|
|
def touch(trigger):
|
|
|
|
"""Touch the trigger file
|
|
|
|
|
|
|
|
If no trigger file is provided then do a return.
|
|
|
|
|
|
|
|
"""
|
|
|
|
if trigger is None:
|
|
|
|
return
|
|
|
|
|
|
|
|
if os.path.exists(trigger):
|
|
|
|
os.utime(trigger, None)
|
2018-06-14 22:27:17 +02:00
|
|
|
else:
|
2020-07-01 15:11:08 +02:00
|
|
|
with open(trigger, 'w') as trigger_fo:
|
|
|
|
trigger_fo.write("")
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
"""Parse command line arguments and take respective actions"""
|
|
|
|
args = parse_args()
|
|
|
|
|
|
|
|
dirs = get_subfolder_list(args.directory, args.create_links)
|
|
|
|
gen_out_file(args.out_file, dirs)
|
2018-06-07 15:50:31 +02:00
|
|
|
|
2018-06-14 22:27:17 +02:00
|
|
|
# Always touch trigger file to ensure json files are updated
|
|
|
|
touch(args.trigger_file)
|
2018-06-07 15:50:31 +02:00
|
|
|
|
2020-04-22 08:06:07 +02:00
|
|
|
|
2018-06-07 15:50:31 +02:00
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|