@mionjs/devtools 0.8.0-alpha.0 → 0.8.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.
Files changed (34) hide show
  1. package/build/vite-plugin/cjs/src/vite-plugin/aotCacheGenerator.cjs +62 -26
  2. package/build/vite-plugin/cjs/src/vite-plugin/aotCacheGenerator.cjs.map +1 -1
  3. package/build/vite-plugin/cjs/src/vite-plugin/aotCacheGenerator.d.ts +11 -3
  4. package/build/vite-plugin/cjs/src/vite-plugin/aotDiskCache.cjs +5 -4
  5. package/build/vite-plugin/cjs/src/vite-plugin/aotDiskCache.cjs.map +1 -1
  6. package/build/vite-plugin/cjs/src/vite-plugin/constants.cjs +4 -0
  7. package/build/vite-plugin/cjs/src/vite-plugin/constants.cjs.map +1 -1
  8. package/build/vite-plugin/cjs/src/vite-plugin/constants.d.ts +2 -0
  9. package/build/vite-plugin/cjs/src/vite-plugin/mionVitePlugin.cjs +137 -30
  10. package/build/vite-plugin/cjs/src/vite-plugin/mionVitePlugin.cjs.map +1 -1
  11. package/build/vite-plugin/cjs/src/vite-plugin/mionVitePlugin.d.ts +2 -2
  12. package/build/vite-plugin/cjs/src/vite-plugin/transformers.cjs +1 -0
  13. package/build/vite-plugin/cjs/src/vite-plugin/transformers.cjs.map +1 -1
  14. package/build/vite-plugin/cjs/src/vite-plugin/types.d.ts +6 -4
  15. package/build/vite-plugin/cjs/src/vite-plugin/virtualModule.cjs +3 -2
  16. package/build/vite-plugin/cjs/src/vite-plugin/virtualModule.cjs.map +1 -1
  17. package/build/vite-plugin/esm/src/vite-plugin/aotCacheGenerator.d.ts +11 -3
  18. package/build/vite-plugin/esm/src/vite-plugin/aotCacheGenerator.js +62 -26
  19. package/build/vite-plugin/esm/src/vite-plugin/aotCacheGenerator.js.map +1 -1
  20. package/build/vite-plugin/esm/src/vite-plugin/aotDiskCache.js +5 -4
  21. package/build/vite-plugin/esm/src/vite-plugin/aotDiskCache.js.map +1 -1
  22. package/build/vite-plugin/esm/src/vite-plugin/constants.d.ts +2 -0
  23. package/build/vite-plugin/esm/src/vite-plugin/constants.js +4 -0
  24. package/build/vite-plugin/esm/src/vite-plugin/constants.js.map +1 -1
  25. package/build/vite-plugin/esm/src/vite-plugin/mionVitePlugin.d.ts +2 -2
  26. package/build/vite-plugin/esm/src/vite-plugin/mionVitePlugin.js +138 -32
  27. package/build/vite-plugin/esm/src/vite-plugin/mionVitePlugin.js.map +1 -1
  28. package/build/vite-plugin/esm/src/vite-plugin/transformers.js +1 -0
  29. package/build/vite-plugin/esm/src/vite-plugin/transformers.js.map +1 -1
  30. package/build/vite-plugin/esm/src/vite-plugin/types.d.ts +6 -4
  31. package/build/vite-plugin/esm/src/vite-plugin/virtualModule.js +3 -2
  32. package/build/vite-plugin/esm/src/vite-plugin/virtualModule.js.map +1 -1
  33. package/package.json +2 -2
  34. package/src/vite-plugin/virtual-modules.d.ts +1 -1
@@ -1,14 +1,13 @@
1
1
  import { resolve } from "path";
2
+ import { createRequire } from "module";
3
+ import { existsSync } from "fs";
2
4
  import * as ts from "typescript";
3
5
  import { createDeepkitConfig, createPureFnTransformerFactory } from "./transformers.js";
4
6
  import { scanClientSource } from "./extractPureFn.js";
5
7
  import { generateServerPureFnsVirtualModule } from "./virtualModule.js";
6
- import { resolveVirtualId, VIRTUAL_SERVER_PURE_FNS, REFLECTION_MODULES, VIRTUAL_STUB_PREFIX } from "./constants.js";
7
- import { generateAOTCaches, logAOTCaches, waitForServer, generateNoopCombinedModule, generateCombinedCachesModule, generateNoopModule, generateRouterCacheModule, generatePureFnsModule, generateJitFnsModule, loadSSRRouterAndGenerateAOTCaches, killPersistentChild } from "./aotCacheGenerator.js";
8
+ import { resolveVirtualId, VIRTUAL_SERVER_PURE_FNS, REFLECTION_MODULES, VIRTUAL_STUB_PREFIX, VIRTUAL_AOT_CACHES, AOT_CACHES_SHIM, SERVER_PURE_FNS_SHIM } from "./constants.js";
9
+ import { generateAOTCaches, logAOTCaches, generateNoopCombinedModule, generateCombinedCachesModule, generateNoopModule, generateRouterCacheModule, generatePureFnsModule, generateJitFnsModule, loadSSRRouterAndGenerateAOTCaches, killPersistentChild } from "./aotCacheGenerator.js";
8
10
  import { updateDiskCache, getOrGenerateAOTCaches, resolveCacheDir } from "./aotDiskCache.js";
