aboutsummaryrefslogtreecommitdiffstats
path: root/build/scripts
diff options
context:
space:
mode:
Diffstat (limited to 'build/scripts')
-rw-r--r--build/scripts/copy_clang_profile_rt.py42
-rw-r--r--build/scripts/ya.make1
2 files changed, 43 insertions, 0 deletions
diff --git a/build/scripts/copy_clang_profile_rt.py b/build/scripts/copy_clang_profile_rt.py
new file mode 100644
index 0000000000..b24dde3959
--- /dev/null
+++ b/build/scripts/copy_clang_profile_rt.py
@@ -0,0 +1,42 @@
+import optparse
+import os
+import shutil
+
+import process_command_files as pcf
+
+CLANG_RT_VERSION = 14
+
+
+def copy_clang_rt_profile(cmd, build_root, arch) -> None:
+ profile_rt_lib = None
+ resource_dir = None
+
+ for arg in cmd:
+ if arg.startswith(f'contrib/libs/clang{CLANG_RT_VERSION}-rt/lib/profile/libclang_rt.profile'):
+ profile_rt_lib = arg
+ if arg.startswith('-resource-dir='):
+ resource_dir = arg[len('-resource-dir='):]
+
+ profile_rt_path = os.path.join(build_root, profile_rt_lib)
+ profile_name = os.path.basename(profile_rt_path)
+
+ dst_dir = os.path.join(build_root, resource_dir, 'lib/{}'.format(arch.lower()))
+ os.makedirs(dst_dir, exist_ok=True)
+ shutil.copy(profile_rt_path, os.path.join(dst_dir, profile_name))
+
+
+def parse_args():
+ parser = optparse.OptionParser()
+ parser.disable_interspersed_args()
+ parser.add_option('--build-root')
+ parser.add_option('--arch')
+ parser.add_option('--need-profile-rt')
+ return parser.parse_args()
+
+
+if __name__ == '__main__':
+ opts, args = parse_args()
+ args = pcf.skip_markers(args)
+
+ if opts.need_profile_rt != "no":
+ copy_clang_rt_profile(args, opts.build_root, opts.arch)
diff --git a/build/scripts/ya.make b/build/scripts/ya.make
index 69a7bd572d..5448ec7db8 100644
--- a/build/scripts/ya.make
+++ b/build/scripts/ya.make
@@ -102,6 +102,7 @@ ELSEIF(PY3)
TEST_SRCS(
build_info_gen.py
+ copy_clang_profile_rt.py
gen_yql_python_udf.py
)
ENDIF()