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 ", "Use specified root directory").option("-c, --config ", "Use specified config file").option("-m, --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 ", "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)) } }; }