9
- function isRunningAsChild() {
10
- return process.env.MION_COMPILE === "onlyAOT" || process.env.MION_COMPILE === "serve";
11
- }
12
11
  function mionVitePlugin(options) {
13
12
  let extractedFns = null;
14
13
  const pureFnOptions = options.serverPureFunctions;
@@ -18,7 +17,8 @@ function mionVitePlugin(options) {
18
17
  const deepkitConfig = runTypesOptions ? createDeepkitConfig(runTypesOptions) : null;
19
18
  const defaultCompilerOptions = {
20
19
  target: ts.ScriptTarget.ESNext,
21
- module: ts.ModuleKind.ESNext
20
+ module: ts.ModuleKind.ESNext,
21
+ sourceMap: true
22
22
  };
23
23
  let pureServerFnCount = 0;
24
24
  let registerPureFnFactoryCount = 0;
@@ -27,7 +27,7 @@ function mionVitePlugin(options) {
27
27
  let aotGenerationPromise = null;
28
28
  let aotCacheDir = "";
29
29
  let ssrLoadModule = null;
30
- const ssrEnabled = serverConfig?.mode === "viteSSR";
30
+ const ssrEnabled = serverConfig?.runMode === "middleware";
31
31
  let ssrInitPromise = null;
32
32
  let persistentChild = null;
33
33
  let cleanupRegistered = false;
@@ -55,7 +55,7 @@ function mionVitePlugin(options) {
55
55
  name: "mion",
56
56
  enforce: "pre",
57
57
  // literal type required: inferred 'string' is not assignable to Vite's 'pre' | 'post'
58
- config(config) {
58
+ config(config, env) {
59
59
  if (aotOptions?.excludeReflection && !isRunningAsChild()) {
60
60
  const aliases = config.resolve?.alias;
61
61
  if (aliases && !Array.isArray(aliases)) {
@@ -64,6 +64,13 @@ function mionVitePlugin(options) {
64
64
  }
65
65
  }
66
66
  }
67
+ const shimModules = [];
68
+ if (pureFnOptions) shimModules.push(SERVER_PURE_FNS_SHIM);
69
+ if (aotOptions) shimModules.push(AOT_CACHES_SHIM);
70
+ addSsrNoExternal(config, shimModules);
71
+ if (env.command === "build" && shimModules.length > 0) {
72
+ wrapBuildExternal(config, shimModules);
73
+ }
67
74
  },
68
75
  configResolved(config) {
69
76
  if (aotOptions) {
@@ -72,7 +79,6 @@ function mionVitePlugin(options) {
72
79
  },
73
80
  async buildStart() {
74
81
  if (serverConfig && !isRunningAsChild() && !ssrEnabled) {
75
- if (serverConfig.port) process.env.MION_TEST_PORT = String(serverConfig.port);
76
82
  try {
77
83
  console.log("[mion] Generating AOT caches...");
78
84
  const resultPromise = getOrGenerateAOTCaches(serverConfig, aotOptions, aotCacheDir);
@@ -86,16 +92,23 @@ function mionVitePlugin(options) {
86
92
  registerCleanupHandlers();
87
93
  console.log(`[mion] Server process persisted (pid: ${persistentChild.pid})`);
88
94
  }
89
- if (serverConfig.port && serverConfig.mode === "IPC") {
90
- const timeout = serverConfig.waitTimeout ?? 3e4;
91
- console.log(`[mion] Waiting for server on port ${serverConfig.port}...`);
92
- waitForServer(serverConfig.port, timeout).then(() => {
93
- console.log(`[mion] Server ready on port ${serverConfig.port}`);
95
+ if (result.platformReady && serverConfig.waitTimeout && serverConfig.runMode === "childProcess") {
96
+ console.log("[mion] Waiting for server to call setPlatformConfig()...");
97
+ const timeout = serverConfig.waitTimeout;
98
+ const timeoutId = setTimeout(() => {
99
+ if (result.childProcess?.connected) result.childProcess.disconnect();
100
+ console.error(
101
+ `[mion] Server did not call setPlatformConfig() within ${timeout / 1e3}s. Ensure your platform adapter (startNodeServer, etc.) is called after initMionRouter().`
102
+ );
103
+ }, timeout);
104
+ result.platformReady.then(() => {
105
+ clearTimeout(timeoutId);
106
+ if (result.childProcess?.connected) result.childProcess.disconnect();
107
+ console.log("[mion] Server ready");
94
108
  onServerReady();
95
- }).catch((err) => {
96
- console.error(`[mion] ${err instanceof Error ? err.message : String(err)}`);
97
109
  });
98
110
  } else {
111
+ if (result.childProcess?.connected) result.childProcess.disconnect();
99
112
  onServerReady();
100
113
  }
101
114
  } catch (err) {
@@ -107,12 +120,12 @@ function mionVitePlugin(options) {
107
120
  configureServer(server) {
108
121
  if (!ssrEnabled || !serverConfig) return;
109
122
  ssrLoadModule = (url) => server.ssrLoadModule(url);
110
- const startServerScript = resolve(serverConfig.startServerScript);
123
+ const startScript = resolve(serverConfig.startScript);
111
124
  let nodeRequestHandler = null;
112
125
  let basePath = null;
113
126
  let initFailed = false;
114
127
  console.log("[mion] Generating SSR AOT caches...");
115
- ssrInitPromise = loadSSRRouterAndGenerateAOTCaches(ssrLoadModule, startServerScript).then(async (data) => {
128
+ ssrInitPromise = loadSSRRouterAndGenerateAOTCaches(ssrLoadModule, startScript, aotOptions?.isClient).then(async (data) => {
116
129
  aotData = data;
117
130
  aotGenerationPromise = Promise.resolve(data);
118
131
  console.log("[mion] SSR AOT caches generated successfully");
@@ -152,9 +165,33 @@ function mionVitePlugin(options) {
152
165
  }
153
166
  });
154
167
  },
155
- resolveId(id) {
168
+ resolveId(id, importer) {
156
169
  if (id === VIRTUAL_SERVER_PURE_FNS) return resolveVirtualId(id);
157
170
  if (aotVirtualModules.has(id)) return resolveVirtualId(id);
171
+ if (aotOptions) {
172
+ const resolved = resolveShimModule(
173
+ id,
174
+ importer,
175
+ AOT_CACHES_SHIM,
176
+ VIRTUAL_AOT_CACHES,
177
+ "aot-caches",
178
+ "aotCaches.ts",
179
+ "emptyCaches.ts"
180
+ );
181
+ if (resolved) return resolved;
182
+ }
183
+ if (pureFnOptions) {
184
+ const resolved = resolveShimModule(
185
+ id,
186
+ importer,
187
+ SERVER_PURE_FNS_SHIM,
188
+ VIRTUAL_SERVER_PURE_FNS,
189
+ "server-pure-fns",
190
+ "serverPureFnsCaches.ts",
191
+ "emptyServerPureFns.ts"
192
+ );
193
+ if (resolved) return resolved;
194
+ }
158
195
  if (aotOptions?.excludeReflection && !isRunningAsChild() && REFLECTION_MODULES.includes(id)) {
159
196
  return resolveVirtualId(VIRTUAL_STUB_PREFIX + id);
160
197
  }
@@ -199,6 +236,8 @@ function mionVitePlugin(options) {
199
236
  transform(code, fileName) {
200
237
  const vueInfo = parseVueModuleId(fileName);
201
238
  const basePath = fileName.includes("?") ? fileName.slice(0, fileName.indexOf("?")) : fileName;
239
+ if (basePath.includes("@mionjs/") && (basePath.includes("/.dist/") || basePath.includes("/build/"))) return null;
240
+ if (basePath.includes("/.cache/vite/") || basePath.includes("/.vite/deps/")) return null;
202
241
  const filterPath = vueInfo ? vueInfo.basePath : basePath;
203
242
  if (basePath.endsWith(".vue") && !vueInfo) return null;
204
243
  const lang = vueInfo?.lang || "ts";
@@ -213,8 +252,12 @@ function mionVitePlugin(options) {
213
252
  if (hasPureFns) {
214
253
  before.push(createPureFnTransformerFactory(code, tsFileName, collected, pureFnOptions?.noViteClient));
215
254
  }
216
- if (deepkitConfig) after.push(...deepkitConfig.afterTransformers);
217
- if (needsDeepkit) before.push(...deepkitConfig.beforeTransformers);
255
+ if (needsDeepkit) {
256
+ before.push(...deepkitConfig.beforeTransformers);
257
+ }
258
+ if (deepkitConfig) {
259
+ after.push(...deepkitConfig.afterTransformers);
260
+ }
218
261
  const baseCompilerOptions = deepkitConfig?.compilerOptions ?? defaultCompilerOptions;
219
262
  const compilerOptions = isTsx ? { ...baseCompilerOptions, jsx: ts.JsxEmit.ReactJSX } : baseCompilerOptions;
220
263
  const result = ts.transpileModule(code, {
@@ -229,7 +272,8 @@ function mionVitePlugin(options) {
229
272
  else pureServerFnCount++;
230
273
  }
231
274
  }
232
- return { code: result.outputText, map: result.sourceMapText };
275
+ const outputCode = result.outputText.replace(/\n\/\/# sourceMappingURL=.*$/, "");
276
+ return { code: outputCode, map: result.sourceMapText };
233
277
  },
234
278
  buildEnd() {
235
279
  if (pureServerFnCount > 0 || registerPureFnFactoryCount > 0) {
@@ -261,7 +305,7 @@ function mionVitePlugin(options) {
261
305
  }
262
306
  }
263
307
  if (serverConfig && !isRunningAsChild()) {
264
- const serverDir = resolve(serverConfig.startServerScript, "..");
308
+ const serverDir = resolve(serverConfig.startScript, "..");
265
309
  if (file.startsWith(serverDir)) {
266
310
  const killPromise = cleanupChild();
267
311
  const regeneratePromise = ssrEnabled && ssrLoadModule ? (
@@ -271,12 +315,13 @@ function mionVitePlugin(options) {
271
315
  routerModule.resetRouter();
272
316
  return loadSSRRouterAndGenerateAOTCaches(
273
317
  ssrLoadModule,
274
- resolve(serverConfig.startServerScript)
318
+ resolve(serverConfig.startScript),
319
+ aotOptions?.isClient
275
320
  );
276
321
  })()
277
322
  ) : (
278
323
  // IPC mode: wait for old child to die, then spawn new
279
- killPromise.then(() => generateAOTCaches(serverConfig))
324
+ killPromise.then(() => generateAOTCaches(serverConfig, void 0, aotOptions?.isClient))
280
325
  );
281
326
  aotGenerationPromise = regeneratePromise.then((r) => "data" in r ? r.data : r);
282
327
  regeneratePromise.then((result) => {
@@ -287,15 +332,24 @@ function mionVitePlugin(options) {
287
332
  persistentChild = result.childProcess;
288
333
  console.log(`[mion] Server process re-persisted (pid: ${persistentChild.pid})`);
289
334
  }
290
- if (serverConfig.port && serverConfig.mode === "IPC") {
291
- const timeout = serverConfig.waitTimeout ?? 3e4;
292
- console.log(`[mion] Waiting for restarted server on port ${serverConfig.port}...`);
293
- waitForServer(serverConfig.port, timeout).then(() => {
294
- console.log(`[mion] Restarted server ready on port ${serverConfig.port}`);
335
+ const platformReady = "platformReady" in result ? result.platformReady : void 0;
336
+ if (platformReady && serverConfig.waitTimeout && serverConfig.runMode === "childProcess") {
337
+ const timeout = serverConfig.waitTimeout;
338
+ console.log("[mion] Waiting for restarted server to call setPlatformConfig()...");
339
+ const timeoutId = setTimeout(() => {
340
+ if (persistentChild?.connected) persistentChild.disconnect();
341
+ console.error(
342
+ `[mion] Restarted server did not call setPlatformConfig() within ${timeout / 1e3}s.`
343
+ );
344
+ }, timeout);
345
+ platformReady.then(() => {
346
+ clearTimeout(timeoutId);
347
+ if (persistentChild?.connected) persistentChild.disconnect();
348
+ console.log("[mion] Restarted server ready");
295
349
  onServerReady();
296
- }).catch((err) => {
297
- console.error(`[mion] ${err instanceof Error ? err.message : String(err)}`);
298
350
  });
351
+ } else if ("childProcess" in result && result.childProcess?.connected) {
352
+ result.childProcess.disconnect();
299
353
  }
300
354
  if (!ssrEnabled) updateDiskCache(serverConfig, aotOptions, data, aotCacheDir);
301
355
  let invalidatedCount = 0;
@@ -318,6 +372,9 @@ function mionVitePlugin(options) {
318
372
  }
319
373
  };
320
374
  }
375
+ function isRunningAsChild() {
376
+ return process.env.MION_COMPILE === "buildOnly" || process.env.MION_COMPILE === "childProcess";
377
+ }
321
378
  function parseVueModuleId(id) {
322
379
  const qIdx = id.indexOf("?");
323
380
  if (qIdx === -1) return null;
@@ -363,6 +420,55 @@ function buildAOTVirtualModuleMaps(customVirtualModuleId) {
363
420
  }
364
421
  return { aotVirtualModules, aotResolvedIds };
365
422
  }
423
+ function resolveShimModule(id, importer, shimSpecifier, virtualModuleId, entryName, sourceFileName, emptyFileName) {
424
+ if (id === shimSpecifier) {
425
+ try {
426
+ const resolved = createRequire(import.meta.url).resolve(shimSpecifier);
427
+ const sourceFile = resolve(resolved.replace(/[/\\].dist[/\\].*$/, ""), "src/aot/" + sourceFileName);
428
+ if (existsSync(sourceFile)) return sourceFile;
429
+ return resolveVirtualId(virtualModuleId);
430
+ } catch {
431
+ return resolveVirtualId(virtualModuleId);
432
+ }
433
+ }
434
+ if (id.endsWith("/" + entryName)) {
435
+ const sourceFile = resolve(id, "..", "src/aot/" + sourceFileName);
436
+ if (existsSync(sourceFile)) return sourceFile;
437
+ }
438
+ const emptyBase = emptyFileName.replace(".ts", "");
439
+ const sourceBase = sourceFileName.replace(".ts", "");
440
+ if (new RegExp(`${emptyBase}\\.(ts|js|mjs|cjs)$`).test(id) && importer && new RegExp(`${sourceBase}\\.(ts|js|mjs|cjs)$`).test(importer)) {
441
+ return resolveVirtualId(virtualModuleId);
442
+ }
443
+ return null;
444
+ }
445
+ function addSsrNoExternal(config, moduleIds) {
446
+ if (moduleIds.length === 0) return;
447
+ const noExternal = config.ssr?.noExternal;
448
+ if (!config.ssr) config.ssr = {};
449
+ if (Array.isArray(noExternal)) {
450
+ for (const moduleId of moduleIds) {
451
+ if (!noExternal.includes(moduleId)) noExternal.push(moduleId);
452
+ }
453
+ } else if (typeof noExternal === "string") {
454
+ config.ssr.noExternal = [noExternal, ...moduleIds];
455
+ } else if (noExternal !== true) {
456
+ config.ssr.noExternal = noExternal ? [noExternal, ...moduleIds] : [...moduleIds];
457
+ }
458
+ }
459
+ function wrapBuildExternal(config, shimModules) {
460
+ if (!config.build) config.build = {};
461
+ if (!config.build.rollupOptions) config.build.rollupOptions = {};
462
+ const original = config.build.rollupOptions.external;
463
+ if (!original) return;
464
+ config.build.rollupOptions.external = (id, ...rest) => {
465
+ if (shimModules.includes(id) || id.startsWith("virtual:mion")) return false;
466
+ if (typeof original === "function") return original(id, ...rest);
467
+ if (Array.isArray(original)) return original.some((ext) => ext instanceof RegExp ? ext.test(id) : ext === id);
468
+ if (original instanceof RegExp) return original.test(id);
469
+ return original === id;
470
+ };
471
+ }
366
472
  const READY_KEY = /* @__PURE__ */ Symbol.for("mion.serverReady");
367
473
  function getOrCreateServerReady() {
368
474
  if (!globalThis[READY_KEY]) {
@@ -1 +1 @@
1
- {"version":3,"file":"mionVitePlugin.js","sources":["../../../../../src/vite-plugin/mionVitePlugin.ts"],"sourcesContent":["/* ########\n * 2026 mion\n * Author: Ma-jerez\n * License: MIT\n * The software is provided \"as is\", without warranty of any kind.\n * ######## */\n\nimport {resolve} from 'path';\nimport * as ts from 'typescript';\nimport {ChildProcess} from 'child_process';\nimport {createDeepkitConfig, DeepkitConfig, createPureFnTransformerFactory} from './transformers.ts';\nimport {ServerPureFunctionsOptions, ExtractedPureFn, DeepkitTypeOptions, AOTCacheOptions, MionServerConfig} from './types.ts';\nimport {scanClientSource} from './extractPureFn.ts';\nimport {generateServerPureFnsVirtualModule} from './virtualModule.ts';\nimport {VIRTUAL_SERVER_PURE_FNS, REFLECTION_MODULES, VIRTUAL_STUB_PREFIX, resolveVirtualId} from './constants.ts';\nimport {\n generateAOTCaches,\n loadSSRRouterAndGenerateAOTCaches,\n killPersistentChild,\n logAOTCaches,\n waitForServer,\n generateJitFnsModule,\n generatePureFnsModule,\n generateRouterCacheModule,\n generateCombinedCachesModule,\n generateNoopModule,\n generateNoopCombinedModule,\n AOTCacheData,\n} from './aotCacheGenerator.ts';\nimport {getOrGenerateAOTCaches, updateDiskCache, resolveCacheDir} from './aotDiskCache.ts';\n\nexport interface MionPluginOptions {\n /** Options for pure function extraction - omit to disable */\n serverPureFunctions?: ServerPureFunctionsOptions;\n /** Options for deepkit type transformation - omit to disable */\n runTypes?: DeepkitTypeOptions;\n /** Options for AOT cache generation - omit to disable */\n aotCaches?: AOTCacheOptions | true;\n /** Server configuration - controls how the server process is managed */\n server?: MionServerConfig;\n}\n\n/** Whether the current process is a child spawned by the mion plugin */\nfunction isRunningAsChild(): boolean {\n return process.env.MION_COMPILE === 'onlyAOT' || process.env.MION_COMPILE === 'serve';\n}\n\n/**\n * Creates the unified mion Vite plugin.\n * This plugin combines pure function extraction, type compiler transformations,\n * and AOT cache generation in a single plugin with correct execution order.\n *\n * Execution order:\n * 1. Extract pure functions from original TypeScript source\n * 2. Apply type metadata transformations to the code\n *\n * This ensures pure function extraction happens on clean, untransformed TypeScript.\n *\n * @example\n * ```ts\n * // vite.config.ts\n * import {mionPlugin} from '@mionjs/devtools/vite-plugin';\n *\n * export default defineConfig({\n * plugins: [\n * mionPlugin({\n * runTypes: {\n * tsConfig: './tsconfig.json',\n * },\n * server: {\n * startServerScript: '../server/src/init.ts',\n * mode: 'onlyAOT',\n * },\n * }),\n * ],\n * });\n * ```\n */\nexport function mionVitePlugin(options: MionPluginOptions) {\n let extractedFns: ExtractedPureFn[] | null = null;\n const pureFnOptions = options.serverPureFunctions;\n const runTypesOptions = options.runTypes;\n const aotOptions: AOTCacheOptions | undefined = options.aotCaches === true ? {} : options.aotCaches;\n const serverConfig = options.server;\n const deepkitConfig: DeepkitConfig | null = runTypesOptions ? createDeepkitConfig(runTypesOptions) : null;\n\n // Default compiler options for when deepkit is disabled\n const defaultCompilerOptions: ts.CompilerOptions = {\n target: ts.ScriptTarget.ESNext,\n module: ts.ModuleKind.ESNext,\n };\n\n // Pure function injection counters — accumulated during transform, logged in buildEnd\n let pureServerFnCount = 0;\n let registerPureFnFactoryCount = 0;\n let pureFnFilesCount = 0;\n\n // AOT cache data - populated during buildStart (IPC) or configureServer (in-process)\n let aotData: AOTCacheData | null = null;\n let aotGenerationPromise: Promise<AOTCacheData> | null = null;\n\n // Resolved cache directory from Vite's config — set in configResolved\n let aotCacheDir = '';\n\n // SSR AOT: module loader (set in configureServer when SSR mode is active)\n let ssrLoadModule: ((url: string) => Promise<Record<string, any>>) | null = null;\n /** Whether SSR mode is active — resolved from server config */\n const ssrEnabled = serverConfig?.mode === 'viteSSR';\n /** SSR init promise: AOT generation + router/platform module loading */\n let ssrInitPromise: Promise<void> | null = null;\n\n // Persistent child process for IPC mode\n let persistentChild: ChildProcess | null = null;\n let cleanupRegistered = false;\n\n const {aotVirtualModules, aotResolvedIds} = buildAOTVirtualModuleMaps(aotOptions?.customVirtualModuleId);\n\n /** Kill persistent child process and clear reference */\n async function cleanupChild() {\n if (persistentChild) {\n await killPersistentChild(persistentChild);\n persistentChild = null;\n }\n }\n\n /** Register process exit handlers (once) */\n function registerCleanupHandlers() {\n if (cleanupRegistered) return;\n cleanupRegistered = true;\n const onExit = () => {\n if (persistentChild && !persistentChild.killed) {\n persistentChild.kill('SIGTERM');\n persistentChild = null;\n }\n };\n process.on('exit', onExit);\n process.on('SIGINT', onExit);\n process.on('SIGTERM', onExit);\n }\n\n return {\n name: 'mion',\n enforce: 'pre' as const, // literal type required: inferred 'string' is not assignable to Vite's 'pre' | 'post'\n\n config(config) {\n // Strip reflection module aliases in bundle build mode so our resolveId can stub them.\n // Vite's alias plugin runs before our resolveId, so we remove aliases here to prevent\n // them from transforming bare package names into file paths before we can intercept.\n if (aotOptions?.excludeReflection && !isRunningAsChild()) {\n const aliases = config.resolve?.alias;\n if (aliases && !Array.isArray(aliases)) {\n for (const mod of REFLECTION_MODULES) {\n delete (aliases as Record<string, string>)[mod];\n }\n }\n }\n },\n\n configResolved(config) {\n if (aotOptions) {\n aotCacheDir = resolveCacheDir(aotOptions, config.cacheDir);\n }\n },\n\n async buildStart() {\n // Generate AOT caches if server is configured\n // Skip when already running as a child process to prevent infinite recursion\n // Skip when SSR mode — configureServer will handle it\n if (serverConfig && !isRunningAsChild() && !ssrEnabled) {\n // Set port env before spawning child so the server uses the correct port\n if (serverConfig.port) process.env.MION_TEST_PORT = String(serverConfig.port);\n try {\n console.log('[mion] Generating AOT caches...');\n const resultPromise = getOrGenerateAOTCaches(serverConfig, aotOptions, aotCacheDir);\n aotGenerationPromise = resultPromise.then((r) => r.data);\n const result = await resultPromise;\n aotData = result.data;\n console.log('[mion] AOT caches generated successfully');\n logAOTCaches(aotData);\n\n // Store persistent child for IPC mode\n if (result.childProcess) {\n persistentChild = result.childProcess;\n registerCleanupHandlers();\n console.log(`[mion] Server process persisted (pid: ${persistentChild.pid})`);\n }\n\n // Non-blocking: poll server port and resolve serverReady promise (IPC mode)\n if (serverConfig.port && serverConfig.mode === 'IPC') {\n const timeout = serverConfig.waitTimeout ?? 30000;\n console.log(`[mion] Waiting for server on port ${serverConfig.port}...`);\n waitForServer(serverConfig.port, timeout)\n .then(() => {\n console.log(`[mion] Server ready on port ${serverConfig.port}`);\n onServerReady();\n })\n .catch((err) => {\n console.error(`[mion] ${err instanceof Error ? err.message : String(err)}`);\n });\n } else {\n // onlyAOT mode: no persistent server, resolve immediately\n onServerReady();\n }\n } catch (err) {\n const message = err instanceof Error ? err.message : String(err);\n throw new Error(`[mion] Failed to generate AOT caches: ${message}`);\n }\n }\n },\n\n configureServer(server) {\n if (!ssrEnabled || !serverConfig) return;\n // SSR mode: use ssrLoadModule to load the server in the same Vite process.\n // ssrLoadModule uses Vite's internal transform pipeline (not HTTP),\n ssrLoadModule = (url: string) => server.ssrLoadModule(url);\n const startServerScript = resolve(serverConfig.startServerScript);\n // Single init chain: generate AOT caches → load router + platform modules\n let nodeRequestHandler: ((req: any, res: any) => void) | null = null;\n let basePath: string | null = null;\n let initFailed = false;\n\n console.log('[mion] Generating SSR AOT caches...');\n ssrInitPromise = loadSSRRouterAndGenerateAOTCaches(ssrLoadModule, startServerScript)\n .then(async (data) => {\n aotData = data;\n aotGenerationPromise = Promise.resolve(data);\n console.log('[mion] SSR AOT caches generated successfully');\n logAOTCaches(data);\n // Invalidate virtual modules so they reload with real data\n for (const resolvedId of aotResolvedIds.keys()) {\n const mod = server.moduleGraph.getModuleById(resolvedId);\n if (mod) server.moduleGraph.invalidateModule(mod);\n }\n // Load router and platform modules now that caches are ready\n const routerModule = await server.ssrLoadModule('@mionjs/router');\n const opts = routerModule.getRouterOptions();\n basePath = '/' + (opts.basePath || '').replace(/^\\//, '');\n const platformNode = await server.ssrLoadModule('@mionjs/platform-node');\n nodeRequestHandler = platformNode.httpRequestHandler;\n console.log('[mion] Dev server proxy initialized');\n onServerReady();\n })\n .catch((err) => {\n initFailed = true;\n const message = err instanceof Error ? err.message : String(err);\n console.error(`[mion] Failed to initialize SSR: ${message}`);\n });\n\n // Dev server proxy: route matching requests to mion's httpRequestHandler\n server.middlewares.use(async (req: any, res: any, next: () => void) => {\n try {\n if (!basePath && !initFailed) await ssrInitPromise;\n if (!basePath || !req.url?.startsWith(basePath)) return next();\n if (nodeRequestHandler) {\n nodeRequestHandler(req, res);\n } else {\n res.statusCode = 503;\n res.end('mion API failed to initialize');\n }\n } catch (err) {\n console.error('[mion] Dev server proxy error:', err);\n if (!res.writableEnded) {\n res.statusCode = 500;\n res.end('Internal Server Error');\n }\n }\n });\n },\n\n resolveId(id) {\n // Pure functions virtual module — always resolve, returns empty cache if not configured\n if (id === VIRTUAL_SERVER_PURE_FNS) return resolveVirtualId(id);\n // AOT virtual modules (default + custom prefix both resolve)\n if (aotVirtualModules.has(id)) return resolveVirtualId(id);\n // Stub out reflection modules in the bundle build (not needed at runtime in AOT mode)\n if (aotOptions?.excludeReflection && !isRunningAsChild() && REFLECTION_MODULES.includes(id)) {\n return resolveVirtualId(VIRTUAL_STUB_PREFIX + id);\n }\n return null;\n },\n\n async load(id) {\n // Pure functions virtual module\n if (id === resolveVirtualId(VIRTUAL_SERVER_PURE_FNS)) {\n // No serverPureFunctions configured — return empty cache\n if (!pureFnOptions) return generateServerPureFnsVirtualModule([]);\n // Lazily scan client source on first load\n if (!extractedFns) extractedFns = scanClientSource(pureFnOptions);\n return generateServerPureFnsVirtualModule(extractedFns);\n }\n\n // AOT virtual modules — check resolved ID against the map\n const aotType = aotResolvedIds.get(id);\n if (aotType) {\n const initPromise = ssrInitPromise || aotGenerationPromise;\n if (!aotData && initPromise) await initPromise;\n\n switch (aotType) {\n case 'jit-fns': {\n if (!aotData) return generateNoopModule('No-op: AOT JIT caches not generated');\n return generateJitFnsModule(aotData.jitFnsCode);\n }\n case 'pure-fns': {\n if (!aotData) return generateNoopModule('No-op: AOT pure fns not generated');\n return generatePureFnsModule(aotData.pureFnsCode);\n }\n case 'router-cache': {\n if (!aotData) return generateNoopModule('No-op: AOT router cache not generated');\n return generateRouterCacheModule(aotData.routerCacheCode);\n }\n case 'caches': {\n if (!aotData) return generateNoopCombinedModule();\n return generateCombinedCachesModule();\n }\n }\n }\n\n // Reflection module stubs (empty modules — all reflection is pre-compiled in AOT caches)\n // syntheticNamedExports tells Rollup to derive named exports from the default export,\n // so any `import {foo} from '...'` resolves to undefined without build errors.\n for (const mod of REFLECTION_MODULES) {\n if (id === resolveVirtualId(VIRTUAL_STUB_PREFIX + mod)) {\n return {code: 'export default {}', syntheticNamedExports: true};\n }\n }\n\n return null;\n },\n\n transform(code: string, fileName: string) {\n // For Vue SFC virtual modules, resolve the base path and lang for downstream tools\n const vueInfo = parseVueModuleId(fileName);\n // Strip any query params (e.g. ?macro=true from Nuxt) to get the real file path\n const basePath = fileName.includes('?') ? fileName.slice(0, fileName.indexOf('?')) : fileName;\n const filterPath = vueInfo ? vueInfo.basePath : basePath;\n\n // Skip .vue files unless they are Vue script virtual modules (?vue&type=script).\n // Bare .vue files and other .vue queries (e.g. ?macro=true from Nuxt) contain raw\n // SFC content — wait for the Vue plugin to extract the <script> block first.\n if (basePath.endsWith('.vue') && !vueInfo) return null;\n\n const lang = vueInfo?.lang || 'ts';\n const tsFileName = vueInfo ? `${vueInfo.basePath}.${lang}` : fileName;\n const isTsx = tsFileName.endsWith('.tsx') || tsFileName.endsWith('.jsx');\n\n const hasPureFns =\n code.includes('pureServerFn') || code.includes('registerPureFnFactory') || code.includes('mapFrom');\n const needsDeepkit = deepkitConfig ? deepkitConfig.filter(filterPath) : false;\n\n if (!hasPureFns && !needsDeepkit) return null;\n\n const before: ts.CustomTransformerFactory[] = [];\n const after: ts.CustomTransformerFactory[] = [];\n\n // Pure function transformer (runs first — sees clean AST)\n const collected: ExtractedPureFn[] | undefined = hasPureFns ? [] : undefined;\n if (hasPureFns) {\n before.push(createPureFnTransformerFactory(code, tsFileName, collected, pureFnOptions?.noViteClient));\n }\n\n // Deepkit has two functions: type metadata emission (follows include/exclude filters)\n // and import restoration (always runs globally for all ts.transpileModule calls).\n // afterTransformers (including requireToImport) must always be included to convert\n // deepkit's CJS require() back to ESM imports in the restored import statements.\n if (deepkitConfig) after.push(...deepkitConfig.afterTransformers);\n if (needsDeepkit) before.push(...deepkitConfig!.beforeTransformers);\n\n const baseCompilerOptions = deepkitConfig?.compilerOptions ?? defaultCompilerOptions;\n const compilerOptions = isTsx ? {...baseCompilerOptions, jsx: ts.JsxEmit.ReactJSX} : baseCompilerOptions;\n\n const result = ts.transpileModule(code, {\n compilerOptions,\n fileName: tsFileName,\n transformers: {before, after},\n });\n\n // Count injected pure functions (collector is populated synchronously by transpileModule)\n if (collected && collected.length > 0) {\n pureFnFilesCount++;\n for (const fn of collected) {\n if (fn.isFactory) registerPureFnFactoryCount++;\n else pureServerFnCount++;\n }\n }\n\n return {code: result.outputText, map: result.sourceMapText};\n },\n\n buildEnd() {\n if (pureServerFnCount > 0 || registerPureFnFactoryCount > 0) {\n const total = pureServerFnCount + registerPureFnFactoryCount;\n const parts = [\n pureServerFnCount > 0 ? `${pureServerFnCount} pureServerFn` : '',\n registerPureFnFactoryCount > 0 ? `${registerPureFnFactoryCount} registerPureFnFactory` : '',\n ].filter(Boolean);\n console.log(`[mion] Injected ${total} pure functions across ${pureFnFilesCount} files (${parts.join(', ')})`);\n }\n },\n\n async closeBundle() {\n await cleanupChild();\n },\n\n handleHotUpdate({file, server}) {\n // In dev mode, re-scan when client source changes (for pure functions)\n if (pureFnOptions) {\n const clientSrcPath = resolve(pureFnOptions.clientSrcPath);\n if (file.startsWith(clientSrcPath)) {\n const include = pureFnOptions.include || ['**/*.ts', '**/*.tsx', '**/*.vue'];\n const exclude = pureFnOptions.exclude || ['../node_modules/**', '**/.dist/**', '**/dist/**'];\n if (isIncluded(file, include, exclude)) {\n // Clear cache and invalidate virtual module\n extractedFns = null;\n const mod = server.moduleGraph.getModuleById(resolveVirtualId(VIRTUAL_SERVER_PURE_FNS));\n if (mod) {\n server.moduleGraph.invalidateModule(mod);\n return [mod];\n }\n }\n }\n }\n\n // In dev mode, regenerate AOT caches when server source changes\n // Skip when running as a child process\n if (serverConfig && !isRunningAsChild()) {\n const serverDir = resolve(serverConfig.startServerScript, '..');\n\n if (file.startsWith(serverDir)) {\n // Kill existing persistent child before regenerating\n const killPromise = cleanupChild();\n\n const regeneratePromise =\n ssrEnabled && ssrLoadModule\n ? // SSR mode: reset router and re-init via ssrLoadModule\n (async () => {\n const routerModule = await ssrLoadModule!('@mionjs/router');\n routerModule.resetRouter();\n return loadSSRRouterAndGenerateAOTCaches(\n ssrLoadModule!,\n resolve(serverConfig.startServerScript)\n );\n })()\n : // IPC mode: wait for old child to die, then spawn new\n killPromise.then(() => generateAOTCaches(serverConfig));\n\n aotGenerationPromise = regeneratePromise.then((r) => ('data' in r ? r.data : r));\n regeneratePromise\n .then((result) => {\n const data = 'data' in result ? result.data : result;\n aotData = data;\n logAOTCaches(data);\n\n // Store new persistent child if IPC mode\n if ('childProcess' in result && result.childProcess) {\n persistentChild = result.childProcess;\n console.log(`[mion] Server process re-persisted (pid: ${persistentChild!.pid})`);\n }\n\n // Non-blocking: poll restarted server and resolve serverReady promise\n if (serverConfig.port && serverConfig.mode === 'IPC') {\n const timeout = serverConfig.waitTimeout ?? 30000;\n console.log(`[mion] Waiting for restarted server on port ${serverConfig.port}...`);\n waitForServer(serverConfig.port, timeout)\n .then(() => {\n console.log(`[mion] Restarted server ready on port ${serverConfig.port}`);\n onServerReady();\n })\n .catch((err) => {\n console.error(`[mion] ${err instanceof Error ? err.message : String(err)}`);\n });\n }\n\n if (!ssrEnabled) updateDiskCache(serverConfig, aotOptions, data, aotCacheDir);\n // Invalidate all AOT virtual modules\n let invalidatedCount = 0;\n for (const resolvedId of aotResolvedIds.keys()) {\n const mod = server.moduleGraph.getModuleById(resolvedId);\n if (mod) {\n server.moduleGraph.invalidateModule(mod);\n invalidatedCount++;\n }\n }\n if (invalidatedCount > 0) {\n console.log('[mion] AOT caches regenerated, invalidating virtual modules');\n }\n })\n .catch((err) => {\n console.error('[mion] Failed to regenerate AOT caches:', err.message);\n });\n }\n }\n\n return undefined;\n },\n };\n}\n\n/** Extracts the base file path and lang from a Vue SFC virtual module ID (e.g. Component.vue?vue&type=script&lang=ts) */\nexport function parseVueModuleId(id: string): {basePath: string; lang: string | null} | null {\n const qIdx = id.indexOf('?');\n if (qIdx === -1) return null;\n const basePath = id.slice(0, qIdx);\n if (!basePath.endsWith('.vue')) return null;\n const params = new URLSearchParams(id.slice(qIdx));\n if (!params.has('vue') || params.get('type') !== 'script') return null;\n return {basePath, lang: params.get('lang')};\n}\n\n/** Checks if a file path matches the include/exclude patterns */\nexport function isIncluded(filePath: string, include: string[], exclude: string[]): boolean {\n // For Vue virtual module IDs, use the base .vue path for matching\n const vueInfo = parseVueModuleId(filePath);\n const effectivePath = vueInfo ? vueInfo.basePath : filePath;\n\n const isTs = /\\.(ts|tsx|js|jsx)$/.test(effectivePath);\n const isVue = effectivePath.endsWith('.vue');\n const isDir = effectivePath.endsWith('/');\n if (!isTs && !isVue && !isDir) return false;\n\n // Check exclude patterns\n for (const pattern of exclude) {\n if (matchGlob(effectivePath, pattern)) return false;\n }\n\n return true;\n}\n\n/** Simple glob matching for common patterns */\nfunction matchGlob(filePath: string, pattern: string): boolean {\n // Handle **/ prefix\n if (pattern.startsWith('**/')) {\n const suffix = pattern.slice(3);\n return filePath.includes(suffix.replace(/\\*/g, ''));\n }\n // Handle simple wildcard\n const regex = new RegExp('^' + pattern.replace(/\\*\\*/g, '.*').replace(/\\*/g, '[^/]*') + '$');\n return regex.test(filePath);\n}\n\n/** AOT virtual module types — each maps to a different cache export */\nconst AOT_MODULE_TYPES = ['jit-fns', 'pure-fns', 'router-cache', 'caches'] as const;\ntype AOTModuleType = (typeof AOT_MODULE_TYPES)[number];\n\n/** Builds maps from virtual module names → AOT type for resolveId and load hooks.\n * Default 'virtual:mion-aot/*' is always registered. If customVirtualModuleId is set,\n * 'virtual:${custom}/*' is also registered — both map to the same cache data. */\nfunction buildAOTVirtualModuleMaps(customVirtualModuleId?: string) {\n const aotVirtualModules = new Map<string, AOTModuleType>();\n const aotResolvedIds = new Map<string, AOTModuleType>();\n for (const type of AOT_MODULE_TYPES) {\n const defaultId = `virtual:mion-aot/${type}`;\n aotVirtualModules.set(defaultId, type);\n aotResolvedIds.set(resolveVirtualId(defaultId), type);\n if (customVirtualModuleId) {\n const customId = `virtual:${customVirtualModuleId}/${type}`;\n aotVirtualModules.set(customId, type);\n aotResolvedIds.set(resolveVirtualId(customId), type);\n }\n }\n return {aotVirtualModules, aotResolvedIds};\n}\n\n// #################### SERVER READY ####################\n\n// Uses globalThis with Symbol.for because vitest loads vitest.config.ts and globalSetup.ts\n// in separate module contexts — without globalThis they'd get different promise instances.\nconst READY_KEY = Symbol.for('mion.serverReady');\nfunction getOrCreateServerReady(): {promise: Promise<void>; resolve: () => void} {\n if (!(globalThis as any)[READY_KEY]) {\n let _resolve: () => void;\n (globalThis as any)[READY_KEY] = {\n promise: new Promise<void>((r) => {\n _resolve = r;\n }),\n resolve: () => _resolve(),\n };\n }\n return (globalThis as any)[READY_KEY];\n}\n\n/** Promise that resolves when the server is ready. Await this in vitest globalSetup. */\nexport const serverReady: Promise<void> = getOrCreateServerReady().promise;\nconst onServerReady: () => void = getOrCreateServerReady().resolve;\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"mionVitePlugin.js","sources":["../../../../../src/vite-plugin/mionVitePlugin.ts"],"sourcesContent":["/* ########\n * 2026 mion\n * Author: Ma-jerez\n * License: MIT\n * The software is provided \"as is\", without warranty of any kind.\n * ######## */\n\nimport {resolve} from 'path';\nimport {createRequire} from 'module';\nimport {existsSync} from 'fs';\nimport * as ts from 'typescript';\nimport {ChildProcess} from 'child_process';\nimport {createDeepkitConfig, DeepkitConfig, createPureFnTransformerFactory} from './transformers.ts';\nimport {ServerPureFunctionsOptions, ExtractedPureFn, DeepkitTypeOptions, AOTCacheOptions, MionServerConfig} from './types.ts';\nimport {scanClientSource} from './extractPureFn.ts';\nimport {generateServerPureFnsVirtualModule} from './virtualModule.ts';\nimport {\n VIRTUAL_SERVER_PURE_FNS,\n REFLECTION_MODULES,\n VIRTUAL_STUB_PREFIX,\n VIRTUAL_AOT_CACHES,\n AOT_CACHES_SHIM,\n SERVER_PURE_FNS_SHIM,\n resolveVirtualId,\n} from './constants.ts';\nimport {\n generateAOTCaches,\n loadSSRRouterAndGenerateAOTCaches,\n killPersistentChild,\n logAOTCaches,\n generateJitFnsModule,\n generatePureFnsModule,\n generateRouterCacheModule,\n generateCombinedCachesModule,\n generateNoopModule,\n generateNoopCombinedModule,\n AOTCacheData,\n} from './aotCacheGenerator.ts';\nimport {getOrGenerateAOTCaches, updateDiskCache, resolveCacheDir} from './aotDiskCache.ts';\n\nexport interface MionPluginOptions {\n /** Options for pure function extraction - omit to disable */\n serverPureFunctions?: ServerPureFunctionsOptions;\n /** Options for deepkit type transformation - omit to disable */\n runTypes?: DeepkitTypeOptions;\n /** Options for AOT cache generation - omit to disable */\n aotCaches?: AOTCacheOptions | true;\n /** Server configuration - controls how the server process is managed */\n server?: MionServerConfig;\n}\n\n/**\n * Creates the unified mion Vite plugin.\n * This plugin combines pure function extraction, type compiler transformations,\n * and AOT cache generation in a single plugin with correct execution order.\n *\n * Execution order:\n * 1. Extract pure functions from original TypeScript source\n * 2. Apply type metadata transformations to the code\n *\n * This ensures pure function extraction happens on clean, untransformed TypeScript.\n *\n * @example\n * ```ts\n * // vite.config.ts\n * import {mionPlugin} from '@mionjs/devtools/vite-plugin';\n *\n * export default defineConfig({\n * plugins: [\n * mionPlugin({\n * runTypes: {\n * tsConfig: './tsconfig.json',\n * },\n * server: {\n * startScript: '../server/src/init.ts',\n * runMode: 'buildOnly',\n * },\n * }),\n * ],\n * });\n * ```\n */\nexport function mionVitePlugin(options: MionPluginOptions) {\n let extractedFns: ExtractedPureFn[] | null = null;\n const pureFnOptions = options.serverPureFunctions;\n const runTypesOptions = options.runTypes;\n const aotOptions: AOTCacheOptions | undefined = options.aotCaches === true ? {} : options.aotCaches;\n const serverConfig = options.server;\n const deepkitConfig: DeepkitConfig | null = runTypesOptions ? createDeepkitConfig(runTypesOptions) : null;\n\n // Default compiler options for when deepkit is disabled\n const defaultCompilerOptions: ts.CompilerOptions = {\n target: ts.ScriptTarget.ESNext,\n module: ts.ModuleKind.ESNext,\n sourceMap: true,\n };\n\n // Pure function injection counters — accumulated during transform, logged in buildEnd\n let pureServerFnCount = 0;\n let registerPureFnFactoryCount = 0;\n let pureFnFilesCount = 0;\n\n // AOT cache data - populated during buildStart (IPC) or configureServer (in-process)\n let aotData: AOTCacheData | null = null;\n let aotGenerationPromise: Promise<AOTCacheData> | null = null;\n\n // Resolved cache directory from Vite's config — set in configResolved\n let aotCacheDir = '';\n\n // SSR AOT: module loader (set in configureServer when SSR mode is active)\n let ssrLoadModule: ((url: string) => Promise<Record<string, any>>) | null = null;\n /** Whether SSR mode is active — resolved from server config */\n const ssrEnabled = serverConfig?.runMode === 'middleware';\n /** SSR init promise: AOT generation + router/platform module loading */\n let ssrInitPromise: Promise<void> | null = null;\n\n // Persistent child process for IPC mode\n let persistentChild: ChildProcess | null = null;\n let cleanupRegistered = false;\n\n const {aotVirtualModules, aotResolvedIds} = buildAOTVirtualModuleMaps(aotOptions?.customVirtualModuleId);\n\n /** Kill persistent child process and clear reference */\n async function cleanupChild() {\n if (persistentChild) {\n await killPersistentChild(persistentChild);\n persistentChild = null;\n }\n }\n\n /** Register process exit handlers (once) */\n function registerCleanupHandlers() {\n if (cleanupRegistered) return;\n cleanupRegistered = true;\n const onExit = () => {\n if (persistentChild && !persistentChild.killed) {\n persistentChild.kill('SIGTERM');\n persistentChild = null;\n }\n };\n process.on('exit', onExit);\n process.on('SIGINT', onExit);\n process.on('SIGTERM', onExit);\n }\n\n return {\n name: 'mion',\n enforce: 'pre' as const, // literal type required: inferred 'string' is not assignable to Vite's 'pre' | 'post'\n\n config(config, env) {\n // Strip reflection module aliases in bundle build mode so our resolveId can stub them.\n // Vite's alias plugin runs before our resolveId, so we remove aliases here to prevent\n // them from transforming bare package names into file paths before we can intercept.\n if (aotOptions?.excludeReflection && !isRunningAsChild()) {\n const aliases = config.resolve?.alias;\n if (aliases && !Array.isArray(aliases)) {\n for (const mod of REFLECTION_MODULES) {\n delete (aliases as Record<string, string>)[mod];\n }\n }\n }\n\n // Ensure Vite bundles shim modules instead of externalizing them\n const shimModules: string[] = [];\n if (pureFnOptions) shimModules.push(SERVER_PURE_FNS_SHIM);\n if (aotOptions) shimModules.push(AOT_CACHES_SHIM);\n addSsrNoExternal(config, shimModules);\n\n // Wrap build.rollupOptions.external so shim and virtual modules are never externalized\n if (env.command === 'build' && shimModules.length > 0) {\n wrapBuildExternal(config, shimModules);\n }\n },\n\n configResolved(config) {\n if (aotOptions) {\n aotCacheDir = resolveCacheDir(aotOptions, config.cacheDir);\n }\n },\n\n async buildStart() {\n // Generate AOT caches if server is configured\n // Skip when already running as a child process to prevent infinite recursion\n // Skip when SSR mode — configureServer will handle it\n if (serverConfig && !isRunningAsChild() && !ssrEnabled) {\n try {\n console.log('[mion] Generating AOT caches...');\n const resultPromise = getOrGenerateAOTCaches(serverConfig, aotOptions, aotCacheDir);\n aotGenerationPromise = resultPromise.then((r) => r.data);\n const result = await resultPromise;\n aotData = result.data;\n console.log('[mion] AOT caches generated successfully');\n logAOTCaches(aotData);\n\n // Store persistent child for IPC mode\n if (result.childProcess) {\n persistentChild = result.childProcess;\n registerCleanupHandlers();\n console.log(`[mion] Server process persisted (pid: ${persistentChild.pid})`);\n }\n\n // Non-blocking: wait for setPlatformConfig() IPC and resolve serverReady promise\n if (result.platformReady && serverConfig.waitTimeout && serverConfig.runMode === 'childProcess') {\n console.log('[mion] Waiting for server to call setPlatformConfig()...');\n const timeout = serverConfig.waitTimeout;\n const timeoutId = setTimeout(() => {\n if (result.childProcess?.connected) result.childProcess.disconnect();\n console.error(\n `[mion] Server did not call setPlatformConfig() within ${timeout / 1000}s. ` +\n `Ensure your platform adapter (startNodeServer, etc.) is called after initMionRouter().`\n );\n }, timeout);\n result.platformReady.then(() => {\n clearTimeout(timeoutId);\n if (result.childProcess?.connected) result.childProcess.disconnect();\n console.log('[mion] Server ready');\n onServerReady();\n });\n } else {\n // buildOnly mode or no waitTimeout: resolve immediately\n if (result.childProcess?.connected) result.childProcess.disconnect();\n onServerReady();\n }\n } catch (err) {\n const message = err instanceof Error ? err.message : String(err);\n throw new Error(`[mion] Failed to generate AOT caches: ${message}`);\n }\n }\n },\n\n configureServer(server) {\n if (!ssrEnabled || !serverConfig) return;\n // SSR mode: use ssrLoadModule to load the server in the same Vite process.\n // ssrLoadModule uses Vite's internal transform pipeline (not HTTP),\n ssrLoadModule = (url: string) => server.ssrLoadModule(url);\n const startScript = resolve(serverConfig.startScript);\n // Single init chain: generate AOT caches → load router + platform modules\n let nodeRequestHandler: ((req: any, res: any) => void) | null = null;\n let basePath: string | null = null;\n let initFailed = false;\n\n console.log('[mion] Generating SSR AOT caches...');\n ssrInitPromise = loadSSRRouterAndGenerateAOTCaches(ssrLoadModule, startScript, aotOptions?.isClient)\n .then(async (data) => {\n aotData = data;\n aotGenerationPromise = Promise.resolve(data);\n console.log('[mion] SSR AOT caches generated successfully');\n logAOTCaches(data);\n // Invalidate virtual modules so they reload with real data\n for (const resolvedId of aotResolvedIds.keys()) {\n const mod = server.moduleGraph.getModuleById(resolvedId);\n if (mod) server.moduleGraph.invalidateModule(mod);\n }\n // Load router and platform modules now that caches are ready\n const routerModule = await server.ssrLoadModule('@mionjs/router');\n const opts = routerModule.getRouterOptions();\n basePath = '/' + (opts.basePath || '').replace(/^\\//, '');\n const platformNode = await server.ssrLoadModule('@mionjs/platform-node');\n nodeRequestHandler = platformNode.httpRequestHandler;\n console.log('[mion] Dev server proxy initialized');\n onServerReady();\n })\n .catch((err) => {\n initFailed = true;\n const message = err instanceof Error ? err.message : String(err);\n console.error(`[mion] Failed to initialize SSR: ${message}`);\n });\n\n // Dev server proxy: route matching requests to mion's httpRequestHandler\n server.middlewares.use(async (req: any, res: any, next: () => void) => {\n try {\n if (!basePath && !initFailed) await ssrInitPromise;\n if (!basePath || !req.url?.startsWith(basePath)) return next();\n if (nodeRequestHandler) {\n nodeRequestHandler(req, res);\n } else {\n res.statusCode = 503;\n res.end('mion API failed to initialize');\n }\n } catch (err) {\n console.error('[mion] Dev server proxy error:', err);\n if (!res.writableEnded) {\n res.statusCode = 500;\n res.end('Internal Server Error');\n }\n }\n });\n },\n\n resolveId(id, importer) {\n // Pure functions virtual module — always resolve, returns empty cache if not configured\n if (id === VIRTUAL_SERVER_PURE_FNS) return resolveVirtualId(id);\n // AOT virtual modules (default + custom prefix both resolve)\n if (aotVirtualModules.has(id)) return resolveVirtualId(id);\n // Resolve shim modules: intercept empty cache imports and replace with virtual modules\n if (aotOptions) {\n const resolved = resolveShimModule(\n id,\n importer,\n AOT_CACHES_SHIM,\n VIRTUAL_AOT_CACHES,\n 'aot-caches',\n 'aotCaches.ts',\n 'emptyCaches.ts'\n );\n if (resolved) return resolved;\n }\n if (pureFnOptions) {\n const resolved = resolveShimModule(\n id,\n importer,\n SERVER_PURE_FNS_SHIM,\n VIRTUAL_SERVER_PURE_FNS,\n 'server-pure-fns',\n 'serverPureFnsCaches.ts',\n 'emptyServerPureFns.ts'\n );\n if (resolved) return resolved;\n }\n // Stub out reflection modules in the bundle build (not needed at runtime in AOT mode)\n if (aotOptions?.excludeReflection && !isRunningAsChild() && REFLECTION_MODULES.includes(id)) {\n return resolveVirtualId(VIRTUAL_STUB_PREFIX + id);\n }\n return null;\n },\n\n async load(id) {\n // Pure functions virtual module\n if (id === resolveVirtualId(VIRTUAL_SERVER_PURE_FNS)) {\n // No serverPureFunctions configured — return empty cache\n if (!pureFnOptions) return generateServerPureFnsVirtualModule([]);\n // Lazily scan client source on first load\n if (!extractedFns) extractedFns = scanClientSource(pureFnOptions);\n return generateServerPureFnsVirtualModule(extractedFns);\n }\n\n // AOT virtual modules — check resolved ID against the map\n const aotType = aotResolvedIds.get(id);\n if (aotType) {\n const initPromise = ssrInitPromise || aotGenerationPromise;\n if (!aotData && initPromise) await initPromise;\n\n switch (aotType) {\n case 'jit-fns': {\n if (!aotData) return generateNoopModule('No-op: AOT JIT caches not generated');\n return generateJitFnsModule(aotData.jitFnsCode);\n }\n case 'pure-fns': {\n if (!aotData) return generateNoopModule('No-op: AOT pure fns not generated');\n return generatePureFnsModule(aotData.pureFnsCode);\n }\n case 'router-cache': {\n if (!aotData) return generateNoopModule('No-op: AOT router cache not generated');\n return generateRouterCacheModule(aotData.routerCacheCode);\n }\n case 'caches': {\n if (!aotData) return generateNoopCombinedModule();\n return generateCombinedCachesModule();\n }\n }\n }\n\n // Reflection module stubs (empty modules — all reflection is pre-compiled in AOT caches)\n // syntheticNamedExports tells Rollup to derive named exports from the default export,\n // so any `import {foo} from '...'` resolves to undefined without build errors.\n for (const mod of REFLECTION_MODULES) {\n if (id === resolveVirtualId(VIRTUAL_STUB_PREFIX + mod)) {\n return {code: 'export default {}', syntheticNamedExports: true};\n }\n }\n\n return null;\n },\n\n transform(code: string, fileName: string) {\n // For Vue SFC virtual modules, resolve the base path and lang for downstream tools\n const vueInfo = parseVueModuleId(fileName);\n // Strip any query params (e.g. ?macro=true from Nuxt) to get the real file path\n const basePath = fileName.includes('?') ? fileName.slice(0, fileName.indexOf('?')) : fileName;\n\n // Skip @mionjs build artifacts and Vite pre-bundled cache files — they already have\n // deepkit types and pure function metadata injected. Re-transpiling them through\n // ts.transpileModule would inject duplicate __assignType declarations.\n if (basePath.includes('@mionjs/') && (basePath.includes('/.dist/') || basePath.includes('/build/'))) return null;\n if (basePath.includes('/.cache/vite/') || basePath.includes('/.vite/deps/')) return null;\n\n const filterPath = vueInfo ? vueInfo.basePath : basePath;\n\n // Skip .vue files unless they are Vue script virtual modules (?vue&type=script).\n // Bare .vue files and other .vue queries (e.g. ?macro=true from Nuxt) contain raw\n // SFC content — wait for the Vue plugin to extract the <script> block first.\n if (basePath.endsWith('.vue') && !vueInfo) return null;\n\n const lang = vueInfo?.lang || 'ts';\n const tsFileName = vueInfo ? `${vueInfo.basePath}.${lang}` : fileName;\n const isTsx = tsFileName.endsWith('.tsx') || tsFileName.endsWith('.jsx');\n\n const hasPureFns =\n code.includes('pureServerFn') || code.includes('registerPureFnFactory') || code.includes('mapFrom');\n const needsDeepkit = deepkitConfig ? deepkitConfig.filter(filterPath) : false;\n\n if (!hasPureFns && !needsDeepkit) return null;\n\n const before: ts.CustomTransformerFactory[] = [];\n const after: ts.CustomTransformerFactory[] = [];\n\n // Pure function transformer (runs first — sees clean AST)\n const collected: ExtractedPureFn[] | undefined = hasPureFns ? [] : undefined;\n if (hasPureFns) {\n before.push(createPureFnTransformerFactory(code, tsFileName, collected, pureFnOptions?.noViteClient));\n }\n\n // Deepkit before-transformers emit type metadata and inject __assignType + CJS require().\n if (needsDeepkit) {\n before.push(...deepkitConfig!.beforeTransformers);\n }\n\n // After-transformers (declarationTransformer, requireToImport) must ALWAYS run when\n // deepkitConfig exists. Deepkit's install script patches typescript.js getTransformers()\n // to inject its transformer into every ts.transpileModule call — even for files outside\n // our include filter. Without requireToImport, those files end up with CJS require()\n // calls (with .ts extensions) that Rollup can't resolve, producing broken build output.\n if (deepkitConfig) {\n after.push(...deepkitConfig.afterTransformers);\n }\n\n const baseCompilerOptions = deepkitConfig?.compilerOptions ?? defaultCompilerOptions;\n const compilerOptions = isTsx ? {...baseCompilerOptions, jsx: ts.JsxEmit.ReactJSX} : baseCompilerOptions;\n\n const result = ts.transpileModule(code, {\n compilerOptions,\n fileName: tsFileName,\n transformers: {before, after},\n });\n\n // Count injected pure functions (collector is populated synchronously by transpileModule)\n if (collected && collected.length > 0) {\n pureFnFilesCount++;\n for (const fn of collected) {\n if (fn.isFactory) registerPureFnFactoryCount++;\n else pureServerFnCount++;\n }\n }\n\n // Strip the //# sourceMappingURL comment that ts.transpileModule appends —\n // Vite consumes the source map via the `map` property, not inline comments.\n const outputCode = result.outputText.replace(/\\n\\/\\/# sourceMappingURL=.*$/, '');\n return {code: outputCode, map: result.sourceMapText};\n },\n\n buildEnd() {\n if (pureServerFnCount > 0 || registerPureFnFactoryCount > 0) {\n const total = pureServerFnCount + registerPureFnFactoryCount;\n const parts = [\n pureServerFnCount > 0 ? `${pureServerFnCount} pureServerFn` : '',\n registerPureFnFactoryCount > 0 ? `${registerPureFnFactoryCount} registerPureFnFactory` : '',\n ].filter(Boolean);\n console.log(`[mion] Injected ${total} pure functions across ${pureFnFilesCount} files (${parts.join(', ')})`);\n }\n },\n\n async closeBundle() {\n await cleanupChild();\n },\n\n handleHotUpdate({file, server}) {\n // In dev mode, re-scan when client source changes (for pure functions)\n if (pureFnOptions) {\n const clientSrcPath = resolve(pureFnOptions.clientSrcPath);\n if (file.startsWith(clientSrcPath)) {\n const include = pureFnOptions.include || ['**/*.ts', '**/*.tsx', '**/*.vue'];\n const exclude = pureFnOptions.exclude || ['../node_modules/**', '**/.dist/**', '**/dist/**'];\n if (isIncluded(file, include, exclude)) {\n // Clear cache and invalidate virtual module\n extractedFns = null;\n const mod = server.moduleGraph.getModuleById(resolveVirtualId(VIRTUAL_SERVER_PURE_FNS));\n if (mod) {\n server.moduleGraph.invalidateModule(mod);\n return [mod];\n }\n }\n }\n }\n\n // In dev mode, regenerate AOT caches when server source changes\n // Skip when running as a child process\n if (serverConfig && !isRunningAsChild()) {\n const serverDir = resolve(serverConfig.startScript, '..');\n\n if (file.startsWith(serverDir)) {\n // Kill existing persistent child before regenerating\n const killPromise = cleanupChild();\n\n const regeneratePromise =\n ssrEnabled && ssrLoadModule\n ? // SSR mode: reset router and re-init via ssrLoadModule\n (async () => {\n const routerModule = await ssrLoadModule!('@mionjs/router');\n routerModule.resetRouter();\n return loadSSRRouterAndGenerateAOTCaches(\n ssrLoadModule!,\n resolve(serverConfig.startScript),\n aotOptions?.isClient\n );\n })()\n : // IPC mode: wait for old child to die, then spawn new\n killPromise.then(() => generateAOTCaches(serverConfig, undefined, aotOptions?.isClient));\n\n aotGenerationPromise = regeneratePromise.then((r) => ('data' in r ? r.data : r));\n regeneratePromise\n .then((result) => {\n const data = 'data' in result ? result.data : result;\n aotData = data;\n logAOTCaches(data);\n\n // Store new persistent child if IPC mode\n if ('childProcess' in result && result.childProcess) {\n persistentChild = result.childProcess;\n console.log(`[mion] Server process re-persisted (pid: ${persistentChild!.pid})`);\n }\n\n // Non-blocking: wait for setPlatformConfig() IPC from restarted server\n const platformReady = 'platformReady' in result ? result.platformReady : undefined;\n if (platformReady && serverConfig.waitTimeout && serverConfig.runMode === 'childProcess') {\n const timeout = serverConfig.waitTimeout;\n console.log('[mion] Waiting for restarted server to call setPlatformConfig()...');\n const timeoutId = setTimeout(() => {\n if (persistentChild?.connected) persistentChild.disconnect();\n console.error(\n `[mion] Restarted server did not call setPlatformConfig() within ${timeout / 1000}s.`\n );\n }, timeout);\n platformReady.then(() => {\n clearTimeout(timeoutId);\n if (persistentChild?.connected) persistentChild.disconnect();\n console.log('[mion] Restarted server ready');\n onServerReady();\n });\n } else if ('childProcess' in result && result.childProcess?.connected) {\n result.childProcess.disconnect();\n }\n\n if (!ssrEnabled) updateDiskCache(serverConfig, aotOptions, data, aotCacheDir);\n // Invalidate all AOT virtual modules\n let invalidatedCount = 0;\n for (const resolvedId of aotResolvedIds.keys()) {\n const mod = server.moduleGraph.getModuleById(resolvedId);\n if (mod) {\n server.moduleGraph.invalidateModule(mod);\n invalidatedCount++;\n }\n }\n if (invalidatedCount > 0) {\n console.log('[mion] AOT caches regenerated, invalidating virtual modules');\n }\n })\n .catch((err) => {\n console.error('[mion] Failed to regenerate AOT caches:', err.message);\n });\n }\n }\n\n return undefined;\n },\n };\n}\n\n/** Whether the current process is a child spawned by the mion plugin */\nfunction isRunningAsChild(): boolean {\n return process.env.MION_COMPILE === 'buildOnly' || process.env.MION_COMPILE === 'childProcess';\n}\n\n/** Extracts the base file path and lang from a Vue SFC virtual module ID (e.g. Component.vue?vue&type=script&lang=ts) */\nexport function parseVueModuleId(id: string): {basePath: string; lang: string | null} | null {\n const qIdx = id.indexOf('?');\n if (qIdx === -1) return null;\n const basePath = id.slice(0, qIdx);\n if (!basePath.endsWith('.vue')) return null;\n const params = new URLSearchParams(id.slice(qIdx));\n if (!params.has('vue') || params.get('type') !== 'script') return null;\n return {basePath, lang: params.get('lang')};\n}\n\n/** Checks if a file path matches the include/exclude patterns */\nexport function isIncluded(filePath: string, include: string[], exclude: string[]): boolean {\n // For Vue virtual module IDs, use the base .vue path for matching\n const vueInfo = parseVueModuleId(filePath);\n const effectivePath = vueInfo ? vueInfo.basePath : filePath;\n\n const isTs = /\\.(ts|tsx|js|jsx)$/.test(effectivePath);\n const isVue = effectivePath.endsWith('.vue');\n const isDir = effectivePath.endsWith('/');\n if (!isTs && !isVue && !isDir) return false;\n\n // Check exclude patterns\n for (const pattern of exclude) {\n if (matchGlob(effectivePath, pattern)) return false;\n }\n\n return true;\n}\n\n/** Simple glob matching for common patterns */\nfunction matchGlob(filePath: string, pattern: string): boolean {\n // Handle **/ prefix\n if (pattern.startsWith('**/')) {\n const suffix = pattern.slice(3);\n return filePath.includes(suffix.replace(/\\*/g, ''));\n }\n // Handle simple wildcard\n const regex = new RegExp('^' + pattern.replace(/\\*\\*/g, '.*').replace(/\\*/g, '[^/]*') + '$');\n return regex.test(filePath);\n}\n\n/** AOT virtual module types — each maps to a different cache export */\nconst AOT_MODULE_TYPES = ['jit-fns', 'pure-fns', 'router-cache', 'caches'] as const;\ntype AOTModuleType = (typeof AOT_MODULE_TYPES)[number];\n\n/** Builds maps from virtual module names → AOT type for resolveId and load hooks.\n * Default 'virtual:mion-aot/*' is always registered. If customVirtualModuleId is set,\n * 'virtual:${custom}/*' is also registered — both map to the same cache data. */\nfunction buildAOTVirtualModuleMaps(customVirtualModuleId?: string) {\n const aotVirtualModules = new Map<string, AOTModuleType>();\n const aotResolvedIds = new Map<string, AOTModuleType>();\n for (const type of AOT_MODULE_TYPES) {\n const defaultId = `virtual:mion-aot/${type}`;\n aotVirtualModules.set(defaultId, type);\n aotResolvedIds.set(resolveVirtualId(defaultId), type);\n if (customVirtualModuleId) {\n const customId = `virtual:${customVirtualModuleId}/${type}`;\n aotVirtualModules.set(customId, type);\n aotResolvedIds.set(resolveVirtualId(customId), type);\n }\n }\n return {aotVirtualModules, aotResolvedIds};\n}\n\n/**\n * Resolves a shim module (e.g. @mionjs/core/aot-caches) to its source file,\n * and intercepts the empty cache import to replace it with the virtual module.\n * Returns the resolved id or null if no match.\n */\nfunction resolveShimModule(\n id: string,\n importer: string | undefined,\n shimSpecifier: string,\n virtualModuleId: string,\n entryName: string,\n sourceFileName: string,\n emptyFileName: string\n): string | null {\n // Bare specifier: resolve to the TS source file so Vite can process it through the plugin pipeline.\n // Using createRequire would return CJS built output whose require() calls bypass resolveId.\n if (id === shimSpecifier) {\n try {\n // Resolve the package directory via Node resolution, then find the source file\n const resolved = createRequire(import.meta.url).resolve(shimSpecifier);\n const sourceFile = resolve(resolved.replace(/[/\\\\].dist[/\\\\].*$/, ''), 'src/aot/' + sourceFileName);\n if (existsSync(sourceFile)) return sourceFile;\n // No source file (tarball/npm install) — resolve to virtual module directly.\n // Returning the .dist path would bypass resolveId (CJS require() calls skip Vite pipeline).\n return resolveVirtualId(virtualModuleId);\n } catch {\n return resolveVirtualId(virtualModuleId);\n }\n }\n // Alias-resolved absolute path (monorepo dev where source files always exist)\n if (id.endsWith('/' + entryName)) {\n const sourceFile = resolve(id, '..', 'src/aot/' + sourceFileName);\n if (existsSync(sourceFile)) return sourceFile;\n }\n // Intercept empty cache imports from the shim loader file (any extension)\n const emptyBase = emptyFileName.replace('.ts', '');\n const sourceBase = sourceFileName.replace('.ts', '');\n if (\n new RegExp(`${emptyBase}\\\\.(ts|js|mjs|cjs)$`).test(id) &&\n importer &&\n new RegExp(`${sourceBase}\\\\.(ts|js|mjs|cjs)$`).test(importer)\n ) {\n return resolveVirtualId(virtualModuleId);\n }\n return null;\n}\n\n/** Adds module specifiers to Vite's ssr.noExternal so they are bundled instead of externalized. */\nfunction addSsrNoExternal(config: Record<string, any>, moduleIds: string[]): void {\n if (moduleIds.length === 0) return;\n const noExternal = config.ssr?.noExternal;\n if (!config.ssr) config.ssr = {};\n if (Array.isArray(noExternal)) {\n for (const moduleId of moduleIds) {\n if (!noExternal.includes(moduleId)) noExternal.push(moduleId);\n }\n } else if (typeof noExternal === 'string') {\n config.ssr.noExternal = [noExternal, ...moduleIds];\n } else if (noExternal !== true) {\n config.ssr.noExternal = noExternal ? [noExternal, ...moduleIds] : [...moduleIds];\n }\n}\n\n/** Wraps build.rollupOptions.external so shim and virtual modules are always bundled. */\nfunction wrapBuildExternal(config: Record<string, any>, shimModules: string[]): void {\n if (!config.build) config.build = {};\n if (!config.build.rollupOptions) config.build.rollupOptions = {};\n const original = config.build.rollupOptions.external;\n if (!original) return; // no external config — nothing to wrap\n config.build.rollupOptions.external = (id: string, ...rest: any[]) => {\n // Never externalize shim modules or virtual modules (plugin replaces them with generated code)\n if (shimModules.includes(id) || id.startsWith('virtual:mion')) return false;\n // Delegate to original external config\n if (typeof original === 'function') return original(id, ...rest);\n if (Array.isArray(original)) return original.some((ext) => (ext instanceof RegExp ? ext.test(id) : ext === id));\n if (original instanceof RegExp) return original.test(id);\n return original === id;\n };\n}\n\n// #################### SERVER READY ####################\n\n// Uses globalThis with Symbol.for because vitest loads vitest.config.ts and globalSetup.ts\n// in separate module contexts — without globalThis they'd get different promise instances.\nconst READY_KEY = Symbol.for('mion.serverReady');\nfunction getOrCreateServerReady(): {promise: Promise<void>; resolve: () => void} {\n if (!(globalThis as any)[READY_KEY]) {\n let _resolve: () => void;\n (globalThis as any)[READY_KEY] = {\n promise: new Promise<void>((r) => {\n _resolve = r;\n }),\n resolve: () => _resolve(),\n };\n }\n return (globalThis as any)[READY_KEY];\n}\n\n/** Promise that resolves when the server is ready. Await this in vitest globalSetup. */\nexport const serverReady: Promise<void> = getOrCreateServerReady().promise;\nconst onServerReady: () => void = getOrCreateServerReady().resolve;\n"],"names":[],"mappings":"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"}
@@ -58,6 +58,7 @@ function createDeepkitConfig(options = {}) {
58
58
  compilerOptions: {
59
59
  target: ts.ScriptTarget.ESNext,
60
60
  module: ts.ModuleKind.ESNext,
61
+ sourceMap: true,
61
62
  configFilePath: options.tsConfig || process.cwd() + "/tsconfig.json",
62
63
  ...options.compilerOptions || {}
63
64
  },
@@ -1 +1 @@
1
- {"version":3,"file":"transformers.js","sources":["../../../../../src/vite-plugin/transformers.ts"],"sourcesContent":["/* ########\n * 2026 mion\n * Author: Ma-jerez\n * License: MIT\n * The software is provided \"as is\", without warranty of any kind.\n * ######## */\n\n// based on https://github.com/marcj/deepkit/blob/e7da3b48c50115d6e59e233eb9f018513d4d68ce/packages/vite/src/plugin.ts\n\nimport {createFilter} from '@rollup/pluginutils';\nimport * as ts from 'typescript';\nimport {transformer, declarationTransformer} from '@deepkit/type-compiler';\nimport {DeepkitTypeOptions, ExtractedPureFn} from './types.ts';\nimport {extractPureFnsFromSource} from './extractPureFn.ts';\n\n// ── Deepkit ─────────────────────────────────────────────────────────\n\n/** Deepkit configuration components for integration into the unified transform pipeline */\nexport interface DeepkitConfig {\n filter: (fileName: string) => boolean;\n compilerOptions: ts.CompilerOptions;\n beforeTransformers: ts.CustomTransformerFactory[];\n afterTransformers: ts.CustomTransformerFactory[];\n}\n\n/**\n * Post-deepkit transformer that converts require() calls back to import declarations.\n * Deepkit's getModuleType() reads tsconfig's module:NodeNext and falls back to 'cjs'\n * because ts.transpileModule doesn't set sourceFile.impliedNodeFormat. This causes\n * deepkit to emit `var {__ΩFoo} = require(\"./bar.ts\")` instead of ESM imports.\n * This transformer converts those back to `import {__ΩFoo} from \"./bar.ts\"` so Rollup\n * can properly resolve and rewrite the module specifiers.\n */\nconst requireToImport: ts.CustomTransformerFactory = (context: ts.TransformationContext): ts.CustomTransformer => ({\n transformSourceFile(sf: ts.SourceFile): ts.SourceFile {\n const newStatements: ts.Statement[] = [];\n let changed = false;\n for (const stmt of sf.statements) {\n const converted = tryConvertRequireToImport(context.factory, stmt);\n if (converted) {\n newStatements.push(converted);\n changed = true;\n } else {\n newStatements.push(stmt);\n }\n }\n return changed ? context.factory.updateSourceFile(sf, newStatements) : sf;\n },\n transformBundle(b: ts.Bundle): ts.Bundle {\n return b;\n },\n});\n\n/**\n * Converts CJS require patterns to ESM import declarations:\n * - `var {a, b} = require(\"./path\")` → `import {a, b} from \"./path\"`\n * - `var mod = require(\"./path\")` → `import mod from \"./path\"`\n */\nfunction tryConvertRequireToImport(f: ts.NodeFactory, stmt: ts.Statement): ts.ImportDeclaration | undefined {\n if (!ts.isVariableStatement(stmt)) return undefined;\n const decls = stmt.declarationList.declarations;\n if (decls.length !== 1) return undefined;\n const decl = decls[0];\n if (!decl.initializer || !ts.isCallExpression(decl.initializer)) return undefined;\n const callee = decl.initializer.expression;\n if (!ts.isIdentifier(callee) || callee.text !== 'require') return undefined;\n if (decl.initializer.arguments.length !== 1) return undefined;\n const specArg = decl.initializer.arguments[0];\n if (!ts.isStringLiteral(specArg)) return undefined;\n\n // var {a, b} = require(\"./path\") → import {a, b} from \"./path\"\n if (ts.isObjectBindingPattern(decl.name)) {\n const specifiers = decl.name.elements.map((el) =>\n f.createImportSpecifier(false, undefined, f.createIdentifier((el.name as ts.Identifier).text))\n );\n return f.createImportDeclaration(\n undefined,\n f.createImportClause(false, undefined, f.createNamedImports(specifiers)),\n f.createStringLiteral(specArg.text)\n );\n }\n\n // var mod = require(\"./path\") → import mod from \"./path\"\n if (ts.isIdentifier(decl.name)) {\n return f.createImportDeclaration(\n undefined,\n f.createImportClause(false, f.createIdentifier(decl.name.text), undefined),\n f.createStringLiteral(specArg.text)\n );\n }\n\n return undefined;\n}\n\n/** Creates deepkit config components that can be integrated into a unified ts.transpileModule call */\nexport function createDeepkitConfig(options: DeepkitTypeOptions = {}): DeepkitConfig {\n const filter = createFilter(options.include ?? ['**/*.tsx', '**/*.ts'], options.exclude ?? 'node_modules/**');\n return {\n filter: (fileName: string) => filter(fileName),\n compilerOptions: {\n target: ts.ScriptTarget.ESNext,\n module: ts.ModuleKind.ESNext,\n configFilePath: options.tsConfig || process.cwd() + '/tsconfig.json',\n ...(options.compilerOptions || {}),\n },\n beforeTransformers: [transformer],\n afterTransformers: [declarationTransformer, requireToImport],\n };\n}\n\n// ── Pure function transformer ───────────────────────────────────────\n\n/**\n * Creates a TypeScript CustomTransformerFactory that injects build-time data into pure function calls.\n * For pureServerFn(def): injects bodyHash as 2nd argument.\n * For registerPureFnFactory(ns, id, fn): injects ParsedFactoryFn as 4th argument.\n *\n * Pre-extracts data using existing extractPureFnsFromSource to ensure hash consistency\n * with the virtual module cache (same whole-file esbuild strip + JS AST path).\n */\nexport function createPureFnTransformerFactory(\n originalSource: string,\n filePath: string,\n collector?: ExtractedPureFn[],\n noViteClient = false\n): ts.CustomTransformerFactory {\n const hasPureServerFn = originalSource.includes('pureServerFn');\n const hasFactory = originalSource.includes('registerPureFnFactory');\n const hasMapFrom = originalSource.includes('mapFrom');\n\n const pureServerFns = hasPureServerFn ? extractPureFnsFromSource(originalSource, filePath, 'pureServerFn', noViteClient) : [];\n const factoryFns = hasFactory ? extractPureFnsFromSource(originalSource, filePath, 'registerPureFnFactory') : [];\n const mapFromFns = hasMapFrom ? extractPureFnsFromSource(originalSource, filePath, 'mapFrom', noViteClient) : [];\n\n return (context: ts.TransformationContext): ts.CustomTransformer => {\n let pureIdx = 0;\n let factoryIdx = 0;\n let mapFromIdx = 0;\n\n function visitor(node: ts.Node): ts.Node {\n if (ts.isCallExpression(node)) {\n const callee = node.expression;\n if (ts.isIdentifier(callee)) {\n if (callee.text === 'pureServerFn' && pureIdx < pureServerFns.length) {\n if (node.arguments.length >= 2) {\n pureIdx++;\n return ts.visitEachChild(node, visitor, context);\n }\n const data = pureServerFns[pureIdx++];\n collector?.push(data);\n return context.factory.updateCallExpression(node, node.expression, node.typeArguments, [\n ...node.arguments,\n context.factory.createStringLiteral(data.bodyHash),\n ]);\n }\n if (callee.text === 'registerPureFnFactory' && factoryIdx < factoryFns.length) {\n if (node.arguments.length >= 4) {\n factoryIdx++;\n return ts.visitEachChild(node, visitor, context);\n }\n const data = factoryFns[factoryIdx++];\n collector?.push(data);\n return context.factory.updateCallExpression(node, node.expression, node.typeArguments, [\n ...node.arguments,\n createParsedFactoryFnNode(context.factory, data),\n ]);\n }\n if (callee.text === 'mapFrom' && mapFromIdx < mapFromFns.length) {\n // mapFrom(source, mapper) -> mapFrom(source, mapper, 'bodyHash')\n if (node.arguments.length >= 3) {\n mapFromIdx++;\n return ts.visitEachChild(node, visitor, context);\n }\n const data = mapFromFns[mapFromIdx++];\n collector?.push(data);\n return context.factory.updateCallExpression(node, node.expression, node.typeArguments, [\n ...node.arguments,\n context.factory.createStringLiteral(data.bodyHash),\n ]);\n }\n }\n }\n return ts.visitEachChild(node, visitor, context);\n }\n\n return {\n transformSourceFile(sourceFile: ts.SourceFile): ts.SourceFile {\n if (pureServerFns.length === 0 && factoryFns.length === 0 && mapFromFns.length === 0) return sourceFile;\n return ts.visitNode(sourceFile, visitor) as ts.SourceFile;\n },\n transformBundle(bundle: ts.Bundle): ts.Bundle {\n return bundle;\n },\n };\n };\n}\n\n/** Creates an AST node for {bodyHash: '...', paramNames: [...], code: '...'} */\nfunction createParsedFactoryFnNode(factory: ts.NodeFactory, data: ExtractedPureFn): ts.ObjectLiteralExpression {\n return factory.createObjectLiteralExpression([\n factory.createPropertyAssignment('bodyHash', factory.createStringLiteral(data.bodyHash)),\n factory.createPropertyAssignment(\n 'paramNames',\n factory.createArrayLiteralExpression(data.paramNames.map((n) => factory.createStringLiteral(n)))\n ),\n factory.createPropertyAssignment('code', factory.createStringLiteral(data.fnBody)),\n ]);\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"transformers.js","sources":["../../../../../src/vite-plugin/transformers.ts"],"sourcesContent":["/* ########\n * 2026 mion\n * Author: Ma-jerez\n * License: MIT\n * The software is provided \"as is\", without warranty of any kind.\n * ######## */\n\n// based on https://github.com/marcj/deepkit/blob/e7da3b48c50115d6e59e233eb9f018513d4d68ce/packages/vite/src/plugin.ts\n\nimport {createFilter} from '@rollup/pluginutils';\nimport * as ts from 'typescript';\nimport {transformer, declarationTransformer} from '@deepkit/type-compiler';\nimport {DeepkitTypeOptions, ExtractedPureFn} from './types.ts';\nimport {extractPureFnsFromSource} from './extractPureFn.ts';\n\n// ── Deepkit ─────────────────────────────────────────────────────────\n\n/** Deepkit configuration components for integration into the unified transform pipeline */\nexport interface DeepkitConfig {\n filter: (fileName: string) => boolean;\n compilerOptions: ts.CompilerOptions;\n beforeTransformers: ts.CustomTransformerFactory[];\n afterTransformers: ts.CustomTransformerFactory[];\n}\n\n/**\n * Post-deepkit transformer that converts require() calls back to import declarations.\n * Deepkit's getModuleType() reads tsconfig's module:NodeNext and falls back to 'cjs'\n * because ts.transpileModule doesn't set sourceFile.impliedNodeFormat. This causes\n * deepkit to emit `var {__ΩFoo} = require(\"./bar.ts\")` instead of ESM imports.\n * This transformer converts those back to `import {__ΩFoo} from \"./bar.ts\"` so Rollup\n * can properly resolve and rewrite the module specifiers.\n */\nconst requireToImport: ts.CustomTransformerFactory = (context: ts.TransformationContext): ts.CustomTransformer => ({\n transformSourceFile(sf: ts.SourceFile): ts.SourceFile {\n const newStatements: ts.Statement[] = [];\n let changed = false;\n for (const stmt of sf.statements) {\n const converted = tryConvertRequireToImport(context.factory, stmt);\n if (converted) {\n newStatements.push(converted);\n changed = true;\n } else {\n newStatements.push(stmt);\n }\n }\n return changed ? context.factory.updateSourceFile(sf, newStatements) : sf;\n },\n transformBundle(b: ts.Bundle): ts.Bundle {\n return b;\n },\n});\n\n/**\n * Converts CJS require patterns to ESM import declarations:\n * - `var {a, b} = require(\"./path\")` → `import {a, b} from \"./path\"`\n * - `var mod = require(\"./path\")` → `import mod from \"./path\"`\n */\nfunction tryConvertRequireToImport(f: ts.NodeFactory, stmt: ts.Statement): ts.ImportDeclaration | undefined {\n if (!ts.isVariableStatement(stmt)) return undefined;\n const decls = stmt.declarationList.declarations;\n if (decls.length !== 1) return undefined;\n const decl = decls[0];\n if (!decl.initializer || !ts.isCallExpression(decl.initializer)) return undefined;\n const callee = decl.initializer.expression;\n if (!ts.isIdentifier(callee) || callee.text !== 'require') return undefined;\n if (decl.initializer.arguments.length !== 1) return undefined;\n const specArg = decl.initializer.arguments[0];\n if (!ts.isStringLiteral(specArg)) return undefined;\n\n // var {a, b} = require(\"./path\") → import {a, b} from \"./path\"\n if (ts.isObjectBindingPattern(decl.name)) {\n const specifiers = decl.name.elements.map((el) =>\n f.createImportSpecifier(false, undefined, f.createIdentifier((el.name as ts.Identifier).text))\n );\n return f.createImportDeclaration(\n undefined,\n f.createImportClause(false, undefined, f.createNamedImports(specifiers)),\n f.createStringLiteral(specArg.text)\n );\n }\n\n // var mod = require(\"./path\") → import mod from \"./path\"\n if (ts.isIdentifier(decl.name)) {\n return f.createImportDeclaration(\n undefined,\n f.createImportClause(false, f.createIdentifier(decl.name.text), undefined),\n f.createStringLiteral(specArg.text)\n );\n }\n\n return undefined;\n}\n\n/** Creates deepkit config components that can be integrated into a unified ts.transpileModule call */\nexport function createDeepkitConfig(options: DeepkitTypeOptions = {}): DeepkitConfig {\n const filter = createFilter(options.include ?? ['**/*.tsx', '**/*.ts'], options.exclude ?? 'node_modules/**');\n return {\n filter: (fileName: string) => filter(fileName),\n compilerOptions: {\n target: ts.ScriptTarget.ESNext,\n module: ts.ModuleKind.ESNext,\n sourceMap: true,\n configFilePath: options.tsConfig || process.cwd() + '/tsconfig.json',\n ...(options.compilerOptions || {}),\n },\n beforeTransformers: [transformer],\n afterTransformers: [declarationTransformer, requireToImport],\n };\n}\n\n// ── Pure function transformer ───────────────────────────────────────\n\n/**\n * Creates a TypeScript CustomTransformerFactory that injects build-time data into pure function calls.\n * For pureServerFn(def): injects bodyHash as 2nd argument.\n * For registerPureFnFactory(ns, id, fn): injects ParsedFactoryFn as 4th argument.\n *\n * Pre-extracts data using existing extractPureFnsFromSource to ensure hash consistency\n * with the virtual module cache (same whole-file esbuild strip + JS AST path).\n */\nexport function createPureFnTransformerFactory(\n originalSource: string,\n filePath: string,\n collector?: ExtractedPureFn[],\n noViteClient = false\n): ts.CustomTransformerFactory {\n const hasPureServerFn = originalSource.includes('pureServerFn');\n const hasFactory = originalSource.includes('registerPureFnFactory');\n const hasMapFrom = originalSource.includes('mapFrom');\n\n const pureServerFns = hasPureServerFn ? extractPureFnsFromSource(originalSource, filePath, 'pureServerFn', noViteClient) : [];\n const factoryFns = hasFactory ? extractPureFnsFromSource(originalSource, filePath, 'registerPureFnFactory') : [];\n const mapFromFns = hasMapFrom ? extractPureFnsFromSource(originalSource, filePath, 'mapFrom', noViteClient) : [];\n\n return (context: ts.TransformationContext): ts.CustomTransformer => {\n let pureIdx = 0;\n let factoryIdx = 0;\n let mapFromIdx = 0;\n\n function visitor(node: ts.Node): ts.Node {\n if (ts.isCallExpression(node)) {\n const callee = node.expression;\n if (ts.isIdentifier(callee)) {\n if (callee.text === 'pureServerFn' && pureIdx < pureServerFns.length) {\n if (node.arguments.length >= 2) {\n pureIdx++;\n return ts.visitEachChild(node, visitor, context);\n }\n const data = pureServerFns[pureIdx++];\n collector?.push(data);\n return context.factory.updateCallExpression(node, node.expression, node.typeArguments, [\n ...node.arguments,\n context.factory.createStringLiteral(data.bodyHash),\n ]);\n }\n if (callee.text === 'registerPureFnFactory' && factoryIdx < factoryFns.length) {\n if (node.arguments.length >= 4) {\n factoryIdx++;\n return ts.visitEachChild(node, visitor, context);\n }\n const data = factoryFns[factoryIdx++];\n collector?.push(data);\n return context.factory.updateCallExpression(node, node.expression, node.typeArguments, [\n ...node.arguments,\n createParsedFactoryFnNode(context.factory, data),\n ]);\n }\n if (callee.text === 'mapFrom' && mapFromIdx < mapFromFns.length) {\n // mapFrom(source, mapper) -> mapFrom(source, mapper, 'bodyHash')\n if (node.arguments.length >= 3) {\n mapFromIdx++;\n return ts.visitEachChild(node, visitor, context);\n }\n const data = mapFromFns[mapFromIdx++];\n collector?.push(data);\n return context.factory.updateCallExpression(node, node.expression, node.typeArguments, [\n ...node.arguments,\n context.factory.createStringLiteral(data.bodyHash),\n ]);\n }\n }\n }\n return ts.visitEachChild(node, visitor, context);\n }\n\n return {\n transformSourceFile(sourceFile: ts.SourceFile): ts.SourceFile {\n if (pureServerFns.length === 0 && factoryFns.length === 0 && mapFromFns.length === 0) return sourceFile;\n return ts.visitNode(sourceFile, visitor) as ts.SourceFile;\n },\n transformBundle(bundle: ts.Bundle): ts.Bundle {\n return bundle;\n },\n };\n };\n}\n\n/** Creates an AST node for {bodyHash: '...', paramNames: [...], code: '...'} */\nfunction createParsedFactoryFnNode(factory: ts.NodeFactory, data: ExtractedPureFn): ts.ObjectLiteralExpression {\n return factory.createObjectLiteralExpression([\n factory.createPropertyAssignment('bodyHash', factory.createStringLiteral(data.bodyHash)),\n factory.createPropertyAssignment(\n 'paramNames',\n factory.createArrayLiteralExpression(data.paramNames.map((n) => factory.createStringLiteral(n)))\n ),\n factory.createPropertyAssignment('code', factory.createStringLiteral(data.fnBody)),\n ]);\n}\n"],"names":[],"mappings":"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"}
@@ -5,13 +5,15 @@ export interface AOTCacheOptions {
5
5
  cache?: boolean | string;
6
6
  excludeReflection?: boolean;
7
7
  customVirtualModuleId?: string;
8
+ isClient?: boolean;
8
9
  }
9
10
  export interface MionServerConfig {
10
- startServerScript: string;
11
- serverViteConfig?: string;
12
- mode: 'onlyAOT' | 'IPC' | 'viteSSR';
13
- port?: number;
11
+ startScript: string;
12
+ viteConfig?: string;
13
+ runMode: 'buildOnly' | 'childProcess' | 'middleware';
14
14
  waitTimeout?: number;
15
+ env?: Record<string, string>;
16
+ args?: string[];
15
17
  }
16
18
  export interface PureServerFnRegistryEntry {
17
19
  readonly namespace: string;