CLI: streamline startup paths and env parsing

Add shared parseBooleanValue()/isTruthyEnvValue() and apply across CLI, gateway, memory, and live-test flags for consistent env handling.
Introduce route-first fast paths, lazy subcommand registration, and deferred plugin loading to reduce CLI startup overhead.
Centralize config validation via ensureConfigReady() and add config caching/deferred shell env fallback for fewer IO passes.
Harden logger initialization/imports and add focused tests for argv, boolean parsing, frontmatter, and CLI subcommands.
This commit is contained in:
Gustavo Madeira Santana
2026-01-18 15:56:24 -05:00
committed by Peter Steinberger
parent 97531f174f
commit acb523de86
58 changed files with 1274 additions and 500 deletions

View File

@@ -150,7 +150,13 @@ export function enableConsoleCapture(): void {
if (loggingState.consolePatched) return;
loggingState.consolePatched = true;
const logger = getLogger();
let logger: ReturnType<typeof getLogger> | null = null;
const getLoggerLazy = () => {
if (!logger) {
logger = getLogger();
}
return logger;
};
const original = {
log: console.log,
@@ -182,19 +188,20 @@ export function enableConsoleCapture(): void {
? formatConsoleTimestamp(getConsoleSettings().style)
: "";
try {
const resolvedLogger = getLoggerLazy();
// Map console levels to file logger
if (level === "trace") {
logger.trace(formatted);
resolvedLogger.trace(formatted);
} else if (level === "debug") {
logger.debug(formatted);
resolvedLogger.debug(formatted);
} else if (level === "info") {
logger.info(formatted);
resolvedLogger.info(formatted);
} else if (level === "warn") {
logger.warn(formatted);
resolvedLogger.warn(formatted);
} else if (level === "error" || level === "fatal") {
logger.error(formatted);
resolvedLogger.error(formatted);
} else {
logger.info(formatted);
resolvedLogger.info(formatted);
}
} catch {
// never block console output on logging failures