2024-08-19 13:15:27 +00:00
|
|
|
import type { SpawnSyncReturns } from 'child_process';
|
2024-08-14 10:42:23 +00:00
|
|
|
import { Command } from 'commander';
|
|
|
|
import fs from 'fs-extra';
|
|
|
|
import { logger } from '../lib/logger';
|
|
|
|
import { generateDocs } from './docs';
|
|
|
|
import { exec } from './utils/exec';
|
|
|
|
|
|
|
|
process.on('unhandledRejection', (err) => {
|
|
|
|
// Will print "unhandledRejection err is not defined"
|
|
|
|
logger.error({ err }, 'unhandledRejection');
|
|
|
|
process.exit(-1);
|
|
|
|
});
|
|
|
|
|
2024-08-14 17:44:52 +00:00
|
|
|
const program = new Command('pnpm mkdocs').description('Run mkdocs');
|
|
|
|
|
|
|
|
program
|
|
|
|
.command('build', { isDefault: true })
|
2024-08-14 10:42:23 +00:00
|
|
|
.description('Build mkdocs')
|
2024-08-14 17:44:52 +00:00
|
|
|
.option('--no-build', 'do not build docs from source')
|
|
|
|
.option('--no-strict', 'do not build in strict mode')
|
|
|
|
.action(async (opts) => {
|
|
|
|
await prepareDocs(opts);
|
|
|
|
logger.info('* running mkdocs build');
|
|
|
|
const args = ['run', 'mkdocs', 'build'];
|
|
|
|
if (opts.strict) {
|
|
|
|
args.push('--strict');
|
|
|
|
}
|
|
|
|
const res = exec('pdm', args, {
|
|
|
|
cwd: 'tools/mkdocs',
|
|
|
|
stdio: 'inherit',
|
|
|
|
});
|
|
|
|
checkResult(res);
|
|
|
|
});
|
|
|
|
|
|
|
|
program
|
|
|
|
.command('serve')
|
|
|
|
.description('serve mkdocs')
|
|
|
|
.option('--no-build', 'do not build docs from source')
|
|
|
|
.option('--no-strict', 'do not build in strict mode')
|
|
|
|
.action(async (opts) => {
|
|
|
|
await prepareDocs(opts);
|
|
|
|
logger.info('serving docs');
|
|
|
|
logger.info('* running mkdocs serve');
|
|
|
|
const args = ['run', 'mkdocs', 'serve'];
|
|
|
|
if (opts.strict) {
|
|
|
|
args.push('--strict');
|
|
|
|
}
|
|
|
|
const res = exec('pdm', args, {
|
|
|
|
cwd: 'tools/mkdocs',
|
|
|
|
stdio: 'inherit',
|
|
|
|
});
|
|
|
|
checkResult(res);
|
|
|
|
});
|
2024-08-14 10:42:23 +00:00
|
|
|
|
2024-08-14 17:44:52 +00:00
|
|
|
async function prepareDocs(opts: any): Promise<void> {
|
|
|
|
logger.info('Building docs');
|
2024-08-14 10:42:23 +00:00
|
|
|
if (opts.build) {
|
|
|
|
logger.info('* generate docs');
|
|
|
|
await generateDocs('tools/mkdocs', false);
|
|
|
|
} else {
|
|
|
|
logger.info('* using prebuild docs from build step');
|
|
|
|
await fs.copy('tmp/docs', 'tools/mkdocs/docs');
|
|
|
|
}
|
2024-08-14 17:44:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function checkResult(res: SpawnSyncReturns<string>): void {
|
2024-08-14 10:42:23 +00:00
|
|
|
if (res.signal) {
|
|
|
|
logger.error(`Signal received: ${res.signal}`);
|
|
|
|
process.exit(-1);
|
|
|
|
} else if (res.status && res.status !== 0) {
|
|
|
|
logger.error(`Error occured:\n${res.stderr || res.stdout}`);
|
|
|
|
process.exit(res.status);
|
|
|
|
} else {
|
|
|
|
logger.debug(`Build completed:\n${res.stdout || res.stderr}`);
|
|
|
|
}
|
2024-08-14 17:44:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void program.parseAsync();
|