vite-plugin-react-server 1.2.5 → 1.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/package.json +8 -4
- package/dist/plugin/orchestrator/createPluginOrchestrator.client.d.ts.map +1 -1
- package/dist/plugin/orchestrator/createPluginOrchestrator.client.js +3 -0
- package/dist/plugin/orchestrator/createPluginOrchestrator.server.d.ts.map +1 -1
- package/dist/plugin/orchestrator/createPluginOrchestrator.server.js +3 -0
- package/dist/plugin/vendor/register-vendor.d.ts +2 -0
- package/dist/plugin/vendor/register-vendor.d.ts.map +1 -0
- package/dist/plugin/vendor/register-vendor.js +50 -0
- package/dist/plugin/vendor/vendor-alias.d.ts +12 -0
- package/dist/plugin/vendor/vendor-alias.d.ts.map +1 -0
- package/dist/plugin/vendor/vendor-alias.js +97 -0
- package/dist/plugin/vendor/vendor.client.d.ts +1 -1
- package/dist/plugin/vendor/vendor.client.d.ts.map +1 -1
- package/dist/plugin/vendor/vendor.client.js +19 -6
- package/dist/plugin/vendor/vendor.server.d.ts.map +1 -1
- package/dist/plugin/vendor/vendor.server.js +18 -5
- package/dist/plugin/vendor/vendor.static.d.ts.map +1 -1
- package/dist/plugin/vendor/vendor.static.js +18 -5
- package/dist/plugin/worker/createWorker.d.ts.map +1 -1
- package/dist/plugin/worker/createWorker.js +5 -2
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/oss-experimental/react-server-dom-esm/LICENSE +21 -0
- package/oss-experimental/react-server-dom-esm/README.md +5 -0
- package/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.development.js +2996 -0
- package/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.browser.production.js +1612 -0
- package/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.node.development.js +3124 -0
- package/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-client.node.production.js +1752 -0
- package/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-server.node.development.js +4213 -0
- package/oss-experimental/react-server-dom-esm/cjs/react-server-dom-esm-server.node.production.js +2857 -0
- package/oss-experimental/react-server-dom-esm/client.browser.js +7 -0
- package/oss-experimental/react-server-dom-esm/client.js +3 -0
- package/oss-experimental/react-server-dom-esm/client.node.js +7 -0
- package/oss-experimental/react-server-dom-esm/esm/package.json +3 -0
- package/oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-client.browser.development.js +3969 -0
- package/oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-client.browser.production.js +2347 -0
- package/oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-node-loader.production.js +515 -0
- package/oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-server.js +13 -0
- package/oss-experimental/react-server-dom-esm/esm/react-server-dom-esm-server.node.js +13 -0
- package/oss-experimental/react-server-dom-esm/index.js +12 -0
- package/oss-experimental/react-server-dom-esm/package.json +63 -0
- package/oss-experimental/react-server-dom-esm/server.js +6 -0
- package/oss-experimental/react-server-dom-esm/server.node.js +17 -0
- package/oss-experimental/react-server-dom-esm/static.js +6 -0
- package/oss-experimental/react-server-dom-esm/static.node.js +12 -0
- package/package.json +8 -4
- package/plugin/orchestrator/createPluginOrchestrator.client.ts +4 -0
- package/plugin/orchestrator/createPluginOrchestrator.server.ts +4 -0
- package/plugin/vendor/register-vendor.ts +51 -0
- package/plugin/vendor/vendor-alias.ts +112 -0
- package/plugin/vendor/vendor.client.ts +24 -9
- package/plugin/vendor/vendor.server.ts +23 -7
- package/plugin/vendor/vendor.static.ts +21 -7
- package/plugin/worker/createWorker.ts +4 -0
- package/scripts/build-oss-experimental.sh +161 -0
package/dist/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "vite-plugin-react-server",
|
|
3
|
-
"version": "1.2
|
|
3
|
+
"version": "1.3.2",
|
|
4
4
|
"description": "Vite plugin for React Server Components (RSC)",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "./dist/plugin/index.js",
|
|
@@ -14,7 +14,8 @@
|
|
|
14
14
|
"virtual.d.ts",
|
|
15
15
|
"README.md",
|
|
16
16
|
"LICENSE",
|
|
17
|
-
"tsconfig.json"
|
|
17
|
+
"tsconfig.json",
|
|
18
|
+
"oss-experimental/react-server-dom-esm"
|
|
18
19
|
],
|
|
19
20
|
"exports": {
|
|
20
21
|
".": "./dist/plugin/index.js",
|
|
@@ -218,9 +219,10 @@
|
|
|
218
219
|
"experimental:copy": "cp -r ./oss-experimental/* ./node_modules/",
|
|
219
220
|
"experimental:patch": "npx patch-package react-server-dom-esm react react-dom --exclude 'nothing'",
|
|
220
221
|
"experimental:move-patches": "mv patches/* ./scripts/",
|
|
222
|
+
"experimental:build-oss": "bash scripts/build-oss-experimental.sh",
|
|
223
|
+
"experimental:build-oss-full": "bash scripts/build-oss-experimental.sh --full",
|
|
221
224
|
"experimental:setup": "rm -rf patches/* && npm run experimental:clean-install && npm run experimental:copy && npm run experimental:patch && npm run experimental:move-patches",
|
|
222
225
|
"experimental:patch-react": "npm run experimental:clean-install && node scripts/check-react-version.mjs && node bin/patch.mjs",
|
|
223
|
-
"postinstall": "patch-package",
|
|
224
226
|
"test-parse": "node -e \"const acorn = require('acorn'); const ast = acorn.parse('export async function test() {}', { sourceType: 'module', ecmaVersion: 'latest' }); console.log(JSON.stringify(ast, null, 2));\"",
|
|
225
227
|
"precoverage": "npm run build",
|
|
226
228
|
"coverage": "npm run test:coverage"
|
|
@@ -248,7 +250,6 @@
|
|
|
248
250
|
"peerDependencies": {
|
|
249
251
|
"react": ">=0.0.0-experimental-0",
|
|
250
252
|
"react-dom": ">=0.0.0-experimental-0",
|
|
251
|
-
"react-server-dom-esm": "^0.0.1",
|
|
252
253
|
"vite": "*"
|
|
253
254
|
},
|
|
254
255
|
"peerDependenciesMeta": {
|
|
@@ -260,6 +261,9 @@
|
|
|
260
261
|
},
|
|
261
262
|
"vite": {
|
|
262
263
|
"optional": false
|
|
264
|
+
},
|
|
265
|
+
"react-server-dom-esm": {
|
|
266
|
+
"optional": true
|
|
263
267
|
}
|
|
264
268
|
},
|
|
265
269
|
"devDependencies": {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createPluginOrchestrator.client.d.ts","sourceRoot":"","sources":["../../../plugin/orchestrator/createPluginOrchestrator.client.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"createPluginOrchestrator.client.d.ts","sourceRoot":"","sources":["../../../plugin/orchestrator/createPluginOrchestrator.client.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAUnC,eAAO,MAAM,wBAAwB,GACnC,aAAa,GAAG,KACf,MAAM,EAsCR,CAAC"}
|
|
@@ -4,11 +4,14 @@ import { vitePluginReactDevServer } from "../dev-server/plugin.client.js";
|
|
|
4
4
|
import { reactStaticPlugin } from "../react-static/plugin.client.js";
|
|
5
5
|
import { createTransformerPlugin } from "../transformer/createTransformerPlugin.js";
|
|
6
6
|
import { virtualRscHmrPlugin } from "../dev-server/virtualRscHmrPlugin.js";
|
|
7
|
+
import { vitePluginVendorAlias } from "../vendor/vendor-alias.js";
|
|
7
8
|
// Client-first orchestrator - includes client SSG plugin for reverse paradigm
|
|
8
9
|
export const createPluginOrchestrator = (userOptions) => {
|
|
9
10
|
// Client-first logic - provide all environments for Environment API builds
|
|
10
11
|
const availableEnvironments = ["client", "ssr", "server"];
|
|
11
12
|
const plugins = [];
|
|
13
|
+
// Alias react-server-dom-esm to our vendored copy
|
|
14
|
+
plugins.push(vitePluginVendorAlias());
|
|
12
15
|
// Virtual module for RSC HMR utilities (works in both dev and build)
|
|
13
16
|
plugins.push(virtualRscHmrPlugin());
|
|
14
17
|
// Add transformer first so it runs before other plugins
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createPluginOrchestrator.server.d.ts","sourceRoot":"","sources":["../../../plugin/orchestrator/createPluginOrchestrator.server.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"createPluginOrchestrator.server.d.ts","sourceRoot":"","sources":["../../../plugin/orchestrator/createPluginOrchestrator.server.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAUnC,eAAO,MAAM,wBAAwB,GACnC,aAAa,GAAG,KACf,MAAM,EA8CR,CAAC"}
|
|
@@ -4,6 +4,7 @@ import { vitePluginReactDevServer } from "../dev-server/plugin.server.js";
|
|
|
4
4
|
import { reactStaticPlugin } from "../react-static/plugin.server.js";
|
|
5
5
|
import { createTransformerPlugin } from "../transformer/createTransformerPlugin.js";
|
|
6
6
|
import { virtualRscHmrPlugin } from "../dev-server/virtualRscHmrPlugin.js";
|
|
7
|
+
import { vitePluginVendorAlias } from "../vendor/vendor-alias.js";
|
|
7
8
|
// Server-first orchestrator - only imports server plugins
|
|
8
9
|
export const createPluginOrchestrator = (userOptions) => {
|
|
9
10
|
// Server-first logic - provide all environments for Environment API builds
|
|
@@ -15,6 +16,8 @@ export const createPluginOrchestrator = (userOptions) => {
|
|
|
15
16
|
ssrBuilds: true,
|
|
16
17
|
};
|
|
17
18
|
const plugins = [];
|
|
19
|
+
// Alias react-server-dom-esm to our vendored copy
|
|
20
|
+
plugins.push(vitePluginVendorAlias());
|
|
18
21
|
// Virtual module for RSC HMR utilities (works in both dev and build)
|
|
19
22
|
plugins.push(virtualRscHmrPlugin());
|
|
20
23
|
// Add transformer first so it runs before other plugins
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"register-vendor.d.ts","sourceRoot":"","sources":["../../../plugin/vendor/register-vendor.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Node.js module resolution hook that redirects `react-server-dom-esm/*`
|
|
3
|
+
* to the vendored copy at runtime. Used by the RSC worker via --import.
|
|
4
|
+
*
|
|
5
|
+
* Server entries use ESM wrappers (in esm/) that re-export from CJS
|
|
6
|
+
* so Node's ESM loader can provide named exports.
|
|
7
|
+
*/
|
|
8
|
+
import { register } from "node:module";
|
|
9
|
+
import { dirname, join } from "node:path";
|
|
10
|
+
import { fileURLToPath } from "node:url";
|
|
11
|
+
import { existsSync } from "node:fs";
|
|
12
|
+
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
13
|
+
function findPkgRoot() {
|
|
14
|
+
let dir = __dirname;
|
|
15
|
+
for (let i = 0; i < 5; i++) {
|
|
16
|
+
if (existsSync(join(dir, "oss-experimental", "react-server-dom-esm")))
|
|
17
|
+
return dir;
|
|
18
|
+
dir = dirname(dir);
|
|
19
|
+
}
|
|
20
|
+
return dirname(dirname(__dirname));
|
|
21
|
+
}
|
|
22
|
+
const ossDir = join(findPkgRoot(), "oss-experimental", "react-server-dom-esm");
|
|
23
|
+
register("data:text/javascript," + encodeURIComponent(`
|
|
24
|
+
const ossDir = ${JSON.stringify(ossDir)};
|
|
25
|
+
const { join } = await import("node:path");
|
|
26
|
+
const { pathToFileURL } = await import("node:url");
|
|
27
|
+
|
|
28
|
+
// Map bare specifiers to vendored files. Server entries use ESM wrappers
|
|
29
|
+
// that re-export from CJS for proper named export support.
|
|
30
|
+
const subpathMap = {
|
|
31
|
+
"react-server-dom-esm": join(ossDir, "index.js"),
|
|
32
|
+
"react-server-dom-esm/client": join(ossDir, "client.js"),
|
|
33
|
+
"react-server-dom-esm/client.browser": join(ossDir, "esm", "react-server-dom-esm-client.browser.production.js"),
|
|
34
|
+
"react-server-dom-esm/client.node": join(ossDir, "client.node.js"),
|
|
35
|
+
"react-server-dom-esm/server": join(ossDir, "esm", "react-server-dom-esm-server.node.js"),
|
|
36
|
+
"react-server-dom-esm/server.node": join(ossDir, "esm", "react-server-dom-esm-server.node.js"),
|
|
37
|
+
"react-server-dom-esm/static": join(ossDir, "static.js"),
|
|
38
|
+
"react-server-dom-esm/static.node": join(ossDir, "static.node.js"),
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
export async function resolve(specifier, context, nextResolve) {
|
|
42
|
+
if (specifier in subpathMap) {
|
|
43
|
+
return {
|
|
44
|
+
shortCircuit: true,
|
|
45
|
+
url: pathToFileURL(subpathMap[specifier]).href,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
return nextResolve(specifier, context);
|
|
49
|
+
}
|
|
50
|
+
`), import.meta.url);
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { Plugin } from "vite";
|
|
2
|
+
/**
|
|
3
|
+
* Vite plugin that aliases `react-server-dom-esm/*` imports to the vendored
|
|
4
|
+
* copy shipped with this plugin. This eliminates the need for consumers to
|
|
5
|
+
* install `react-server-dom-esm` separately or use patch-package.
|
|
6
|
+
*
|
|
7
|
+
* Browser client entries use true ESM files for Rollup tree-shaking.
|
|
8
|
+
* Server/static entries are marked external during builds — they're CJS
|
|
9
|
+
* modules loaded at runtime via createRequire in vendor.*.ts files.
|
|
10
|
+
*/
|
|
11
|
+
export declare function vitePluginVendorAlias(): Plugin;
|
|
12
|
+
//# sourceMappingURL=vendor-alias.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vendor-alias.d.ts","sourceRoot":"","sources":["../../../plugin/vendor/vendor-alias.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAmBnC;;;;;;;;GAQG;AACH,wBAAgB,qBAAqB,IAAI,MAAM,CAqD9C"}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import { dirname, join } from "node:path";
|
|
2
|
+
import { fileURLToPath } from "node:url";
|
|
3
|
+
import { existsSync } from "node:fs";
|
|
4
|
+
// Find package root by walking up from current file until we find oss-experimental/
|
|
5
|
+
// Works from both plugin/vendor/ (source) and dist/plugin/vendor/ (built)
|
|
6
|
+
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
7
|
+
function findPkgRoot() {
|
|
8
|
+
let dir = __dirname;
|
|
9
|
+
for (let i = 0; i < 5; i++) {
|
|
10
|
+
if (existsSync(join(dir, "oss-experimental", "react-server-dom-esm")))
|
|
11
|
+
return dir;
|
|
12
|
+
dir = dirname(dir);
|
|
13
|
+
}
|
|
14
|
+
return dirname(dirname(__dirname)); // fallback
|
|
15
|
+
}
|
|
16
|
+
const pkgRoot = findPkgRoot();
|
|
17
|
+
const ossDir = join(pkgRoot, "oss-experimental");
|
|
18
|
+
/**
|
|
19
|
+
* Vite plugin that aliases `react-server-dom-esm/*` imports to the vendored
|
|
20
|
+
* copy shipped with this plugin. This eliminates the need for consumers to
|
|
21
|
+
* install `react-server-dom-esm` separately or use patch-package.
|
|
22
|
+
*
|
|
23
|
+
* Browser client entries use true ESM files for Rollup tree-shaking.
|
|
24
|
+
* Server/static entries are marked external during builds — they're CJS
|
|
25
|
+
* modules loaded at runtime via createRequire in vendor.*.ts files.
|
|
26
|
+
*/
|
|
27
|
+
export function vitePluginVendorAlias() {
|
|
28
|
+
let isBuild = false;
|
|
29
|
+
return {
|
|
30
|
+
name: "vite-plugin-react-server:vendor-alias",
|
|
31
|
+
enforce: "pre",
|
|
32
|
+
config(_config, env) {
|
|
33
|
+
const pkg = join(ossDir, "react-server-dom-esm");
|
|
34
|
+
const isProd = env.mode === "production";
|
|
35
|
+
// Only alias browser client to ESM for Rollup tree-shaking.
|
|
36
|
+
// Server/static are handled by resolveId with external:true.
|
|
37
|
+
return {
|
|
38
|
+
resolve: {
|
|
39
|
+
alias: [
|
|
40
|
+
{
|
|
41
|
+
find: "react-server-dom-esm/client.browser",
|
|
42
|
+
replacement: join(pkg, "esm", isProd
|
|
43
|
+
? "react-server-dom-esm-client.browser.production.js"
|
|
44
|
+
: "react-server-dom-esm-client.browser.development.js")
|
|
45
|
+
},
|
|
46
|
+
],
|
|
47
|
+
},
|
|
48
|
+
};
|
|
49
|
+
},
|
|
50
|
+
configResolved(config) {
|
|
51
|
+
isBuild = config.command === "build";
|
|
52
|
+
},
|
|
53
|
+
resolveId(source) {
|
|
54
|
+
// Only handle react-server-dom-esm specifiers (not already aliased paths)
|
|
55
|
+
if (!source.startsWith("react-server-dom-esm")) {
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
// Skip client.browser — handled by config alias above
|
|
59
|
+
if (source === "react-server-dom-esm/client.browser") {
|
|
60
|
+
return;
|
|
61
|
+
}
|
|
62
|
+
// For server/static entries during build: mark external with resolved path.
|
|
63
|
+
// At runtime, vendor.*.ts uses createRequire to load from this path.
|
|
64
|
+
if (isBuild && isServerEntry(source)) {
|
|
65
|
+
const resolved = resolveVendored(source);
|
|
66
|
+
return { id: resolved, external: true };
|
|
67
|
+
}
|
|
68
|
+
// For all other entries (client.node, client, index), resolve to vendored path
|
|
69
|
+
return resolveVendored(source);
|
|
70
|
+
},
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
function isServerEntry(source) {
|
|
74
|
+
return (source.includes("/server") ||
|
|
75
|
+
source.includes("/static"));
|
|
76
|
+
}
|
|
77
|
+
// Explicit subpath → file mapping. Server entries always resolve to .node
|
|
78
|
+
// variants to bypass the react-server condition guard in server.js.
|
|
79
|
+
const subpathMap = {
|
|
80
|
+
"react-server-dom-esm": "index.js",
|
|
81
|
+
"react-server-dom-esm/client": "client.js",
|
|
82
|
+
"react-server-dom-esm/client.browser": "client.browser.js",
|
|
83
|
+
"react-server-dom-esm/client.node": "client.node.js",
|
|
84
|
+
"react-server-dom-esm/server": "server.node.js",
|
|
85
|
+
"react-server-dom-esm/server.node": "server.node.js",
|
|
86
|
+
"react-server-dom-esm/static": "static.node.js",
|
|
87
|
+
"react-server-dom-esm/static.node": "static.node.js",
|
|
88
|
+
};
|
|
89
|
+
function resolveVendored(source) {
|
|
90
|
+
const file = subpathMap[source];
|
|
91
|
+
if (file) {
|
|
92
|
+
return join(ossDir, "react-server-dom-esm", file);
|
|
93
|
+
}
|
|
94
|
+
// Fallback for unknown subpaths
|
|
95
|
+
const subpath = source.replace("react-server-dom-esm", "");
|
|
96
|
+
return join(ossDir, "react-server-dom-esm", subpath || "index.js");
|
|
97
|
+
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
declare const ReactDOMServer: typeof import("react-dom/server");
|
|
2
1
|
declare const ReactDOMClient: typeof import("react-server-dom-esm/client.node");
|
|
2
|
+
declare const ReactDOMServer: typeof import("react-dom/server");
|
|
3
3
|
declare const React: typeof import("react");
|
|
4
4
|
export { ReactDOMServer, React, ReactDOMClient };
|
|
5
5
|
//# sourceMappingURL=vendor.client.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vendor.client.d.ts","sourceRoot":"","sources":["../../../plugin/vendor/vendor.client.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"vendor.client.d.ts","sourceRoot":"","sources":["../../../plugin/vendor/vendor.client.ts"],"names":[],"mappings":"AAqBA,QAAA,MAAM,cAAc,EAA4E,cAAc,kCAAkC,CAAC,CAAC;AAKlJ,QAAA,MAAM,cAAc,EAAyC,cAAc,kBAAkB,CAAC,CAAC;AAC/F,QAAA,MAAM,KAAK,EAA8B,cAAc,OAAO,CAAC,CAAC;AAEhE,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC"}
|
|
@@ -4,15 +4,28 @@
|
|
|
4
4
|
* MIT License
|
|
5
5
|
*/
|
|
6
6
|
import { createRequire } from 'node:module';
|
|
7
|
-
import { join } from 'node:path';
|
|
7
|
+
import { dirname, join } from 'node:path';
|
|
8
|
+
import { fileURLToPath } from 'node:url';
|
|
9
|
+
import { existsSync } from 'node:fs';
|
|
8
10
|
import { assertNonReactServer } from '../config/getCondition.js';
|
|
9
11
|
|
|
10
12
|
assertNonReactServer();
|
|
13
|
+
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
14
|
+
function findPkgRoot() {
|
|
15
|
+
let dir = __dirname;
|
|
16
|
+
for (let i = 0; i < 5; i++) {
|
|
17
|
+
if (existsSync(join(dir, "oss-experimental", "react-server-dom-esm"))) return dir;
|
|
18
|
+
dir = dirname(dir);
|
|
19
|
+
}
|
|
20
|
+
return dirname(dirname(__dirname));
|
|
21
|
+
}
|
|
22
|
+
const ossDir = join(findPkgRoot(), "oss-experimental");
|
|
23
|
+
const vendorRequire = createRequire(join(ossDir, "react-server-dom-esm", "package.json"));
|
|
24
|
+
const ReactDOMClient = vendorRequire(join(ossDir, "react-server-dom-esm", "client.node.js"));
|
|
11
25
|
const projectRoot = process.env["npm_config_local_prefix"] || process.cwd();
|
|
12
|
-
const
|
|
13
|
-
const ReactDOMServer =
|
|
14
|
-
const
|
|
15
|
-
const React = nodeRequire("react");
|
|
26
|
+
const projectRequire = createRequire(join(projectRoot, "package.json"));
|
|
27
|
+
const ReactDOMServer = projectRequire("react-dom/server");
|
|
28
|
+
const React = projectRequire("react");
|
|
16
29
|
|
|
17
30
|
export { React, ReactDOMClient, ReactDOMServer };
|
|
18
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVuZG9yLmNsaWVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGx1Z2luL3ZlbmRvci92ZW5kb3IuY2xpZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZVJlcXVpcmUgfSBmcm9tIFwibm9kZTptb2R1bGVcIjtcbmltcG9ydCB7IGRpcm5hbWUsIGpvaW4gfSBmcm9tIFwibm9kZTpwYXRoXCI7XG5pbXBvcnQgeyBmaWxlVVJMVG9QYXRoIH0gZnJvbSBcIm5vZGU6dXJsXCI7XG5pbXBvcnQgeyBleGlzdHNTeW5jIH0gZnJvbSBcIm5vZGU6ZnNcIjtcbmltcG9ydCB7IGFzc2VydE5vblJlYWN0U2VydmVyIH0gZnJvbSBcIi4uL2NvbmZpZy9nZXRDb25kaXRpb24uanNcIjtcblxuYXNzZXJ0Tm9uUmVhY3RTZXJ2ZXIoKTtcblxuY29uc3QgX19kaXJuYW1lID0gZGlybmFtZShmaWxlVVJMVG9QYXRoKGltcG9ydC5tZXRhLnVybCkpO1xuZnVuY3Rpb24gZmluZFBrZ1Jvb3QoKTogc3RyaW5nIHtcbiAgbGV0IGRpciA9IF9fZGlybmFtZTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCA1OyBpKyspIHtcbiAgICBpZiAoZXhpc3RzU3luYyhqb2luKGRpciwgXCJvc3MtZXhwZXJpbWVudGFsXCIsIFwicmVhY3Qtc2VydmVyLWRvbS1lc21cIikpKSByZXR1cm4gZGlyO1xuICAgIGRpciA9IGRpcm5hbWUoZGlyKTtcbiAgfVxuICByZXR1cm4gZGlybmFtZShkaXJuYW1lKF9fZGlybmFtZSkpO1xufVxuY29uc3Qgb3NzRGlyID0gam9pbihmaW5kUGtnUm9vdCgpLCBcIm9zcy1leHBlcmltZW50YWxcIik7XG5cbi8vIExvYWQgcmVhY3Qtc2VydmVyLWRvbS1lc20vY2xpZW50Lm5vZGUgZGlyZWN0bHkgZnJvbSB2ZW5kb3JlZCBjb3B5XG5jb25zdCB2ZW5kb3JSZXF1aXJlID0gY3JlYXRlUmVxdWlyZShqb2luKG9zc0RpciwgXCJyZWFjdC1zZXJ2ZXItZG9tLWVzbVwiLCBcInBhY2thZ2UuanNvblwiKSk7XG5jb25zdCBSZWFjdERPTUNsaWVudCA9IHZlbmRvclJlcXVpcmUoam9pbihvc3NEaXIsIFwicmVhY3Qtc2VydmVyLWRvbS1lc21cIiwgXCJjbGllbnQubm9kZS5qc1wiKSkgYXMgdHlwZW9mIGltcG9ydChcInJlYWN0LXNlcnZlci1kb20tZXNtL2NsaWVudC5ub2RlXCIpO1xuXG4vLyBSZWFjdCBhbmQgcmVhY3QtZG9tIHN0aWxsIGNvbWUgZnJvbSB0aGUgY29uc3VtZXIncyBwcm9qZWN0XG5jb25zdCBwcm9qZWN0Um9vdCA9IHByb2Nlc3MuZW52W1wibnBtX2NvbmZpZ19sb2NhbF9wcmVmaXhcIl0gfHwgcHJvY2Vzcy5jd2QoKTtcbmNvbnN0IHByb2plY3RSZXF1aXJlID0gY3JlYXRlUmVxdWlyZShqb2luKHByb2plY3RSb290LCBcInBhY2thZ2UuanNvblwiKSk7XG5jb25zdCBSZWFjdERPTVNlcnZlciA9IHByb2plY3RSZXF1aXJlKFwicmVhY3QtZG9tL3NlcnZlclwiKSBhcyB0eXBlb2YgaW1wb3J0KFwicmVhY3QtZG9tL3NlcnZlclwiKTtcbmNvbnN0IFJlYWN0ID0gcHJvamVjdFJlcXVpcmUoXCJyZWFjdFwiKSBhcyB0eXBlb2YgaW1wb3J0KFwicmVhY3RcIik7XG5cbmV4cG9ydCB7IFJlYWN0RE9NU2VydmVyLCBSZWFjdCwgUmVhY3RET01DbGllbnQgfTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQU1BLG9CQUFxQixFQUFBO0FBRXJCLE1BQU0sU0FBWSxHQUFBLE9BQUEsQ0FBUSxhQUFjLENBQUEsTUFBQSxDQUFBLElBQUEsQ0FBWSxHQUFHLENBQUMsQ0FBQTtBQUN4RCxTQUFTLFdBQXNCLEdBQUE7QUFDN0IsRUFBQSxJQUFJLEdBQU0sR0FBQSxTQUFBO0FBQ1YsRUFBQSxLQUFBLElBQVMsQ0FBSSxHQUFBLENBQUEsRUFBRyxDQUFJLEdBQUEsQ0FBQSxFQUFHLENBQUssRUFBQSxFQUFBO0FBQzFCLElBQUEsSUFBSSxXQUFXLElBQUssQ0FBQSxHQUFBLEVBQUssb0JBQW9CLHNCQUFzQixDQUFDLEdBQVUsT0FBQSxHQUFBO0FBQzlFLElBQUEsR0FBQSxHQUFNLFFBQVEsR0FBRyxDQUFBO0FBQUE7QUFFbkIsRUFBTyxPQUFBLE9BQUEsQ0FBUSxPQUFRLENBQUEsU0FBUyxDQUFDLENBQUE7QUFDbkM7QUFDQSxNQUFNLE1BQVMsR0FBQSxJQUFBLENBQUssV0FBWSxFQUFBLEVBQUcsa0JBQWtCLENBQUE7QUFHckQsTUFBTSxnQkFBZ0IsYUFBYyxDQUFBLElBQUEsQ0FBSyxNQUFRLEVBQUEsc0JBQUEsRUFBd0IsY0FBYyxDQUFDLENBQUE7QUFDeEYsTUFBTSxpQkFBaUIsYUFBYyxDQUFBLElBQUEsQ0FBSyxNQUFRLEVBQUEsc0JBQUEsRUFBd0IsZ0JBQWdCLENBQUM7QUFHM0YsTUFBTSxjQUFjLE9BQVEsQ0FBQSxHQUFBLENBQUkseUJBQXlCLENBQUEsSUFBSyxRQUFRLEdBQUksRUFBQTtBQUMxRSxNQUFNLGNBQWlCLEdBQUEsYUFBQSxDQUFjLElBQUssQ0FBQSxXQUFBLEVBQWEsY0FBYyxDQUFDLENBQUE7QUFDaEUsTUFBQSxjQUFBLEdBQWlCLGVBQWUsa0JBQWtCO0FBQ2xELE1BQUEsS0FBQSxHQUFRLGVBQWUsT0FBTzs7OzsifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vendor.server.d.ts","sourceRoot":"","sources":["../../../plugin/vendor/vendor.server.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"vendor.server.d.ts","sourceRoot":"","sources":["../../../plugin/vendor/vendor.server.ts"],"names":[],"mappings":"AAmBA,QAAA,MAAM,cAAc,EAA4E,cAAc,kCAAkC,CAAC,CAAC;AAKlJ,QAAA,MAAM,KAAK,EAA8B,cAAc,OAAO,CAAC,CAAC;AAEhE,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC;AACjC,mBAAmB,kCAAkC,CAAC;AACtD,MAAM,MAAM,KAAK,GAAG,cAAc,OAAO,CAAC,CAAC"}
|
|
@@ -4,12 +4,25 @@
|
|
|
4
4
|
* MIT License
|
|
5
5
|
*/
|
|
6
6
|
import { createRequire } from 'node:module';
|
|
7
|
-
import { join } from 'node:path';
|
|
7
|
+
import { dirname, join } from 'node:path';
|
|
8
|
+
import { fileURLToPath } from 'node:url';
|
|
9
|
+
import { existsSync } from 'node:fs';
|
|
8
10
|
|
|
11
|
+
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
12
|
+
function findPkgRoot() {
|
|
13
|
+
let dir = __dirname;
|
|
14
|
+
for (let i = 0; i < 5; i++) {
|
|
15
|
+
if (existsSync(join(dir, "oss-experimental", "react-server-dom-esm"))) return dir;
|
|
16
|
+
dir = dirname(dir);
|
|
17
|
+
}
|
|
18
|
+
return dirname(dirname(__dirname));
|
|
19
|
+
}
|
|
20
|
+
const ossDir = join(findPkgRoot(), "oss-experimental");
|
|
21
|
+
const vendorRequire = createRequire(join(ossDir, "react-server-dom-esm", "package.json"));
|
|
22
|
+
const ReactDOMServer = vendorRequire(join(ossDir, "react-server-dom-esm", "server.node.js"));
|
|
9
23
|
const projectRoot = process.env["npm_config_local_prefix"] || process.cwd();
|
|
10
|
-
const
|
|
11
|
-
const
|
|
12
|
-
const React = nodeRequire("react");
|
|
24
|
+
const projectRequire = createRequire(join(projectRoot, "package.json"));
|
|
25
|
+
const React = projectRequire("react");
|
|
13
26
|
|
|
14
27
|
export { React, ReactDOMServer };
|
|
15
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVuZG9yLnNlcnZlci5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGx1Z2luL3ZlbmRvci92ZW5kb3Iuc2VydmVyLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZVJlcXVpcmUgfSBmcm9tIFwibm9kZTptb2R1bGVcIjtcbmltcG9ydCB7IGRpcm5hbWUsIGpvaW4gfSBmcm9tIFwibm9kZTpwYXRoXCI7XG5pbXBvcnQgeyBmaWxlVVJMVG9QYXRoIH0gZnJvbSBcIm5vZGU6dXJsXCI7XG5pbXBvcnQgeyBleGlzdHNTeW5jIH0gZnJvbSBcIm5vZGU6ZnNcIjtcblxuY29uc3QgX19kaXJuYW1lID0gZGlybmFtZShmaWxlVVJMVG9QYXRoKGltcG9ydC5tZXRhLnVybCkpO1xuZnVuY3Rpb24gZmluZFBrZ1Jvb3QoKTogc3RyaW5nIHtcbiAgbGV0IGRpciA9IF9fZGlybmFtZTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCA1OyBpKyspIHtcbiAgICBpZiAoZXhpc3RzU3luYyhqb2luKGRpciwgXCJvc3MtZXhwZXJpbWVudGFsXCIsIFwicmVhY3Qtc2VydmVyLWRvbS1lc21cIikpKSByZXR1cm4gZGlyO1xuICAgIGRpciA9IGRpcm5hbWUoZGlyKTtcbiAgfVxuICByZXR1cm4gZGlybmFtZShkaXJuYW1lKF9fZGlybmFtZSkpO1xufVxuY29uc3Qgb3NzRGlyID0gam9pbihmaW5kUGtnUm9vdCgpLCBcIm9zcy1leHBlcmltZW50YWxcIik7XG5cbi8vIExvYWQgcmVhY3Qtc2VydmVyLWRvbS1lc20vc2VydmVyLm5vZGUgZGlyZWN0bHkgZnJvbSB2ZW5kb3JlZCBjb3B5XG4vLyBVc2Ugc2VydmVyLm5vZGUuanMgKG5vdCBzZXJ2ZXIuanMgd2hpY2ggaXMgYSByZWFjdC1zZXJ2ZXIgY29uZGl0aW9uIGd1YXJkKVxuY29uc3QgdmVuZG9yUmVxdWlyZSA9IGNyZWF0ZVJlcXVpcmUoam9pbihvc3NEaXIsIFwicmVhY3Qtc2VydmVyLWRvbS1lc21cIiwgXCJwYWNrYWdlLmpzb25cIikpO1xuY29uc3QgUmVhY3RET01TZXJ2ZXIgPSB2ZW5kb3JSZXF1aXJlKGpvaW4ob3NzRGlyLCBcInJlYWN0LXNlcnZlci1kb20tZXNtXCIsIFwic2VydmVyLm5vZGUuanNcIikpIGFzIHR5cGVvZiBpbXBvcnQoXCJyZWFjdC1zZXJ2ZXItZG9tLWVzbS9zZXJ2ZXIubm9kZVwiKTtcblxuLy8gUmVhY3Qgc3RpbGwgY29tZXMgZnJvbSB0aGUgY29uc3VtZXIncyBwcm9qZWN0XG5jb25zdCBwcm9qZWN0Um9vdCA9IHByb2Nlc3MuZW52W1wibnBtX2NvbmZpZ19sb2NhbF9wcmVmaXhcIl0gfHwgcHJvY2Vzcy5jd2QoKTtcbmNvbnN0IHByb2plY3RSZXF1aXJlID0gY3JlYXRlUmVxdWlyZShqb2luKHByb2plY3RSb290LCBcInBhY2thZ2UuanNvblwiKSk7XG5jb25zdCBSZWFjdCA9IHByb2plY3RSZXF1aXJlKFwicmVhY3RcIikgYXMgdHlwZW9mIGltcG9ydChcInJlYWN0XCIpO1xuXG5leHBvcnQgeyBSZWFjdERPTVNlcnZlciwgUmVhY3QgfTtcbmV4cG9ydCB0eXBlICogZnJvbSBcInJlYWN0LXNlcnZlci1kb20tZXNtL3NlcnZlci5ub2RlXCI7XG5leHBvcnQgdHlwZSBSZWFjdCA9IHR5cGVvZiBpbXBvcnQoXCJyZWFjdFwiKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7O0FBS0EsTUFBTSxTQUFZLEdBQUEsT0FBQSxDQUFRLGFBQWMsQ0FBQSxNQUFBLENBQUEsSUFBQSxDQUFZLEdBQUcsQ0FBQyxDQUFBO0FBQ3hELFNBQVMsV0FBc0IsR0FBQTtBQUM3QixFQUFBLElBQUksR0FBTSxHQUFBLFNBQUE7QUFDVixFQUFBLEtBQUEsSUFBUyxDQUFJLEdBQUEsQ0FBQSxFQUFHLENBQUksR0FBQSxDQUFBLEVBQUcsQ0FBSyxFQUFBLEVBQUE7QUFDMUIsSUFBQSxJQUFJLFdBQVcsSUFBSyxDQUFBLEdBQUEsRUFBSyxvQkFBb0Isc0JBQXNCLENBQUMsR0FBVSxPQUFBLEdBQUE7QUFDOUUsSUFBQSxHQUFBLEdBQU0sUUFBUSxHQUFHLENBQUE7QUFBQTtBQUVuQixFQUFPLE9BQUEsT0FBQSxDQUFRLE9BQVEsQ0FBQSxTQUFTLENBQUMsQ0FBQTtBQUNuQztBQUNBLE1BQU0sTUFBUyxHQUFBLElBQUEsQ0FBSyxXQUFZLEVBQUEsRUFBRyxrQkFBa0IsQ0FBQTtBQUlyRCxNQUFNLGdCQUFnQixhQUFjLENBQUEsSUFBQSxDQUFLLE1BQVEsRUFBQSxzQkFBQSxFQUF3QixjQUFjLENBQUMsQ0FBQTtBQUN4RixNQUFNLGlCQUFpQixhQUFjLENBQUEsSUFBQSxDQUFLLE1BQVEsRUFBQSxzQkFBQSxFQUF3QixnQkFBZ0IsQ0FBQztBQUczRixNQUFNLGNBQWMsT0FBUSxDQUFBLEdBQUEsQ0FBSSx5QkFBeUIsQ0FBQSxJQUFLLFFBQVEsR0FBSSxFQUFBO0FBQzFFLE1BQU0sY0FBaUIsR0FBQSxhQUFBLENBQWMsSUFBSyxDQUFBLFdBQUEsRUFBYSxjQUFjLENBQUMsQ0FBQTtBQUNoRSxNQUFBLEtBQUEsR0FBUSxlQUFlLE9BQU87Ozs7In0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vendor.static.d.ts","sourceRoot":"","sources":["../../../plugin/vendor/vendor.static.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"vendor.static.d.ts","sourceRoot":"","sources":["../../../plugin/vendor/vendor.static.ts"],"names":[],"mappings":"AAkBA,QAAA,MAAM,cAAc,EAA4E,cAAc,kCAAkC,CAAC,CAAC;AAKlJ,QAAA,MAAM,KAAK,EAA8B,cAAc,OAAO,CAAC,CAAC;AAEhE,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC"}
|
|
@@ -4,12 +4,25 @@
|
|
|
4
4
|
* MIT License
|
|
5
5
|
*/
|
|
6
6
|
import { createRequire } from 'node:module';
|
|
7
|
-
import { join } from 'node:path';
|
|
7
|
+
import { dirname, join } from 'node:path';
|
|
8
|
+
import { fileURLToPath } from 'node:url';
|
|
9
|
+
import { existsSync } from 'node:fs';
|
|
8
10
|
|
|
11
|
+
const __dirname = dirname(fileURLToPath(import.meta.url));
|
|
12
|
+
function findPkgRoot() {
|
|
13
|
+
let dir = __dirname;
|
|
14
|
+
for (let i = 0; i < 5; i++) {
|
|
15
|
+
if (existsSync(join(dir, "oss-experimental", "react-server-dom-esm"))) return dir;
|
|
16
|
+
dir = dirname(dir);
|
|
17
|
+
}
|
|
18
|
+
return dirname(dirname(__dirname));
|
|
19
|
+
}
|
|
20
|
+
const ossDir = join(findPkgRoot(), "oss-experimental");
|
|
21
|
+
const vendorRequire = createRequire(join(ossDir, "react-server-dom-esm", "package.json"));
|
|
22
|
+
const ReactDOMServer = vendorRequire(join(ossDir, "react-server-dom-esm", "static.node.js"));
|
|
9
23
|
const projectRoot = process.env["npm_config_local_prefix"] || process.cwd();
|
|
10
|
-
const
|
|
11
|
-
const
|
|
12
|
-
const React = nodeRequire("react");
|
|
24
|
+
const projectRequire = createRequire(join(projectRoot, "package.json"));
|
|
25
|
+
const React = projectRequire("react");
|
|
13
26
|
|
|
14
27
|
export { React, ReactDOMServer };
|
|
15
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVuZG9yLnN0YXRpYy5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcGx1Z2luL3ZlbmRvci92ZW5kb3Iuc3RhdGljLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZVJlcXVpcmUgfSBmcm9tIFwibm9kZTptb2R1bGVcIjtcbmltcG9ydCB7IGRpcm5hbWUsIGpvaW4gfSBmcm9tIFwibm9kZTpwYXRoXCI7XG5pbXBvcnQgeyBmaWxlVVJMVG9QYXRoIH0gZnJvbSBcIm5vZGU6dXJsXCI7XG5pbXBvcnQgeyBleGlzdHNTeW5jIH0gZnJvbSBcIm5vZGU6ZnNcIjtcblxuY29uc3QgX19kaXJuYW1lID0gZGlybmFtZShmaWxlVVJMVG9QYXRoKGltcG9ydC5tZXRhLnVybCkpO1xuZnVuY3Rpb24gZmluZFBrZ1Jvb3QoKTogc3RyaW5nIHtcbiAgbGV0IGRpciA9IF9fZGlybmFtZTtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCA1OyBpKyspIHtcbiAgICBpZiAoZXhpc3RzU3luYyhqb2luKGRpciwgXCJvc3MtZXhwZXJpbWVudGFsXCIsIFwicmVhY3Qtc2VydmVyLWRvbS1lc21cIikpKSByZXR1cm4gZGlyO1xuICAgIGRpciA9IGRpcm5hbWUoZGlyKTtcbiAgfVxuICByZXR1cm4gZGlybmFtZShkaXJuYW1lKF9fZGlybmFtZSkpO1xufVxuY29uc3Qgb3NzRGlyID0gam9pbihmaW5kUGtnUm9vdCgpLCBcIm9zcy1leHBlcmltZW50YWxcIik7XG5cbi8vIExvYWQgcmVhY3Qtc2VydmVyLWRvbS1lc20vc3RhdGljLm5vZGUgZGlyZWN0bHkgZnJvbSB2ZW5kb3JlZCBjb3B5XG5jb25zdCB2ZW5kb3JSZXF1aXJlID0gY3JlYXRlUmVxdWlyZShqb2luKG9zc0RpciwgXCJyZWFjdC1zZXJ2ZXItZG9tLWVzbVwiLCBcInBhY2thZ2UuanNvblwiKSk7XG5jb25zdCBSZWFjdERPTVNlcnZlciA9IHZlbmRvclJlcXVpcmUoam9pbihvc3NEaXIsIFwicmVhY3Qtc2VydmVyLWRvbS1lc21cIiwgXCJzdGF0aWMubm9kZS5qc1wiKSkgYXMgdHlwZW9mIGltcG9ydChcInJlYWN0LXNlcnZlci1kb20tZXNtL3N0YXRpYy5ub2RlXCIpO1xuXG4vLyBSZWFjdCBzdGlsbCBjb21lcyBmcm9tIHRoZSBjb25zdW1lcidzIHByb2plY3RcbmNvbnN0IHByb2plY3RSb290ID0gcHJvY2Vzcy5lbnZbXCJucG1fY29uZmlnX2xvY2FsX3ByZWZpeFwiXSB8fCBwcm9jZXNzLmN3ZCgpO1xuY29uc3QgcHJvamVjdFJlcXVpcmUgPSBjcmVhdGVSZXF1aXJlKGpvaW4ocHJvamVjdFJvb3QsIFwicGFja2FnZS5qc29uXCIpKTtcbmNvbnN0IFJlYWN0ID0gcHJvamVjdFJlcXVpcmUoXCJyZWFjdFwiKSBhcyB0eXBlb2YgaW1wb3J0KFwicmVhY3RcIik7XG5cbmV4cG9ydCB7IFJlYWN0RE9NU2VydmVyLCBSZWFjdCB9O1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7QUFLQSxNQUFNLFNBQVksR0FBQSxPQUFBLENBQVEsYUFBYyxDQUFBLE1BQUEsQ0FBQSxJQUFBLENBQVksR0FBRyxDQUFDLENBQUE7QUFDeEQsU0FBUyxXQUFzQixHQUFBO0FBQzdCLEVBQUEsSUFBSSxHQUFNLEdBQUEsU0FBQTtBQUNWLEVBQUEsS0FBQSxJQUFTLENBQUksR0FBQSxDQUFBLEVBQUcsQ0FBSSxHQUFBLENBQUEsRUFBRyxDQUFLLEVBQUEsRUFBQTtBQUMxQixJQUFBLElBQUksV0FBVyxJQUFLLENBQUEsR0FBQSxFQUFLLG9CQUFvQixzQkFBc0IsQ0FBQyxHQUFVLE9BQUEsR0FBQTtBQUM5RSxJQUFBLEdBQUEsR0FBTSxRQUFRLEdBQUcsQ0FBQTtBQUFBO0FBRW5CLEVBQU8sT0FBQSxPQUFBLENBQVEsT0FBUSxDQUFBLFNBQVMsQ0FBQyxDQUFBO0FBQ25DO0FBQ0EsTUFBTSxNQUFTLEdBQUEsSUFBQSxDQUFLLFdBQVksRUFBQSxFQUFHLGtCQUFrQixDQUFBO0FBR3JELE1BQU0sZ0JBQWdCLGFBQWMsQ0FBQSxJQUFBLENBQUssTUFBUSxFQUFBLHNCQUFBLEVBQXdCLGNBQWMsQ0FBQyxDQUFBO0FBQ3hGLE1BQU0saUJBQWlCLGFBQWMsQ0FBQSxJQUFBLENBQUssTUFBUSxFQUFBLHNCQUFBLEVBQXdCLGdCQUFnQixDQUFDO0FBRzNGLE1BQU0sY0FBYyxPQUFRLENBQUEsR0FBQSxDQUFJLHlCQUF5QixDQUFBLElBQUssUUFBUSxHQUFJLEVBQUE7QUFDMUUsTUFBTSxjQUFpQixHQUFBLGFBQUEsQ0FBYyxJQUFLLENBQUEsV0FBQSxFQUFhLGNBQWMsQ0FBQyxDQUFBO0FBQ2hFLE1BQUEsS0FBQSxHQUFRLGVBQWUsT0FBTzs7OzsifQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createWorker.d.ts","sourceRoot":"","sources":["../../../plugin/worker/createWorker.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"createWorker.d.ts","sourceRoot":"","sources":["../../../plugin/worker/createWorker.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,MAAM,EACN,KAAK,cAAc,EACnB,KAAK,gBAAgB,EACrB,KAAK,WAAW,EACjB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAOtC,OAAO,EAAgB,KAAK,MAAM,EAAE,MAAM,MAAM,CAAC;AAGjD,OAAO,KAAK,EACV,wBAAwB,EACxB,qBAAqB,EACtB,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AACrC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAQ3C,wBAAsB,kBAAkB,CAAC,OAAO,GAAE,MAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAuD9E;AAGD,KAAK,mBAAmB,GAAG;IACzB,IAAI,EAAE,SAAS,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,KAAK,CAAC;IACf,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,KAAK,iBAAiB,GAAG;IACvB,IAAI,EAAE,OAAO,CAAC;IACd,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC;IACpB,MAAM,CAAC,EAAE,KAAK,CAAC;IACf,MAAM,CAAC,EAAE,KAAK,CAAC;CAChB,CAAC;AAEF,KAAK,gBAAgB,GAAG;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,KAAK,CAAC;IACf,KAAK,CAAC,EAAE,KAAK,CAAC;CACf,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAC1B,mBAAmB,GACnB,iBAAiB,GACjB,gBAAgB,CAAC;AAErB,MAAM,MAAM,mBAAmB,GAAG;IAChC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,gBAAgB,CAAC,EAAE,cAAc,GAAG,cAAc,CAAC;IACnD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,IAAI,CAAC,EAAE,YAAY,GAAG,aAAa,GAAG,MAAM,CAAC;IAC7C,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,UAAU,EAAE;QACV,WAAW,CAAC,EAAE,qBAAqB,CAAC;QACpC,cAAc,CAAC,EAAE,wBAAwB,CAAC;QAC1C,SAAS,CAAC,EAAE,SAAS,CAAC;QACtB,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,EAAE,CAAC,EAAE,MAAM,CAAC;QACZ,cAAc,CAAC,EAAE,QAAQ,CAAC;QAC1B,MAAM,CAAC,EAAE,YAAY,CAAC;QACtB,YAAY,CAAC,EAAE,YAAY,CAAC;QAC5B,2BAA2B,CAAC,EAAE,GAAG,CAAC;QAClC,2BAA2B,CAAC,EAAE,GAAG,CAAC;QAClC,OAAO,CAAC,EAAE,WAAW,CAAC;KACvB,CAAC;IACF,YAAY,CAAC,EAAE,gBAAgB,EAAE,CAAC;IAClC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,CAC3B,OAAO,EAAE,mBAAmB,KACzB,OAAO,CAAC,kBAAkB,CAAC,CAAC;AAEjC,eAAO,MAAM,YAAY,EAAE,cAiU1B,CAAC"}
|
|
@@ -136,10 +136,13 @@ Current condition: ${currentCondition}, Reverse condition: ${reverseCondition}`
|
|
|
136
136
|
}
|
|
137
137
|
return out;
|
|
138
138
|
};
|
|
139
|
+
const vendorRegisterPath = new URL("../vendor/register-vendor.js", import.meta.url).href;
|
|
139
140
|
const computedExecArgv = [
|
|
140
141
|
...stripConditionsFromArgv(process.execArgv || []),
|
|
141
142
|
"--conditions",
|
|
142
|
-
reverseCondition
|
|
143
|
+
reverseCondition,
|
|
144
|
+
"--import",
|
|
145
|
+
vendorRegisterPath
|
|
143
146
|
];
|
|
144
147
|
if (verbose) {
|
|
145
148
|
logger.info(
|
|
@@ -315,4 +318,4 @@ ${err.stack}`,
|
|
|
315
318
|
};
|
|
316
319
|
|
|
317
320
|
export { createWorker, shutdownAllWorkers };
|
|
318
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"createWorker.js","sources":["../../../plugin/worker/createWorker.ts"],"sourcesContent":["import {\n  Worker,\n  type ResourceLimits,\n  type TransferListItem,\n  type MessagePort,\n} from \"node:worker_threads\";\nimport type { ConfigEnv } from \"vite\";\nimport { getMode, getNodePath } from \"../config/getPaths.js\";\nimport { getCondition } from \"../config/getCondition.js\";\nimport { join } from \"node:path\";\nimport { existsSync } from \"node:fs\";\nimport { pluginRoot } from \"../root.js\";\nimport { DEFAULT_CONFIG } from \"../config/defaults.js\";\nimport { createLogger, type Logger } from \"vite\";\nimport type { HtmlWorkerOutputMessage } from \"./html/types.js\";\nimport type { RscWorkerOutputMessage } from \"./rsc/types.js\";\nimport type {\n  SerializedResolvedConfig,\n  SerializedUserOptions,\n} from \"../types.js\";\nimport type { Manifest } from \"vite\";\nimport type { OutputBundle } from \"rollup\";\nimport { handleError } from \"../error/handleError.js\";\nimport { toError } from \"../error/toError.js\";\n\n// Global worker registry for graceful shutdown\nconst activeWorkers = new Set<Worker>();\n\n// Graceful shutdown function using the existing SHUTDOWN protocol\nexport async function shutdownAllWorkers(timeout: number = 1000): Promise<void> {\n  if (activeWorkers.size === 0) return;\n\n  const shutdownPromises = Array.from(activeWorkers).map(worker => {\n    return new Promise<void>((resolve) => {\n      let messageHandler: ((message: any) => void) | undefined;\n      \n      const timeoutId = setTimeout(() => {\n        worker.removeListener(\"message\", messageHandler!);\n        worker.removeAllListeners();\n        try {\n          worker.terminate();\n        } catch (error) {\n          // Ignore termination errors\n        }\n        activeWorkers.delete(worker);\n        resolve();\n      }, timeout);\n\n      messageHandler = (message: any) => {\n        if (message.type === \"SHUTDOWN_COMPLETE\") {\n          clearTimeout(timeoutId);\n          worker.removeListener(\"message\", messageHandler!);\n          worker.removeAllListeners();\n          activeWorkers.delete(worker);\n          resolve();\n        }\n      };\n\n      worker.on(\"message\", messageHandler);\n      \n      // Send graceful shutdown message\n      try {\n        worker.postMessage({\n          type: \"SHUTDOWN\",\n          id: \"*\",\n        });\n      } catch (error) {\n        // If we can't send the message, force terminate\n        clearTimeout(timeoutId);\n        worker.removeListener(\"message\", messageHandler!);\n        worker.removeAllListeners();\n        try {\n          worker.terminate();\n        } catch (terminateError) {\n          // Ignore termination errors\n        }\n        activeWorkers.delete(worker);\n        resolve();\n      }\n    });\n  });\n\n  await Promise.all(shutdownPromises);\n  activeWorkers.clear();\n}\n\n\ntype CreateWorkerSuccess = {\n  type: \"success\";\n  workerPath: string;\n  reason?: never;\n  error?: never;\n  worker: Worker;\n};\n\ntype CreateWorkerError = {\n  type: \"error\";\n  workerPath: string;\n  error: Error | null;\n  worker?: never;\n  reason?: never;\n};\n\ntype CreateWorkerSkip = {\n  type: \"skip\";\n  reason: string;\n  workerPath: string;\n  worker?: never;\n  error?: never;\n};\n\nexport type CreateWorkerReturn =\n  | CreateWorkerSuccess\n  | CreateWorkerError\n  | CreateWorkerSkip;\n\nexport type CreateWorkerOptions = {\n  projectRoot?: string;\n  currentCondition?: \"react-server\" | \"react-client\";\n  nodePath?: string;\n  nodeOptions?: string[];\n  envPrefix?: string;\n  mode?: \"production\" | \"development\" | \"test\";\n  reverseCondition?: string;\n  maxListeners?: number;\n  workerPath?: string;\n  resourceLimits?: ResourceLimits;\n  typescript?: boolean;\n  htmlChunkSize?: number; // Size of HTML chunks in bytes\n  workerData: {\n    userOptions?: SerializedUserOptions;\n    resolvedConfig?: SerializedResolvedConfig;\n    configEnv?: ConfigEnv;\n    reactVersion?: string;\n    id?: string;\n    serverManifest?: Manifest;\n    bundle?: OutputBundle;\n    staticBundle?: OutputBundle;\n    serverPipeableStreamOptions?: any;\n    clientPipeableStreamOptions?: any;\n    hmrPort?: MessagePort;\n  };\n  transferList?: TransferListItem[];\n  logger?: Logger;\n  verbose?: boolean;\n};\n\nexport type CreateWorkerFn = (\n  options: CreateWorkerOptions\n) => Promise<CreateWorkerReturn>;\n\nexport const createWorker: CreateWorkerFn = async function _createWorker(\n  options\n) {\n  const {\n    projectRoot = process.cwd(),\n    nodePath = getNodePath(projectRoot),\n    currentCondition = getCondition(),\n    envPrefix = DEFAULT_CONFIG.ENV_PREFIX,\n    reverseCondition = currentCondition === \"react-server\"\n      ? \"react-client\"\n      : \"react-server\",\n    maxListeners = 100,\n    mode = getMode(),\n    workerPath,\n    resourceLimits = {\n      maxOldGenerationSizeMb: 128,\n      maxYoungGenerationSizeMb: 64,\n    },\n    htmlChunkSize = 8 * 1024,\n    transferList = [],\n    logger = createLogger(),\n    verbose = false,\n  } = options;\n  const id = reverseCondition === \"react-server\" ? \"worker/rsc\" : \"worker/html\";\n  let workerPathWithDefault =\n    typeof workerPath === \"string\" ? workerPath : undefined;\n  if (!workerPathWithDefault) {\n    // Use the default worker paths that include the full filename\n    const isProduction = mode === \"production\";\n    const workerFileName =\n      reverseCondition === \"react-server\"\n        ? `rsc-worker.${isProduction ? \"production\" : \"development\"}.js`\n        : `html-worker.${isProduction ? \"production\" : \"development\"}.js`;\n\n    // Try source directory first\n    const sourcePath = join(pluginRoot, id, workerFileName);\n\n    // Always log the paths for debugging\n    if (verbose) {\n      logger.info(\n        `[create:${id}] Checking paths - Source: ${sourcePath}, PluginRoot: ${pluginRoot}`\n      );\n    }\n\n    // If source path doesn't exist, try built directory\n    if (!existsSync(sourcePath)) {\n      throw new Error(\n        `[create:${id}] Worker file doesn't exist: ${sourcePath}`\n      );\n      // const builtPath = join(pluginRoot.replace(\"/plugin/\", \"/dist/plugin/\"), id, workerFileName);\n      // logger.info(`[create:${id}] Source path doesn't exist, checking built path: ${builtPath}`);\n\n      // if (existsSync(builtPath)) {\n      //   workerPathWithDefault = builtPath;\n      //   logger.info(`[create:${id}] Using built worker path: ${builtPath}`);\n      // } else {\n      //   workerPathWithDefault = sourcePath; // Fallback to source path for error message\n      //   logger.info(`[create:${id}] Neither source nor built path exists. Source: ${sourcePath}, Built: ${builtPath}`);\n      // }\n    } else {\n      workerPathWithDefault = sourcePath;\n      if (verbose) {\n        logger.info(`[create:${id}] Using source worker path: ${sourcePath}`);\n      }\n    }\n  }\n  if (!workerPathWithDefault.startsWith(\"/\")) {\n    workerPathWithDefault = join(\"./\", workerPathWithDefault);\n  }\n  // Ensure worker uses the same React version\n  const workerData = {\n    ...options.workerData,\n    id: options.workerData.id ?? id,\n  };\n\n  try {\n    // Ensure consistent NODE_ENV between main thread and worker\n\n    if (verbose) {\n      logger.info(\n        `[create:${id}] workerData.userOptions.build:\n${JSON.stringify(workerData.userOptions?.build)}\n\nCall stack: ${new Error().stack?.split(\"\\n\").slice(1, 4).join(\"\\n\")}\nCreating worker with path: ${workerPathWithDefault}\nNode environment: ${mode}\nCurrent condition: ${currentCondition}, Reverse condition: ${reverseCondition}`\n      );\n    }\n\n    // Compute execArgv for the worker with exactly one --conditions flag\n    const stripConditionsFromArgv = (argv: string[]) => {\n      const out: string[] = [];\n      for (let i = 0; i < argv.length; i++) {\n        const arg = argv[i];\n        if (arg === \"--conditions\" || arg === \"-C\") {\n          i++; // skip value\n          continue;\n        }\n        if (arg.startsWith(\"--conditions=\")) {\n          continue;\n        }\n        out.push(arg);\n      }\n      return out;\n    };\n    const computedExecArgv = [\n      ...stripConditionsFromArgv(process.execArgv || []),\n      \"--conditions\",\n      reverseCondition,\n    ];\n\n    // Always log the condition setup for debugging\n    if (verbose) {\n      logger.info(\n        `[create:${id}] Setting up worker with reverse condition: ${reverseCondition}`\n      );\n      logger.info(\n        `[create:${id}] Computed execArgv: ${JSON.stringify(computedExecArgv)}`\n      );\n      logger.info(\n        `[create:${id}] Current NODE_OPTIONS: ${process.env[\"NODE_OPTIONS\"]}`\n      );\n    }\n\n    const env = {\n      // Inherit all existing environment variables\n      ...process.env,\n\n      // Override with our specific variables\n      [envPrefix + \"DEV\"]: mode === \"development\" ? \"1\" : \"0\",\n      [envPrefix + \"MODE\"]: mode,\n      [envPrefix + \"PROD\"]: mode === \"production\" ? \"1\" : \"0\",\n      [envPrefix + \"SSR\"]: \"true\",\n      [envPrefix + \"BASE_URL\"]: workerData.userOptions?.moduleBaseURL ?? \"\",\n      [envPrefix + \"PUBLIC_ORIGIN\"]: workerData.userOptions?.publicOrigin ?? \"\",\n      NODE_ENV: process.env[\"NODE_ENV\"] ?? \"production\",\n      NODE_PATH: nodePath,\n\n      // Ensure NODE_OPTIONS has the correct condition\n      NODE_OPTIONS: process.env[\"NODE_OPTIONS\"]?.includes(reverseCondition)\n        ? process.env[\"NODE_OPTIONS\"]\n        : currentCondition != null &&\n          process.env[\"NODE_OPTIONS\"]?.includes(currentCondition)\n        ? process.env[\"NODE_OPTIONS\"]?.replaceAll(\n            currentCondition,\n            reverseCondition\n          )\n        : `${\n            process.env[\"NODE_OPTIONS\"] ?? \"\"\n          } --conditions ${reverseCondition}`,\n      HTML_CHUNK_SIZE: htmlChunkSize.toString(),\n    };\n\n    if (verbose) {\n      // Always log the NODE_OPTIONS for debugging\n      logger.info(\n        `[create:${id}] Worker NODE_OPTIONS will be: ${env.NODE_OPTIONS}`\n      );\n      logger.info(\n        `[create:${id}] Environment variables: ${Object.keys(env).join(\", \")}`\n      );\n      logger.info(`[create:${id}] execArgv: ${computedExecArgv.join(\" \")}`);\n    }\n\n    // Create worker with proper environment and loaders\n    const worker = new Worker(workerPathWithDefault, {\n      env,\n      execArgv: computedExecArgv,\n      resourceLimits,\n      workerData,\n      transferList,\n    });\n\n    // Register worker for graceful shutdown\n    activeWorkers.add(worker);\n\n    worker.setMaxListeners(maxListeners);\n\n    if (verbose) {\n      logger.info(\n        `[create:${id}] Worker created, waiting for READY message...`\n      );\n    }\n\n    return await new Promise<CreateWorkerSuccess | CreateWorkerSkip>(\n      (resolve, reject) => {\n        // Use appropriate timeout based on worker type\n        const workerType = reverseCondition === \"react-server\" ? \"rsc\" : \"html\";\n        const startupTimeout =\n          workerType === \"rsc\"\n            ? options.workerData.userOptions?.rscWorkerStartupTimeout\n            : options.workerData.userOptions?.htmlWorkerStartupTimeout;\n\n        const timeout = setTimeout(() => {\n          reject({ type: \"error\", error: new Error(\"Worker ready timeout\") });\n        }, startupTimeout);\n        const exitHandler = (code: number) => {\n          clearTimeout(timeout);\n          worker.removeListener(\"message\", messageHandler);\n          // Remove worker from registry when it exits\n          activeWorkers.delete(worker);\n          // Do not remove exit handler here, let it fire if needed\n          if (code !== 0) {\n            reject({\n              type: \"error\",\n              error: new Error(\n                `[create:${id}] Worker exited with code ${code}`\n              ),\n              workerPath: workerPathWithDefault,\n            });\n          }\n        };\n        const messageHandler = (\n          msg: RscWorkerOutputMessage | HtmlWorkerOutputMessage\n        ) => {\n          if (verbose)\n            logger.info(`[create:${id}] Initial worker message ${msg.type}`);\n          if (msg.type === \"READY\" && msg.id === id) {\n            if (verbose)\n              logger.info(`[create:${id}] Worker running for ${msg.env}`);\n            clearTimeout(timeout);\n            worker.removeListener(\"message\", messageHandler);\n            worker.removeListener(\"exit\", exitHandler);\n            if (msg.env !== mode) {\n              if (verbose)\n                logger.info(`[create:${id}] Worker environment mismatch.`);\n              reject({\n                type: \"error\",\n                error: new Error(\n                  `Worker environment mismatch: ${msg.env} !== ${mode}`\n                ),\n                workerPath: workerPathWithDefault,\n              } satisfies CreateWorkerError);\n            }\n            resolve({\n              type: \"success\",\n              worker,\n              workerPath: workerPathWithDefault,\n            } satisfies CreateWorkerSuccess);\n          }\n        };\n        worker.once(\"message\", messageHandler);\n        worker.once(\"exit\", exitHandler);\n        worker.on(\"error\", (err) => {\n          // Remove worker from registry on error\n          activeWorkers.delete(worker);\n          \n          if (verbose && err != null) {\n            logger.error(\n              `[create:${id}] Worker error: ${err.message}.\\n${err.stack}`,\n              { error: err }\n            );\n          }\n          const panicError = handleError({\n            error: err,\n            logger: logger,\n            panicThreshold: workerData.userOptions?.panicThreshold,\n            critical: false,\n            context: `Worker thread error for route ${id}`,\n          });\n          if (panicError != null) {\n            if (verbose) {\n              logger.error(\n                `[create:${id}] Panic error detected: ${panicError.message}`,\n                { error: panicError }\n              );\n            }\n            reject({\n              type: \"error\",\n              error: err,\n              workerPath: workerPathWithDefault,\n            });\n          }\n          reject({\n            type: \"error\",\n            error: new Error(\"Worker thread error\", { cause: err }),\n            workerPath: workerPathWithDefault,\n          });\n        });\n      }\n    );\n  } catch (error) {\n    if (verbose) {\n      logger.error(\n        `[create:${id}] Caught error during worker creation: ${\n          toError(error).message\n        }`,\n        { error: error instanceof Error ? error : new Error(String(error)) }\n      );\n    }\n    const panicError = handleError({\n      error: error,\n      logger: logger,\n      panicThreshold: workerData.userOptions?.panicThreshold,\n      critical: false,\n      context: `Worker thread error for route ${id}`,\n    });\n    if (panicError != null) {\n      if (verbose) {\n        logger.error(\n          `[create:${id}] Panic error in catch block: ${panicError.message}`,\n          { error: panicError }\n        );\n      }\n      return {\n        type: \"error\",\n        error: panicError,\n        workerPath: workerPathWithDefault,\n      };\n    }\n    return {\n      type: \"error\",\n      error: error instanceof Error ? error : new Error(String(error)),\n      workerPath: workerPathWithDefault,\n    };\n  }\n};\n"],"names":[],"mappings":"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"}
|
|
321
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"createWorker.js","sources":["../../../plugin/worker/createWorker.ts"],"sourcesContent":["import {\n  Worker,\n  type ResourceLimits,\n  type TransferListItem,\n  type MessagePort,\n} from \"node:worker_threads\";\nimport type { ConfigEnv } from \"vite\";\nimport { getMode, getNodePath } from \"../config/getPaths.js\";\nimport { getCondition } from \"../config/getCondition.js\";\nimport { join } from \"node:path\";\nimport { existsSync } from \"node:fs\";\nimport { pluginRoot } from \"../root.js\";\nimport { DEFAULT_CONFIG } from \"../config/defaults.js\";\nimport { createLogger, type Logger } from \"vite\";\nimport type { HtmlWorkerOutputMessage } from \"./html/types.js\";\nimport type { RscWorkerOutputMessage } from \"./rsc/types.js\";\nimport type {\n  SerializedResolvedConfig,\n  SerializedUserOptions,\n} from \"../types.js\";\nimport type { Manifest } from \"vite\";\nimport type { OutputBundle } from \"rollup\";\nimport { handleError } from \"../error/handleError.js\";\nimport { toError } from \"../error/toError.js\";\n\n// Global worker registry for graceful shutdown\nconst activeWorkers = new Set<Worker>();\n\n// Graceful shutdown function using the existing SHUTDOWN protocol\nexport async function shutdownAllWorkers(timeout: number = 1000): Promise<void> {\n  if (activeWorkers.size === 0) return;\n\n  const shutdownPromises = Array.from(activeWorkers).map(worker => {\n    return new Promise<void>((resolve) => {\n      let messageHandler: ((message: any) => void) | undefined;\n      \n      const timeoutId = setTimeout(() => {\n        worker.removeListener(\"message\", messageHandler!);\n        worker.removeAllListeners();\n        try {\n          worker.terminate();\n        } catch (error) {\n          // Ignore termination errors\n        }\n        activeWorkers.delete(worker);\n        resolve();\n      }, timeout);\n\n      messageHandler = (message: any) => {\n        if (message.type === \"SHUTDOWN_COMPLETE\") {\n          clearTimeout(timeoutId);\n          worker.removeListener(\"message\", messageHandler!);\n          worker.removeAllListeners();\n          activeWorkers.delete(worker);\n          resolve();\n        }\n      };\n\n      worker.on(\"message\", messageHandler);\n      \n      // Send graceful shutdown message\n      try {\n        worker.postMessage({\n          type: \"SHUTDOWN\",\n          id: \"*\",\n        });\n      } catch (error) {\n        // If we can't send the message, force terminate\n        clearTimeout(timeoutId);\n        worker.removeListener(\"message\", messageHandler!);\n        worker.removeAllListeners();\n        try {\n          worker.terminate();\n        } catch (terminateError) {\n          // Ignore termination errors\n        }\n        activeWorkers.delete(worker);\n        resolve();\n      }\n    });\n  });\n\n  await Promise.all(shutdownPromises);\n  activeWorkers.clear();\n}\n\n\ntype CreateWorkerSuccess = {\n  type: \"success\";\n  workerPath: string;\n  reason?: never;\n  error?: never;\n  worker: Worker;\n};\n\ntype CreateWorkerError = {\n  type: \"error\";\n  workerPath: string;\n  error: Error | null;\n  worker?: never;\n  reason?: never;\n};\n\ntype CreateWorkerSkip = {\n  type: \"skip\";\n  reason: string;\n  workerPath: string;\n  worker?: never;\n  error?: never;\n};\n\nexport type CreateWorkerReturn =\n  | CreateWorkerSuccess\n  | CreateWorkerError\n  | CreateWorkerSkip;\n\nexport type CreateWorkerOptions = {\n  projectRoot?: string;\n  currentCondition?: \"react-server\" | \"react-client\";\n  nodePath?: string;\n  nodeOptions?: string[];\n  envPrefix?: string;\n  mode?: \"production\" | \"development\" | \"test\";\n  reverseCondition?: string;\n  maxListeners?: number;\n  workerPath?: string;\n  resourceLimits?: ResourceLimits;\n  typescript?: boolean;\n  htmlChunkSize?: number; // Size of HTML chunks in bytes\n  workerData: {\n    userOptions?: SerializedUserOptions;\n    resolvedConfig?: SerializedResolvedConfig;\n    configEnv?: ConfigEnv;\n    reactVersion?: string;\n    id?: string;\n    serverManifest?: Manifest;\n    bundle?: OutputBundle;\n    staticBundle?: OutputBundle;\n    serverPipeableStreamOptions?: any;\n    clientPipeableStreamOptions?: any;\n    hmrPort?: MessagePort;\n  };\n  transferList?: TransferListItem[];\n  logger?: Logger;\n  verbose?: boolean;\n};\n\nexport type CreateWorkerFn = (\n  options: CreateWorkerOptions\n) => Promise<CreateWorkerReturn>;\n\nexport const createWorker: CreateWorkerFn = async function _createWorker(\n  options\n) {\n  const {\n    projectRoot = process.cwd(),\n    nodePath = getNodePath(projectRoot),\n    currentCondition = getCondition(),\n    envPrefix = DEFAULT_CONFIG.ENV_PREFIX,\n    reverseCondition = currentCondition === \"react-server\"\n      ? \"react-client\"\n      : \"react-server\",\n    maxListeners = 100,\n    mode = getMode(),\n    workerPath,\n    resourceLimits = {\n      maxOldGenerationSizeMb: 128,\n      maxYoungGenerationSizeMb: 64,\n    },\n    htmlChunkSize = 8 * 1024,\n    transferList = [],\n    logger = createLogger(),\n    verbose = false,\n  } = options;\n  const id = reverseCondition === \"react-server\" ? \"worker/rsc\" : \"worker/html\";\n  let workerPathWithDefault =\n    typeof workerPath === \"string\" ? workerPath : undefined;\n  if (!workerPathWithDefault) {\n    // Use the default worker paths that include the full filename\n    const isProduction = mode === \"production\";\n    const workerFileName =\n      reverseCondition === \"react-server\"\n        ? `rsc-worker.${isProduction ? \"production\" : \"development\"}.js`\n        : `html-worker.${isProduction ? \"production\" : \"development\"}.js`;\n\n    // Try source directory first\n    const sourcePath = join(pluginRoot, id, workerFileName);\n\n    // Always log the paths for debugging\n    if (verbose) {\n      logger.info(\n        `[create:${id}] Checking paths - Source: ${sourcePath}, PluginRoot: ${pluginRoot}`\n      );\n    }\n\n    // If source path doesn't exist, try built directory\n    if (!existsSync(sourcePath)) {\n      throw new Error(\n        `[create:${id}] Worker file doesn't exist: ${sourcePath}`\n      );\n      // const builtPath = join(pluginRoot.replace(\"/plugin/\", \"/dist/plugin/\"), id, workerFileName);\n      // logger.info(`[create:${id}] Source path doesn't exist, checking built path: ${builtPath}`);\n\n      // if (existsSync(builtPath)) {\n      //   workerPathWithDefault = builtPath;\n      //   logger.info(`[create:${id}] Using built worker path: ${builtPath}`);\n      // } else {\n      //   workerPathWithDefault = sourcePath; // Fallback to source path for error message\n      //   logger.info(`[create:${id}] Neither source nor built path exists. Source: ${sourcePath}, Built: ${builtPath}`);\n      // }\n    } else {\n      workerPathWithDefault = sourcePath;\n      if (verbose) {\n        logger.info(`[create:${id}] Using source worker path: ${sourcePath}`);\n      }\n    }\n  }\n  if (!workerPathWithDefault.startsWith(\"/\")) {\n    workerPathWithDefault = join(\"./\", workerPathWithDefault);\n  }\n  // Ensure worker uses the same React version\n  const workerData = {\n    ...options.workerData,\n    id: options.workerData.id ?? id,\n  };\n\n  try {\n    // Ensure consistent NODE_ENV between main thread and worker\n\n    if (verbose) {\n      logger.info(\n        `[create:${id}] workerData.userOptions.build:\n${JSON.stringify(workerData.userOptions?.build)}\n\nCall stack: ${new Error().stack?.split(\"\\n\").slice(1, 4).join(\"\\n\")}\nCreating worker with path: ${workerPathWithDefault}\nNode environment: ${mode}\nCurrent condition: ${currentCondition}, Reverse condition: ${reverseCondition}`\n      );\n    }\n\n    // Compute execArgv for the worker with exactly one --conditions flag\n    const stripConditionsFromArgv = (argv: string[]) => {\n      const out: string[] = [];\n      for (let i = 0; i < argv.length; i++) {\n        const arg = argv[i];\n        if (arg === \"--conditions\" || arg === \"-C\") {\n          i++; // skip value\n          continue;\n        }\n        if (arg.startsWith(\"--conditions=\")) {\n          continue;\n        }\n        out.push(arg);\n      }\n      return out;\n    };\n    // Register vendor resolution hook so the worker can find react-server-dom-esm\n    const vendorRegisterPath = new URL(\"../vendor/register-vendor.js\", import.meta.url).href;\n    const computedExecArgv = [\n      ...stripConditionsFromArgv(process.execArgv || []),\n      \"--conditions\",\n      reverseCondition,\n      \"--import\",\n      vendorRegisterPath,\n    ];\n\n    // Always log the condition setup for debugging\n    if (verbose) {\n      logger.info(\n        `[create:${id}] Setting up worker with reverse condition: ${reverseCondition}`\n      );\n      logger.info(\n        `[create:${id}] Computed execArgv: ${JSON.stringify(computedExecArgv)}`\n      );\n      logger.info(\n        `[create:${id}] Current NODE_OPTIONS: ${process.env[\"NODE_OPTIONS\"]}`\n      );\n    }\n\n    const env = {\n      // Inherit all existing environment variables\n      ...process.env,\n\n      // Override with our specific variables\n      [envPrefix + \"DEV\"]: mode === \"development\" ? \"1\" : \"0\",\n      [envPrefix + \"MODE\"]: mode,\n      [envPrefix + \"PROD\"]: mode === \"production\" ? \"1\" : \"0\",\n      [envPrefix + \"SSR\"]: \"true\",\n      [envPrefix + \"BASE_URL\"]: workerData.userOptions?.moduleBaseURL ?? \"\",\n      [envPrefix + \"PUBLIC_ORIGIN\"]: workerData.userOptions?.publicOrigin ?? \"\",\n      NODE_ENV: process.env[\"NODE_ENV\"] ?? \"production\",\n      NODE_PATH: nodePath,\n\n      // Ensure NODE_OPTIONS has the correct condition\n      NODE_OPTIONS: process.env[\"NODE_OPTIONS\"]?.includes(reverseCondition)\n        ? process.env[\"NODE_OPTIONS\"]\n        : currentCondition != null &&\n          process.env[\"NODE_OPTIONS\"]?.includes(currentCondition)\n        ? process.env[\"NODE_OPTIONS\"]?.replaceAll(\n            currentCondition,\n            reverseCondition\n          )\n        : `${\n            process.env[\"NODE_OPTIONS\"] ?? \"\"\n          } --conditions ${reverseCondition}`,\n      HTML_CHUNK_SIZE: htmlChunkSize.toString(),\n    };\n\n    if (verbose) {\n      // Always log the NODE_OPTIONS for debugging\n      logger.info(\n        `[create:${id}] Worker NODE_OPTIONS will be: ${env.NODE_OPTIONS}`\n      );\n      logger.info(\n        `[create:${id}] Environment variables: ${Object.keys(env).join(\", \")}`\n      );\n      logger.info(`[create:${id}] execArgv: ${computedExecArgv.join(\" \")}`);\n    }\n\n    // Create worker with proper environment and loaders\n    const worker = new Worker(workerPathWithDefault, {\n      env,\n      execArgv: computedExecArgv,\n      resourceLimits,\n      workerData,\n      transferList,\n    });\n\n    // Register worker for graceful shutdown\n    activeWorkers.add(worker);\n\n    worker.setMaxListeners(maxListeners);\n\n    if (verbose) {\n      logger.info(\n        `[create:${id}] Worker created, waiting for READY message...`\n      );\n    }\n\n    return await new Promise<CreateWorkerSuccess | CreateWorkerSkip>(\n      (resolve, reject) => {\n        // Use appropriate timeout based on worker type\n        const workerType = reverseCondition === \"react-server\" ? \"rsc\" : \"html\";\n        const startupTimeout =\n          workerType === \"rsc\"\n            ? options.workerData.userOptions?.rscWorkerStartupTimeout\n            : options.workerData.userOptions?.htmlWorkerStartupTimeout;\n\n        const timeout = setTimeout(() => {\n          reject({ type: \"error\", error: new Error(\"Worker ready timeout\") });\n        }, startupTimeout);\n        const exitHandler = (code: number) => {\n          clearTimeout(timeout);\n          worker.removeListener(\"message\", messageHandler);\n          // Remove worker from registry when it exits\n          activeWorkers.delete(worker);\n          // Do not remove exit handler here, let it fire if needed\n          if (code !== 0) {\n            reject({\n              type: \"error\",\n              error: new Error(\n                `[create:${id}] Worker exited with code ${code}`\n              ),\n              workerPath: workerPathWithDefault,\n            });\n          }\n        };\n        const messageHandler = (\n          msg: RscWorkerOutputMessage | HtmlWorkerOutputMessage\n        ) => {\n          if (verbose)\n            logger.info(`[create:${id}] Initial worker message ${msg.type}`);\n          if (msg.type === \"READY\" && msg.id === id) {\n            if (verbose)\n              logger.info(`[create:${id}] Worker running for ${msg.env}`);\n            clearTimeout(timeout);\n            worker.removeListener(\"message\", messageHandler);\n            worker.removeListener(\"exit\", exitHandler);\n            if (msg.env !== mode) {\n              if (verbose)\n                logger.info(`[create:${id}] Worker environment mismatch.`);\n              reject({\n                type: \"error\",\n                error: new Error(\n                  `Worker environment mismatch: ${msg.env} !== ${mode}`\n                ),\n                workerPath: workerPathWithDefault,\n              } satisfies CreateWorkerError);\n            }\n            resolve({\n              type: \"success\",\n              worker,\n              workerPath: workerPathWithDefault,\n            } satisfies CreateWorkerSuccess);\n          }\n        };\n        worker.once(\"message\", messageHandler);\n        worker.once(\"exit\", exitHandler);\n        worker.on(\"error\", (err) => {\n          // Remove worker from registry on error\n          activeWorkers.delete(worker);\n          \n          if (verbose && err != null) {\n            logger.error(\n              `[create:${id}] Worker error: ${err.message}.\\n${err.stack}`,\n              { error: err }\n            );\n          }\n          const panicError = handleError({\n            error: err,\n            logger: logger,\n            panicThreshold: workerData.userOptions?.panicThreshold,\n            critical: false,\n            context: `Worker thread error for route ${id}`,\n          });\n          if (panicError != null) {\n            if (verbose) {\n              logger.error(\n                `[create:${id}] Panic error detected: ${panicError.message}`,\n                { error: panicError }\n              );\n            }\n            reject({\n              type: \"error\",\n              error: err,\n              workerPath: workerPathWithDefault,\n            });\n          }\n          reject({\n            type: \"error\",\n            error: new Error(\"Worker thread error\", { cause: err }),\n            workerPath: workerPathWithDefault,\n          });\n        });\n      }\n    );\n  } catch (error) {\n    if (verbose) {\n      logger.error(\n        `[create:${id}] Caught error during worker creation: ${\n          toError(error).message\n        }`,\n        { error: error instanceof Error ? error : new Error(String(error)) }\n      );\n    }\n    const panicError = handleError({\n      error: error,\n      logger: logger,\n      panicThreshold: workerData.userOptions?.panicThreshold,\n      critical: false,\n      context: `Worker thread error for route ${id}`,\n    });\n    if (panicError != null) {\n      if (verbose) {\n        logger.error(\n          `[create:${id}] Panic error in catch block: ${panicError.message}`,\n          { error: panicError }\n        );\n      }\n      return {\n        type: \"error\",\n        error: panicError,\n        workerPath: workerPathWithDefault,\n      };\n    }\n    return {\n      type: \"error\",\n      error: error instanceof Error ? error : new Error(String(error)),\n      workerPath: workerPathWithDefault,\n    };\n  }\n};\n"],"names":[],"mappings":"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"}
|