vite-plugin-react-server 1.2.2 → 1.2.4
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/README.md +2 -1
- package/dist/package.json +1 -1
- package/dist/plugin/helpers/createSharedLoader.d.ts +1 -1
- package/dist/plugin/helpers/createSharedLoader.d.ts.map +1 -1
- package/dist/plugin/helpers/createSharedLoader.js +14 -56
- package/dist/plugin/loader/directives/analyzeDirectives.js +2 -2
- package/dist/plugin/loader/react-loader.d.ts.map +1 -1
- package/dist/plugin/loader/react-loader.js +4 -70
- package/dist/plugin/worker/rsc/createRscWorkerLoader.d.ts +2 -6
- package/dist/plugin/worker/rsc/createRscWorkerLoader.d.ts.map +1 -1
- package/dist/plugin/worker/rsc/createRscWorkerLoader.js +1 -34
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
- package/plugin/helpers/createSharedLoader.ts +17 -70
- package/plugin/loader/directives/analyzeDirectives.ts +5 -1
- package/plugin/loader/react-loader.ts +5 -79
- package/plugin/worker/rsc/createRscWorkerLoader.ts +4 -51
package/README.md
CHANGED
|
@@ -306,7 +306,7 @@ export function Counter() {
|
|
|
306
306
|
|
|
307
307
|
## Contributing
|
|
308
308
|
|
|
309
|
-
This project uses experimental React features and includes a patch system for compatibility. See [
|
|
309
|
+
This project uses experimental React features and includes a patch system for compatibility. See [React Type Compatibility](./docs/react-type-compatibility.md) for maintenance details.
|
|
310
310
|
|
|
311
311
|
## Documentation
|
|
312
312
|
|
|
@@ -325,6 +325,7 @@ This project uses experimental React features and includes a patch system for co
|
|
|
325
325
|
| [React Compatibility](./docs/react-type-compatibility.md) |
|
|
326
326
|
| [Troubleshooting](./docs/troubleshooting-guide.md) |
|
|
327
327
|
| [Package Exports](./docs/package-exports.md) |
|
|
328
|
+
| [Transformations](./docs/transformations.md) |
|
|
328
329
|
|
|
329
330
|
|
|
330
331
|
## License
|
package/dist/package.json
CHANGED
|
@@ -16,7 +16,7 @@ import type { InputNormalizer } from "../types.js";
|
|
|
16
16
|
* @param options - Loader configuration options
|
|
17
17
|
* @returns The resolved module (already a module object, not a Promise)
|
|
18
18
|
*/
|
|
19
|
-
export declare function createSharedLoader({ moduleId, exportName, verbose, logger, resolveVirtual, manifest, normalizer, moduleBase, preserveModulesRoot, projectRoot, buildOutDir, buildServerDir, isBuildMode, isServeMode, effectiveProjectRoot, build, }: {
|
|
19
|
+
export declare function createSharedLoader({ moduleId, exportName, verbose, logger, resolveVirtual, manifest, normalizer, moduleBase, preserveModulesRoot, projectRoot, buildOutDir, buildServerDir, isBuildMode, isServeMode: _isServeMode, effectiveProjectRoot, build, }: {
|
|
20
20
|
moduleId: string;
|
|
21
21
|
exportName?: string;
|
|
22
22
|
verbose?: boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createSharedLoader.d.ts","sourceRoot":"","sources":["../../../plugin/helpers/createSharedLoader.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAInD;;;;;;;;;;;;;;;GAeG;AACH,wBAAsB,kBAAkB,CAAC,EACvC,QAAQ,EACR,UAAU,EACV,OAAe,EACf,MAAM,EAEN,cAAqB,EAErB,QAAQ,EACR,UAAU,EACV,UAAU,EACV,mBAAmB,EACnB,WAAW,EACX,WAAW,EACX,cAAc,EAEd,WAAmB,EACnB,
|
|
1
|
+
{"version":3,"file":"createSharedLoader.d.ts","sourceRoot":"","sources":["../../../plugin/helpers/createSharedLoader.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAInD;;;;;;;;;;;;;;;GAeG;AACH,wBAAsB,kBAAkB,CAAC,EACvC,QAAQ,EACR,UAAU,EACV,OAAe,EACf,MAAM,EAEN,cAAqB,EAErB,QAAQ,EACR,UAAU,EACV,UAAU,EACV,mBAAmB,EACnB,WAAW,EACX,WAAW,EACX,cAAc,EAEd,WAAmB,EACnB,WAAW,EAAE,YAAoB,EACjC,oBAAoB,EACpB,KAAK,GACN,EAAE;IACD,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB,cAAc,CAAC,EAAE,OAAO,CAAC;IAEzB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,GAAG,SAAS,CAAC,CAAC;IACxD,UAAU,CAAC,EAAE,eAAe,CAAC;IAC7B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,cAAc,CAAC,EAAE,MAAM,CAAC;IAExB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,KAAK,CAAC,EAAE;QACN,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;KACjB,CAAC;CACH,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAoF/B"}
|
|
@@ -25,7 +25,7 @@ async function createSharedLoader({
|
|
|
25
25
|
buildServerDir,
|
|
26
26
|
// Direct import options
|
|
27
27
|
isBuildMode = false,
|
|
28
|
-
isServeMode = false,
|
|
28
|
+
isServeMode: _isServeMode = false,
|
|
29
29
|
effectiveProjectRoot,
|
|
30
30
|
build
|
|
31
31
|
}) {
|
|
@@ -56,82 +56,40 @@ async function createSharedLoader({
|
|
|
56
56
|
});
|
|
57
57
|
if (manifestResolution.manifestEntry && manifestResolution.resolvedPath) {
|
|
58
58
|
resolvedModuleID = manifestResolution.resolvedPath;
|
|
59
|
-
if (verbose) {
|
|
60
|
-
logger?.info(
|
|
61
|
-
`[createSharedLoader] Build mode: resolved via manifest to: ${resolvedModuleID}`
|
|
62
|
-
);
|
|
63
|
-
}
|
|
64
59
|
} else {
|
|
65
60
|
resolvedModuleID = manifestResolution.builtModuleId;
|
|
66
|
-
if (verbose) {
|
|
67
|
-
logger?.info(
|
|
68
|
-
`[createSharedLoader] Build mode: not in manifest, using builtModuleId: ${resolvedModuleID}`
|
|
69
|
-
);
|
|
70
|
-
}
|
|
71
61
|
const isSourcePath = moduleId.startsWith(moduleBase + "/") || moduleId.startsWith("./" + moduleBase + "/") || isAbsolute(moduleId) && moduleId.includes(moduleBase);
|
|
72
62
|
if (!isSourcePath && !isAbsolute(resolvedModuleID) && effectiveProjectRoot && build) {
|
|
73
|
-
|
|
63
|
+
resolvedModuleID = join(
|
|
74
64
|
effectiveProjectRoot,
|
|
75
65
|
build.outDir || "dist",
|
|
76
|
-
build.server || "server"
|
|
77
|
-
|
|
78
|
-
resolvedModuleID = join(serverBuildPath, resolvedModuleID);
|
|
79
|
-
if (verbose) {
|
|
80
|
-
logger?.info(
|
|
81
|
-
`[createSharedLoader] Build mode: prefixing with ${serverBuildPath}: ${resolvedModuleID}`
|
|
82
|
-
);
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
} else if (isServeMode) {
|
|
87
|
-
if (verbose) {
|
|
88
|
-
logger?.info(
|
|
89
|
-
`[createSharedLoader] Dev mode: loading directly from source`
|
|
90
|
-
);
|
|
91
|
-
}
|
|
92
|
-
} else if (isBuildMode && effectiveProjectRoot && build) {
|
|
93
|
-
if (!isAbsolute(resolvedModuleID)) {
|
|
94
|
-
const serverBuildPath = join(
|
|
95
|
-
effectiveProjectRoot,
|
|
96
|
-
build.outDir || "dist",
|
|
97
|
-
build.server || "server"
|
|
98
|
-
);
|
|
99
|
-
resolvedModuleID = join(serverBuildPath, resolvedModuleID);
|
|
100
|
-
if (verbose) {
|
|
101
|
-
logger?.info(
|
|
102
|
-
`[createSharedLoader] Build mode fallback: prefixing with ${serverBuildPath}: ${resolvedModuleID}`
|
|
66
|
+
build.server || "server",
|
|
67
|
+
resolvedModuleID
|
|
103
68
|
);
|
|
104
69
|
}
|
|
105
70
|
}
|
|
71
|
+
} else if (isBuildMode && effectiveProjectRoot && build && !isAbsolute(resolvedModuleID)) {
|
|
72
|
+
resolvedModuleID = join(
|
|
73
|
+
effectiveProjectRoot,
|
|
74
|
+
build.outDir || "dist",
|
|
75
|
+
build.server || "server",
|
|
76
|
+
resolvedModuleID
|
|
77
|
+
);
|
|
106
78
|
}
|
|
107
79
|
const fullPath = isAbsolute(resolvedModuleID) ? resolvedModuleID : effectiveProjectRoot ? join(effectiveProjectRoot, resolvedModuleID) : resolvedModuleID;
|
|
108
|
-
if (verbose) {
|
|
109
|
-
logger?.info(`[createSharedLoader] Importing from: ${fullPath}`);
|
|
110
|
-
}
|
|
111
80
|
const fileUrl = isAbsolute(fullPath) ? pathToFileURL(fullPath).href : fullPath;
|
|
112
81
|
const result = await import(fileUrl);
|
|
113
82
|
if (result == null) {
|
|
114
83
|
throw new Error(`Module "${moduleId}" does not have any exports`);
|
|
115
84
|
}
|
|
116
85
|
if (!Object.keys(result).length && exportName?.length) {
|
|
117
|
-
throw new Error(
|
|
118
|
-
`Module "${moduleId}" is a module, but does not have any exports so it can't find ${exportName}`
|
|
119
|
-
);
|
|
86
|
+
throw new Error(`Module "${moduleId}" has no exports, can't find ${exportName}`);
|
|
120
87
|
}
|
|
121
88
|
if (exportName && !(exportName in result)) {
|
|
122
|
-
throw new Error(
|
|
123
|
-
`Module "${moduleId}" exists, but does not export "${exportName}"`
|
|
124
|
-
);
|
|
125
|
-
}
|
|
126
|
-
if (verbose) {
|
|
127
|
-
logger?.info(
|
|
128
|
-
`[createSharedLoader] Module loaded successfully, exports: ${Object.keys(
|
|
129
|
-
result
|
|
130
|
-
).join(", ")}`
|
|
131
|
-
);
|
|
89
|
+
throw new Error(`Module "${moduleId}" does not export "${exportName}"`);
|
|
132
90
|
}
|
|
133
91
|
return result;
|
|
134
92
|
}
|
|
135
93
|
|
|
136
94
|
export { createSharedLoader };
|
|
137
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"createSharedLoader.js","sources":["../../../plugin/helpers/createSharedLoader.ts"],"sourcesContent":["import { join, isAbsolute } from \"node:path\";\nimport { pathToFileURL } from \"node:url\";\nimport type { Logger } from \"vite\";\nimport type { InputNormalizer } from \"../types.js\";\nimport { resolveVirtualAndNodeModules } from \"./resolveVirtualAndNodeModules.js\";\nimport { resolveModuleFromManifest } from \"./resolveModuleFromManifest.js\";\n\n/**\n * Shared loader utility that both RSC worker loader and build loader can use.\n * \n * This handles the common pattern:\n * 1. Parse id to get moduleId and exportName\n * 2. Handle virtual modules and node_modules (via resolveVirtualAndNodeModules)\n * 3. Try manifest-based resolution (build mode)\n * 4. Import the module\n * 5. Validate exports\n * \n * If the result is already a module object (not a Promise), it's returned directly.\n * This allows loaders to reuse already-loaded modules.\n * \n * @param options - Loader configuration options\n * @returns The resolved module (already a module object, not a Promise)\n */\nexport async function createSharedLoader({\n  moduleId,\n  exportName,\n  verbose = false,\n  logger,\n  // Virtual module handling\n  resolveVirtual = true,\n  // Manifest resolution\n  manifest,\n  normalizer,\n  moduleBase,\n  preserveModulesRoot,\n  projectRoot,\n  buildOutDir,\n  buildServerDir,\n  // Direct import options\n  isBuildMode = false,\n  isServeMode = false,\n  effectiveProjectRoot,\n  build,\n}: {\n  moduleId: string;\n  exportName?: string;\n  verbose?: boolean;\n  logger?: Logger;\n  // Virtual module handling\n  resolveVirtual?: boolean;\n  // Manifest resolution\n  manifest?: Record<string, { file: string } | undefined>;\n  normalizer?: InputNormalizer;\n  moduleBase?: string;\n  preserveModulesRoot?: boolean;\n  projectRoot?: string;\n  buildOutDir?: string;\n  buildServerDir?: string;\n  // Direct import options\n  isBuildMode?: boolean;\n  isServeMode?: boolean;\n  effectiveProjectRoot?: string;\n  build?: {\n    server?: string;\n    client?: string;\n    static?: string;\n    outDir?: string;\n  };\n}): Promise<Record<string, any>> {\n  // Step 1: Handle virtual modules and node_modules first (if enabled)\n  if (resolveVirtual) {\n    const virtualOrNodeModule = await resolveVirtualAndNodeModules(\n      moduleId,\n      exportName,\n      verbose,\n      logger\n    );\n    if (virtualOrNodeModule !== null) {\n      // resolveVirtualAndNodeModules returns a module object directly (not a Promise)\n      // If it's already a module object, return it directly\n      return virtualOrNodeModule;\n    }\n  }\n\n  // Step 2: Try manifest-based resolution (build mode)\n  let resolvedModuleID = moduleId;\n  if (isBuildMode && manifest && normalizer && moduleBase && projectRoot && buildOutDir && buildServerDir) {\n    const manifestResolution = resolveModuleFromManifest({\n      moduleId,\n      normalizer,\n      manifest,\n      moduleBase,\n      preserveModulesRoot,\n      projectRoot,\n      buildOutDir,\n      buildServerDir,\n      verbose,\n      logger,\n    });\n\n    if (manifestResolution.manifestEntry && manifestResolution.resolvedPath) {\n      // Found in manifest - use the resolved path (it's already a full absolute path)\n      resolvedModuleID = manifestResolution.resolvedPath;\n      if (verbose) {\n        logger?.info(\n          `[createSharedLoader] Build mode: resolved via manifest to: ${resolvedModuleID}`\n        );\n      }\n    } else {\n      // Not in manifest - use the builtModuleId from resolution\n      resolvedModuleID = manifestResolution.builtModuleId;\n      if (verbose) {\n        logger?.info(\n          `[createSharedLoader] Build mode: not in manifest, using builtModuleId: ${resolvedModuleID}`\n        );\n      }\n      \n      // Check if we need to prefix with build directory\n      // A source path starts with moduleBase (e.g., \"src/\"), a built path doesn't\n      // Also check if it's already an absolute path or starts with file://\n      const isSourcePath = moduleId.startsWith(moduleBase + \"/\") || \n                          moduleId.startsWith(\"./\" + moduleBase + \"/\") ||\n                          (isAbsolute(moduleId) && moduleId.includes(moduleBase));\n      \n      // If it's not a source path and not already absolute, prefix with server build directory\n      if (!isSourcePath && !isAbsolute(resolvedModuleID) && effectiveProjectRoot && build) {\n        const serverBuildPath = join(\n          effectiveProjectRoot,\n          build.outDir || \"dist\",\n          build.server || \"server\"\n        );\n        resolvedModuleID = join(serverBuildPath, resolvedModuleID);\n        if (verbose) {\n          logger?.info(\n            `[createSharedLoader] Build mode: prefixing with ${serverBuildPath}: ${resolvedModuleID}`\n          );\n        }\n      }\n    }\n  } else if (isServeMode) {\n    // Dev mode: load directly from source files, no build path prefixing\n    if (verbose) {\n      logger?.info(\n        `[createSharedLoader] Dev mode: loading directly from source`\n      );\n    }\n  } else if (isBuildMode && effectiveProjectRoot && build) {\n    // Build mode fallback: prefix with server build directory even without manifest/normalizer\n    if (!isAbsolute(resolvedModuleID)) {\n      const serverBuildPath = join(\n        effectiveProjectRoot,\n        build.outDir || \"dist\",\n        build.server || \"server\"\n      );\n      resolvedModuleID = join(serverBuildPath, resolvedModuleID);\n      if (verbose) {\n        logger?.info(\n          `[createSharedLoader] Build mode fallback: prefixing with ${serverBuildPath}: ${resolvedModuleID}`\n        );\n      }\n    }\n  }\n\n  // Step 3: Construct the full path and import\n  const fullPath = isAbsolute(resolvedModuleID) \n    ? resolvedModuleID \n    : effectiveProjectRoot \n      ? join(effectiveProjectRoot, resolvedModuleID)\n      : resolvedModuleID;\n\n  if (verbose) {\n    logger?.info(`[createSharedLoader] Importing from: ${fullPath}`);\n  }\n\n  // Step 4: Import the module\n  const fileUrl = isAbsolute(fullPath) ? pathToFileURL(fullPath).href : fullPath;\n  const result = await import(fileUrl);\n\n  // Step 5: Validate exports\n  if (result == null) {\n    throw new Error(`Module \"${moduleId}\" does not have any exports`);\n  }\n\n  if (!Object.keys(result).length && exportName?.length) {\n    throw new Error(\n      `Module \"${moduleId}\" is a module, but does not have any exports so it can't find ${exportName}`\n    );\n  }\n\n  if (exportName && !(exportName in result)) {\n    throw new Error(\n      `Module \"${moduleId}\" exists, but does not export \"${exportName}\"`\n    );\n  }\n\n  if (verbose) {\n    logger?.info(\n      `[createSharedLoader] Module loaded successfully, exports: ${Object.keys(\n        result\n      ).join(\", \")}`\n    );\n  }\n\n  // Import always returns a module object (not a Promise), so return it directly\n  return result;\n}\n\n"],"names":[],"mappings":"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"}
|
|
95
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"createSharedLoader.js","sources":["../../../plugin/helpers/createSharedLoader.ts"],"sourcesContent":["import { join, isAbsolute } from \"node:path\";\nimport { pathToFileURL } from \"node:url\";\nimport type { Logger } from \"vite\";\nimport type { InputNormalizer } from \"../types.js\";\nimport { resolveVirtualAndNodeModules } from \"./resolveVirtualAndNodeModules.js\";\nimport { resolveModuleFromManifest } from \"./resolveModuleFromManifest.js\";\n\n/**\n * Shared loader utility that both RSC worker loader and build loader can use.\n * \n * This handles the common pattern:\n * 1. Parse id to get moduleId and exportName\n * 2. Handle virtual modules and node_modules (via resolveVirtualAndNodeModules)\n * 3. Try manifest-based resolution (build mode)\n * 4. Import the module\n * 5. Validate exports\n * \n * If the result is already a module object (not a Promise), it's returned directly.\n * This allows loaders to reuse already-loaded modules.\n * \n * @param options - Loader configuration options\n * @returns The resolved module (already a module object, not a Promise)\n */\nexport async function createSharedLoader({\n  moduleId,\n  exportName,\n  verbose = false,\n  logger,\n  // Virtual module handling\n  resolveVirtual = true,\n  // Manifest resolution\n  manifest,\n  normalizer,\n  moduleBase,\n  preserveModulesRoot,\n  projectRoot,\n  buildOutDir,\n  buildServerDir,\n  // Direct import options\n  isBuildMode = false,\n  isServeMode: _isServeMode = false,\n  effectiveProjectRoot,\n  build,\n}: {\n  moduleId: string;\n  exportName?: string;\n  verbose?: boolean;\n  logger?: Logger;\n  // Virtual module handling\n  resolveVirtual?: boolean;\n  // Manifest resolution\n  manifest?: Record<string, { file: string } | undefined>;\n  normalizer?: InputNormalizer;\n  moduleBase?: string;\n  preserveModulesRoot?: boolean;\n  projectRoot?: string;\n  buildOutDir?: string;\n  buildServerDir?: string;\n  // Direct import options\n  isBuildMode?: boolean;\n  isServeMode?: boolean;\n  effectiveProjectRoot?: string;\n  build?: {\n    server?: string;\n    client?: string;\n    static?: string;\n    outDir?: string;\n  };\n}): Promise<Record<string, any>> {\n  // Step 1: Handle virtual modules and node_modules first (if enabled)\n  if (resolveVirtual) {\n    const virtualOrNodeModule = await resolveVirtualAndNodeModules(\n      moduleId,\n      exportName,\n      verbose,\n      logger\n    );\n    if (virtualOrNodeModule !== null) {\n      // resolveVirtualAndNodeModules returns a module object directly (not a Promise)\n      // If it's already a module object, return it directly\n      return virtualOrNodeModule;\n    }\n  }\n\n  // Step 2: Try manifest-based resolution (build mode)\n  let resolvedModuleID = moduleId;\n  if (isBuildMode && manifest && normalizer && moduleBase && projectRoot && buildOutDir && buildServerDir) {\n    const manifestResolution = resolveModuleFromManifest({\n      moduleId,\n      normalizer,\n      manifest,\n      moduleBase,\n      preserveModulesRoot,\n      projectRoot,\n      buildOutDir,\n      buildServerDir,\n      verbose,\n      logger,\n    });\n\n    if (manifestResolution.manifestEntry && manifestResolution.resolvedPath) {\n      resolvedModuleID = manifestResolution.resolvedPath;\n    } else {\n      resolvedModuleID = manifestResolution.builtModuleId;\n      \n      // Prefix non-source, non-absolute paths with server build directory\n      const isSourcePath = moduleId.startsWith(moduleBase + \"/\") || \n                          moduleId.startsWith(\"./\" + moduleBase + \"/\") ||\n                          (isAbsolute(moduleId) && moduleId.includes(moduleBase));\n      \n      if (!isSourcePath && !isAbsolute(resolvedModuleID) && effectiveProjectRoot && build) {\n        resolvedModuleID = join(\n          effectiveProjectRoot,\n          build.outDir || \"dist\",\n          build.server || \"server\",\n          resolvedModuleID\n        );\n      }\n    }\n  } else if (isBuildMode && effectiveProjectRoot && build && !isAbsolute(resolvedModuleID)) {\n    // Build mode fallback without manifest\n    resolvedModuleID = join(\n      effectiveProjectRoot,\n      build.outDir || \"dist\",\n      build.server || \"server\",\n      resolvedModuleID\n    );\n  }\n\n  // Step 3: Construct the full path and import\n  const fullPath = isAbsolute(resolvedModuleID) \n    ? resolvedModuleID \n    : effectiveProjectRoot \n      ? join(effectiveProjectRoot, resolvedModuleID)\n      : resolvedModuleID;\n\n  // Import the module\n  const fileUrl = isAbsolute(fullPath) ? pathToFileURL(fullPath).href : fullPath;\n  const result = await import(fileUrl);\n\n  // Validate exports\n  if (result == null) {\n    throw new Error(`Module \"${moduleId}\" does not have any exports`);\n  }\n  if (!Object.keys(result).length && exportName?.length) {\n    throw new Error(`Module \"${moduleId}\" has no exports, can't find ${exportName}`);\n  }\n  if (exportName && !(exportName in result)) {\n    throw new Error(`Module \"${moduleId}\" does not export \"${exportName}\"`);\n  }\n\n  return result;\n}\n\n"],"names":[],"mappings":"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"}
|
|
@@ -24,7 +24,7 @@ function analyzeDirectives(ast, source, optionsOrMatches, _logger) {
|
|
|
24
24
|
let firstDirective = null;
|
|
25
25
|
const verbose = hasOptions && typeof optionsOrMatches === "object" && "verbose" in optionsOrMatches && optionsOrMatches.verbose;
|
|
26
26
|
const logger = hasOptions && typeof optionsOrMatches === "object" && "logger" in optionsOrMatches ? optionsOrMatches.logger ?? _logger ?? createLogger() : _logger ?? createLogger();
|
|
27
|
-
const isViteInjectedCode = source.includes("__vite__createHotContext") || source.includes("import.meta.hot") || source.includes("import.meta.env") || source.includes("/@vite/client");
|
|
27
|
+
const isViteInjectedCode = source.includes("__vite__createHotContext") || source.includes("import.meta.hot") || source.includes("import.meta.env") || source.includes("/@vite/client") || source.includes("__vitePreload") || source.includes("\0vite/");
|
|
28
28
|
for (const node of ast.body) {
|
|
29
29
|
if (verbose) {
|
|
30
30
|
logger.info(
|
|
@@ -245,4 +245,4 @@ beforeNode: ${node.start > 0 ? JSON.stringify(source.slice(0, node.start)).slice
|
|
|
245
245
|
}
|
|
246
246
|
|
|
247
247
|
export { analyzeDirectives };
|
|
248
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"analyzeDirectives.js","sources":["../../../../plugin/loader/directives/analyzeDirectives.ts"],"sourcesContent":["import { findDirectiveMatches } from \"./findDirectiveMatches.js\";\nimport { isFunctionNode } from \"./typeGuards.js\";\nimport { getFunctionBody } from \"./getFunctionBody.js\";\nimport { getFunctionName } from \"./getFunctionName.js\";\nimport { getExportedName } from \"./getExportedName.js\";\nimport { processFunctionNode } from \"./processFunctionNode.js\";\nimport {\n  isDirectiveAtStart,\n  getDirectiveValue,\n  matchOverlapsDirective,\n} from \"./utils.js\";\nimport type {\n  DirectiveInfo,\n  DirectiveMatch,\n  DirectiveMatches,\n} from \"./types.js\";\nimport type { Node, Program } from \"acorn\";\nimport type { DirectiveOptions } from \"../../types.js\";\nimport { createLogger, type Logger } from \"vite\";\n\n/**\n * Analyzes directives in the given source and AST, returning directiveInfo.\n */\nexport function analyzeDirectives(\n  ast: Program,\n  source: string,\n  matches?: DirectiveMatches,\n  logger?: Logger\n): DirectiveInfo;\nexport function analyzeDirectives(\n  ast: Program,\n  source: string,\n  options?: DirectiveOptions,\n  logger?: Logger\n): DirectiveInfo;\nexport function analyzeDirectives(\n  ast: Program,\n  source: string,\n  optionsOrMatches?: DirectiveMatches | DirectiveOptions,\n  _logger?: Logger\n): DirectiveInfo {\n  const hasOptions =\n    optionsOrMatches != null && typeof optionsOrMatches === \"object\";\n  const directiveMatches =\n    hasOptions && \"matches\" in optionsOrMatches\n      ? optionsOrMatches\n      : findDirectiveMatches(source);\n\n  const directiveInfo: DirectiveInfo = {\n    fileLevel: null,\n    functionLevel: [],\n    warnings: [],\n  };\n\n  // Find file-level directives by checking AST\n  let foundNonDirective = false;\n  let firstDirective: DirectiveMatch | null = null;\n  const verbose =\n    hasOptions &&\n    typeof optionsOrMatches === \"object\" &&\n    \"verbose\" in optionsOrMatches &&\n    optionsOrMatches.verbose;\n  const logger =\n    hasOptions &&\n    typeof optionsOrMatches === \"object\" &&\n    \"logger\" in optionsOrMatches\n      ? optionsOrMatches.logger ?? _logger ?? createLogger()\n      : _logger ?? createLogger();\n  // Check if this looks like Vite-injected code\n  const isViteInjectedCode =\n    source.includes(\"__vite__createHotContext\") ||\n    source.includes(\"import.meta.hot\") ||\n    source.includes(\"import.meta.env\") ||\n    source.includes(\"/@vite/client\");\n\n  for (const node of ast.body) {\n    // Debug logging\n    if (verbose) {\n      logger.info(\n        `[analyzeDirectives] Processing node: ${node.type} start: ${node.start} end: ${node.end}\ndirective: ${\"directive\" in node ? node.directive : \"none\"}\nbeforeNode: ${node.start! > 0 ? JSON.stringify(source.slice(0, node.start!)).slice(0, 100) : \"none\"}`\n      );\n    }\n\n    // Only check for directives in expression statements\n    if (node.type === \"ExpressionStatement\") {\n      let directive: string | null = null;\n      if (\"directive\" in node && typeof node.directive === \"string\") {\n        directive = node.directive;\n      } else if (\n        node.expression.type === \"Literal\" &&\n        typeof node.expression.value === \"string\" &&\n        (node.expression.value === \"use server\" ||\n          node.expression.value === \"use client\")\n      ) {\n        directive = node.expression.value;\n      }\n\n      if (directive) {\n        const getDirectiveType =\n          optionsOrMatches != null && \"loader\" in optionsOrMatches\n            ? optionsOrMatches.loader?.getDirectiveType\n            : undefined;\n        const type =\n          getDirectiveType?.(directive) ??\n          (directive === \"use server\" ? \"server\" : \"client\");\n        if (!firstDirective) {\n          firstDirective = { type, range: [node.start!, node.end!] };\n          if (verbose) {\n            logger.info(\n              `[analyzeDirectives] Found first directive: ${directive} at range: ${[\n                node.start!,\n                node.end!,\n              ]}`\n            );\n          }\n        } else {\n          directiveInfo.warnings.push({\n            message:\n              \"Cannot have both 'use client' and 'use server' directives in the same file\",\n            range: [0, 0],\n            type: \"server\",\n          });\n        }\n      } else {\n        // This expression statement is not a directive, so mark as non-directive\n        // if we haven't found the first directive yet\n        if (!firstDirective) {\n          foundNonDirective = true;\n          if (verbose) {\n            logger.info(\n              `[analyzeDirectives] Found non-directive expression before first directive, setting foundNonDirective=true`\n            );\n          }\n        }\n      }\n    } else {\n      // Only mark actual code (not imports/exports) as non-directive\n      // if we haven't found the first directive yet\n      if (!firstDirective) {\n        foundNonDirective = true;\n        if (verbose) {\n          logger.info(\n            `[analyzeDirectives] Found non-directive node before first directive: ${node.type}, setting foundNonDirective=true`\n          );\n        }\n      }\n    }\n\n    // Check if this node is after any comments or non-whitespace content\n    // Only matters if we haven't found the first directive yet\n    if (!firstDirective && node.start! > 0) {\n      const beforeNode = source.slice(0, node.start!).trim();\n      if (beforeNode.length > 0) {\n        foundNonDirective = true;\n        if (verbose) {\n          logger.info(\n            `[analyzeDirectives] Found content before first directive: ${JSON.stringify(\n              beforeNode.slice(0, 100)\n            )}, setting foundNonDirective=true`\n          );\n        }\n      }\n    }\n  }\n\n  // Set the first directive as file-level if found\n  if (firstDirective) {\n    directiveInfo.fileLevel = firstDirective;\n\n    // Check if there was content (including comments) before the directive\n    if (!foundNonDirective && firstDirective.range[0] > 0) {\n      const beforeDirective = source.slice(0, firstDirective.range[0]).trim();\n      if (beforeDirective.length > 0) {\n        foundNonDirective = true;\n        if (verbose) {\n          logger.info(\n            `[analyzeDirectives] Found content before directive: ${JSON.stringify(\n              beforeDirective\n            )}, setting foundNonDirective=true for directive`\n          );\n        }\n      }\n    }\n\n    // Only warn about directive placement if it's not Vite-injected code\n    if (foundNonDirective && !isViteInjectedCode) {\n      directiveInfo.warnings.push({\n        message:\n          \"File-level directives must be at the top of the file, before any other code\",\n        range: [firstDirective.range[0], firstDirective.range[1]],\n        type: firstDirective.type,\n      });\n    }\n  }\n\n  // Process function-level directives\n  const functionLevelMatches = directiveMatches.matches.filter(\n    (match: DirectiveMatch) => {\n      // Skip if this match is already used as a file-level directive\n      if (\n        directiveInfo.fileLevel &&\n        match.range[0] === directiveInfo.fileLevel.range[0] &&\n        match.range[1] === directiveInfo.fileLevel.range[1]\n      ) {\n        return false;\n      }\n      return true;\n    }\n  );\n\n  const processedFunctions = new Set<string>();\n\n  // First pass: collect all function nodes with their directives\n  const functionNodes: Array<{\n    node: Node;\n    match: DirectiveMatch;\n    context: string;\n  }> = [];\n\n  // Track context during traversal\n  function traverseWithContext(\n    node: Node,\n    context: { inFunction: boolean; inClass: boolean }\n  ) {\n    if (isFunctionNode(node)) {\n      const body = getFunctionBody(node);\n      if (body) {\n        // Check if directive is at the start of the function body\n        for (const match of functionLevelMatches) {\n          const directiveValue = getDirectiveValue(match.type);\n\n          if (isDirectiveAtStart(node, directiveValue)) {\n            // Check if the match range corresponds to this specific directive position\n            const directiveNode = body.body[0];\n            const directiveStart = directiveNode.start!;\n            const directiveEnd = directiveNode.end!;\n\n            // Match based on position - the match should overlap with the directive node\n            const matchOverlaps = matchOverlapsDirective(\n              match.range,\n              directiveStart,\n              directiveEnd\n            );\n\n            if (matchOverlaps) {\n              const functionName = getFunctionName(node) || \"anonymous\";\n\n              // Check for invalid contexts based on traversal context\n              if (context.inFunction) {\n                const nameDesc =\n                  functionName === \"anonymous\" ? \"\" : ` '${functionName}'`;\n                directiveInfo.warnings.push({\n                  message: `Function${nameDesc} with '${directiveValue}' directive cannot be nested inside another function. Directives are only allowed in top-level functions.`,\n                  range: match.range,\n                  type: match.type,\n                });\n                return; // Skip this function entirely\n              }\n\n              if (context.inClass) {\n                const nameDesc =\n                  functionName === \"anonymous\" ? \"\" : ` '${functionName}'`;\n                directiveInfo.warnings.push({\n                  message: `Class method${nameDesc} with '${directiveValue}' directive is not supported. Directives are only allowed in top-level functions.`,\n                  range: match.range,\n                  type: match.type,\n                });\n                return; // Skip this function entirely\n              }\n\n              // Only allow server directives in function-level contexts\n              if (match.type === \"server\") {\n                functionNodes.push({\n                  node,\n                  match,\n                  context: context.inFunction\n                    ? \"nested\"\n                    : context.inClass\n                    ? \"class\"\n                    : \"top-level\",\n                });\n              } else {\n                // Generate warning for client directives in functions\n                directiveInfo.warnings.push({\n                  message: \"Function-level 'use client' isn't allowed\",\n                  range: match.range,\n                  type: \"client\",\n                });\n              }\n              break;\n            }\n          }\n        }\n      }\n\n      // Continue traversal with updated context (now inside a function)\n      traverseChildren(node, { inFunction: true, inClass: context.inClass });\n    } else if (\n      node.type === \"ClassDeclaration\" ||\n      node.type === \"ClassExpression\"\n    ) {\n      // Continue traversal with updated context (now inside a class)\n      traverseChildren(node, { inFunction: context.inFunction, inClass: true });\n    } else if (node.type === \"MethodDefinition\") {\n      // Method definitions are inside classes\n      traverseChildren(node, { inFunction: context.inFunction, inClass: true });\n    } else {\n      // Continue with same context\n      traverseChildren(node, context);\n    }\n  }\n\n  function traverseChildren(\n    node: Node,\n    context: { inFunction: boolean; inClass: boolean }\n  ) {\n    const nodeWithChildren = node as any;\n    for (const key in nodeWithChildren) {\n      if (\n        key === \"parent\" ||\n        key === \"start\" ||\n        key === \"end\" ||\n        key === \"loc\" ||\n        key === \"range\"\n      ) {\n        continue;\n      }\n\n      const value = nodeWithChildren[key];\n      if (value && typeof value === \"object\") {\n        if (Array.isArray(value)) {\n          for (const child of value) {\n            if (child && typeof child === \"object\" && child.type) {\n              traverseWithContext(child, context);\n            }\n          }\n        } else if (value.type) {\n          traverseWithContext(value, context);\n        }\n      }\n    }\n  }\n\n  // Start traversal at top level (not in function or class)\n  traverseWithContext(ast, { inFunction: false, inClass: false });\n\n  // Second pass: process functions in order\n  for (const { node, match } of functionNodes) {\n    const name = getFunctionName(node) || \"anonymous\";\n    const exportName = getExportedName(node);\n    const functionKey = `${name}-${exportName || \"\"}-${match.range[0]}`;\n\n    // Skip if we've already processed this function\n    if (processedFunctions.has(functionKey)) continue;\n    processedFunctions.add(functionKey);\n\n    processFunctionNode(node, name, exportName, match, directiveInfo);\n  }\n\n  // Add warnings for mixed server/client directives\n  if (directiveInfo.fileLevel && directiveInfo.functionLevel.length > 0) {\n    for (const func of directiveInfo.functionLevel) {\n      if (directiveInfo.fileLevel.type !== func.type) {\n        directiveInfo.warnings.push({\n          message: `Cannot have both 'use ${directiveInfo.fileLevel.type}' and 'use ${func.type}' directives in the same file`,\n          range: func.range,\n          type: \"server\",\n        });\n      } else if (func.type !== \"server\") {\n        directiveInfo.warnings.push({\n          message: `Function-level directives should be 'use server', but got 'use ${func.type}'`,\n          range: func.range,\n          type: \"client\",\n        });\n      } else {\n        directiveInfo.warnings.push({\n          message: `'use server' is already defined at the top of the file, this directive should be removed.`,\n          range: func.range,\n          type: \"server\",\n        });\n      }\n    }\n  }\n\n  return directiveInfo;\n}\n"],"names":[],"mappings":"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"}
|
|
248
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"analyzeDirectives.js","sources":["../../../../plugin/loader/directives/analyzeDirectives.ts"],"sourcesContent":["import { findDirectiveMatches } from \"./findDirectiveMatches.js\";\nimport { isFunctionNode } from \"./typeGuards.js\";\nimport { getFunctionBody } from \"./getFunctionBody.js\";\nimport { getFunctionName } from \"./getFunctionName.js\";\nimport { getExportedName } from \"./getExportedName.js\";\nimport { processFunctionNode } from \"./processFunctionNode.js\";\nimport {\n  isDirectiveAtStart,\n  getDirectiveValue,\n  matchOverlapsDirective,\n} from \"./utils.js\";\nimport type {\n  DirectiveInfo,\n  DirectiveMatch,\n  DirectiveMatches,\n} from \"./types.js\";\nimport type { Node, Program } from \"acorn\";\nimport type { DirectiveOptions } from \"../../types.js\";\nimport { createLogger, type Logger } from \"vite\";\n\n/**\n * Analyzes directives in the given source and AST, returning directiveInfo.\n */\nexport function analyzeDirectives(\n  ast: Program,\n  source: string,\n  matches?: DirectiveMatches,\n  logger?: Logger\n): DirectiveInfo;\nexport function analyzeDirectives(\n  ast: Program,\n  source: string,\n  options?: DirectiveOptions,\n  logger?: Logger\n): DirectiveInfo;\nexport function analyzeDirectives(\n  ast: Program,\n  source: string,\n  optionsOrMatches?: DirectiveMatches | DirectiveOptions,\n  _logger?: Logger\n): DirectiveInfo {\n  const hasOptions =\n    optionsOrMatches != null && typeof optionsOrMatches === \"object\";\n  const directiveMatches =\n    hasOptions && \"matches\" in optionsOrMatches\n      ? optionsOrMatches\n      : findDirectiveMatches(source);\n\n  const directiveInfo: DirectiveInfo = {\n    fileLevel: null,\n    functionLevel: [],\n    warnings: [],\n  };\n\n  // Find file-level directives by checking AST\n  let foundNonDirective = false;\n  let firstDirective: DirectiveMatch | null = null;\n  const verbose =\n    hasOptions &&\n    typeof optionsOrMatches === \"object\" &&\n    \"verbose\" in optionsOrMatches &&\n    optionsOrMatches.verbose;\n  const logger =\n    hasOptions &&\n    typeof optionsOrMatches === \"object\" &&\n    \"logger\" in optionsOrMatches\n      ? optionsOrMatches.logger ?? _logger ?? createLogger()\n      : _logger ?? createLogger();\n  // Check if this looks like Vite-injected code\n  // During build, Vite may prepend imports (e.g., __vitePreload for dynamic imports)\n  // before \"use client\"/\"use server\" directives\n  const isViteInjectedCode =\n    source.includes(\"__vite__createHotContext\") ||\n    source.includes(\"import.meta.hot\") ||\n    source.includes(\"import.meta.env\") ||\n    source.includes(\"/@vite/client\") ||\n    source.includes(\"__vitePreload\") ||\n    source.includes(\"\\0vite/\");\n\n  for (const node of ast.body) {\n    // Debug logging\n    if (verbose) {\n      logger.info(\n        `[analyzeDirectives] Processing node: ${node.type} start: ${node.start} end: ${node.end}\ndirective: ${\"directive\" in node ? node.directive : \"none\"}\nbeforeNode: ${node.start! > 0 ? JSON.stringify(source.slice(0, node.start!)).slice(0, 100) : \"none\"}`\n      );\n    }\n\n    // Only check for directives in expression statements\n    if (node.type === \"ExpressionStatement\") {\n      let directive: string | null = null;\n      if (\"directive\" in node && typeof node.directive === \"string\") {\n        directive = node.directive;\n      } else if (\n        node.expression.type === \"Literal\" &&\n        typeof node.expression.value === \"string\" &&\n        (node.expression.value === \"use server\" ||\n          node.expression.value === \"use client\")\n      ) {\n        directive = node.expression.value;\n      }\n\n      if (directive) {\n        const getDirectiveType =\n          optionsOrMatches != null && \"loader\" in optionsOrMatches\n            ? optionsOrMatches.loader?.getDirectiveType\n            : undefined;\n        const type =\n          getDirectiveType?.(directive) ??\n          (directive === \"use server\" ? \"server\" : \"client\");\n        if (!firstDirective) {\n          firstDirective = { type, range: [node.start!, node.end!] };\n          if (verbose) {\n            logger.info(\n              `[analyzeDirectives] Found first directive: ${directive} at range: ${[\n                node.start!,\n                node.end!,\n              ]}`\n            );\n          }\n        } else {\n          directiveInfo.warnings.push({\n            message:\n              \"Cannot have both 'use client' and 'use server' directives in the same file\",\n            range: [0, 0],\n            type: \"server\",\n          });\n        }\n      } else {\n        // This expression statement is not a directive, so mark as non-directive\n        // if we haven't found the first directive yet\n        if (!firstDirective) {\n          foundNonDirective = true;\n          if (verbose) {\n            logger.info(\n              `[analyzeDirectives] Found non-directive expression before first directive, setting foundNonDirective=true`\n            );\n          }\n        }\n      }\n    } else {\n      // Only mark actual code (not imports/exports) as non-directive\n      // if we haven't found the first directive yet\n      if (!firstDirective) {\n        foundNonDirective = true;\n        if (verbose) {\n          logger.info(\n            `[analyzeDirectives] Found non-directive node before first directive: ${node.type}, setting foundNonDirective=true`\n          );\n        }\n      }\n    }\n\n    // Check if this node is after any comments or non-whitespace content\n    // Only matters if we haven't found the first directive yet\n    if (!firstDirective && node.start! > 0) {\n      const beforeNode = source.slice(0, node.start!).trim();\n      if (beforeNode.length > 0) {\n        foundNonDirective = true;\n        if (verbose) {\n          logger.info(\n            `[analyzeDirectives] Found content before first directive: ${JSON.stringify(\n              beforeNode.slice(0, 100)\n            )}, setting foundNonDirective=true`\n          );\n        }\n      }\n    }\n  }\n\n  // Set the first directive as file-level if found\n  if (firstDirective) {\n    directiveInfo.fileLevel = firstDirective;\n\n    // Check if there was content (including comments) before the directive\n    if (!foundNonDirective && firstDirective.range[0] > 0) {\n      const beforeDirective = source.slice(0, firstDirective.range[0]).trim();\n      if (beforeDirective.length > 0) {\n        foundNonDirective = true;\n        if (verbose) {\n          logger.info(\n            `[analyzeDirectives] Found content before directive: ${JSON.stringify(\n              beforeDirective\n            )}, setting foundNonDirective=true for directive`\n          );\n        }\n      }\n    }\n\n    // Only warn about directive placement if it's not Vite-injected code\n    if (foundNonDirective && !isViteInjectedCode) {\n      directiveInfo.warnings.push({\n        message:\n          \"File-level directives must be at the top of the file, before any other code\",\n        range: [firstDirective.range[0], firstDirective.range[1]],\n        type: firstDirective.type,\n      });\n    }\n  }\n\n  // Process function-level directives\n  const functionLevelMatches = directiveMatches.matches.filter(\n    (match: DirectiveMatch) => {\n      // Skip if this match is already used as a file-level directive\n      if (\n        directiveInfo.fileLevel &&\n        match.range[0] === directiveInfo.fileLevel.range[0] &&\n        match.range[1] === directiveInfo.fileLevel.range[1]\n      ) {\n        return false;\n      }\n      return true;\n    }\n  );\n\n  const processedFunctions = new Set<string>();\n\n  // First pass: collect all function nodes with their directives\n  const functionNodes: Array<{\n    node: Node;\n    match: DirectiveMatch;\n    context: string;\n  }> = [];\n\n  // Track context during traversal\n  function traverseWithContext(\n    node: Node,\n    context: { inFunction: boolean; inClass: boolean }\n  ) {\n    if (isFunctionNode(node)) {\n      const body = getFunctionBody(node);\n      if (body) {\n        // Check if directive is at the start of the function body\n        for (const match of functionLevelMatches) {\n          const directiveValue = getDirectiveValue(match.type);\n\n          if (isDirectiveAtStart(node, directiveValue)) {\n            // Check if the match range corresponds to this specific directive position\n            const directiveNode = body.body[0];\n            const directiveStart = directiveNode.start!;\n            const directiveEnd = directiveNode.end!;\n\n            // Match based on position - the match should overlap with the directive node\n            const matchOverlaps = matchOverlapsDirective(\n              match.range,\n              directiveStart,\n              directiveEnd\n            );\n\n            if (matchOverlaps) {\n              const functionName = getFunctionName(node) || \"anonymous\";\n\n              // Check for invalid contexts based on traversal context\n              if (context.inFunction) {\n                const nameDesc =\n                  functionName === \"anonymous\" ? \"\" : ` '${functionName}'`;\n                directiveInfo.warnings.push({\n                  message: `Function${nameDesc} with '${directiveValue}' directive cannot be nested inside another function. Directives are only allowed in top-level functions.`,\n                  range: match.range,\n                  type: match.type,\n                });\n                return; // Skip this function entirely\n              }\n\n              if (context.inClass) {\n                const nameDesc =\n                  functionName === \"anonymous\" ? \"\" : ` '${functionName}'`;\n                directiveInfo.warnings.push({\n                  message: `Class method${nameDesc} with '${directiveValue}' directive is not supported. Directives are only allowed in top-level functions.`,\n                  range: match.range,\n                  type: match.type,\n                });\n                return; // Skip this function entirely\n              }\n\n              // Only allow server directives in function-level contexts\n              if (match.type === \"server\") {\n                functionNodes.push({\n                  node,\n                  match,\n                  context: context.inFunction\n                    ? \"nested\"\n                    : context.inClass\n                    ? \"class\"\n                    : \"top-level\",\n                });\n              } else {\n                // Generate warning for client directives in functions\n                directiveInfo.warnings.push({\n                  message: \"Function-level 'use client' isn't allowed\",\n                  range: match.range,\n                  type: \"client\",\n                });\n              }\n              break;\n            }\n          }\n        }\n      }\n\n      // Continue traversal with updated context (now inside a function)\n      traverseChildren(node, { inFunction: true, inClass: context.inClass });\n    } else if (\n      node.type === \"ClassDeclaration\" ||\n      node.type === \"ClassExpression\"\n    ) {\n      // Continue traversal with updated context (now inside a class)\n      traverseChildren(node, { inFunction: context.inFunction, inClass: true });\n    } else if (node.type === \"MethodDefinition\") {\n      // Method definitions are inside classes\n      traverseChildren(node, { inFunction: context.inFunction, inClass: true });\n    } else {\n      // Continue with same context\n      traverseChildren(node, context);\n    }\n  }\n\n  function traverseChildren(\n    node: Node,\n    context: { inFunction: boolean; inClass: boolean }\n  ) {\n    const nodeWithChildren = node as any;\n    for (const key in nodeWithChildren) {\n      if (\n        key === \"parent\" ||\n        key === \"start\" ||\n        key === \"end\" ||\n        key === \"loc\" ||\n        key === \"range\"\n      ) {\n        continue;\n      }\n\n      const value = nodeWithChildren[key];\n      if (value && typeof value === \"object\") {\n        if (Array.isArray(value)) {\n          for (const child of value) {\n            if (child && typeof child === \"object\" && child.type) {\n              traverseWithContext(child, context);\n            }\n          }\n        } else if (value.type) {\n          traverseWithContext(value, context);\n        }\n      }\n    }\n  }\n\n  // Start traversal at top level (not in function or class)\n  traverseWithContext(ast, { inFunction: false, inClass: false });\n\n  // Second pass: process functions in order\n  for (const { node, match } of functionNodes) {\n    const name = getFunctionName(node) || \"anonymous\";\n    const exportName = getExportedName(node);\n    const functionKey = `${name}-${exportName || \"\"}-${match.range[0]}`;\n\n    // Skip if we've already processed this function\n    if (processedFunctions.has(functionKey)) continue;\n    processedFunctions.add(functionKey);\n\n    processFunctionNode(node, name, exportName, match, directiveInfo);\n  }\n\n  // Add warnings for mixed server/client directives\n  if (directiveInfo.fileLevel && directiveInfo.functionLevel.length > 0) {\n    for (const func of directiveInfo.functionLevel) {\n      if (directiveInfo.fileLevel.type !== func.type) {\n        directiveInfo.warnings.push({\n          message: `Cannot have both 'use ${directiveInfo.fileLevel.type}' and 'use ${func.type}' directives in the same file`,\n          range: func.range,\n          type: \"server\",\n        });\n      } else if (func.type !== \"server\") {\n        directiveInfo.warnings.push({\n          message: `Function-level directives should be 'use server', but got 'use ${func.type}'`,\n          range: func.range,\n          type: \"client\",\n        });\n      } else {\n        directiveInfo.warnings.push({\n          message: `'use server' is already defined at the top of the file, this directive should be removed.`,\n          range: func.range,\n          type: \"server\",\n        });\n      }\n    }\n  }\n\n  return directiveInfo;\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"react-loader.d.ts","sourceRoot":"","sources":["../../../plugin/loader/react-loader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,wBAAwB,EACxB,qBAAqB,EACtB,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEzC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AASvD,OAAO,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAOzD,MAAM,MAAM,aAAa,GAAG;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3C,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3C,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,CAAC,OAAO,EAAE,aAAa,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;AAyB7E,wBAAgB,UAAU,CAAC,IAAI,EAAE;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,WAAW,CAAC;IAClB,WAAW,EAAE,qBAAqB,CAAC;IACnC,cAAc,EAAE,wBAAwB,CAAC;CAC1C,QA4CA;AAED,eAAO,MAAM,IAAI,EAAE,
|
|
1
|
+
{"version":3,"file":"react-loader.d.ts","sourceRoot":"","sources":["../../../plugin/loader/react-loader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,wBAAwB,EACxB,qBAAqB,EACtB,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEzC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AASvD,OAAO,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAOzD,MAAM,MAAM,aAAa,GAAG;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3C,gBAAgB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC3C,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,CAAC,OAAO,EAAE,aAAa,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC;AAyB7E,wBAAgB,UAAU,CAAC,IAAI,EAAE;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,WAAW,CAAC;IAClB,WAAW,EAAE,qBAAqB,CAAC;IACnC,cAAc,EAAE,wBAAwB,CAAC;CAC1C,QA4CA;AAED,eAAO,MAAM,IAAI,EAAE,QAqHlB,CAAC;AAEF,eAAO,MAAM,OAAO,EAAE,WAErB,CAAC"}
|
|
@@ -65,26 +65,9 @@ const load = async (url, context, nextLoad) => {
|
|
|
65
65
|
});
|
|
66
66
|
}
|
|
67
67
|
const verbose2 = userOptions?.verbose ?? false;
|
|
68
|
-
if (verbose2) {
|
|
69
|
-
logger.info(`Attempting to load: ${url}`);
|
|
70
|
-
logger.info(`Context: ${JSON.stringify({
|
|
71
|
-
format: context.format,
|
|
72
|
-
conditions: context.conditions
|
|
73
|
-
})}`);
|
|
74
|
-
}
|
|
75
68
|
const { format } = context;
|
|
76
69
|
if (format === "module" || format === "module-typescript") {
|
|
77
|
-
if (verbose2) {
|
|
78
|
-
logger.info(`Loading module: ${url}`);
|
|
79
|
-
}
|
|
80
70
|
const result = await nextLoad(url, context);
|
|
81
|
-
if (verbose2) {
|
|
82
|
-
logger.info(`Next load result: ${JSON.stringify({
|
|
83
|
-
format: result.format,
|
|
84
|
-
shortCircuit: result.shortCircuit,
|
|
85
|
-
source: typeof result.source
|
|
86
|
-
})}`);
|
|
87
|
-
}
|
|
88
71
|
let source = typeof result.source === "string" ? result.source : result.source instanceof Uint8Array ? new TextDecoder().decode(result.source) : String(result.source);
|
|
89
72
|
if (!url.includes("node_modules")) {
|
|
90
73
|
const namedImportRe = /import\s*\{([^}]+)\}\s*from\s*["']react["']\s*;?/g;
|
|
@@ -104,35 +87,13 @@ const load = async (url, context, nextLoad) => {
|
|
|
104
87
|
const hasFileLevelClientDirective = source.startsWith('"use client"') || source.startsWith("'use client'");
|
|
105
88
|
const isServer = hasFileLevelServerDirective || (typeof isServerFunction === "function" ? isServerFunction(source, url) : false);
|
|
106
89
|
const isClient = hasFileLevelClientDirective || (typeof isClientComponent === "function" ? isClientComponent(source, url) : false);
|
|
107
|
-
if (verbose2) {
|
|
108
|
-
let startPreviewIndex = 0;
|
|
109
|
-
let startLine = 0;
|
|
110
|
-
const lines = source.split("\n");
|
|
111
|
-
while (lines[startLine].trim() === "" || lines[startLine].trim() === "\r" || // comment lines
|
|
112
|
-
lines[startLine].trim().startsWith("//") || lines[startLine].trim().startsWith("/**") || lines[startLine].trim().startsWith("*")) {
|
|
113
|
-
startPreviewIndex += lines[startLine].length;
|
|
114
|
-
startLine++;
|
|
115
|
-
}
|
|
116
|
-
logger.info(`Module analysis: ${JSON.stringify({
|
|
117
|
-
url,
|
|
118
|
-
isServer,
|
|
119
|
-
isClient,
|
|
120
|
-
hasFileLevelServerDirective,
|
|
121
|
-
hasFileLevelClientDirective,
|
|
122
|
-
sourceLength: source.length,
|
|
123
|
-
sourcePreview: source.slice(startPreviewIndex, startPreviewIndex + 100) + "..."
|
|
124
|
-
})}`);
|
|
125
|
-
}
|
|
126
90
|
if (!isServer && !isClient) {
|
|
127
|
-
if (verbose2) {
|
|
128
|
-
logger.info(`Skipping non-server/non-client module: ${url}`);
|
|
129
|
-
}
|
|
130
91
|
return { ...result, source };
|
|
131
92
|
}
|
|
132
|
-
const filePath = url.startsWith("file://") ? fileURLToPath(url) : url;
|
|
133
93
|
if (verbose2) {
|
|
134
|
-
logger.info(`
|
|
94
|
+
logger.info(`[react-loader] ${isServer ? "server" : "client"} module: ${url}`);
|
|
135
95
|
}
|
|
96
|
+
const filePath = url.startsWith("file://") ? fileURLToPath(url) : url;
|
|
136
97
|
if (typeof userOptions.moduleID !== "function") {
|
|
137
98
|
const buildConfigEnv = resolvedConfig?.configEnv ?? { command: "build"};
|
|
138
99
|
userOptions.moduleID = createDefaultModuleID({
|
|
@@ -151,24 +112,9 @@ const load = async (url, context, nextLoad) => {
|
|
|
151
112
|
const [, value] = userOptions.normalizer(filePath);
|
|
152
113
|
moduleID = join(userOptions.moduleBasePath, value);
|
|
153
114
|
finalID = userOptions.moduleID?.(moduleID) || moduleID;
|
|
154
|
-
if (verbose2) {
|
|
155
|
-
logger.info(`Normalized IDs: ${moduleID} -> ${finalID}`);
|
|
156
|
-
logger.info(`userOptions: ${JSON.stringify(userOptions)}`);
|
|
157
|
-
}
|
|
158
115
|
}
|
|
159
116
|
const { code: transformed, map } = await transformer(source, moduleID, finalID);
|
|
160
|
-
if (verbose2) {
|
|
161
|
-
logger.info(`Transformation result: ${JSON.stringify({
|
|
162
|
-
originalLength: source.length,
|
|
163
|
-
transformedLength: transformed.length,
|
|
164
|
-
wasTransformed: source !== transformed,
|
|
165
|
-
hasSourceMap: !!map
|
|
166
|
-
})}`);
|
|
167
|
-
}
|
|
168
117
|
if (loaderPort) {
|
|
169
|
-
if (verbose2) {
|
|
170
|
-
logger.info("Sending SERVER_MODULE message");
|
|
171
|
-
}
|
|
172
118
|
loaderPort.postMessage({
|
|
173
119
|
type: "SERVER_MODULE",
|
|
174
120
|
id: finalID,
|
|
@@ -182,23 +128,11 @@ const load = async (url, context, nextLoad) => {
|
|
|
182
128
|
map
|
|
183
129
|
};
|
|
184
130
|
}
|
|
185
|
-
if (verbose2) {
|
|
186
|
-
logger.info(`Skipping non-module format: ${format}`);
|
|
187
|
-
}
|
|
188
131
|
return nextLoad(url, context);
|
|
189
132
|
};
|
|
190
133
|
const resolve = async (specifier, context, nextResolve) => {
|
|
191
|
-
|
|
192
|
-
if (verbose) {
|
|
193
|
-
logger.info(`Resolving: ${specifier}`);
|
|
194
|
-
logger.info(`Resolve context: ${JSON.stringify(context)}`);
|
|
195
|
-
}
|
|
196
|
-
const result = await nextResolve(specifier, context);
|
|
197
|
-
if (verbose) {
|
|
198
|
-
logger.info(`Resolve result: ${JSON.stringify(result)}`);
|
|
199
|
-
}
|
|
200
|
-
return result;
|
|
134
|
+
return nextResolve(specifier, context);
|
|
201
135
|
};
|
|
202
136
|
|
|
203
137
|
export { initialize, load, resolve };
|
|
204
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"react-loader.js","sources":["../../../plugin/loader/react-loader.ts"],"sourcesContent":["import type {\n  ResolvedUserOptions,\n  SerializedResolvedConfig,\n  SerializedUserOptions,\n} from \"../types.js\";\nimport type { ModuleInfo } from \"rollup\";\nimport { parentPort } from \"node:worker_threads\";\nimport type { MessagePort } from \"node:worker_threads\";\nimport type {\n  InitializedReactLoaderMessage,\n  ServerModuleMessage,\n} from \"../worker/rsc/types.js\";\nimport { fileURLToPath } from \"node:url\";\nimport { join } from \"node:path\";\nimport { hydrateUserOptions } from \"../helpers/hydrateUserOptions.js\";\nimport { DEFAULT_LOADER_CONFIG } from \"../config/defaults.js\";\nimport type { LoadHook, ResolveHook } from \"node:module\";\nimport type { RawSourceMap } from \"source-map\";\nimport { createTransformer } from \"./createTransformer.js\";\n\nimport { createLogger, type Logger } from \"vite\";\nimport { createDefaultModuleID } from \"../config/createModuleID.js\";\n\nexport type LoaderOptions = {\n  id: string;\n  resolveDependencies?: boolean;\n  format?: string;\n  conditions?: string[];\n  importAssertions?: Record<string, unknown>;\n  importAttributes?: Record<string, unknown>;\n  source: string;\n};\n\nexport type LoaderFunction = (options: LoaderOptions) => Promise<ModuleInfo>;\n\nlet initialized = false;\nlet userOptions: ResolvedUserOptions;\nlet loaderPort: MessagePort | null;\nlet resolvedConfig: SerializedResolvedConfig;\nlet isServerFunction:\n  | RegExpMatchArray\n  | RegExp\n  | ((source: string, url: string) => boolean)\n  | null = DEFAULT_LOADER_CONFIG.isServerFunctionCode;\n\nlet isClientComponent:\n  | RegExpMatchArray\n  | RegExp\n  | ((source: string, url: string) => boolean)\n  | null = DEFAULT_LOADER_CONFIG.isClientComponentCode;\nlet logger: Logger;\nlet verbose: boolean;\nlet transformer: (\n  source: string,\n  moduleId: string,\n  transformedModuleId: string\n) => Promise<{ code: string; map: RawSourceMap | null }>;\n\nexport function initialize(data: {\n  id: string;\n  port: MessagePort;\n  userOptions: SerializedUserOptions;\n  resolvedConfig: SerializedResolvedConfig;\n}) {\n  const {\n    id,\n    port,\n    userOptions: serializedUserOptions,\n    resolvedConfig: serializedResolvedConfig,\n  } = data;\n  \n  verbose = serializedUserOptions?.verbose ?? false;\n  logger = createLogger(serializedResolvedConfig?.logLevel ?? \"info\", {\n    prefix: id,\n  });\n  \n  // Store resolvedConfig at module level for use in other functions\n  resolvedConfig = serializedResolvedConfig;\n  \n  if (verbose) {\n    logger.info(`Initializing with options: ${id}`);\n  }\n  loaderPort = port;\n  \n  // when user options are provided, use the user options using the hydrateUserOptions function\n  const resolvedUserOptions = hydrateUserOptions(serializedUserOptions);\n  if (resolvedUserOptions.type === \"error\") {\n    throw resolvedUserOptions.error;\n  }\n\n  // Use the hydrated user options directly (includes recreated functions)\n  userOptions = resolvedUserOptions.userOptions;\n\n  isServerFunction = userOptions.loader?.isServerFunctionCode ?? DEFAULT_LOADER_CONFIG.isServerFunctionCode;\n  isClientComponent = userOptions.loader?.isClientComponentCode ?? DEFAULT_LOADER_CONFIG.isClientComponentCode;\n  \n  transformer = createTransformer({\n    options: userOptions,\n  });\n  \n  if (!initialized && loaderPort) {\n    loaderPort.postMessage({\n      type: \"INITIALIZED_REACT_LOADER\",\n      id,\n    } satisfies InitializedReactLoaderMessage);\n  }\n  initialized = true;\n}\n\nexport const load: LoadHook = async (url, context, nextLoad) => {\n  if (!initialized) {\n    // Fallback initialization when not properly set up\n    // This should not happen in normal usage, but provides a basic fallback\n    initialize({\n      id: \"react-loader\",\n      port: parentPort!,\n      userOptions: {} as any,\n      resolvedConfig: {} as any,\n    });\n  }\n  const verbose = userOptions?.verbose ?? false;\n  if (verbose) {\n    logger.info(`Attempting to load: ${url}`);\n    logger.info(`Context: ${JSON.stringify({\n      format: context.format,\n      conditions: context.conditions,\n    })}`);\n  }\n\n  const { format } = context;\n  if (format === \"module\" || format === \"module-typescript\") {\n    if (verbose) {\n      logger.info(`Loading module: ${url}`);\n    }\n    \n    // Load the URL normally\n    const result = await nextLoad(url, context);\n    \n    if (verbose) {\n      logger.info(`Next load result: ${JSON.stringify({\n        format: result.format,\n        shortCircuit: result.shortCircuit,\n        source: typeof result.source,\n      })}`);\n    }\n\n    let source =\n      typeof result.source === \"string\"\n        ? result.source\n        : result.source instanceof Uint8Array\n        ? new TextDecoder().decode(result.source)\n        : String(result.source);\n\n    // Fix CJS React named imports: React's react-server condition exports CJS,\n    // but esbuild/tsx transforms produce ESM named imports that fail at runtime.\n    // Rewrite `import { X } from \"react\"` → `import __react from \"react\"; const { X } = __react;`\n    if (!url.includes('node_modules')) {\n      const namedImportRe = /import\\s*\\{([^}]+)\\}\\s*from\\s*[\"']react[\"']\\s*;?/g;\n      if (namedImportRe.test(source)) {\n        namedImportRe.lastIndex = 0;\n        let counter = 0;\n        source = source.replace(namedImportRe, (_match: string, imports: string) => {\n          const alias = `__react_cjs_${counter++}`;\n          return `import ${alias} from \"react\"; const {${imports}} = ${alias};`;\n        });\n        if (verbose) {\n          logger.info(`Rewrote CJS React named imports in: ${url}`);\n        }\n      }\n    }\n\n    // Check for file-level server directive first\n    const hasFileLevelServerDirective =\n      source.startsWith('\"use server\"') || source.startsWith(\"'use server'\");\n    const hasFileLevelClientDirective =\n      source.startsWith('\"use client\"') || source.startsWith(\"'use client'\");\n\n    const isServer =\n      hasFileLevelServerDirective ||\n      (typeof isServerFunction === \"function\"\n        ? isServerFunction(source, url)\n        : false);\n\n    const isClient =\n      hasFileLevelClientDirective ||\n      (typeof isClientComponent === \"function\"\n        ? isClientComponent(source, url)\n        : false);\n\n    if (verbose) {\n      let startPreviewIndex = 0;\n      let startLine = 0;\n      const lines = source.split(\"\\n\");\n      while (\n        lines[startLine].trim() === \"\" || lines[startLine].trim() === \"\\r\" ||\n        // comment lines\n        lines[startLine].trim().startsWith(\"//\")\n        || lines[startLine].trim().startsWith(\"/**\")\n        || lines[startLine].trim().startsWith(\"*\")\n      ) {\n        startPreviewIndex += lines[startLine].length;\n        startLine++;\n      }\n      logger.info(`Module analysis: ${JSON.stringify({\n        url,\n        isServer,\n        isClient,\n        hasFileLevelServerDirective,\n        hasFileLevelClientDirective,\n        sourceLength: source.length,\n        sourcePreview: source.slice(startPreviewIndex, startPreviewIndex + 100) + \"...\",\n      })}`);\n    }\n\n    if (!isServer && !isClient) {\n      if (verbose) {\n        logger.info(`Skipping non-server/non-client module: ${url}`);\n      }\n      // Return modified source if CJS React imports were rewritten\n      return { ...result, source };\n    }\n\n    // Handle file URLs\n    const filePath = url.startsWith(\"file://\") ? fileURLToPath(url) : url;\n    if (verbose) {\n      logger.info(`File path: ${filePath}`);\n    }\n\n    if(typeof userOptions.moduleID !== \"function\") {\n      // Ensure we have proper build context for RSC worker\n      // If configEnv is not available or doesn't indicate build mode, create a build-compatible configEnv\n      const buildConfigEnv = resolvedConfig?.configEnv ?? { command: \"build\", mode: \"production\" };\n      \n      userOptions.moduleID = createDefaultModuleID({\n        moduleBase: userOptions.moduleBase,\n        moduleBasePath: userOptions.moduleBasePath,\n        autoDiscover: userOptions.autoDiscover,\n        build: userOptions.build,\n        dev: userOptions.dev,\n        moduleBaseURL: userOptions.moduleBaseURL,\n        projectRoot: userOptions.projectRoot,\n      }, buildConfigEnv);\n    }\n\n    // Normalize the URL using the same logic as plugin.server.ts\n    let moduleID = filePath;\n    let finalID = filePath;\n    if (userOptions?.normalizer) {\n      const [, value] = userOptions.normalizer(filePath);\n      moduleID = join(userOptions.moduleBasePath, value);\n      finalID = userOptions.moduleID?.(moduleID) || moduleID;\n      if (verbose) {\n        logger.info(`Normalized IDs: ${moduleID} -> ${finalID}`);\n        logger.info(`userOptions: ${JSON.stringify(userOptions)}`);\n      }\n    }\n\n    const { code: transformed, map } = await transformer(source, moduleID, finalID);\n\n    if (verbose) {\n      logger.info(`Transformation result: ${JSON.stringify({\n        originalLength: source.length,\n        transformedLength: transformed.length,\n        wasTransformed: source !== transformed,\n        hasSourceMap: !!map,\n      })}`);\n    }\n\n    if (loaderPort) {\n      if (verbose) {\n        logger.info(\"Sending SERVER_MODULE message\");\n      }\n      loaderPort.postMessage({\n        type: \"SERVER_MODULE\",\n        id: finalID,\n        url: filePath,\n        source: transformed,\n      } satisfies ServerModuleMessage);\n    }\n\n    return {\n      ...result,\n      source: transformed,\n      map,\n    };\n  }\n\n  if (verbose) {\n    logger.info(`Skipping non-module format: ${format}`);\n  }\n  return nextLoad(url, context);\n};\n\nexport const resolve: ResolveHook = async (specifier, context, nextResolve) => {\n  verbose = userOptions?.verbose ?? false;\n  if (verbose) {\n    logger.info(`Resolving: ${specifier}`);\n    logger.info(`Resolve context: ${JSON.stringify(context)}`);\n  }\n  const result = await nextResolve(specifier, context);\n  if (verbose) {\n    logger.info(`Resolve result: ${JSON.stringify(result)}`);\n  }\n  return result;\n};\n"],"names":["verbose"],"mappings":"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"}
|
|
138
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"react-loader.js","sources":["../../../plugin/loader/react-loader.ts"],"sourcesContent":["import type {\n  ResolvedUserOptions,\n  SerializedResolvedConfig,\n  SerializedUserOptions,\n} from \"../types.js\";\nimport type { ModuleInfo } from \"rollup\";\nimport { parentPort } from \"node:worker_threads\";\nimport type { MessagePort } from \"node:worker_threads\";\nimport type {\n  InitializedReactLoaderMessage,\n  ServerModuleMessage,\n} from \"../worker/rsc/types.js\";\nimport { fileURLToPath } from \"node:url\";\nimport { join } from \"node:path\";\nimport { hydrateUserOptions } from \"../helpers/hydrateUserOptions.js\";\nimport { DEFAULT_LOADER_CONFIG } from \"../config/defaults.js\";\nimport type { LoadHook, ResolveHook } from \"node:module\";\nimport type { RawSourceMap } from \"source-map\";\nimport { createTransformer } from \"./createTransformer.js\";\n\nimport { createLogger, type Logger } from \"vite\";\nimport { createDefaultModuleID } from \"../config/createModuleID.js\";\n\nexport type LoaderOptions = {\n  id: string;\n  resolveDependencies?: boolean;\n  format?: string;\n  conditions?: string[];\n  importAssertions?: Record<string, unknown>;\n  importAttributes?: Record<string, unknown>;\n  source: string;\n};\n\nexport type LoaderFunction = (options: LoaderOptions) => Promise<ModuleInfo>;\n\nlet initialized = false;\nlet userOptions: ResolvedUserOptions;\nlet loaderPort: MessagePort | null;\nlet resolvedConfig: SerializedResolvedConfig;\nlet isServerFunction:\n  | RegExpMatchArray\n  | RegExp\n  | ((source: string, url: string) => boolean)\n  | null = DEFAULT_LOADER_CONFIG.isServerFunctionCode;\n\nlet isClientComponent:\n  | RegExpMatchArray\n  | RegExp\n  | ((source: string, url: string) => boolean)\n  | null = DEFAULT_LOADER_CONFIG.isClientComponentCode;\nlet logger: Logger;\nlet verbose: boolean;\nlet transformer: (\n  source: string,\n  moduleId: string,\n  transformedModuleId: string\n) => Promise<{ code: string; map: RawSourceMap | null }>;\n\nexport function initialize(data: {\n  id: string;\n  port: MessagePort;\n  userOptions: SerializedUserOptions;\n  resolvedConfig: SerializedResolvedConfig;\n}) {\n  const {\n    id,\n    port,\n    userOptions: serializedUserOptions,\n    resolvedConfig: serializedResolvedConfig,\n  } = data;\n  \n  verbose = serializedUserOptions?.verbose ?? false;\n  logger = createLogger(serializedResolvedConfig?.logLevel ?? \"info\", {\n    prefix: id,\n  });\n  \n  // Store resolvedConfig at module level for use in other functions\n  resolvedConfig = serializedResolvedConfig;\n  \n  if (verbose) {\n    logger.info(`Initializing with options: ${id}`);\n  }\n  loaderPort = port;\n  \n  // when user options are provided, use the user options using the hydrateUserOptions function\n  const resolvedUserOptions = hydrateUserOptions(serializedUserOptions);\n  if (resolvedUserOptions.type === \"error\") {\n    throw resolvedUserOptions.error;\n  }\n\n  // Use the hydrated user options directly (includes recreated functions)\n  userOptions = resolvedUserOptions.userOptions;\n\n  isServerFunction = userOptions.loader?.isServerFunctionCode ?? DEFAULT_LOADER_CONFIG.isServerFunctionCode;\n  isClientComponent = userOptions.loader?.isClientComponentCode ?? DEFAULT_LOADER_CONFIG.isClientComponentCode;\n  \n  transformer = createTransformer({\n    options: userOptions,\n  });\n  \n  if (!initialized && loaderPort) {\n    loaderPort.postMessage({\n      type: \"INITIALIZED_REACT_LOADER\",\n      id,\n    } satisfies InitializedReactLoaderMessage);\n  }\n  initialized = true;\n}\n\nexport const load: LoadHook = async (url, context, nextLoad) => {\n  if (!initialized) {\n    // Fallback initialization when not properly set up\n    // This should not happen in normal usage, but provides a basic fallback\n    initialize({\n      id: \"react-loader\",\n      port: parentPort!,\n      userOptions: {} as any,\n      resolvedConfig: {} as any,\n    });\n  }\n  const verbose = userOptions?.verbose ?? false;\n\n  const { format } = context;\n  if (format === \"module\" || format === \"module-typescript\") {\n    // Load the URL normally\n    const result = await nextLoad(url, context);\n\n    let source =\n      typeof result.source === \"string\"\n        ? result.source\n        : result.source instanceof Uint8Array\n        ? new TextDecoder().decode(result.source)\n        : String(result.source);\n\n    // Fix CJS React named imports: React's react-server condition exports CJS,\n    // but esbuild/tsx transforms produce ESM named imports that fail at runtime.\n    // Rewrite `import { X } from \"react\"` → `import __react from \"react\"; const { X } = __react;`\n    if (!url.includes('node_modules')) {\n      const namedImportRe = /import\\s*\\{([^}]+)\\}\\s*from\\s*[\"']react[\"']\\s*;?/g;\n      if (namedImportRe.test(source)) {\n        namedImportRe.lastIndex = 0;\n        let counter = 0;\n        source = source.replace(namedImportRe, (_match: string, imports: string) => {\n          const alias = `__react_cjs_${counter++}`;\n          return `import ${alias} from \"react\"; const {${imports}} = ${alias};`;\n        });\n        if (verbose) {\n          logger.info(`Rewrote CJS React named imports in: ${url}`);\n        }\n      }\n    }\n\n    // Check for file-level server directive first\n    const hasFileLevelServerDirective =\n      source.startsWith('\"use server\"') || source.startsWith(\"'use server'\");\n    const hasFileLevelClientDirective =\n      source.startsWith('\"use client\"') || source.startsWith(\"'use client'\");\n\n    const isServer =\n      hasFileLevelServerDirective ||\n      (typeof isServerFunction === \"function\"\n        ? isServerFunction(source, url)\n        : false);\n\n    const isClient =\n      hasFileLevelClientDirective ||\n      (typeof isClientComponent === \"function\"\n        ? isClientComponent(source, url)\n        : false);\n\n    if (!isServer && !isClient) {\n      // Return modified source if CJS React imports were rewritten\n      return { ...result, source };\n    }\n\n    if (verbose) {\n      logger.info(`[react-loader] ${isServer ? 'server' : 'client'} module: ${url}`);\n    }\n\n    // Handle file URLs\n    const filePath = url.startsWith(\"file://\") ? fileURLToPath(url) : url;\n\n    if(typeof userOptions.moduleID !== \"function\") {\n      // Ensure we have proper build context for RSC worker\n      // If configEnv is not available or doesn't indicate build mode, create a build-compatible configEnv\n      const buildConfigEnv = resolvedConfig?.configEnv ?? { command: \"build\", mode: \"production\" };\n      \n      userOptions.moduleID = createDefaultModuleID({\n        moduleBase: userOptions.moduleBase,\n        moduleBasePath: userOptions.moduleBasePath,\n        autoDiscover: userOptions.autoDiscover,\n        build: userOptions.build,\n        dev: userOptions.dev,\n        moduleBaseURL: userOptions.moduleBaseURL,\n        projectRoot: userOptions.projectRoot,\n      }, buildConfigEnv);\n    }\n\n    // Normalize the URL using the same logic as plugin.server.ts\n    let moduleID = filePath;\n    let finalID = filePath;\n    if (userOptions?.normalizer) {\n      const [, value] = userOptions.normalizer(filePath);\n      moduleID = join(userOptions.moduleBasePath, value);\n      finalID = userOptions.moduleID?.(moduleID) || moduleID;\n    }\n\n    const { code: transformed, map } = await transformer(source, moduleID, finalID);\n\n    if (loaderPort) {\n      loaderPort.postMessage({\n        type: \"SERVER_MODULE\",\n        id: finalID,\n        url: filePath,\n        source: transformed,\n      } satisfies ServerModuleMessage);\n    }\n\n    return {\n      ...result,\n      source: transformed,\n      map,\n    };\n  }\n\n  return nextLoad(url, context);\n};\n\nexport const resolve: ResolveHook = async (specifier, context, nextResolve) => {\n  return nextResolve(specifier, context);\n};\n"],"names":["verbose"],"mappings":"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"}
|
|
@@ -1,12 +1,8 @@
|
|
|
1
1
|
import { type Logger } from "vite";
|
|
2
2
|
import type { GenericModuleLoader } from "../../types.js";
|
|
3
3
|
/**
|
|
4
|
-
* Creates a
|
|
5
|
-
*
|
|
6
|
-
* This follows the same pattern as the main thread server version:
|
|
7
|
-
* - Simple dynamic import-based loading
|
|
8
|
-
* - Proper export name resolution
|
|
9
|
-
* - Works in both dev and build scenarios
|
|
4
|
+
* Creates a GenericModuleLoader for the RSC worker.
|
|
5
|
+
* Uses createSharedLoader for virtual modules, manifest resolution, and imports.
|
|
10
6
|
*/
|
|
11
7
|
export declare const createRscWorkerLoader: ({ verbose, logger, projectRoot, build, manifest, }?: {
|
|
12
8
|
verbose?: boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createRscWorkerLoader.d.ts","sourceRoot":"","sources":["../../../../plugin/worker/rsc/createRscWorkerLoader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,KAAK,MAAM,EAAE,MAAM,MAAM,CAAC;AAEjD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAG1D
|
|
1
|
+
{"version":3,"file":"createRscWorkerLoader.d.ts","sourceRoot":"","sources":["../../../../plugin/worker/rsc/createRscWorkerLoader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,KAAK,MAAM,EAAE,MAAM,MAAM,CAAC;AAEjD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAG1D;;;GAGG;AACH,eAAO,MAAM,qBAAqB,GAAI,qDAQnC;IACD,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE;QACN,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;KACjB,CAAC;IACF,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAC3B,KAAG,mBA4BR,CAAC"}
|