From 7182bc2359b213688cafcea19b18efb2c4dabc99 Mon Sep 17 00:00:00 2001 From: "trop[bot]" <37223003+trop[bot]@users.noreply.github.com> Date: Fri, 11 Oct 2024 15:25:34 -0400 Subject: [PATCH] fix: clang variable configuration in generated node headers (#44201) * fix: clang variable configuration in generated node headers Co-authored-by: deepak1556 * chore: restore value in common.gypi Co-authored-by: deepak1556 * chore: update patches --------- Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com> Co-authored-by: deepak1556 Co-authored-by: John Kleinschmidt --- patches/node/.patches | 1 + ...e_clang_as_default_compiler_on_macos.patch | 24 +++++++++++++++++++ script/generate-config-gypi.py | 4 ++++ 3 files changed, 29 insertions(+) create mode 100644 patches/node/build_restore_clang_as_default_compiler_on_macos.patch diff --git a/patches/node/.patches b/patches/node/.patches index 497c66df2c0..19f4bcf9d66 100644 --- a/patches/node/.patches +++ b/patches/node/.patches @@ -50,3 +50,4 @@ fix_add_property_query_interceptors.patch src_use_supported_api_to_get_stalled_tla_messages.patch build_don_t_redefine_win32_lean_and_mean.patch build_compile_with_c_20_support.patch +build_restore_clang_as_default_compiler_on_macos.patch diff --git a/patches/node/build_restore_clang_as_default_compiler_on_macos.patch b/patches/node/build_restore_clang_as_default_compiler_on_macos.patch new file mode 100644 index 00000000000..0423182e8bb --- /dev/null +++ b/patches/node/build_restore_clang_as_default_compiler_on_macos.patch @@ -0,0 +1,24 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: deepak1556 +Date: Fri, 11 Oct 2024 15:01:25 +0900 +Subject: build: restore clang as default compiler on macOS + +Refs https://github.com/nodejs/node/commit/6e0a2bb54c5bbeff0e9e33e1a0c683ed980a8a0f +configures the value at build time which doesn't work in Electron +as it depends on the environment in which the headers got generated from which +cannot reflect the value per platform. It works for Node.js since +node-gyp will use the result of `process.config` that reflects the environment +in which the binary got built. + +diff --git a/common.gypi b/common.gypi +index 2eb62610db2f0ebf68fa9a55ffba98291ecfe451..3ec08ee144b586d05c4e49c2251416734cbc02c5 100644 +--- a/common.gypi ++++ b/common.gypi +@@ -125,6 +125,7 @@ + 'v8_base': '<(PRODUCT_DIR)/obj.target/tools/v8_gypfiles/libv8_snapshot.a', + }], + ['OS=="mac"', { ++ 'clang%': 1, + 'obj_dir%': '<(PRODUCT_DIR)/obj.target', + 'v8_base': '<(PRODUCT_DIR)/libv8_snapshot.a', + }], diff --git a/script/generate-config-gypi.py b/script/generate-config-gypi.py index b41cd7eb450..19e3f86be5e 100755 --- a/script/generate-config-gypi.py +++ b/script/generate-config-gypi.py @@ -61,6 +61,10 @@ def main(target_file, target_cpu): v['node_module_version'] = int(args['node_module_version']) # Used by certain versions of node-gyp. v['build_v8_with_gn'] = 'false' + # Enable clang conditionally based on target platform + # in common.gypi + if 'clang' in v: + del v['clang'] with open(target_file, 'w+', encoding='utf-8') as file_out: file_out.write(pprint.pformat(config, indent=2))