summary refs log tree commit diff
path: root/pkgs/development/web
diff options
context:
space:
mode:
authorRandy Eckenrode <randy@largeandhighquality.com>2023-09-02 11:50:17 -0400
committerRandy Eckenrode <randy@largeandhighquality.com>2023-10-19 15:22:52 -0400
commit3ad67b4e12eebbb23ab2632d44c74662709e02a5 (patch)
tree5fa7847fb1716a8e335efb5d5045113cec9c7167 /pkgs/development/web
parentcf1128c17a8a94bea4c12487a865a8e231d931e7 (diff)
downloadnixpkgs-3ad67b4e12eebbb23ab2632d44c74662709e02a5.tar
nixpkgs-3ad67b4e12eebbb23ab2632d44c74662709e02a5.tar.gz
nixpkgs-3ad67b4e12eebbb23ab2632d44c74662709e02a5.tar.bz2
nixpkgs-3ad67b4e12eebbb23ab2632d44c74662709e02a5.tar.lz
nixpkgs-3ad67b4e12eebbb23ab2632d44c74662709e02a5.tar.xz
nixpkgs-3ad67b4e12eebbb23ab2632d44c74662709e02a5.tar.zst
nixpkgs-3ad67b4e12eebbb23ab2632d44c74662709e02a5.zip
nodejs_14: work around building with clang 16
Node v14 can’t build with clang 16 due to `-Wenum-constexpr-conversion`
errors. Since the backport patch from v8 does not apply to Node v14, and
it is likely this will become a hard error in future versions of clang,
use clang 15 when the version in the stdenv is newer.

The version of libc++ used with the clang is made to match the one used
in the stdenv to avoid possible issues with mixing multiple versions of
libc++ in one binary (e.g., icu links against libc++).
Diffstat (limited to 'pkgs/development/web')
-rw-r--r--pkgs/development/web/nodejs/v14.nix16
1 files changed, 14 insertions, 2 deletions
diff --git a/pkgs/development/web/nodejs/v14.nix b/pkgs/development/web/nodejs/v14.nix
index e7dec1c12f6..c2d5d58bea7 100644
--- a/pkgs/development/web/nodejs/v14.nix
+++ b/pkgs/development/web/nodejs/v14.nix
@@ -1,8 +1,20 @@
-{ callPackage, python3, lib, stdenv, openssl, enableNpm ? true }:
+{ callPackage, lib, overrideCC, pkgs, buildPackages, openssl, python3, enableNpm ? true }:
 
 let
+  # Clang 16+ cannot build Node v14 due to -Wenum-constexpr-conversion errors.
+  # Use an older version of clang with the current libc++ for compatibility (e.g., with icu).
+  ensureCompatibleCC = packages:
+    if packages.stdenv.cc.isClang && lib.versionAtLeast (lib.getVersion packages.stdenv.cc.cc) "16"
+      then overrideCC packages.llvmPackages_15.stdenv (packages.llvmPackages_15.stdenv.cc.override {
+        inherit (packages.llvmPackages) libcxx;
+        extraPackages = [ packages.llvmPackages.libcxxabi ];
+      })
+      else packages.stdenv;
+
   buildNodejs = callPackage ./nodejs.nix {
     inherit openssl;
+    stdenv = ensureCompatibleCC pkgs;
+    buildPackages = buildPackages // { stdenv = ensureCompatibleCC buildPackages; };
     python = python3;
   };
 in
@@ -10,5 +22,5 @@ in
     inherit enableNpm;
     version = "14.21.3";
     sha256 = "sha256-RY7AkuYK1wDdzwectj1DXBXaTHuz0/mbmo5YqZ5UB14=";
-    patches = lib.optional stdenv.isDarwin ./bypass-xcodebuild.diff;
+    patches = lib.optional pkgs.stdenv.isDarwin ./bypass-xcodebuild.diff;
   }