nitro-nightly 3.0.1-20260106-130706-e20c92d9 → 3.0.1-20260106-202835-5325b208
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/_build/rolldown.mjs +6 -14
- package/dist/_build/rollup.mjs +6 -41
- package/dist/_build/rollup2.mjs +56 -0
- package/dist/_build/shared.mjs +2 -1
- package/dist/_build/shared2.mjs +1 -1
- package/dist/_build/shared3.mjs +1 -1
- package/dist/_build/vite.build.mjs +1 -19
- package/dist/_dev.mjs +2 -1
- package/dist/_libs/@hiogawa/vite-plugin-fullstack.mjs +5 -1560
- package/dist/_libs/@jridgewell/gen-mapping.mjs +2 -304
- package/dist/_libs/@jridgewell/remapping.mjs +2 -1
- package/dist/_libs/@jridgewell/resolve-uri.mjs +166 -0
- package/dist/_libs/@jridgewell/sourcemap-codec.mjs +167 -0
- package/dist/_libs/@jridgewell/trace-mapping.mjs +141 -0
- package/dist/_libs/@rolldown/pluginutils.mjs +31 -0
- package/dist/_libs/@rollup/plugin-commonjs.mjs +33 -2636
- package/dist/_libs/@rollup/plugin-inject.mjs +3 -2
- package/dist/_libs/@rollup/plugin-json.mjs +1 -1
- package/dist/_libs/@rollup/plugin-node-resolve.mjs +7 -1111
- package/dist/_libs/@rollup/plugin-replace.mjs +2 -2
- package/dist/_libs/@rollup/pluginutils.mjs +241 -0
- package/dist/_libs/c12.mjs +63 -2513
- package/dist/_libs/chokidar.mjs +1 -234
- package/dist/_libs/commondir.mjs +22 -0
- package/dist/_libs/confbox.mjs +1102 -502
- package/dist/_libs/deepmerge.mjs +86 -0
- package/dist/_libs/dotenv.mjs +345 -0
- package/dist/_libs/estree-walker.mjs +144 -1
- package/dist/_libs/exsolve.mjs +1007 -0
- package/dist/_libs/fdir.mjs +514 -0
- package/dist/_libs/function-bind.mjs +63 -0
- package/dist/_libs/giget.mjs +1376 -2234
- package/dist/_libs/hasown.mjs +14 -0
- package/dist/_libs/is-core-module.mjs +220 -0
- package/dist/_libs/is-module.mjs +13 -0
- package/dist/_libs/is-reference.mjs +33 -0
- package/dist/_libs/js-tokens.mjs +382 -0
- package/dist/_libs/local-pkg.mjs +6 -1560
- package/dist/_libs/magic-string.mjs +939 -0
- package/dist/_libs/mlly.mjs +1415 -0
- package/dist/_libs/node-fetch-native.mjs +7 -0
- package/dist/_libs/nypm.mjs +239 -0
- package/dist/_libs/path-parse.mjs +47 -0
- package/dist/_libs/pathe.mjs +163 -2
- package/dist/_libs/perfect-debounce.mjs +89 -0
- package/dist/_libs/picomatch.mjs +1673 -0
- package/dist/_libs/pkg-types.mjs +197 -0
- package/dist/_libs/quansync.mjs +90 -0
- package/dist/_libs/rc9.mjs +136 -0
- package/dist/_libs/readdirp.mjs +237 -0
- package/dist/_libs/resolve.mjs +689 -0
- package/dist/_libs/strip-literal.mjs +51 -0
- package/dist/_libs/tinyexec.mjs +627 -0
- package/dist/_libs/tinyglobby.mjs +2 -1
- package/dist/_libs/unimport.mjs +42 -1575
- package/dist/_libs/unplugin-utils.mjs +61 -0
- package/dist/_libs/unplugin.mjs +1225 -0
- package/dist/_libs/unwasm.mjs +3 -2
- package/dist/_libs/webpack-virtual-modules.mjs +272 -0
- package/dist/_nitro.mjs +7 -4
- package/dist/_nitro2.mjs +3 -3
- package/dist/_presets.mjs +5 -3
- package/dist/builder.mjs +4 -4
- package/dist/cli/_chunks/{build.mjs → build2.mjs} +1 -1
- package/dist/cli/_chunks/dev.mjs +1 -1
- package/dist/cli/_chunks/list.mjs +1 -1
- package/dist/cli/_chunks/prepare.mjs +1 -1
- package/dist/cli/_chunks/run.mjs +1 -1
- package/dist/cli/index.mjs +1 -1
- package/dist/types/index.d.mts +4 -4
- package/dist/vite.mjs +1824 -19
- package/package.json +2 -2
- package/dist/_build/shared4.mjs +0 -1114
- package/dist/_build/vite.plugin.mjs +0 -712
|
@@ -1,712 +0,0 @@
|
|
|
1
|
-
import { A as resolve$1, S as dirname$1, T as join$1, k as relative$1, s as debounce, w as isAbsolute$1, x as basename$1, y as resolveModulePath } from "../_libs/c12.mjs";
|
|
2
|
-
import { t as formatCompatibilityDate } from "../_libs/compatx.mjs";
|
|
3
|
-
import { i as a, r as T } from "../_libs/std-env.mjs";
|
|
4
|
-
import { a as copyPublicAssets, i as prepare, s as createNitro } from "../_nitro.mjs";
|
|
5
|
-
import { n as prettyPath } from "./shared2.mjs";
|
|
6
|
-
import { i as scanHandlers } from "../_nitro2.mjs";
|
|
7
|
-
import { r as assetsPlugin } from "../_libs/@hiogawa/vite-plugin-fullstack.mjs";
|
|
8
|
-
import { n as writeBuildInfo, t as getBuildInfo } from "./shared3.mjs";
|
|
9
|
-
import { i as NodeEnvRunner, r as NitroDevApp } from "../_dev.mjs";
|
|
10
|
-
import { a as watch$1 } from "../_libs/chokidar.mjs";
|
|
11
|
-
import { t as alias } from "../_libs/@rollup/plugin-alias.mjs";
|
|
12
|
-
import { t as inject } from "../_libs/@rollup/plugin-inject.mjs";
|
|
13
|
-
import { a as baseBuildConfig, i as libChunkName, n as NODE_MODULES_RE, r as getChunkName, t as baseBuildPlugins } from "./shared4.mjs";
|
|
14
|
-
import consola$1 from "consola";
|
|
15
|
-
import { existsSync, watch } from "node:fs";
|
|
16
|
-
import { mkdir, readFile, rm, writeFile } from "node:fs/promises";
|
|
17
|
-
import { join, resolve } from "node:path";
|
|
18
|
-
import { defu } from "defu";
|
|
19
|
-
import { runtimeDependencies, runtimeDir } from "nitro/meta";
|
|
20
|
-
import { colors } from "consola/utils";
|
|
21
|
-
import { NodeRequest, sendNodeResponse } from "srvx/node";
|
|
22
|
-
import { DevEnvironment } from "vite";
|
|
23
|
-
import { spawn } from "node:child_process";
|
|
24
|
-
|
|
25
|
-
//#region src/build/vite/rollup.ts
|
|
26
|
-
const getViteRollupConfig = async (ctx) => {
|
|
27
|
-
const nitro$1 = ctx.nitro;
|
|
28
|
-
const base = baseBuildConfig(nitro$1);
|
|
29
|
-
let config = {
|
|
30
|
-
input: nitro$1.options.entry,
|
|
31
|
-
external: [...base.env.external],
|
|
32
|
-
plugins: [
|
|
33
|
-
...await baseBuildPlugins(nitro$1, base),
|
|
34
|
-
alias({ entries: base.aliases }),
|
|
35
|
-
!ctx._isRolldown && inject(base.env.inject)
|
|
36
|
-
].filter(Boolean),
|
|
37
|
-
...ctx._isRolldown ? { transform: { inject: base.env.inject } } : {},
|
|
38
|
-
treeshake: { moduleSideEffects(id) {
|
|
39
|
-
return nitro$1.options.moduleSideEffects.some((p) => id.startsWith(p));
|
|
40
|
-
} },
|
|
41
|
-
onwarn(warning, warn) {
|
|
42
|
-
if (!base.ignoreWarningCodes.has(warning.code || "")) warn(warning);
|
|
43
|
-
},
|
|
44
|
-
output: {
|
|
45
|
-
format: "esm",
|
|
46
|
-
entryFileNames: "index.mjs",
|
|
47
|
-
chunkFileNames: (chunk) => getChunkName(chunk, nitro$1),
|
|
48
|
-
...ctx._isRolldown ? { advancedChunks: { groups: [{
|
|
49
|
-
test: NODE_MODULES_RE,
|
|
50
|
-
name: (id) => libChunkName(id)
|
|
51
|
-
}] } } : { manualChunks(id) {
|
|
52
|
-
if (NODE_MODULES_RE.test(id)) return libChunkName(id);
|
|
53
|
-
} },
|
|
54
|
-
inlineDynamicImports: nitro$1.options.inlineDynamicImports,
|
|
55
|
-
dir: nitro$1.options.output.serverDir,
|
|
56
|
-
generatedCode: { ...ctx._isRolldown ? {} : { constBindings: true } },
|
|
57
|
-
...ctx._isRolldown ? {} : { sourcemapExcludeSources: true },
|
|
58
|
-
sourcemapIgnoreList: (id) => id.includes("node_modules")
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
config = defu(nitro$1.options.rollupConfig, config);
|
|
62
|
-
return {
|
|
63
|
-
config,
|
|
64
|
-
base
|
|
65
|
-
};
|
|
66
|
-
};
|
|
67
|
-
|
|
68
|
-
//#endregion
|
|
69
|
-
//#region src/build/vite/prod.ts
|
|
70
|
-
const BuilderNames = {
|
|
71
|
-
nitro: colors.magenta("Nitro"),
|
|
72
|
-
client: colors.green("Client"),
|
|
73
|
-
ssr: colors.blue("SSR")
|
|
74
|
-
};
|
|
75
|
-
async function buildEnvironments(ctx, builder) {
|
|
76
|
-
const nitro$1 = ctx.nitro;
|
|
77
|
-
for (const [envName, env] of Object.entries(builder.environments)) {
|
|
78
|
-
const fmtName = BuilderNames[envName] || (envName.length <= 3 ? envName.toUpperCase() : envName[0].toUpperCase() + envName.slice(1));
|
|
79
|
-
if (envName === "nitro" || !env.config.build.rollupOptions.input || env.isBuilt) {
|
|
80
|
-
if (![
|
|
81
|
-
"nitro",
|
|
82
|
-
"ssr",
|
|
83
|
-
"client"
|
|
84
|
-
].includes(envName)) nitro$1.logger.info(env.isBuilt ? `Skipping ${fmtName} (already built)` : `Skipping ${fmtName} (no input defined)`);
|
|
85
|
-
continue;
|
|
86
|
-
}
|
|
87
|
-
if (!a && !T) console.log();
|
|
88
|
-
nitro$1.logger.start(`Building [${fmtName}]`);
|
|
89
|
-
await builder.build(env);
|
|
90
|
-
}
|
|
91
|
-
const nitroOptions = ctx.nitro.options;
|
|
92
|
-
const clientInput = builder.environments.client?.config?.build?.rollupOptions?.input;
|
|
93
|
-
if (nitroOptions.renderer?.template && nitroOptions.renderer?.template === clientInput) {
|
|
94
|
-
const outputPath = resolve$1(nitroOptions.output.publicDir, basename$1(clientInput));
|
|
95
|
-
if (existsSync(outputPath)) {
|
|
96
|
-
const html = await readFile(outputPath, "utf8").then((r) => r.replace("<!--ssr-outlet-->", `{{{ globalThis.__nitro_vite_envs__?.["ssr"]?.fetch($REQUEST) || "" }}}`));
|
|
97
|
-
await rm(outputPath);
|
|
98
|
-
const tmp = resolve$1(nitroOptions.buildDir, "vite/index.html");
|
|
99
|
-
await mkdir(dirname$1(tmp), { recursive: true });
|
|
100
|
-
await writeFile(tmp, html, "utf8");
|
|
101
|
-
nitroOptions.renderer.template = tmp;
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
await builder.writeAssetsManifest?.();
|
|
105
|
-
if (!a && !T) console.log();
|
|
106
|
-
const buildInfo = [["preset", nitro$1.options.preset], ["compatibility", formatCompatibilityDate(nitro$1.options.compatibilityDate)]].filter((e) => e[1]);
|
|
107
|
-
nitro$1.logger.start(`Building [${BuilderNames.nitro}] ${colors.dim(`(${buildInfo.map(([k, v]) => `${k}: \`${v}\``).join(", ")})`)}`);
|
|
108
|
-
await copyPublicAssets(nitro$1);
|
|
109
|
-
const assetDirs = new Set(Object.values(builder.environments).filter((env) => env.config.consumer === "client").map((env) => env.config.build.assetsDir).filter(Boolean));
|
|
110
|
-
for (const assetsDir of assetDirs) {
|
|
111
|
-
if (!existsSync(resolve$1(nitro$1.options.output.publicDir, assetsDir))) continue;
|
|
112
|
-
const rule = ctx.nitro.options.routeRules[`/${assetsDir}/**`] ??= {};
|
|
113
|
-
if (!rule.headers?.["cache-control"]) rule.headers = {
|
|
114
|
-
...rule.headers,
|
|
115
|
-
"cache-control": `public, max-age=31536000, immutable`
|
|
116
|
-
};
|
|
117
|
-
}
|
|
118
|
-
ctx.nitro.routing.sync();
|
|
119
|
-
await builder.build(builder.environments.nitro);
|
|
120
|
-
await nitro$1.close();
|
|
121
|
-
await nitro$1.hooks.callHook("compiled", nitro$1);
|
|
122
|
-
await writeBuildInfo(nitro$1);
|
|
123
|
-
const rOutput = relative$1(process.cwd(), nitro$1.options.output.dir);
|
|
124
|
-
const rewriteRelativePaths = (input) => {
|
|
125
|
-
return input.replace(/([\s:])\.\/(\S*)/g, `$1${rOutput}/$2`);
|
|
126
|
-
};
|
|
127
|
-
if (!a && !T) console.log();
|
|
128
|
-
if (nitro$1.options.commands.preview) nitro$1.logger.success(`You can preview this build using \`${rewriteRelativePaths(nitro$1.options.commands.preview)}\``);
|
|
129
|
-
if (nitro$1.options.commands.deploy) nitro$1.logger.success(`You can deploy this build using \`${rewriteRelativePaths(nitro$1.options.commands.deploy)}\``);
|
|
130
|
-
}
|
|
131
|
-
function prodSetup(ctx) {
|
|
132
|
-
return `
|
|
133
|
-
function lazyService(loader) {
|
|
134
|
-
let promise, mod
|
|
135
|
-
return {
|
|
136
|
-
fetch(req) {
|
|
137
|
-
if (mod) { return mod.fetch(req) }
|
|
138
|
-
if (!promise) {
|
|
139
|
-
promise = loader().then(_mod => (mod = _mod.default || _mod))
|
|
140
|
-
}
|
|
141
|
-
return promise.then(mod => mod.fetch(req))
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
const services = {
|
|
147
|
-
${Object.keys(ctx.services).map((name) => {
|
|
148
|
-
return [name, resolve$1(ctx.nitro.options.buildDir, "vite/services", name, ctx._entryPoints[name])];
|
|
149
|
-
}).map(([name, entry]) => `[${JSON.stringify(name)}]: lazyService(() => import(${JSON.stringify(entry)}))`).join(",\n")}
|
|
150
|
-
};
|
|
151
|
-
|
|
152
|
-
globalThis.__nitro_vite_envs__ = services;
|
|
153
|
-
`;
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
//#endregion
|
|
157
|
-
//#region src/build/vite/dev.ts
|
|
158
|
-
function createFetchableDevEnvironment(name, config, devServer, entry) {
|
|
159
|
-
return new FetchableDevEnvironment(name, config, {
|
|
160
|
-
hot: true,
|
|
161
|
-
transport: createTransport(name, devServer)
|
|
162
|
-
}, devServer, entry);
|
|
163
|
-
}
|
|
164
|
-
var FetchableDevEnvironment = class extends DevEnvironment {
|
|
165
|
-
devServer;
|
|
166
|
-
constructor(name, config, context, devServer, entry) {
|
|
167
|
-
super(name, config, context);
|
|
168
|
-
this.devServer = devServer;
|
|
169
|
-
this.devServer.sendMessage({
|
|
170
|
-
type: "custom",
|
|
171
|
-
event: "nitro:vite-env",
|
|
172
|
-
data: {
|
|
173
|
-
name,
|
|
174
|
-
entry
|
|
175
|
-
}
|
|
176
|
-
});
|
|
177
|
-
}
|
|
178
|
-
async dispatchFetch(request) {
|
|
179
|
-
return this.devServer.fetch(request);
|
|
180
|
-
}
|
|
181
|
-
async init(...args) {
|
|
182
|
-
await this.devServer.init?.();
|
|
183
|
-
return super.init(...args);
|
|
184
|
-
}
|
|
185
|
-
};
|
|
186
|
-
function createTransport(name, hooks) {
|
|
187
|
-
const listeners = /* @__PURE__ */ new WeakMap();
|
|
188
|
-
return {
|
|
189
|
-
send: (data) => hooks.sendMessage({
|
|
190
|
-
...data,
|
|
191
|
-
viteEnv: name
|
|
192
|
-
}),
|
|
193
|
-
on: (event, handler) => {
|
|
194
|
-
if (event === "connection") return;
|
|
195
|
-
const listener = (value) => {
|
|
196
|
-
if (value?.type === "custom" && value.event === event && value.viteEnv === name) handler(value.data, { send: (payload) => hooks.sendMessage({
|
|
197
|
-
...payload,
|
|
198
|
-
viteEnv: name
|
|
199
|
-
}) });
|
|
200
|
-
};
|
|
201
|
-
listeners.set(handler, listener);
|
|
202
|
-
hooks.onMessage(listener);
|
|
203
|
-
},
|
|
204
|
-
off: (event, handler) => {
|
|
205
|
-
if (event === "connection") return;
|
|
206
|
-
const listener = listeners.get(handler);
|
|
207
|
-
if (listener) {
|
|
208
|
-
hooks.offMessage(listener);
|
|
209
|
-
listeners.delete(handler);
|
|
210
|
-
}
|
|
211
|
-
}
|
|
212
|
-
};
|
|
213
|
-
}
|
|
214
|
-
async function configureViteDevServer(ctx, server) {
|
|
215
|
-
const nitro$1 = ctx.nitro;
|
|
216
|
-
const nitroEnv$1 = server.environments.nitro;
|
|
217
|
-
const nitroConfigFile = nitro$1.options._c12.configFile;
|
|
218
|
-
if (nitroConfigFile) server.config.configFileDependencies.push(nitroConfigFile);
|
|
219
|
-
if (nitro$1.options.features.websocket ?? nitro$1.options.experimental.websocket) server.httpServer.on("upgrade", (req, socket, head) => {
|
|
220
|
-
if (req.url?.startsWith("/?token")) return;
|
|
221
|
-
getEnvRunner(ctx).upgrade?.(req, socket, head);
|
|
222
|
-
});
|
|
223
|
-
const reload = debounce(async () => {
|
|
224
|
-
await scanHandlers(nitro$1);
|
|
225
|
-
nitro$1.routing.sync();
|
|
226
|
-
nitroEnv$1.moduleGraph.invalidateAll();
|
|
227
|
-
nitroEnv$1.hot.send({ type: "full-reload" });
|
|
228
|
-
});
|
|
229
|
-
const scanDirs = nitro$1.options.scanDirs.flatMap((dir) => [
|
|
230
|
-
join$1(dir, nitro$1.options.apiDir || "api"),
|
|
231
|
-
join$1(dir, nitro$1.options.routesDir || "routes"),
|
|
232
|
-
join$1(dir, "middleware"),
|
|
233
|
-
join$1(dir, "plugins"),
|
|
234
|
-
join$1(dir, "modules")
|
|
235
|
-
]);
|
|
236
|
-
const watchReloadEvents = new Set([
|
|
237
|
-
"add",
|
|
238
|
-
"addDir",
|
|
239
|
-
"unlink",
|
|
240
|
-
"unlinkDir"
|
|
241
|
-
]);
|
|
242
|
-
const scanDirsWatcher = watch$1(scanDirs, { ignoreInitial: true }).on("all", (event, path$1, stat$2) => {
|
|
243
|
-
if (watchReloadEvents.has(event)) reload();
|
|
244
|
-
});
|
|
245
|
-
const rootDirWatcher = watch(nitro$1.options.rootDir, { persistent: false }, (_event, filename) => {
|
|
246
|
-
if (filename && /^server\.[mc]?[jt]sx?$/.test(filename)) reload();
|
|
247
|
-
});
|
|
248
|
-
nitro$1.hooks.hook("close", () => {
|
|
249
|
-
scanDirsWatcher.close();
|
|
250
|
-
rootDirWatcher.close();
|
|
251
|
-
});
|
|
252
|
-
const hostIPC = { async transformHTML(html) {
|
|
253
|
-
return server.transformIndexHtml("/", html).then((r) => r.replace("<!--ssr-outlet-->", `{{{ globalThis.__nitro_vite_envs__?.["ssr"]?.fetch($REQUEST) || "" }}}`));
|
|
254
|
-
} };
|
|
255
|
-
nitroEnv$1.devServer.onMessage(async (payload) => {
|
|
256
|
-
if (payload.type === "custom" && payload.event === "nitro:vite-invoke") {
|
|
257
|
-
const res = await hostIPC[payload.data.name](payload.data.data).then((data) => ({ data })).catch((error) => ({ error }));
|
|
258
|
-
nitroEnv$1.devServer.sendMessage({
|
|
259
|
-
type: "custom",
|
|
260
|
-
event: "nitro:vite-invoke-response",
|
|
261
|
-
data: {
|
|
262
|
-
id: payload.data.id,
|
|
263
|
-
data: res
|
|
264
|
-
}
|
|
265
|
-
});
|
|
266
|
-
}
|
|
267
|
-
});
|
|
268
|
-
const nitroDevMiddleware = async (nodeReq, nodeRes, next) => {
|
|
269
|
-
if (!nodeReq.url || /^\/@(?:vite|fs|id)\//.test(nodeReq.url) || nodeReq._nitroHandled || server.middlewares.stack.map((mw) => mw.route).some((base) => base && nodeReq.url.startsWith(base))) return next();
|
|
270
|
-
nodeReq._nitroHandled = true;
|
|
271
|
-
try {
|
|
272
|
-
const req = new NodeRequest({
|
|
273
|
-
req: nodeReq,
|
|
274
|
-
res: nodeRes
|
|
275
|
-
});
|
|
276
|
-
const devAppRes = await ctx.devApp.fetch(req);
|
|
277
|
-
if (nodeRes.writableEnded || nodeRes.headersSent) return;
|
|
278
|
-
if (devAppRes.status !== 404) return await sendNodeResponse(nodeRes, devAppRes);
|
|
279
|
-
const envRes = await nitroEnv$1.dispatchFetch(req);
|
|
280
|
-
if (nodeRes.writableEnded || nodeRes.headersSent) return;
|
|
281
|
-
return await sendNodeResponse(nodeRes, envRes);
|
|
282
|
-
} catch (error) {
|
|
283
|
-
return next(error);
|
|
284
|
-
}
|
|
285
|
-
};
|
|
286
|
-
server.middlewares.use(function nitroDevMiddlewarePre(req, res, next) {
|
|
287
|
-
const fetchDest = req.headers["sec-fetch-dest"];
|
|
288
|
-
res.setHeader("vary", "sec-fetch-dest");
|
|
289
|
-
if ((!fetchDest || /^(document|iframe|frame|empty)$/.test(fetchDest)) && !req.url.match(/\.([a-z0-9]+)(?:[?#]|$)/i)?.[1] && !/^\/(?:__|@)/.test(req.url)) nitroDevMiddleware(req, res, next);
|
|
290
|
-
else next();
|
|
291
|
-
});
|
|
292
|
-
return () => {
|
|
293
|
-
server.middlewares.use(nitroDevMiddleware);
|
|
294
|
-
};
|
|
295
|
-
}
|
|
296
|
-
|
|
297
|
-
//#endregion
|
|
298
|
-
//#region src/build/vite/env.ts
|
|
299
|
-
function getEnvRunner(ctx) {
|
|
300
|
-
return ctx._envRunner ??= new NodeEnvRunner({
|
|
301
|
-
name: "nitro-vite",
|
|
302
|
-
entry: resolve(runtimeDir, "internal/vite/node-runner.mjs"),
|
|
303
|
-
data: { server: true }
|
|
304
|
-
});
|
|
305
|
-
}
|
|
306
|
-
function createNitroEnvironment(ctx) {
|
|
307
|
-
return {
|
|
308
|
-
consumer: "server",
|
|
309
|
-
build: {
|
|
310
|
-
rollupOptions: ctx.rollupConfig.config,
|
|
311
|
-
minify: ctx.nitro.options.minify,
|
|
312
|
-
emptyOutDir: false,
|
|
313
|
-
sourcemap: ctx.nitro.options.sourcemap,
|
|
314
|
-
commonjsOptions: ctx.nitro.options.commonJS
|
|
315
|
-
},
|
|
316
|
-
resolve: {
|
|
317
|
-
noExternal: ctx.nitro.options.dev ? [
|
|
318
|
-
/^nitro$/,
|
|
319
|
-
/* @__PURE__ */ new RegExp(`^(${runtimeDependencies.join("|")})$`),
|
|
320
|
-
...ctx.rollupConfig.base.noExternal
|
|
321
|
-
] : true,
|
|
322
|
-
conditions: ctx.nitro.options.exportConditions,
|
|
323
|
-
externalConditions: ctx.nitro.options.exportConditions?.filter((c) => !/browser|wasm|module/.test(c))
|
|
324
|
-
},
|
|
325
|
-
define: { "process.env.NODE_ENV": JSON.stringify(ctx.nitro.options.dev ? "development" : "production") },
|
|
326
|
-
dev: { createEnvironment: (envName, envConfig) => createFetchableDevEnvironment(envName, envConfig, getEnvRunner(ctx), resolve(runtimeDir, "internal/vite/dev-entry.mjs")) }
|
|
327
|
-
};
|
|
328
|
-
}
|
|
329
|
-
function createServiceEnvironment(ctx, name, serviceConfig) {
|
|
330
|
-
return {
|
|
331
|
-
consumer: "server",
|
|
332
|
-
build: {
|
|
333
|
-
rollupOptions: { input: { index: serviceConfig.entry } },
|
|
334
|
-
minify: ctx.nitro.options.minify,
|
|
335
|
-
sourcemap: ctx.nitro.options.sourcemap,
|
|
336
|
-
outDir: join(ctx.nitro.options.buildDir, "vite/services", name),
|
|
337
|
-
emptyOutDir: true
|
|
338
|
-
},
|
|
339
|
-
resolve: {
|
|
340
|
-
conditions: ctx.nitro.options.exportConditions,
|
|
341
|
-
externalConditions: ctx.nitro.options.exportConditions?.filter((c) => !/browser|wasm|module/.test(c))
|
|
342
|
-
},
|
|
343
|
-
dev: { createEnvironment: (envName, envConfig) => createFetchableDevEnvironment(envName, envConfig, getEnvRunner(ctx), tryResolve(serviceConfig.entry)) }
|
|
344
|
-
};
|
|
345
|
-
}
|
|
346
|
-
function createServiceEnvironments(ctx) {
|
|
347
|
-
return Object.fromEntries(Object.entries(ctx.services).map(([name, config]) => [name, createServiceEnvironment(ctx, name, config)]));
|
|
348
|
-
}
|
|
349
|
-
function tryResolve(id) {
|
|
350
|
-
if (/^[~#/\0]/.test(id) || isAbsolute$1(id)) return id;
|
|
351
|
-
return resolveModulePath(id, {
|
|
352
|
-
suffixes: ["", "/index"],
|
|
353
|
-
extensions: [
|
|
354
|
-
"",
|
|
355
|
-
".ts",
|
|
356
|
-
".mjs",
|
|
357
|
-
".cjs",
|
|
358
|
-
".js",
|
|
359
|
-
".mts",
|
|
360
|
-
".cts"
|
|
361
|
-
],
|
|
362
|
-
try: true
|
|
363
|
-
}) || id;
|
|
364
|
-
}
|
|
365
|
-
|
|
366
|
-
//#endregion
|
|
367
|
-
//#region src/build/vite/preview.ts
|
|
368
|
-
function nitroPreviewPlugin(ctx) {
|
|
369
|
-
return {
|
|
370
|
-
name: "nitro:preview",
|
|
371
|
-
apply: (_config, configEnv) => !!configEnv.isPreview,
|
|
372
|
-
config(config) {
|
|
373
|
-
return { preview: { port: config.preview?.port || 3e3 } };
|
|
374
|
-
},
|
|
375
|
-
async configurePreviewServer(server) {
|
|
376
|
-
const { outputDir, buildInfo } = await getBuildInfo(server.config.root);
|
|
377
|
-
if (!buildInfo) throw this.error("Cannot load nitro build info. Make sure to build first.");
|
|
378
|
-
const info = [
|
|
379
|
-
["Build Directory:", prettyPath(outputDir)],
|
|
380
|
-
["Date:", buildInfo.date && new Date(buildInfo.date).toLocaleString()],
|
|
381
|
-
["Nitro Version:", buildInfo.versions.nitro],
|
|
382
|
-
["Nitro Preset:", buildInfo.preset],
|
|
383
|
-
buildInfo.framework?.name !== "nitro" && ["Framework:", buildInfo.framework?.name + (buildInfo.framework?.version ? ` (v${buildInfo.framework.version})` : "")]
|
|
384
|
-
].filter((i) => i && i[1]);
|
|
385
|
-
consola$1.box({
|
|
386
|
-
title: " [Build Info] ",
|
|
387
|
-
message: info.map((i) => `- ${i[0]} ${i[1]}`).join("\n")
|
|
388
|
-
});
|
|
389
|
-
if (!buildInfo.commands?.preview) {
|
|
390
|
-
consola$1.warn("No nitro build preview command found for this preset.");
|
|
391
|
-
return;
|
|
392
|
-
}
|
|
393
|
-
const dotEnvEntries = await loadPreviewDotEnv(server.config.root);
|
|
394
|
-
if (dotEnvEntries.length > 0) consola$1.box({
|
|
395
|
-
title: " [Environment Variables] ",
|
|
396
|
-
message: [
|
|
397
|
-
"Loaded variables from .env files (preview mode only).",
|
|
398
|
-
"Set platform environment variables for production:",
|
|
399
|
-
...dotEnvEntries.map(([key, val]) => ` - ${key}`)
|
|
400
|
-
].join("\n")
|
|
401
|
-
});
|
|
402
|
-
const [command, ...args] = buildInfo.commands.preview.split(" ");
|
|
403
|
-
consola$1.info(`Spawning preview server...`);
|
|
404
|
-
consola$1.info(buildInfo.commands?.preview);
|
|
405
|
-
console.log("");
|
|
406
|
-
const { getRandomPort, waitForPort } = await import("get-port-please");
|
|
407
|
-
const randomPort = await getRandomPort();
|
|
408
|
-
const child = spawn(command, args, {
|
|
409
|
-
stdio: "inherit",
|
|
410
|
-
cwd: outputDir,
|
|
411
|
-
env: {
|
|
412
|
-
...process.env,
|
|
413
|
-
...Object.fromEntries(dotEnvEntries),
|
|
414
|
-
PORT: String(randomPort)
|
|
415
|
-
}
|
|
416
|
-
});
|
|
417
|
-
const killChild = (signal) => {
|
|
418
|
-
if (child && !child.killed) child.kill(signal);
|
|
419
|
-
};
|
|
420
|
-
for (const sig of ["SIGINT", "SIGHUP"]) process.once(sig, () => {
|
|
421
|
-
consola$1.info(`Stopping preview server...`);
|
|
422
|
-
killChild(sig);
|
|
423
|
-
process.exit();
|
|
424
|
-
});
|
|
425
|
-
server.httpServer.once("close", () => {
|
|
426
|
-
killChild("SIGTERM");
|
|
427
|
-
});
|
|
428
|
-
child.once("exit", (code) => {
|
|
429
|
-
if (code && code !== 0) consola$1.error(`[nitro] Preview server exited with code ${code}`);
|
|
430
|
-
});
|
|
431
|
-
const { createProxyServer } = await import("../_libs/httpxy.mjs").then((n) => n.r);
|
|
432
|
-
const proxy = createProxyServer({ target: `http://localhost:${randomPort}` });
|
|
433
|
-
server.middlewares.use((req, res, next) => {
|
|
434
|
-
if (child && !child.killed) proxy.web(req, res).catch(next);
|
|
435
|
-
else res.end(`Nitro preview server is not running.`);
|
|
436
|
-
});
|
|
437
|
-
await waitForPort(randomPort, {
|
|
438
|
-
retries: 20,
|
|
439
|
-
delay: 500
|
|
440
|
-
});
|
|
441
|
-
}
|
|
442
|
-
};
|
|
443
|
-
}
|
|
444
|
-
async function loadPreviewDotEnv(root) {
|
|
445
|
-
const { loadDotenv } = await import("../_libs/c12.mjs").then((n) => n.n);
|
|
446
|
-
const env = await loadDotenv({
|
|
447
|
-
cwd: root,
|
|
448
|
-
fileName: [
|
|
449
|
-
".env.preview",
|
|
450
|
-
".env.production",
|
|
451
|
-
".env"
|
|
452
|
-
]
|
|
453
|
-
});
|
|
454
|
-
return Object.entries(env).filter(([_key, val]) => val);
|
|
455
|
-
}
|
|
456
|
-
|
|
457
|
-
//#endregion
|
|
458
|
-
//#region src/build/vite/plugin.ts
|
|
459
|
-
const DEFAULT_EXTENSIONS = [
|
|
460
|
-
".ts",
|
|
461
|
-
".js",
|
|
462
|
-
".mts",
|
|
463
|
-
".mjs",
|
|
464
|
-
".tsx",
|
|
465
|
-
".jsx"
|
|
466
|
-
];
|
|
467
|
-
const debug = process.env.NITRO_DEBUG ? (...args) => console.log("[nitro]", ...args) : () => {};
|
|
468
|
-
function nitro(pluginConfig = {}) {
|
|
469
|
-
const ctx = createContext(pluginConfig);
|
|
470
|
-
return [
|
|
471
|
-
nitroInit(ctx),
|
|
472
|
-
nitroEnv(ctx),
|
|
473
|
-
nitroMain(ctx),
|
|
474
|
-
nitroPrepare(ctx),
|
|
475
|
-
nitroService(ctx),
|
|
476
|
-
nitroPreviewPlugin(ctx),
|
|
477
|
-
pluginConfig.experimental?.vite?.assetsImport !== false && assetsPlugin({ experimental: { clientBuildFallback: false } })
|
|
478
|
-
].filter(Boolean);
|
|
479
|
-
}
|
|
480
|
-
function nitroInit(ctx) {
|
|
481
|
-
return {
|
|
482
|
-
name: "nitro:init",
|
|
483
|
-
sharedDuringBuild: true,
|
|
484
|
-
apply: (_config, configEnv) => !configEnv.isPreview,
|
|
485
|
-
async config(config, configEnv) {
|
|
486
|
-
ctx._isRolldown = !!this.meta.rolldownVersion;
|
|
487
|
-
if (!ctx._initialized) {
|
|
488
|
-
debug("[init] Initializing nitro");
|
|
489
|
-
ctx._initialized = true;
|
|
490
|
-
await setupNitroContext(ctx, configEnv, config);
|
|
491
|
-
}
|
|
492
|
-
},
|
|
493
|
-
applyToEnvironment(env) {
|
|
494
|
-
if (env.name === "nitro" && ctx.nitro?.options.dev) {
|
|
495
|
-
debug("[init] Adding rollup plugins for dev");
|
|
496
|
-
return [...ctx.rollupConfig?.config.plugins || []];
|
|
497
|
-
}
|
|
498
|
-
}
|
|
499
|
-
};
|
|
500
|
-
}
|
|
501
|
-
function nitroEnv(ctx) {
|
|
502
|
-
return {
|
|
503
|
-
name: "nitro:env",
|
|
504
|
-
sharedDuringBuild: true,
|
|
505
|
-
apply: (_config, configEnv) => !configEnv.isPreview,
|
|
506
|
-
async config(userConfig, _configEnv) {
|
|
507
|
-
debug("[env] Extending config (environments)");
|
|
508
|
-
const environments = {
|
|
509
|
-
...createServiceEnvironments(ctx),
|
|
510
|
-
nitro: createNitroEnvironment(ctx)
|
|
511
|
-
};
|
|
512
|
-
environments.client = {
|
|
513
|
-
consumer: userConfig.environments?.client?.consumer ?? "client",
|
|
514
|
-
build: { rollupOptions: { input: userConfig.environments?.client?.build?.rollupOptions?.input ?? useNitro(ctx).options.renderer?.template } }
|
|
515
|
-
};
|
|
516
|
-
debug("[env] Environments:", Object.keys(environments).join(", "));
|
|
517
|
-
return { environments };
|
|
518
|
-
},
|
|
519
|
-
configEnvironment(name, config) {
|
|
520
|
-
if (config.consumer === "client") {
|
|
521
|
-
debug("[env] Configuring client environment", name === "client" ? "" : ` (${name})`);
|
|
522
|
-
config.build.emptyOutDir = false;
|
|
523
|
-
config.build.outDir = useNitro(ctx).options.output.publicDir;
|
|
524
|
-
}
|
|
525
|
-
}
|
|
526
|
-
};
|
|
527
|
-
}
|
|
528
|
-
function nitroMain(ctx) {
|
|
529
|
-
return {
|
|
530
|
-
name: "nitro:main",
|
|
531
|
-
sharedDuringBuild: true,
|
|
532
|
-
apply: (_config, configEnv) => !configEnv.isPreview,
|
|
533
|
-
async config(userConfig, _configEnv) {
|
|
534
|
-
debug("[main] Extending config (appType, resolve, server)");
|
|
535
|
-
if (!ctx.rollupConfig) throw new Error("Nitro rollup config is not initialized yet.");
|
|
536
|
-
return {
|
|
537
|
-
appType: userConfig.appType || "custom",
|
|
538
|
-
resolve: { alias: ctx.rollupConfig.base.aliases },
|
|
539
|
-
builder: { sharedConfigBuild: true },
|
|
540
|
-
server: {
|
|
541
|
-
port: Number.parseInt(process.env.PORT || "") || userConfig.server?.port || useNitro(ctx).options.devServer?.port || 3e3,
|
|
542
|
-
cors: false
|
|
543
|
-
}
|
|
544
|
-
};
|
|
545
|
-
},
|
|
546
|
-
buildApp: {
|
|
547
|
-
order: "post",
|
|
548
|
-
handler(builder) {
|
|
549
|
-
debug("[main] Building environments");
|
|
550
|
-
return buildEnvironments(ctx, builder);
|
|
551
|
-
}
|
|
552
|
-
},
|
|
553
|
-
generateBundle: { handler(_options, bundle) {
|
|
554
|
-
const environment = this.environment;
|
|
555
|
-
debug("[main] Generating manifest and entry points for environment:", environment.name);
|
|
556
|
-
const isRegisteredService = Object.keys(ctx.services).includes(environment.name);
|
|
557
|
-
let entryFile;
|
|
558
|
-
for (const [_name, file] of Object.entries(bundle)) if (file.type === "chunk" && isRegisteredService && file.isEntry) if (entryFile === void 0) entryFile = file.fileName;
|
|
559
|
-
else this.warn(`Multiple entry points found for service "${environment.name}"`);
|
|
560
|
-
if (isRegisteredService) {
|
|
561
|
-
if (entryFile === void 0) this.error(`No entry point found for service "${this.environment.name}".`);
|
|
562
|
-
ctx._entryPoints[this.environment.name] = entryFile;
|
|
563
|
-
}
|
|
564
|
-
} },
|
|
565
|
-
configureServer: (server) => {
|
|
566
|
-
debug("[main] Configuring dev server");
|
|
567
|
-
return configureViteDevServer(ctx, server);
|
|
568
|
-
},
|
|
569
|
-
async hotUpdate({ server, modules, timestamp }) {
|
|
570
|
-
const env = this.environment;
|
|
571
|
-
if (ctx.pluginConfig.experimental?.vite.serverReload === false || env.config.consumer === "client") return;
|
|
572
|
-
const clientEnvs = Object.values(server.environments).filter((env$1) => env$1.config.consumer === "client");
|
|
573
|
-
let hasServerOnlyModule = false;
|
|
574
|
-
const invalidated = /* @__PURE__ */ new Set();
|
|
575
|
-
for (const mod of modules) if (mod.id && !clientEnvs.some((env$1) => env$1.moduleGraph.getModuleById(mod.id))) {
|
|
576
|
-
hasServerOnlyModule = true;
|
|
577
|
-
env.moduleGraph.invalidateModule(mod, invalidated, timestamp, false);
|
|
578
|
-
}
|
|
579
|
-
if (hasServerOnlyModule) {
|
|
580
|
-
env.hot.send({ type: "full-reload" });
|
|
581
|
-
server.ws.send({ type: "full-reload" });
|
|
582
|
-
return [];
|
|
583
|
-
}
|
|
584
|
-
}
|
|
585
|
-
};
|
|
586
|
-
}
|
|
587
|
-
function nitroPrepare(ctx) {
|
|
588
|
-
return {
|
|
589
|
-
name: "nitro:prepare",
|
|
590
|
-
sharedDuringBuild: true,
|
|
591
|
-
applyToEnvironment: (env) => env.name === "nitro",
|
|
592
|
-
buildApp: {
|
|
593
|
-
order: "pre",
|
|
594
|
-
async handler() {
|
|
595
|
-
debug("[prepare] Preparing output directory");
|
|
596
|
-
const nitro$1 = ctx.nitro;
|
|
597
|
-
await prepare(nitro$1);
|
|
598
|
-
}
|
|
599
|
-
}
|
|
600
|
-
};
|
|
601
|
-
}
|
|
602
|
-
function nitroService(ctx) {
|
|
603
|
-
return {
|
|
604
|
-
name: "nitro:service",
|
|
605
|
-
enforce: "pre",
|
|
606
|
-
sharedDuringBuild: true,
|
|
607
|
-
applyToEnvironment: (env) => env.name === "nitro",
|
|
608
|
-
resolveId: {
|
|
609
|
-
filter: { id: /^#nitro-vite-setup$/ },
|
|
610
|
-
async handler(id) {
|
|
611
|
-
if (id === "#nitro-vite-setup") return {
|
|
612
|
-
id,
|
|
613
|
-
moduleSideEffects: true
|
|
614
|
-
};
|
|
615
|
-
}
|
|
616
|
-
},
|
|
617
|
-
load: {
|
|
618
|
-
filter: { id: /^#nitro-vite-setup$/ },
|
|
619
|
-
async handler(id) {
|
|
620
|
-
if (id === "#nitro-vite-setup") return prodSetup(ctx);
|
|
621
|
-
}
|
|
622
|
-
}
|
|
623
|
-
};
|
|
624
|
-
}
|
|
625
|
-
function createContext(pluginConfig) {
|
|
626
|
-
return {
|
|
627
|
-
pluginConfig,
|
|
628
|
-
services: { ...pluginConfig.experimental?.vite?.services },
|
|
629
|
-
_entryPoints: {}
|
|
630
|
-
};
|
|
631
|
-
}
|
|
632
|
-
function useNitro(ctx) {
|
|
633
|
-
if (!ctx.nitro) throw new Error("Nitro instance is not initialized yet.");
|
|
634
|
-
return ctx.nitro;
|
|
635
|
-
}
|
|
636
|
-
async function setupNitroContext(ctx, configEnv, userConfig) {
|
|
637
|
-
const nitroConfig = {
|
|
638
|
-
dev: configEnv.command === "serve",
|
|
639
|
-
builder: "vite",
|
|
640
|
-
rootDir: userConfig.root,
|
|
641
|
-
...defu(ctx.pluginConfig, ctx.pluginConfig.config, userConfig.nitro)
|
|
642
|
-
};
|
|
643
|
-
nitroConfig.modules ??= [];
|
|
644
|
-
for (const plugin of flattenPlugins(userConfig.plugins || [])) if (plugin.nitro) nitroConfig.modules.push(plugin.nitro);
|
|
645
|
-
ctx.nitro = ctx.pluginConfig._nitro || await createNitro(nitroConfig);
|
|
646
|
-
if (!ctx.services?.ssr) if (userConfig.environments?.ssr === void 0) {
|
|
647
|
-
const ssrEntry = resolveModulePath("./entry-server", {
|
|
648
|
-
from: [
|
|
649
|
-
"app",
|
|
650
|
-
"src",
|
|
651
|
-
""
|
|
652
|
-
].flatMap((d) => [ctx.nitro.options.rootDir, ...ctx.nitro.options.scanDirs].map((s) => join$1(s, d) + "/")),
|
|
653
|
-
extensions: DEFAULT_EXTENSIONS,
|
|
654
|
-
try: true
|
|
655
|
-
});
|
|
656
|
-
if (ssrEntry) {
|
|
657
|
-
ctx.services.ssr = { entry: ssrEntry };
|
|
658
|
-
ctx.nitro.logger.info(`Using \`${prettyPath(ssrEntry)}\` as vite ssr entry.`);
|
|
659
|
-
}
|
|
660
|
-
} else {
|
|
661
|
-
let ssrEntry = getEntry(userConfig.environments.ssr.build?.rollupOptions?.input);
|
|
662
|
-
if (typeof ssrEntry === "string") {
|
|
663
|
-
ssrEntry = resolveModulePath(ssrEntry, {
|
|
664
|
-
from: [ctx.nitro.options.rootDir, ...ctx.nitro.options.scanDirs],
|
|
665
|
-
extensions: DEFAULT_EXTENSIONS,
|
|
666
|
-
suffixes: ["", "/index"],
|
|
667
|
-
try: true
|
|
668
|
-
}) || ssrEntry;
|
|
669
|
-
ctx.services.ssr = { entry: ssrEntry };
|
|
670
|
-
}
|
|
671
|
-
}
|
|
672
|
-
if (ctx.nitro.options.serverEntry && ctx.nitro.options.serverEntry.handler === ctx.services.ssr?.entry) {
|
|
673
|
-
ctx.nitro.logger.warn(`Nitro server entry and Vite SSR both set to ${prettyPath(ctx.services.ssr.entry)}. Use a separate SSR entry (e.g. \`src/server.ts\`).`);
|
|
674
|
-
ctx.nitro.options.serverEntry = false;
|
|
675
|
-
}
|
|
676
|
-
if (!ctx.nitro.options.renderer?.handler && !ctx.nitro.options.renderer?.template && ctx.services.ssr?.entry) {
|
|
677
|
-
ctx.nitro.options.renderer ??= {};
|
|
678
|
-
ctx.nitro.options.renderer.handler = resolve$1(runtimeDir, "internal/vite/ssr-renderer");
|
|
679
|
-
ctx.nitro.routing.sync();
|
|
680
|
-
}
|
|
681
|
-
const publicDistDir = ctx._publicDistDir = userConfig.build?.outDir || resolve$1(ctx.nitro.options.buildDir, "vite/public");
|
|
682
|
-
ctx.nitro.options.publicAssets.push({
|
|
683
|
-
dir: publicDistDir,
|
|
684
|
-
maxAge: 0,
|
|
685
|
-
baseURL: "/",
|
|
686
|
-
fallthrough: true
|
|
687
|
-
});
|
|
688
|
-
if (!ctx.nitro.options.dev) ctx.nitro.options.unenv.push({
|
|
689
|
-
meta: { name: "nitro-vite" },
|
|
690
|
-
polyfill: ["#nitro-vite-setup"]
|
|
691
|
-
});
|
|
692
|
-
await ctx.nitro.hooks.callHook("build:before", ctx.nitro);
|
|
693
|
-
ctx.rollupConfig = await getViteRollupConfig(ctx);
|
|
694
|
-
await ctx.nitro.hooks.callHook("rollup:before", ctx.nitro, ctx.rollupConfig.config);
|
|
695
|
-
if (ctx.nitro.options.dev) getEnvRunner(ctx);
|
|
696
|
-
ctx.nitro.fetch = (req) => getEnvRunner(ctx).fetch(req);
|
|
697
|
-
if (ctx.nitro.options.dev && !ctx.devApp) ctx.devApp = new NitroDevApp(ctx.nitro);
|
|
698
|
-
ctx.nitro.hooks.hook("close", async () => {
|
|
699
|
-
if (ctx._envRunner) await ctx._envRunner.close();
|
|
700
|
-
});
|
|
701
|
-
}
|
|
702
|
-
function getEntry(input) {
|
|
703
|
-
if (typeof input === "string") return input;
|
|
704
|
-
else if (Array.isArray(input) && input.length > 0) return input[0];
|
|
705
|
-
else if (input && "index" in input) return input.index;
|
|
706
|
-
}
|
|
707
|
-
function flattenPlugins(plugins) {
|
|
708
|
-
return plugins.flatMap((plugin) => Array.isArray(plugin) ? flattenPlugins(plugin) : [plugin]).filter((p) => p && !(p instanceof Promise));
|
|
709
|
-
}
|
|
710
|
-
|
|
711
|
-
//#endregion
|
|
712
|
-
export { nitro as t };
|