nodejs: refactor derivations (#19973)
* refactor and clean up the derivation composition * add slim variation: the slim variations configure node without npm. Building node with npm introduces a python runtime depndency through gyp - slim variation makes sense for building small nodejs production images
This commit is contained in:
parent
a890d1765b
commit
a5dad8aeeb
@ -1,67 +1,65 @@
|
|||||||
{ stdenv, fetchurl, openssl, python2, zlib, libuv, v8, utillinux, http-parser
|
{ stdenv, fetchurl, openssl, python2, zlib, libuv, v8, utillinux, http-parser
|
||||||
, pkgconfig, runCommand, which, libtool
|
, pkgconfig, runCommand, which, libtool, fetchpatch
|
||||||
, version
|
, callPackage
|
||||||
, sha256 ? null
|
, darwin ? null
|
||||||
, src ? fetchurl { url = "https://nodejs.org/download/release/v${version}/node-v${version}.tar.xz"; inherit sha256; }
|
, enableNpm ? true
|
||||||
, preBuild ? ""
|
|
||||||
, extraConfigFlags ? []
|
|
||||||
, extraBuildInputs ? []
|
|
||||||
, patches ? [],
|
|
||||||
...
|
|
||||||
}:
|
}:
|
||||||
|
|
||||||
assert stdenv.system != "armv5tel-linux";
|
with stdenv.lib;
|
||||||
|
|
||||||
let
|
let
|
||||||
|
|
||||||
deps = {
|
inherit (darwin.apple_sdk.frameworks) CoreServices ApplicationServices;
|
||||||
inherit openssl zlib libuv;
|
|
||||||
} // (stdenv.lib.optionalAttrs (!stdenv.isDarwin) {
|
|
||||||
inherit http-parser;
|
|
||||||
});
|
|
||||||
|
|
||||||
sharedConfigureFlags = name: [
|
sharedLibDeps = { inherit openssl zlib libuv; } // (optionalAttrs (!stdenv.isDarwin) { inherit http-parser; });
|
||||||
|
|
||||||
|
sharedConfigureFlags = concatMap (name: [
|
||||||
"--shared-${name}"
|
"--shared-${name}"
|
||||||
"--shared-${name}-includes=${builtins.getAttr name deps}/include"
|
"--shared-${name}-libpath=${getLib sharedLibDeps.${name}}/lib"
|
||||||
"--shared-${name}-libpath=${builtins.getAttr name deps}/lib"
|
]) (builtins.attrNames sharedLibDeps);
|
||||||
];
|
|
||||||
|
|
||||||
inherit (stdenv.lib) concatMap optional optionals maintainers licenses platforms;
|
extraConfigFlags = optionals (!enableNpm) [ "--without-npm" ];
|
||||||
|
in
|
||||||
|
|
||||||
in stdenv.mkDerivation {
|
rec {
|
||||||
|
|
||||||
inherit version src preBuild;
|
buildInputs = optionals stdenv.isDarwin [ CoreServices ApplicationServices ]
|
||||||
|
|
||||||
name = "nodejs-${version}";
|
|
||||||
|
|
||||||
configureFlags = concatMap sharedConfigureFlags (builtins.attrNames deps) ++ [ "--without-dtrace" ] ++ extraConfigFlags;
|
|
||||||
dontDisableStatic = true;
|
|
||||||
prePatch = ''
|
|
||||||
patchShebangs .
|
|
||||||
sed -i 's/raise.*No Xcode or CLT version detected.*/version = "7.0.0"/' tools/gyp/pylib/gyp/xcode_emulation.py
|
|
||||||
'';
|
|
||||||
|
|
||||||
postInstall = ''
|
|
||||||
PATH=$out/bin:$PATH patchShebangs $out
|
|
||||||
'';
|
|
||||||
|
|
||||||
patches = patches ++ stdenv.lib.optionals stdenv.isDarwin [ ./no-xcode.patch ];
|
|
||||||
|
|
||||||
buildInputs = extraBuildInputs
|
|
||||||
++ [ python2 which zlib libuv openssl ]
|
++ [ python2 which zlib libuv openssl ]
|
||||||
++ optionals stdenv.isLinux [ utillinux http-parser ]
|
++ optionals stdenv.isLinux [ utillinux http-parser ]
|
||||||
++ optionals stdenv.isDarwin [ pkgconfig libtool ];
|
++ optionals stdenv.isDarwin [ pkgconfig libtool ];
|
||||||
setupHook = ./setup-hook.sh;
|
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
configureFlags = sharedConfigureFlags ++ [ "--without-dtrace" ] ++ extraConfigFlags;
|
||||||
|
|
||||||
passthru.interpreterName = "nodejs";
|
dontDisableStatic = true;
|
||||||
|
|
||||||
meta = {
|
enableParallelBuilding = true;
|
||||||
description = "Event-driven I/O framework for the V8 JavaScript engine";
|
|
||||||
homepage = http://nodejs.org;
|
passthru.interpreterName = "nodejs";
|
||||||
license = licenses.mit;
|
|
||||||
maintainers = [ maintainers.goibhniu maintainers.havvy maintainers.gilligan maintainers.cko ];
|
|
||||||
platforms = platforms.linux ++ platforms.darwin;
|
setupHook = ./setup-hook.sh;
|
||||||
};
|
|
||||||
|
patches = optionals stdenv.isDarwin [ ./no-xcode.patch ];
|
||||||
|
|
||||||
|
preBuild = optionalString stdenv.isDarwin ''
|
||||||
|
sed -i -e "s|tr1/type_traits|type_traits|g" \
|
||||||
|
-e "s|std::tr1|std|" src/util.h
|
||||||
|
'';
|
||||||
|
|
||||||
|
prePatch = ''
|
||||||
|
patchShebangs .
|
||||||
|
sed -i 's/raise.*No Xcode or CLT version detected.*/version = "7.0.0"/' tools/gyp/pylib/gyp/xcode_emulation.py
|
||||||
|
'';
|
||||||
|
|
||||||
|
postInstall = ''
|
||||||
|
PATH=$out/bin:$PATH patchShebangs $out
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description = "Event-driven I/O framework for the V8 JavaScript engine";
|
||||||
|
homepage = http://nodejs.org;
|
||||||
|
license = licenses.mit;
|
||||||
|
maintainers = with maintainers; [ goibhniu havvy gilligan cko ];
|
||||||
|
platforms = platforms.linux ++ platforms.darwin;
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
@ -1,17 +1,20 @@
|
|||||||
{ stdenv, fetchurl, openssl, python2, zlib, libuv, v8, utillinux, http-parser
|
{ stdenv, fetchurl, openssl, python2, zlib, libuv, v8, utillinux, http-parser
|
||||||
, pkgconfig, runCommand, which, libtool
|
, pkgconfig, runCommand, which, libtool, fetchpatch
|
||||||
, callPackage
|
, callPackage
|
||||||
|
, darwin ? null
|
||||||
|
, enableNpm ? true
|
||||||
}@args:
|
}@args:
|
||||||
|
|
||||||
import ./nodejs.nix (args // rec {
|
let
|
||||||
version = "4.6.0";
|
nodejs = import ./nodejs.nix args;
|
||||||
src = fetchurl {
|
baseName = if enableNpm then "nodejs" else "nodejs-slim";
|
||||||
url = "http://nodejs.org/dist/v${version}/node-v${version}.tar.xz";
|
in
|
||||||
sha256 = "1566q1kkv8j30fgqx8sm2h8323f38wwpa1hfb10gr6z46jyhv4a2";
|
stdenv.mkDerivation (nodejs // rec {
|
||||||
};
|
version = "4.6.0";
|
||||||
|
name = "${baseName}-${version}";
|
||||||
|
src = fetchurl {
|
||||||
|
url = "http://nodejs.org/dist/v${version}/node-v${version}.tar.xz";
|
||||||
|
sha256 = "1566q1kkv8j30fgqx8sm2h8323f38wwpa1hfb10gr6z46jyhv4a2";
|
||||||
|
};
|
||||||
|
|
||||||
preBuild = stdenv.lib.optionalString stdenv.isDarwin ''
|
})
|
||||||
substituteInPlace src/util.h \
|
|
||||||
--replace "tr1/type_traits" "type_traits"
|
|
||||||
'';
|
|
||||||
})
|
|
||||||
|
@ -2,24 +2,27 @@
|
|||||||
, pkgconfig, runCommand, which, libtool, fetchpatch
|
, pkgconfig, runCommand, which, libtool, fetchpatch
|
||||||
, callPackage
|
, callPackage
|
||||||
, darwin ? null
|
, darwin ? null
|
||||||
|
, enableNpm ? true
|
||||||
}@args:
|
}@args:
|
||||||
|
|
||||||
let
|
let
|
||||||
inherit (darwin.apple_sdk.frameworks) CoreServices ApplicationServices;
|
nodejs = import ./nodejs.nix args;
|
||||||
|
baseName = if enableNpm then "nodejs" else "nodejs-slim";
|
||||||
|
in
|
||||||
|
stdenv.mkDerivation (nodejs // rec {
|
||||||
|
version = "6.8.0";
|
||||||
|
name = "${baseName}-${version}";
|
||||||
|
src = fetchurl {
|
||||||
|
url = "https://nodejs.org/download/release/v${version}/node-v${version}.tar.xz";
|
||||||
|
sha256 = "13arzwki13688hr1lh871y06lrk019g4hkasmg11arm8j1dcwcpq";
|
||||||
|
};
|
||||||
|
|
||||||
|
patches = nodejs.patches ++ [
|
||||||
|
(fetchpatch {
|
||||||
|
url = "https://github.com/nodejs/node/commit/fc164acbbb700fd50ab9c04b47fc1b2687e9c0f4.patch";
|
||||||
|
sha256 = "1rms3n09622xmddn013yvf5c6p3s8w8s0d2h813zs8c1l15k4k1i";
|
||||||
|
})
|
||||||
|
];
|
||||||
|
|
||||||
|
})
|
||||||
|
|
||||||
in import ./nodejs.nix (args // rec {
|
|
||||||
version = "6.8.0";
|
|
||||||
sha256 = "13arzwki13688hr1lh871y06lrk019g4hkasmg11arm8j1dcwcpq";
|
|
||||||
extraBuildInputs = stdenv.lib.optionals stdenv.isDarwin
|
|
||||||
[ CoreServices ApplicationServices ];
|
|
||||||
preBuild = stdenv.lib.optionalString stdenv.isDarwin ''
|
|
||||||
sed -i -e "s|tr1/type_traits|type_traits|g" \
|
|
||||||
-e "s|std::tr1|std|" src/util.h
|
|
||||||
'';
|
|
||||||
patches = [
|
|
||||||
(fetchpatch {
|
|
||||||
url = "https://github.com/nodejs/node/commit/fc164acbbb700fd50ab9c04b47fc1b2687e9c0f4.patch";
|
|
||||||
sha256 = "1rms3n09622xmddn013yvf5c6p3s8w8s0d2h813zs8c1l15k4k1i";
|
|
||||||
})
|
|
||||||
];
|
|
||||||
})
|
|
||||||
|
@ -2426,15 +2426,27 @@ in
|
|||||||
|
|
||||||
ninka = callPackage ../development/tools/misc/ninka { };
|
ninka = callPackage ../development/tools/misc/ninka { };
|
||||||
|
|
||||||
|
nodejs = nodejs-6_x;
|
||||||
|
|
||||||
|
nodejs-slim = nodejs-slim-6_x;
|
||||||
|
|
||||||
nodejs-4_x = callPackage ../development/web/nodejs/v4.nix {
|
nodejs-4_x = callPackage ../development/web/nodejs/v4.nix {
|
||||||
libtool = darwin.cctools;
|
libtool = darwin.cctools;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
nodejs-slim-4_x = callPackage ../development/web/nodejs/v4.nix {
|
||||||
|
libtool = darwin.cctools;
|
||||||
|
enableNpm = false;
|
||||||
|
};
|
||||||
|
|
||||||
nodejs-6_x = callPackage ../development/web/nodejs/v6.nix {
|
nodejs-6_x = callPackage ../development/web/nodejs/v6.nix {
|
||||||
libtool = darwin.cctools;
|
libtool = darwin.cctools;
|
||||||
};
|
};
|
||||||
|
|
||||||
nodejs = nodejs-6_x;
|
nodejs-slim-6_x = callPackage ../development/web/nodejs/v6.nix {
|
||||||
|
libtool = darwin.cctools;
|
||||||
|
enableNpm = false;
|
||||||
|
};
|
||||||
|
|
||||||
nodePackages_6_x = callPackage ../development/node-packages/default-v6.nix {
|
nodePackages_6_x = callPackage ../development/node-packages/default-v6.nix {
|
||||||
nodejs = pkgs.nodejs-6_x;
|
nodejs = pkgs.nodejs-6_x;
|
||||||
@ -2444,7 +2456,7 @@ in
|
|||||||
nodejs = pkgs.nodejs-4_x;
|
nodejs = pkgs.nodejs-4_x;
|
||||||
};
|
};
|
||||||
|
|
||||||
nodePackages = nodePackages_4_x;
|
nodePackages = nodePackages_6_x;
|
||||||
|
|
||||||
# Can be used as a user shell
|
# Can be used as a user shell
|
||||||
nologin = shadow;
|
nologin = shadow;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user