meson: make install_test_files more generic, rename to install_files
Now it supports installing directories and directory contents as well. This will be used in a subsequent patch to install documentation. Discussion: https://postgr.es/m/3fc3bb9b-f7f8-d442-35c1-ec82280c564a@enterprisedb.com
This commit is contained in:
parent
0f0a7183d7
commit
614c5f5f52
3 changed files with 78 additions and 35 deletions
|
@ -369,6 +369,8 @@ flex_cmd = [python, flex_wrapper,
|
|||
wget = find_program('wget', required: false, native: true)
|
||||
wget_flags = ['-O', '@OUTPUT0@', '--no-use-server-timestamps']
|
||||
|
||||
install_files = files('src/tools/install_files')
|
||||
|
||||
|
||||
|
||||
###############################################################
|
||||
|
@ -2845,9 +2847,8 @@ testprep_targets += test_install_libs
|
|||
|
||||
|
||||
# command to install files used for tests, which aren't installed by default
|
||||
install_test_files = files('src/tools/install_test_files')
|
||||
install_test_files_args = [
|
||||
install_test_files,
|
||||
install_files,
|
||||
'--prefix', dir_prefix,
|
||||
'--install', contrib_data_dir, test_install_data,
|
||||
'--install', dir_lib_pkg, test_install_libs,
|
||||
|
|
75
src/tools/install_files
Normal file
75
src/tools/install_files
Normal file
|
@ -0,0 +1,75 @@
|
|||
#!/usr/bin/env python3
|
||||
|
||||
# Helper to install files that are not part of the default meson install
|
||||
# target.
|
||||
#
|
||||
# This includes files that should only get installed into the temporary
|
||||
# installation for tests and documentation.
|
||||
|
||||
import argparse
|
||||
import os
|
||||
import shutil
|
||||
import sys
|
||||
from pathlib import PurePath
|
||||
|
||||
parser = argparse.ArgumentParser()
|
||||
|
||||
parser.add_argument('--destdir', type=str,
|
||||
default=os.environ.get('DESTDIR', None))
|
||||
parser.add_argument('--prefix', type=str)
|
||||
parser.add_argument('--install', type=str, nargs='+',
|
||||
action='append', default=[])
|
||||
parser.add_argument('--install-dirs', type=str, nargs='+',
|
||||
action='append', default=[])
|
||||
parser.add_argument('--install-dir-contents', type=str, nargs='+',
|
||||
action='append', default=[])
|
||||
|
||||
args = parser.parse_args()
|
||||
|
||||
|
||||
def error_exit(msg: str):
|
||||
print(msg, file=sys.stderr)
|
||||
exit(1)
|
||||
|
||||
|
||||
def create_target_dir(prefix: str, destdir: str, targetdir: str):
|
||||
if not os.path.isabs(targetdir):
|
||||
targetdir = os.path.join(prefix, targetdir)
|
||||
|
||||
if destdir is not None:
|
||||
# copy of meson's logic for joining destdir and install paths
|
||||
targetdir = str(PurePath(destdir, *PurePath(targetdir).parts[1:]))
|
||||
|
||||
os.makedirs(targetdir, exist_ok=True)
|
||||
|
||||
return targetdir
|
||||
|
||||
|
||||
def copy_files(targetdir: str, src_list: list):
|
||||
for src in src_list:
|
||||
shutil.copy2(src, targetdir)
|
||||
|
||||
|
||||
def copy_dirs(targetdir: str, src_list: list, contents: bool):
|
||||
for src in src_list:
|
||||
if not os.path.isdir(src):
|
||||
error_exit('{0} is not a directory'.format(src))
|
||||
|
||||
if contents:
|
||||
target = targetdir
|
||||
else:
|
||||
target = os.path.join(targetdir, os.path.split(src)[1])
|
||||
shutil.copytree(src, target, dirs_exist_ok=True)
|
||||
|
||||
|
||||
for installs in args.install:
|
||||
targetdir = create_target_dir(args.prefix, args.destdir, installs[0])
|
||||
copy_files(targetdir, installs[1:])
|
||||
|
||||
for installs in args.install_dirs:
|
||||
targetdir = create_target_dir(args.prefix, args.destdir, installs[0])
|
||||
copy_dirs(targetdir, installs[1:], contents=False)
|
||||
|
||||
for installs in args.install_dir_contents:
|
||||
targetdir = create_target_dir(args.prefix, args.destdir, installs[0])
|
||||
copy_dirs(targetdir, installs[1:], contents=True)
|
|
@ -1,33 +0,0 @@
|
|||
#!/usr/bin/env python3
|
||||
|
||||
# Helper to install additional files into the temporary installation
|
||||
# for tests, beyond those that are installed by meson/ninja install.
|
||||
|
||||
import argparse
|
||||
import shutil
|
||||
import os
|
||||
from pathlib import PurePath
|
||||
|
||||
parser = argparse.ArgumentParser()
|
||||
|
||||
parser.add_argument('--destdir', type=str, default=os.environ.get('DESTDIR', None))
|
||||
parser.add_argument('--prefix', type=str)
|
||||
parser.add_argument('--install', type=str, nargs='+', action='append')
|
||||
|
||||
args = parser.parse_args()
|
||||
|
||||
def copy_files(prefix: str, destdir: str, targetdir: str, src_list: list):
|
||||
if not os.path.isabs(targetdir):
|
||||
targetdir = os.path.join(prefix, targetdir)
|
||||
|
||||
if destdir is not None:
|
||||
# copy of meson's logic for joining destdir and install paths
|
||||
targetdir = str(PurePath(destdir, *PurePath(targetdir).parts[1:]))
|
||||
|
||||
os.makedirs(targetdir, exist_ok=True)
|
||||
|
||||
for src in src_list:
|
||||
shutil.copy2(src, targetdir)
|
||||
|
||||
for installs in args.install:
|
||||
copy_files(args.prefix, args.destdir, installs[0], installs[1:])
|
Loading…
Reference in a new issue