mirror of
https://github.com/Kaelio/ktx.git
synced 2026-06-10 08:05:14 +02:00
The 34 `index.ts` re-export barrels inside `packages/cli/src/` were holdovers from the pre-fold multi-workspace structure. Post-fold-in they served no production purpose: external consumers go through the single package main entry, and in-repo callers mostly imported through them only because the path was short. Internally, knip flagged most barrel re-exports as production-dead (only reached via tests). This change: - Deletes every internal barrel except `packages/cli/src/index.ts` (the published package entry). - Rewrites ~270 source/test files to import each name directly from the file that defines it. - Moves `tools/warehouse-verification/index.ts` to `create-warehouse-verification-tools.ts` (the function it defined locally) and updates its single consumer. - Renames `search/backend-conformance.ts` → `.test-utils.ts` to match the existing test-helper file convention. - Deletes 13 dead test-only chains (dbt-descriptions/*, live-database/extracted-schema, live-database/structural-sync, relationship-* feedback/review chain) plus their tests and a cascading orphan integration test. - Updates test mocks that pointed at deleted barrel paths (notion-client, connector barrels in scan/local-scan-connectors tests) to mock the source files instead. - Points the maintainer benchmark script (`scripts/relationship-benchmark-report.mjs`) at source files instead of `dist/context/scan/index.js`. - Drops the barrel `!` entries from `knip.json`; adds explicit production entries only for the benchmark code reached via dist by the maintainer script. Net: 413 files changed, ~1.2k insertions, ~9.4k deletions. `pnpm run dead-code` (Biome + knip default + knip production) and `pnpm run type-check` are clean; 2277 tests pass.
104 lines
3.8 KiB
TypeScript
104 lines
3.8 KiB
TypeScript
import { createRequire } from 'node:module';
|
|
|
|
import type { KtxConnectionArgs } from './connection.js';
|
|
import type { KtxAdminReindexArgs } from './admin-reindex.js';
|
|
import type { KtxDoctorArgs } from './doctor.js';
|
|
import type { KtxKnowledgeArgs } from './knowledge.js';
|
|
import type { KtxPublicIngestArgs } from './public-ingest.js';
|
|
import type { KtxRuntimeArgs } from './runtime.js';
|
|
import type { KtxSetupArgs } from './setup.js';
|
|
import type { KtxSlArgs } from './sl.js';
|
|
import type { KtxSqlArgs } from './sql.js';
|
|
import { profileMark, profileSpan } from './startup-profile.js';
|
|
import type { KtxTextIngestArgs } from './text-ingest.js';
|
|
import { assertCliVersion } from './release-version.js';
|
|
|
|
profileMark('module:cli-runtime');
|
|
|
|
const requirePackageJson = createRequire(import.meta.url);
|
|
|
|
export interface KtxCliPackageInfo {
|
|
name: string;
|
|
version: string;
|
|
}
|
|
|
|
export interface KtxCliIo {
|
|
stdout: { isTTY?: boolean; columns?: number; write(chunk: string): void };
|
|
stderr: { write(chunk: string): void };
|
|
}
|
|
|
|
export interface KtxCliDeps {
|
|
adminReindex?: (args: KtxAdminReindexArgs, io: KtxCliIo) => Promise<number>;
|
|
setup?: (args: KtxSetupArgs, io: KtxCliIo) => Promise<number>;
|
|
connection?: (args: KtxConnectionArgs, io: KtxCliIo) => Promise<number>;
|
|
doctor?: (args: KtxDoctorArgs, io: KtxCliIo) => Promise<number>;
|
|
publicIngest?: (args: KtxPublicIngestArgs, io: KtxCliIo) => Promise<number>;
|
|
textIngest?: (args: KtxTextIngestArgs, io: KtxCliIo) => Promise<number>;
|
|
runtime?: (args: KtxRuntimeArgs, io: KtxCliIo) => Promise<number>;
|
|
knowledge?: (args: KtxKnowledgeArgs, io: KtxCliIo) => Promise<number>;
|
|
sl?: (args: KtxSlArgs, io: KtxCliIo) => Promise<number>;
|
|
sql?: (args: KtxSqlArgs, io: KtxCliIo) => Promise<number>;
|
|
mcp?: {
|
|
startDaemon?: typeof import('./managed-mcp-daemon.js').startKtxMcpDaemon;
|
|
stopDaemon?: typeof import('./managed-mcp-daemon.js').stopKtxMcpDaemon;
|
|
readStatus?: typeof import('./managed-mcp-daemon.js').readKtxMcpDaemonStatus;
|
|
runServer?: typeof import('./mcp-http-server.js').runKtxMcpHttpServer;
|
|
runStdioServer?: typeof import('./mcp-stdio-server.js').runKtxMcpStdioServer;
|
|
};
|
|
}
|
|
|
|
export function getKtxCliPackageInfo(): KtxCliPackageInfo {
|
|
return packageInfoFromJson(requirePackageJson('../package.json'));
|
|
}
|
|
|
|
export function packageInfoFromJson(packageJson: unknown): KtxCliPackageInfo {
|
|
if (
|
|
typeof packageJson !== 'object' ||
|
|
packageJson === null ||
|
|
!('name' in packageJson) ||
|
|
!('version' in packageJson) ||
|
|
typeof packageJson.name !== 'string' ||
|
|
typeof packageJson.version !== 'string'
|
|
) {
|
|
throw new Error('Invalid KTX CLI package metadata');
|
|
}
|
|
|
|
return {
|
|
name: packageJson.name,
|
|
version: assertCliVersion(packageJson.version, `${packageJson.name}/package.json`),
|
|
};
|
|
}
|
|
|
|
async function runInit(args: { projectDir: string; force: boolean }, io: KtxCliIo): Promise<number> {
|
|
const { initKtxProject } = await import('./context/project/project.js');;
|
|
const result = await initKtxProject({
|
|
projectDir: args.projectDir,
|
|
force: args.force,
|
|
});
|
|
|
|
io.stdout.write(`Initialized KTX project at ${result.projectDir}\n`);
|
|
io.stdout.write(`Config: ${result.configPath}\n`);
|
|
io.stdout.write(`Commit: ${result.commitHash ?? 'none'}\n`);
|
|
return 0;
|
|
}
|
|
|
|
export async function runInitForCommander(
|
|
args: { projectDir: string; force: boolean },
|
|
io: KtxCliIo,
|
|
): Promise<number> {
|
|
return await runInit(args, io);
|
|
}
|
|
|
|
export async function runKtxCli(
|
|
argv = process.argv.slice(2),
|
|
io: KtxCliIo = process,
|
|
deps: KtxCliDeps = {},
|
|
): Promise<number> {
|
|
const info = getKtxCliPackageInfo();
|
|
profileMark('runtime:runKtxCli');
|
|
const { runCommanderKtxCli } = await profileSpan('import ./cli-program.js', () => import('./cli-program.js'));
|
|
|
|
return await runCommanderKtxCli(argv, io, deps, info, {
|
|
runInit: runInitForCommander,
|
|
});
|
|
}
|