UNPKG

one

Version:

One is a new React Framework that makes Vite serve both native and web.

152 lines 4.87 kB
var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod)); var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var dev_exports = {}; __export(dev_exports, { dev: () => dev }); module.exports = __toCommonJS(dev_exports); var path = __toESM(require("node:path"), 1); var import_picocolors = __toESM(require("picocolors"), 1); var import_setServerGlobals = require("../server/setServerGlobals.cjs"); var import_virtualEntryConstants = require("../vite/plugins/virtualEntryConstants.cjs"); var import_checkNodeVersion = require("./checkNodeVersion.cjs"); var import_label_process = require("./label-process.cjs"); const DAEMON_PORT = 8081; async function dev(args) { (0, import_label_process.labelProcess)("dev"); (0, import_checkNodeVersion.checkNodeVersion)(); (0, import_setServerGlobals.setServerGlobals)(); const root = process.cwd(); let daemonServerId; let useDaemon = false; const forcePort = process.env.ONE_FORCE_PORT ? +process.env.ONE_FORCE_PORT : void 0; const envPort = process.env.ONE_PORT ? +process.env.ONE_PORT : void 0; let effectivePort = forcePort ?? (args.port ? +args.port : void 0) ?? envPort; const { isDaemonRunning, registerWithDaemon, unregisterFromDaemon, writeServerFile, removeServerFile } = await import("../daemon/ipc"); const { getBundleIdFromConfig, getAvailablePort } = await import("../daemon/utils"); const daemonRunning = await isDaemonRunning(); const bundleId = getBundleIdFromConfig(root) || path.basename(root); if (daemonRunning) { if (!effectivePort || effectivePort === DAEMON_PORT) { effectivePort = await getAvailablePort(8082, DAEMON_PORT); console.log(import_picocolors.default.cyan(`[daemon] Detected running daemon on :${DAEMON_PORT}`)); console.log(import_picocolors.default.cyan(`[daemon] Using port :${effectivePort} for this server`)); useDaemon = true; } } const { dev: dev2 } = await import("vxrn/dev"); const { start, stop } = await dev2({ mode: args.mode, clean: args.clean, root, debugBundle: args.debugBundle, debug: args.debug, extraConfig: args.extraConfig, server: { host: args.host, port: effectivePort }, entries: { native: import_virtualEntryConstants.virtualEntryIdNative } }); const { closePromise } = await start(); if (useDaemon && bundleId) { try { daemonServerId = await registerWithDaemon({ port: effectivePort, bundleId, root }); console.log(import_picocolors.default.green(`[daemon] Registered as ${bundleId} (${daemonServerId}) \u2192 accessible via :${DAEMON_PORT}`)); writeServerFile({ port: effectivePort, bundleId, root, pid: process.pid }); } catch (err) { console.log(import_picocolors.default.yellow(`[daemon] Failed to register: ${err}`)); } } const cleanup = async () => { if (daemonServerId) { try { await unregisterFromDaemon(daemonServerId); removeServerFile(root); } catch {} } await stop(); }; process.on("beforeExit", () => { cleanup(); }); process.on("SIGINT", async () => { try { await cleanup(); } finally { process.exit(2); } }); process.on("SIGTERM", async () => { try { await cleanup(); } finally { process.exit(0); } }); process.on("uncaughtException", err => { console.error(err?.message || err); }); process.on("unhandledRejection", err => { console.error(err); }); await closePromise; }