Split runtime node_modules into reusable layers

- Add shared installFlags support to the common Bun node_modules builder
- Factor base and desktop overlay node_modules derivations for reuse
- Reuse the new runtime node_modules outputs in desktop and server builds
This commit is contained in:
2026-04-27 12:45:00 +03:00
parent 3fbafbc0ea
commit 9e96208724
4 changed files with 127 additions and 6 deletions
+5
View File
@@ -17,6 +17,9 @@
renderBunFilters = filters: renderBunFilters = filters:
lib.concatMapStringsSep "\n" (filter: " --filter ${filter} \\") filters; lib.concatMapStringsSep "\n" (filter: " --filter ${filter} \\") filters;
renderBunInstallFlags = flags:
lib.concatMapStringsSep "\n" (flag: " ${flag} \\") flags;
in { in {
inherit workspacePreparePatched; inherit workspacePreparePatched;
@@ -29,6 +32,7 @@ in {
src, src,
outputHash, outputHash,
filters, filters,
installFlags ? [],
extraNativeBuildInputs ? [], extraNativeBuildInputs ? [],
impureEnvVars ? [], impureEnvVars ? [],
extraEnv ? "", extraEnv ? "",
@@ -68,6 +72,7 @@ in {
--backend=copyfile \ --backend=copyfile \
--linker=hoisted \ --linker=hoisted \
--no-progress \ --no-progress \
${renderBunInstallFlags installFlags}
${renderBunFilters filters} ${renderBunFilters filters}
bun --bun ${./scripts/canonicalize-node-modules.ts} bun --bun ${./scripts/canonicalize-node-modules.ts}
+58
View File
@@ -0,0 +1,58 @@
{
lib,
pkgs,
src,
}: let
common = pkgs.callPackage ./common.nix {};
t3codeNodeModulesBase = common.mkNodeModules {
pname = "t3code";
version = "base";
inherit src;
outputHash = "sha256-eXNOHRuNv9XFhXmsFtkunZswtRPd8gzJB1Jdw2DxYZY=";
filters = [
"."
"./apps/server"
"./apps/web"
"./packages/client-runtime"
"./packages/contracts"
"./packages/effect-acp"
"./packages/effect-codex-app-server"
"./packages/shared"
];
};
t3codeNodeModulesDesktopOverlay = common.mkNodeModules {
pname = "t3code-desktop-overlay";
version = "overlay";
inherit src;
outputHash = "sha256-P6hlfpIZOLmkdXn99e0WC1CHAf7SD4CjouVwvAYo0+w=";
filters = [
"."
"./apps/desktop"
];
impureEnvVars =
lib.fetchers.proxyImpureEnvVars
++ [
"GIT_PROXY_COMMAND"
"SOCKS_SERVER"
];
extraNativeBuildInputs = [
pkgs.gcc
pkgs.gnumake
pkgs.pkg-config
pkgs.python3
];
extraEnv = ''
export ELECTRON_SKIP_BINARY_DOWNLOAD=1
export PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD=1
export npm_config_build_from_source=true
'';
};
in {
inherit
t3codeNodeModulesBase
t3codeNodeModulesDesktopOverlay
;
}
+42 -5
View File
@@ -29,7 +29,6 @@
pname = "t3code-desktop"; pname = "t3code-desktop";
version = desktopPackageJson.version; version = desktopPackageJson.version;
in in
stdenv.mkDerivation (finalAttrs: { stdenv.mkDerivation (finalAttrs: {
inherit pname version; inherit pname version;
@@ -71,6 +70,42 @@ in
''; '';
}; };
runtimeNodeModules = common.mkNodeModules {
inherit (finalAttrs) pname version src;
outputHash = "sha256-q1xo2GiU3Ct4Sq5+qGsfXMI0ei1c5AXkdq0GaBWr1PI=";
installFlags = [
"--production"
];
filters = [
"."
"./apps/desktop"
"./apps/server"
"./apps/web"
"./packages/client-runtime"
"./packages/contracts"
"./packages/effect-acp"
"./packages/effect-codex-app-server"
"./packages/shared"
];
impureEnvVars =
lib.fetchers.proxyImpureEnvVars
++ [
"GIT_PROXY_COMMAND"
"SOCKS_SERVER"
];
extraNativeBuildInputs = [
gcc
gnumake
pkg-config
python3
];
extraEnv = ''
export ELECTRON_SKIP_BINARY_DOWNLOAD=1
export PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD=1
export npm_config_build_from_source=true
'';
};
nativeBuildInputs = [ nativeBuildInputs = [
asar asar
bun bun
@@ -104,8 +139,10 @@ in
bun run build:desktop bun run build:desktop
node ${./build-nix-desktop-package.mjs} --output-dir packaged-app node ${./build-nix-desktop-package.mjs} --output-dir packaged-app
cp -R node_modules packaged-app/node_modules cp -R ${finalAttrs.runtimeNodeModules} packaged-app/node_modules
chmod -R u+rwX packaged-app/node_modules chmod -R u+rwX packaged-app/node_modules
rm -rf packaged-app/node_modules/node-pty
cp -R node_modules/node-pty packaged-app/node_modules/
patchShebangs packaged-app/node_modules patchShebangs packaged-app/node_modules
find packaged-app/node_modules -xtype l -delete find packaged-app/node_modules -xtype l -delete
rm -rf packaged-app/node_modules/electron rm -rf packaged-app/node_modules/electron
@@ -132,9 +169,9 @@ in
--set-default ELECTRON_FORCE_IS_PACKAGED 1 \ --set-default ELECTRON_FORCE_IS_PACKAGED 1 \
--set-default ELECTRON_IS_DEV 0 \ --set-default ELECTRON_IS_DEV 0 \
--prefix PATH : ${lib.makeBinPath [ --prefix PATH : ${lib.makeBinPath [
git git
xdg-utils xdg-utils
]} \ ]} \
--add-flags "$out/share/${pname}/resources/app.asar" --add-flags "$out/share/${pname}/resources/app.asar"
export out export out
+22 -1
View File
@@ -44,6 +44,24 @@ in
]; ];
}; };
runtimeNodeModules = common.mkNodeModules {
inherit (finalAttrs) pname version src;
outputHash = "sha256-EcUsCt8liYnmzsDXzdwfLbMEk4/OYHB6DkcjjvmTWEM=";
installFlags = [
"--production"
];
filters = [
"."
"./apps/server"
"./apps/web"
"./packages/client-runtime"
"./packages/contracts"
"./packages/effect-acp"
"./packages/effect-codex-app-server"
"./packages/shared"
];
};
nativeBuildInputs = [ nativeBuildInputs = [
bun bun
makeBinaryWrapper makeBinaryWrapper
@@ -76,7 +94,10 @@ in
mkdir -p "$out/libexec/t3code/apps" mkdir -p "$out/libexec/t3code/apps"
mkdir -p "$out/libexec/t3code/packages" mkdir -p "$out/libexec/t3code/packages"
cp -R --no-preserve=mode node_modules "$out/libexec/t3code/" cp -R --no-preserve=mode ${finalAttrs.runtimeNodeModules} "$out/libexec/t3code/node_modules"
chmod -R u+rwX "$out/libexec/t3code/node_modules"
rm -rf "$out/libexec/t3code/node_modules/node-pty"
cp -R --no-preserve=mode node_modules/node-pty "$out/libexec/t3code/node_modules/"
cp -R --no-preserve=mode apps/server/dist "$out/libexec/t3code/apps/server/" cp -R --no-preserve=mode apps/server/dist "$out/libexec/t3code/apps/server/"
cp -R --no-preserve=mode apps/web "$out/libexec/t3code/apps/" cp -R --no-preserve=mode apps/web "$out/libexec/t3code/apps/"
cp -R --no-preserve=mode packages/client-runtime "$out/libexec/t3code/packages/" cp -R --no-preserve=mode packages/client-runtime "$out/libexec/t3code/packages/"