chore: 引入统一日志模块,统一 cli 输出

This commit is contained in:
rbetree
2026-01-16 17:29:05 +08:00
parent f2f59108a0
commit 87d1f0244c
26 changed files with 903 additions and 150 deletions

42
scripts/build.js Normal file
View File

@@ -0,0 +1,42 @@
const path = require('node:path');
const { spawnSync } = require('node:child_process');
const { createLogger, isVerbose, startTimer } = require('../src/generator/utils/logger');
const log = createLogger('build');
function runNode(scriptPath) {
const result = spawnSync(process.execPath, [scriptPath], { stdio: 'inherit' });
return result && Number.isFinite(result.status) ? result.status : 1;
}
async function main() {
const elapsedMs = startTimer();
log.info('开始', { version: process.env.npm_package_version });
const repoRoot = path.resolve(__dirname, '..');
const cleanExit = runNode(path.join(repoRoot, 'scripts', 'clean.js'));
if (cleanExit !== 0) {
log.error('clean 失败', { exit: cleanExit });
process.exitCode = cleanExit;
return;
}
const generatorExit = runNode(path.join(repoRoot, 'src', 'generator.js'));
if (generatorExit !== 0) {
log.error('generate 失败', { exit: generatorExit });
process.exitCode = generatorExit;
return;
}
log.ok('完成', { ms: elapsedMs(), dist: 'dist/' });
}
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;
});
}