Files
menav/scripts/dev-offline.js

90 lines
2.6 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
const path = require('node:path');
const { spawnSync } = require('node:child_process');
const { createLogger, isVerbose, startTimer } = require('../src/generator/utils/logger');
const { startServer } = require('./serve-dist');
const log = createLogger('dev:offline');
let serverRef = null;
let shuttingDown = false;
function runNode(scriptPath) {
const result = spawnSync(process.execPath, [scriptPath], { stdio: 'inherit' });
return result && Number.isFinite(result.status) ? result.status : 1;
}
function closeServer(server, exitCode) {
if (!server) {
process.exit(exitCode);
return;
}
try {
if (typeof server.closeIdleConnections === 'function') server.closeIdleConnections();
if (typeof server.closeAllConnections === 'function') server.closeAllConnections();
} catch {
// ignore
}
const forceTimer = setTimeout(() => process.exit(exitCode), 2000);
if (typeof forceTimer.unref === 'function') forceTimer.unref();
server.close(() => {
clearTimeout(forceTimer);
process.exit(exitCode);
});
}
async function main() {
const elapsedMs = startTimer();
log.info('开始', { version: process.env.npm_package_version });
const repoRoot = path.resolve(__dirname, '..');
const generatorPath = path.join(repoRoot, 'src', 'generator.js');
const exitCode = runNode(generatorPath);
if (exitCode !== 0) {
log.error('生成失败', { exit: exitCode });
process.exitCode = exitCode;
return;
}
const portRaw = process.env.PORT || process.env.MENAV_PORT || '5173';
const port = Number.parseInt(portRaw, 10) || 5173;
const { server, port: actualPort } = await startServer({
rootDir: path.join(repoRoot, 'dist'),
host: process.env.HOST || '0.0.0.0',
port,
});
serverRef = server;
log.ok('就绪', { ms: elapsedMs(), url: `http://localhost:${actualPort}` });
const shutdown = (signal) => {
if (shuttingDown) return;
shuttingDown = true;
// 让 Ctrl-C 的 ^C 与日志分行显示
process.stdout.write('\n');
log.info('正在关闭...', { signal });
// 再次 SIGINT直接强制退出
process.once('SIGINT', () => process.exit(130));
const exit = signal === 'SIGINT' ? 130 : 0;
closeServer(serverRef, exit);
};
process.once('SIGINT', () => shutdown('SIGINT'));
process.once('SIGTERM', () => shutdown('SIGTERM'));
}
if (require.main === module) {
main().catch((error) => {
log.error('启动失败', { message: error && error.message ? error.message : String(error) });
if (isVerbose() && error && error.stack) console.error(error.stack);
process.exitCode = 1;
});
}