From 1002052ba417e387345872e81e78c13585d48c61 Mon Sep 17 00:00:00 2001 From: Joey Riches Date: Wed, 29 May 2024 14:05:19 +0100 Subject: [PATCH] ypkg: Always check for broken symlinks post-install --- ypkg2/main.py | 27 +++++++++++++++++++-------- 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/ypkg2/main.py b/ypkg2/main.py index 7fd9ca3..29e2c63 100644 --- a/ypkg2/main.py +++ b/ypkg2/main.py @@ -118,6 +118,8 @@ def clean_build_dirs(context): def execute_step(context, step, step_n, work_dir): script = ScriptGenerator(context, context.spec, work_dir) + preExtraScripts = [] + postExtraScripts = [] if context.emul32: script.define_export("EMUL32BUILD", "1") script.define_export("PKG_CONFIG_PATH", EMUL32PC) @@ -127,8 +129,6 @@ def execute_step(context, step, step_n, work_dir): script.define_export("PGO_GEN_BUILD", "1") if context.use_pgo: script.define_export("PGO_USE_BUILD", "1") - extraScript = None - endScript = None # Allow GCC and such to pick up on our timestamp script.define_export("SOURCE_DATE_EPOCH", @@ -143,12 +143,15 @@ def execute_step(context, step, step_n, work_dir): elif context.use_pgo and context.spec.pkg_clang: profileFile = os.path.join(context.get_pgo_dir(), "default.profdata") - extraScript = "%llvm_profile_merge" + preExtraScripts.append("%llvm_profile_merge") script.define_export("LLVM_PROFILE_FILE", profileFile) script.define_export("YPKG_PGO_DIR", context.get_pgo_dir()) if context.avx2 and step_n == "install": - endScript = "%avx2_lib_shift" + postExtraScripts.append("%avx2_lib_shift") + + if step_n == "install": + postExtraScripts.append("%symlink_check") # Generally, we only want fakeroot for the install and check steps due # to the massive performance overhead unless fatfakeroot is requested. @@ -167,11 +170,19 @@ def execute_step(context, step, step_n, work_dir): full_text += "\n".join(exports) if context.spec.pkg_environment: full_text += "\n\n{}\n".format(context.spec.pkg_environment) - if extraScript: - full_text += "\n\n{}\n".format(extraScript) + + # Any scripts to execute before running the step + if preExtraScripts is not None: + for preScript in preExtraScripts: + full_text += "\n\n{}\n".format(preScript) + full_text += "\n\n{}\n".format(step) - if endScript: - full_text += "\n\n{}\n".format(endScript) + + # Any post scripts to execute after running the step + if postExtraScripts is not None: + for postScript in postExtraScripts: + full_text += "\n\n{}\n".format(postScript) + output = script.escape_string(full_text) with tempfile.NamedTemporaryFile(prefix="ypkg-%s" % step_n) as script_ex: