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:
@@ -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}
|
||||||
|
|||||||
@@ -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
|
||||||
|
;
|
||||||
|
}
|
||||||
@@ -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
|
||||||
|
|||||||
@@ -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/"
|
||||||
|
|||||||
Reference in New Issue
Block a user