wrangler-action/node_modules/vite-node/dist/cli.mjs
2023-08-07 15:11:15 -05:00

103 lines
3.9 KiB
JavaScript

import cac from 'cac';
import c from 'picocolors';
import { createServer } from 'vite';
import { ViteNodeServer } from './server.mjs';
import { ViteNodeRunner } from './client.mjs';
import { toArray } from './utils.mjs';
import { installSourcemapsSupport } from './source-map.mjs';
import { v as viteNodeHmrPlugin, c as createHotContext, h as handleMessage } from './chunk-hmr.mjs';
import 'node:perf_hooks';
import 'node:fs';
import 'pathe';
import 'debug';
import 'mlly';
import 'node:url';
import 'node:module';
import 'node:path';
import 'node:vm';
import 'node:events';
var version = "0.33.0";
const cli = cac("vite-node");
cli.version(version).option("-r, --root <path>", "Use specified root directory").option("-c, --config <path>", "Use specified config file").option("-m, --mode <mode>", "Set env mode").option("-w, --watch", 'Restart on file changes, similar to "nodemon"').option("--script", "Use vite-node as a script runner").option("--options <options>", "Use specified Vite server options").help();
cli.command("[...files]").allowUnknownOptions().action(run);
cli.parse();
async function run(files, options = {}) {
var _a;
if (options.script) {
files = [files[0]];
options = {};
process.argv = [process.argv[0], files[0], ...process.argv.slice(2).filter((arg) => arg !== "--script" && arg !== files[0])];
} else {
process.argv = [...process.argv.slice(0, 2), ...options["--"] || []];
}
if (!files.length) {
console.error(c.red("No files specified."));
cli.outputHelp();
process.exit(1);
}
const serverOptions = options.options ? parseServerOptions(options.options) : {};
const server = await createServer({
logLevel: "error",
configFile: options.config,
root: options.root,
mode: options.mode,
plugins: [
options.watch && viteNodeHmrPlugin()
]
});
await server.pluginContainer.buildStart({});
const node = new ViteNodeServer(server, serverOptions);
installSourcemapsSupport({
getSourceMap: (source) => node.getSourceMap(source)
});
const runner = new ViteNodeRunner({
root: server.config.root,
base: server.config.base,
fetchModule(id) {
return node.fetchModule(id);
},
resolveId(id, importer) {
return node.resolveId(id, importer);
},
createHotContext(runner2, url) {
return createHotContext(runner2, server.emitter, files, url);
}
});
await runner.executeId("/@vite/env");
for (const file of files)
await runner.executeFile(file);
if (!options.watch)
await server.close();
(_a = server.emitter) == null ? void 0 : _a.on("message", (payload) => {
handleMessage(runner, server.emitter, files, payload);
});
if (options.watch) {
process.on("uncaughtException", (err) => {
console.error(c.red("[vite-node] Failed to execute file: \n"), err);
});
}
}
function parseServerOptions(serverOptions) {
var _a, _b, _c, _d, _e, _f, _g;
const inlineOptions = ((_a = serverOptions.deps) == null ? void 0 : _a.inline) === true ? true : toArray((_b = serverOptions.deps) == null ? void 0 : _b.inline);
return {
...serverOptions,
deps: {
...serverOptions.deps,
inline: inlineOptions !== true ? inlineOptions.map((dep) => {
return dep.startsWith("/") && dep.endsWith("/") ? new RegExp(dep) : dep;
}) : true,
external: toArray((_c = serverOptions.deps) == null ? void 0 : _c.external).map((dep) => {
return dep.startsWith("/") && dep.endsWith("/") ? new RegExp(dep) : dep;
}),
moduleDirectories: ((_d = serverOptions.deps) == null ? void 0 : _d.moduleDirectories) ? toArray((_e = serverOptions.deps) == null ? void 0 : _e.moduleDirectories) : void 0
},
transformMode: {
...serverOptions.transformMode,
ssr: toArray((_f = serverOptions.transformMode) == null ? void 0 : _f.ssr).map((dep) => new RegExp(dep)),
web: toArray((_g = serverOptions.transformMode) == null ? void 0 : _g.web).map((dep) => new RegExp(dep))
}
};
}