sdl-mcp 0.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +132 -0
- package/config/benchmark.ci.config.json +86 -0
- package/config/benchmark.ci.windows.config.json +86 -0
- package/config/benchmark.config.example.json +86 -0
- package/config/benchmark.config.json +86 -0
- package/config/sdlmcp.config.example.json +139 -0
- package/config/sdlmcp.config.json +48 -0
- package/config/sdlmcp.config.schema.json +381 -0
- package/dist/agent/evidence.d.ts +18 -0
- package/dist/agent/evidence.d.ts.map +1 -0
- package/dist/agent/evidence.js +107 -0
- package/dist/agent/evidence.js.map +1 -0
- package/dist/agent/executor.d.ts +28 -0
- package/dist/agent/executor.d.ts.map +1 -0
- package/dist/agent/executor.js +261 -0
- package/dist/agent/executor.js.map +1 -0
- package/dist/agent/index.d.ts +6 -0
- package/dist/agent/index.d.ts.map +1 -0
- package/dist/agent/index.js +6 -0
- package/dist/agent/index.js.map +1 -0
- package/dist/agent/orchestrator.d.ts +14 -0
- package/dist/agent/orchestrator.d.ts.map +1 -0
- package/dist/agent/orchestrator.js +108 -0
- package/dist/agent/orchestrator.js.map +1 -0
- package/dist/agent/planner.d.ts +21 -0
- package/dist/agent/planner.d.ts.map +1 -0
- package/dist/agent/planner.js +153 -0
- package/dist/agent/planner.js.map +1 -0
- package/dist/agent/types.d.ts +86 -0
- package/dist/agent/types.d.ts.map +1 -0
- package/dist/agent/types.js +2 -0
- package/dist/agent/types.js.map +1 -0
- package/dist/benchmark/index.d.ts +4 -0
- package/dist/benchmark/index.d.ts.map +1 -0
- package/dist/benchmark/index.js +4 -0
- package/dist/benchmark/index.js.map +1 -0
- package/dist/benchmark/regression.d.ts +40 -0
- package/dist/benchmark/regression.d.ts.map +1 -0
- package/dist/benchmark/regression.js +199 -0
- package/dist/benchmark/regression.js.map +1 -0
- package/dist/benchmark/smoothing.d.ts +40 -0
- package/dist/benchmark/smoothing.d.ts.map +1 -0
- package/dist/benchmark/smoothing.js +121 -0
- package/dist/benchmark/smoothing.js.map +1 -0
- package/dist/benchmark/threshold.d.ts +64 -0
- package/dist/benchmark/threshold.d.ts.map +1 -0
- package/dist/benchmark/threshold.js +173 -0
- package/dist/benchmark/threshold.js.map +1 -0
- package/dist/cli/argParsing.d.ts +34 -0
- package/dist/cli/argParsing.d.ts.map +1 -0
- package/dist/cli/argParsing.js +329 -0
- package/dist/cli/argParsing.js.map +1 -0
- package/dist/cli/commands/benchmark.d.ts +16 -0
- package/dist/cli/commands/benchmark.d.ts.map +1 -0
- package/dist/cli/commands/benchmark.js +412 -0
- package/dist/cli/commands/benchmark.js.map +1 -0
- package/dist/cli/commands/doctor.d.ts +3 -0
- package/dist/cli/commands/doctor.d.ts.map +1 -0
- package/dist/cli/commands/doctor.js +218 -0
- package/dist/cli/commands/doctor.js.map +1 -0
- package/dist/cli/commands/export.d.ts +12 -0
- package/dist/cli/commands/export.d.ts.map +1 -0
- package/dist/cli/commands/export.js +70 -0
- package/dist/cli/commands/export.js.map +1 -0
- package/dist/cli/commands/import.d.ts +10 -0
- package/dist/cli/commands/import.d.ts.map +1 -0
- package/dist/cli/commands/import.js +40 -0
- package/dist/cli/commands/import.js.map +1 -0
- package/dist/cli/commands/index.d.ts +3 -0
- package/dist/cli/commands/index.d.ts.map +1 -0
- package/dist/cli/commands/index.js +89 -0
- package/dist/cli/commands/index.js.map +1 -0
- package/dist/cli/commands/init.d.ts +3 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +221 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/pull.d.ts +11 -0
- package/dist/cli/commands/pull.d.ts.map +1 -0
- package/dist/cli/commands/pull.js +47 -0
- package/dist/cli/commands/pull.js.map +1 -0
- package/dist/cli/commands/serve.d.ts +3 -0
- package/dist/cli/commands/serve.d.ts.map +1 -0
- package/dist/cli/commands/serve.js +72 -0
- package/dist/cli/commands/serve.js.map +1 -0
- package/dist/cli/commands/version.d.ts +3 -0
- package/dist/cli/commands/version.d.ts.map +1 -0
- package/dist/cli/commands/version.js +24 -0
- package/dist/cli/commands/version.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +213 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/logging.d.ts +10 -0
- package/dist/cli/logging.d.ts.map +1 -0
- package/dist/cli/logging.js +48 -0
- package/dist/cli/logging.js.map +1 -0
- package/dist/cli/transport/http.d.ts +3 -0
- package/dist/cli/transport/http.d.ts.map +1 -0
- package/dist/cli/transport/http.js +106 -0
- package/dist/cli/transport/http.js.map +1 -0
- package/dist/cli/transport/stdio.d.ts +3 -0
- package/dist/cli/transport/stdio.d.ts.map +1 -0
- package/dist/cli/transport/stdio.js +6 -0
- package/dist/cli/transport/stdio.js.map +1 -0
- package/dist/cli/types.d.ts +41 -0
- package/dist/cli/types.d.ts.map +1 -0
- package/dist/cli/types.js +2 -0
- package/dist/cli/types.js.map +1 -0
- package/dist/code/gate.d.ts +11 -0
- package/dist/code/gate.d.ts.map +1 -0
- package/dist/code/gate.js +134 -0
- package/dist/code/gate.js.map +1 -0
- package/dist/code/hotpath.d.ts +17 -0
- package/dist/code/hotpath.d.ts.map +1 -0
- package/dist/code/hotpath.js +200 -0
- package/dist/code/hotpath.js.map +1 -0
- package/dist/code/redact.d.ts +19 -0
- package/dist/code/redact.d.ts.map +1 -0
- package/dist/code/redact.js +92 -0
- package/dist/code/redact.js.map +1 -0
- package/dist/code/skeleton.d.ts +32 -0
- package/dist/code/skeleton.d.ts.map +1 -0
- package/dist/code/skeleton.js +610 -0
- package/dist/code/skeleton.js.map +1 -0
- package/dist/code/windows.d.ts +18 -0
- package/dist/code/windows.d.ts.map +1 -0
- package/dist/code/windows.js +236 -0
- package/dist/code/windows.js.map +1 -0
- package/dist/config/constants.d.ts +340 -0
- package/dist/config/constants.d.ts.map +1 -0
- package/dist/config/constants.js +379 -0
- package/dist/config/constants.js.map +1 -0
- package/dist/config/loadConfig.d.ts +3 -0
- package/dist/config/loadConfig.d.ts.map +1 -0
- package/dist/config/loadConfig.js +71 -0
- package/dist/config/loadConfig.js.map +1 -0
- package/dist/config/types.d.ts +509 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +139 -0
- package/dist/config/types.js.map +1 -0
- package/dist/db/db.d.ts +4 -0
- package/dist/db/db.d.ts.map +1 -0
- package/dist/db/db.js +47 -0
- package/dist/db/db.js.map +1 -0
- package/dist/db/migrations.d.ts +15 -0
- package/dist/db/migrations.d.ts.map +1 -0
- package/dist/db/migrations.js +81 -0
- package/dist/db/migrations.js.map +1 -0
- package/dist/db/queries.d.ts +440 -0
- package/dist/db/queries.d.ts.map +1 -0
- package/dist/db/queries.js +1054 -0
- package/dist/db/queries.js.map +1 -0
- package/dist/db/schema.d.ts +132 -0
- package/dist/db/schema.d.ts.map +1 -0
- package/dist/db/schema.js +2 -0
- package/dist/db/schema.js.map +1 -0
- package/dist/delta/blastRadius.d.ts +24 -0
- package/dist/delta/blastRadius.d.ts.map +1 -0
- package/dist/delta/blastRadius.js +239 -0
- package/dist/delta/blastRadius.js.map +1 -0
- package/dist/delta/diff.d.ts +16 -0
- package/dist/delta/diff.d.ts.map +1 -0
- package/dist/delta/diff.js +236 -0
- package/dist/delta/diff.js.map +1 -0
- package/dist/delta/versioning.d.ts +11 -0
- package/dist/delta/versioning.d.ts.map +1 -0
- package/dist/delta/versioning.js +68 -0
- package/dist/delta/versioning.js.map +1 -0
- package/dist/graph/buildGraph.d.ts +12 -0
- package/dist/graph/buildGraph.d.ts.map +1 -0
- package/dist/graph/buildGraph.js +81 -0
- package/dist/graph/buildGraph.js.map +1 -0
- package/dist/graph/cache.d.ts +111 -0
- package/dist/graph/cache.d.ts.map +1 -0
- package/dist/graph/cache.js +237 -0
- package/dist/graph/cache.js.map +1 -0
- package/dist/graph/metrics.d.ts +12 -0
- package/dist/graph/metrics.d.ts.map +1 -0
- package/dist/graph/metrics.js +253 -0
- package/dist/graph/metrics.js.map +1 -0
- package/dist/graph/minHeap.d.ts +91 -0
- package/dist/graph/minHeap.d.ts.map +1 -0
- package/dist/graph/minHeap.js +159 -0
- package/dist/graph/minHeap.js.map +1 -0
- package/dist/graph/overview.d.ts +22 -0
- package/dist/graph/overview.d.ts.map +1 -0
- package/dist/graph/overview.js +379 -0
- package/dist/graph/overview.js.map +1 -0
- package/dist/graph/score.d.ts +27 -0
- package/dist/graph/score.d.ts.map +1 -0
- package/dist/graph/score.js +214 -0
- package/dist/graph/score.js.map +1 -0
- package/dist/graph/slice.d.ts +51 -0
- package/dist/graph/slice.d.ts.map +1 -0
- package/dist/graph/slice.js +1047 -0
- package/dist/graph/slice.js.map +1 -0
- package/dist/graph/sliceCache.d.ts +33 -0
- package/dist/graph/sliceCache.d.ts.map +1 -0
- package/dist/graph/sliceCache.js +140 -0
- package/dist/graph/sliceCache.js.map +1 -0
- package/dist/indexer/adapter/BaseAdapter.d.ts +29 -0
- package/dist/indexer/adapter/BaseAdapter.d.ts.map +1 -0
- package/dist/indexer/adapter/BaseAdapter.js +97 -0
- package/dist/indexer/adapter/BaseAdapter.js.map +1 -0
- package/dist/indexer/adapter/LanguageAdapter.d.ts +20 -0
- package/dist/indexer/adapter/LanguageAdapter.d.ts.map +1 -0
- package/dist/indexer/adapter/LanguageAdapter.js +2 -0
- package/dist/indexer/adapter/LanguageAdapter.js.map +1 -0
- package/dist/indexer/adapter/adapters.d.ts +57 -0
- package/dist/indexer/adapter/adapters.d.ts.map +1 -0
- package/dist/indexer/adapter/adapters.js +129 -0
- package/dist/indexer/adapter/adapters.js.map +1 -0
- package/dist/indexer/adapter/c.d.ts +18 -0
- package/dist/indexer/adapter/c.d.ts.map +1 -0
- package/dist/indexer/adapter/c.js +443 -0
- package/dist/indexer/adapter/c.js.map +1 -0
- package/dist/indexer/adapter/cpp.d.ts +18 -0
- package/dist/indexer/adapter/cpp.d.ts.map +1 -0
- package/dist/indexer/adapter/cpp.js +493 -0
- package/dist/indexer/adapter/cpp.js.map +1 -0
- package/dist/indexer/adapter/csharp.d.ts +48 -0
- package/dist/indexer/adapter/csharp.d.ts.map +1 -0
- package/dist/indexer/adapter/csharp.js +638 -0
- package/dist/indexer/adapter/csharp.js.map +1 -0
- package/dist/indexer/adapter/go.d.ts +14 -0
- package/dist/indexer/adapter/go.d.ts.map +1 -0
- package/dist/indexer/adapter/go.js +400 -0
- package/dist/indexer/adapter/go.js.map +1 -0
- package/dist/indexer/adapter/index.d.ts +14 -0
- package/dist/indexer/adapter/index.d.ts.map +1 -0
- package/dist/indexer/adapter/index.js +13 -0
- package/dist/indexer/adapter/index.js.map +1 -0
- package/dist/indexer/adapter/java.d.ts +14 -0
- package/dist/indexer/adapter/java.d.ts.map +1 -0
- package/dist/indexer/adapter/java.js +391 -0
- package/dist/indexer/adapter/java.js.map +1 -0
- package/dist/indexer/adapter/kotlin.d.ts +18 -0
- package/dist/indexer/adapter/kotlin.d.ts.map +1 -0
- package/dist/indexer/adapter/kotlin.js +599 -0
- package/dist/indexer/adapter/kotlin.js.map +1 -0
- package/dist/indexer/adapter/php.d.ts +18 -0
- package/dist/indexer/adapter/php.d.ts.map +1 -0
- package/dist/indexer/adapter/php.js +574 -0
- package/dist/indexer/adapter/php.js.map +1 -0
- package/dist/indexer/adapter/plugin/index.d.ts +3 -0
- package/dist/indexer/adapter/plugin/index.d.ts.map +1 -0
- package/dist/indexer/adapter/plugin/index.js +3 -0
- package/dist/indexer/adapter/plugin/index.js.map +1 -0
- package/dist/indexer/adapter/plugin/loader.d.ts +13 -0
- package/dist/indexer/adapter/plugin/loader.d.ts.map +1 -0
- package/dist/indexer/adapter/plugin/loader.js +154 -0
- package/dist/indexer/adapter/plugin/loader.js.map +1 -0
- package/dist/indexer/adapter/plugin/types.d.ts +76 -0
- package/dist/indexer/adapter/plugin/types.d.ts.map +1 -0
- package/dist/indexer/adapter/plugin/types.js +47 -0
- package/dist/indexer/adapter/plugin/types.js.map +1 -0
- package/dist/indexer/adapter/python.d.ts +14 -0
- package/dist/indexer/adapter/python.d.ts.map +1 -0
- package/dist/indexer/adapter/python.js +511 -0
- package/dist/indexer/adapter/python.js.map +1 -0
- package/dist/indexer/adapter/registry.d.ts +17 -0
- package/dist/indexer/adapter/registry.d.ts.map +1 -0
- package/dist/indexer/adapter/registry.js +134 -0
- package/dist/indexer/adapter/registry.js.map +1 -0
- package/dist/indexer/adapter/rust.d.ts +18 -0
- package/dist/indexer/adapter/rust.d.ts.map +1 -0
- package/dist/indexer/adapter/rust.js +709 -0
- package/dist/indexer/adapter/rust.js.map +1 -0
- package/dist/indexer/adapter/shell.d.ts +18 -0
- package/dist/indexer/adapter/shell.d.ts.map +1 -0
- package/dist/indexer/adapter/shell.js +345 -0
- package/dist/indexer/adapter/shell.js.map +1 -0
- package/dist/indexer/adapter/typescript.d.ts +14 -0
- package/dist/indexer/adapter/typescript.d.ts.map +1 -0
- package/dist/indexer/adapter/typescript.js +31 -0
- package/dist/indexer/adapter/typescript.js.map +1 -0
- package/dist/indexer/configEdges.d.ts +30 -0
- package/dist/indexer/configEdges.d.ts.map +1 -0
- package/dist/indexer/configEdges.js +260 -0
- package/dist/indexer/configEdges.js.map +1 -0
- package/dist/indexer/fileScanner.d.ts +16 -0
- package/dist/indexer/fileScanner.d.ts.map +1 -0
- package/dist/indexer/fileScanner.js +90 -0
- package/dist/indexer/fileScanner.js.map +1 -0
- package/dist/indexer/fingerprints.d.ts +23 -0
- package/dist/indexer/fingerprints.d.ts.map +1 -0
- package/dist/indexer/fingerprints.js +97 -0
- package/dist/indexer/fingerprints.js.map +1 -0
- package/dist/indexer/indexer.d.ts +58 -0
- package/dist/indexer/indexer.d.ts.map +1 -0
- package/dist/indexer/indexer.js +1229 -0
- package/dist/indexer/indexer.js.map +1 -0
- package/dist/indexer/summaries.d.ts +5 -0
- package/dist/indexer/summaries.d.ts.map +1 -0
- package/dist/indexer/summaries.js +331 -0
- package/dist/indexer/summaries.js.map +1 -0
- package/dist/indexer/treesitter/extractCalls.d.ts +40 -0
- package/dist/indexer/treesitter/extractCalls.d.ts.map +1 -0
- package/dist/indexer/treesitter/extractCalls.js +561 -0
- package/dist/indexer/treesitter/extractCalls.js.map +1 -0
- package/dist/indexer/treesitter/extractImports.d.ts +12 -0
- package/dist/indexer/treesitter/extractImports.d.ts.map +1 -0
- package/dist/indexer/treesitter/extractImports.js +184 -0
- package/dist/indexer/treesitter/extractImports.js.map +1 -0
- package/dist/indexer/treesitter/extractSymbols.d.ts +24 -0
- package/dist/indexer/treesitter/extractSymbols.d.ts.map +1 -0
- package/dist/indexer/treesitter/extractSymbols.js +389 -0
- package/dist/indexer/treesitter/extractSymbols.js.map +1 -0
- package/dist/indexer/treesitter/grammarLoader.d.ts +6 -0
- package/dist/indexer/treesitter/grammarLoader.d.ts.map +1 -0
- package/dist/indexer/treesitter/grammarLoader.js +125 -0
- package/dist/indexer/treesitter/grammarLoader.js.map +1 -0
- package/dist/indexer/treesitter/symbolUtils.d.ts +4 -0
- package/dist/indexer/treesitter/symbolUtils.d.ts.map +1 -0
- package/dist/indexer/treesitter/symbolUtils.js +26 -0
- package/dist/indexer/treesitter/symbolUtils.js.map +1 -0
- package/dist/indexer/treesitter/tsTreesitter.d.ts +9 -0
- package/dist/indexer/treesitter/tsTreesitter.d.ts.map +1 -0
- package/dist/indexer/treesitter/tsTreesitter.js +54 -0
- package/dist/indexer/treesitter/tsTreesitter.js.map +1 -0
- package/dist/indexer/treesitter/types.d.ts +19 -0
- package/dist/indexer/treesitter/types.d.ts.map +1 -0
- package/dist/indexer/treesitter/types.js +7 -0
- package/dist/indexer/treesitter/types.js.map +1 -0
- package/dist/indexer/ts/tsParser.d.ts +20 -0
- package/dist/indexer/ts/tsParser.d.ts.map +1 -0
- package/dist/indexer/ts/tsParser.js +114 -0
- package/dist/indexer/ts/tsParser.js.map +1 -0
- package/dist/indexer/worker.d.ts +2 -0
- package/dist/indexer/worker.d.ts.map +1 -0
- package/dist/indexer/worker.js +59 -0
- package/dist/indexer/worker.js.map +1 -0
- package/dist/indexer/workerPool.d.ts +20 -0
- package/dist/indexer/workerPool.d.ts.map +1 -0
- package/dist/indexer/workerPool.js +93 -0
- package/dist/indexer/workerPool.js.map +1 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +111 -0
- package/dist/main.js.map +1 -0
- package/dist/mcp/errors.d.ts +40 -0
- package/dist/mcp/errors.d.ts.map +1 -0
- package/dist/mcp/errors.js +66 -0
- package/dist/mcp/errors.js.map +1 -0
- package/dist/mcp/resources.d.ts +24 -0
- package/dist/mcp/resources.d.ts.map +1 -0
- package/dist/mcp/resources.js +140 -0
- package/dist/mcp/resources.js.map +1 -0
- package/dist/mcp/telemetry.d.ts +67 -0
- package/dist/mcp/telemetry.d.ts.map +1 -0
- package/dist/mcp/telemetry.js +128 -0
- package/dist/mcp/telemetry.js.map +1 -0
- package/dist/mcp/tools/agent.d.ts +241 -0
- package/dist/mcp/tools/agent.d.ts.map +1 -0
- package/dist/mcp/tools/agent.js +113 -0
- package/dist/mcp/tools/agent.js.map +1 -0
- package/dist/mcp/tools/code.d.ts +32 -0
- package/dist/mcp/tools/code.d.ts.map +1 -0
- package/dist/mcp/tools/code.js +388 -0
- package/dist/mcp/tools/code.js.map +1 -0
- package/dist/mcp/tools/delta.d.ts +12 -0
- package/dist/mcp/tools/delta.d.ts.map +1 -0
- package/dist/mcp/tools/delta.js +82 -0
- package/dist/mcp/tools/delta.js.map +1 -0
- package/dist/mcp/tools/index.d.ts +3 -0
- package/dist/mcp/tools/index.d.ts.map +1 -0
- package/dist/mcp/tools/index.js +35 -0
- package/dist/mcp/tools/index.js.map +1 -0
- package/dist/mcp/tools/policy.d.ts +20 -0
- package/dist/mcp/tools/policy.d.ts.map +1 -0
- package/dist/mcp/tools/policy.js +67 -0
- package/dist/mcp/tools/policy.js.map +1 -0
- package/dist/mcp/tools/prRisk.d.ts +34 -0
- package/dist/mcp/tools/prRisk.d.ts.map +1 -0
- package/dist/mcp/tools/prRisk.js +304 -0
- package/dist/mcp/tools/prRisk.js.map +1 -0
- package/dist/mcp/tools/repo.d.ts +46 -0
- package/dist/mcp/tools/repo.d.ts.map +1 -0
- package/dist/mcp/tools/repo.js +224 -0
- package/dist/mcp/tools/repo.js.map +1 -0
- package/dist/mcp/tools/slice.d.ts +44 -0
- package/dist/mcp/tools/slice.d.ts.map +1 -0
- package/dist/mcp/tools/slice.js +688 -0
- package/dist/mcp/tools/slice.js.map +1 -0
- package/dist/mcp/tools/symbol.d.ts +21 -0
- package/dist/mcp/tools/symbol.d.ts.map +1 -0
- package/dist/mcp/tools/symbol.js +416 -0
- package/dist/mcp/tools/symbol.js.map +1 -0
- package/dist/mcp/tools.d.ts +6003 -0
- package/dist/mcp/tools.d.ts.map +1 -0
- package/dist/mcp/tools.js +932 -0
- package/dist/mcp/tools.js.map +1 -0
- package/dist/mcp/types.d.ts +500 -0
- package/dist/mcp/types.d.ts.map +1 -0
- package/dist/mcp/types.js +2 -0
- package/dist/mcp/types.js.map +1 -0
- package/dist/policy/engine.d.ts +21 -0
- package/dist/policy/engine.d.ts.map +1 -0
- package/dist/policy/engine.js +477 -0
- package/dist/policy/engine.js.map +1 -0
- package/dist/policy/types.d.ts +73 -0
- package/dist/policy/types.d.ts.map +1 -0
- package/dist/policy/types.js +12 -0
- package/dist/policy/types.js.map +1 -0
- package/dist/server.d.ts +17 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +136 -0
- package/dist/server.js.map +1 -0
- package/dist/sync/pull.d.ts +4 -0
- package/dist/sync/pull.d.ts.map +1 -0
- package/dist/sync/pull.js +113 -0
- package/dist/sync/pull.js.map +1 -0
- package/dist/sync/sync.d.ts +6 -0
- package/dist/sync/sync.d.ts.map +1 -0
- package/dist/sync/sync.js +244 -0
- package/dist/sync/sync.js.map +1 -0
- package/dist/sync/types.d.ts +136 -0
- package/dist/sync/types.d.ts.map +1 -0
- package/dist/sync/types.js +2 -0
- package/dist/sync/types.js.map +1 -0
- package/dist/ts/diagnostics.d.ts +61 -0
- package/dist/ts/diagnostics.d.ts.map +1 -0
- package/dist/ts/diagnostics.js +259 -0
- package/dist/ts/diagnostics.js.map +1 -0
- package/dist/ts/mapping.d.ts +27 -0
- package/dist/ts/mapping.d.ts.map +1 -0
- package/dist/ts/mapping.js +68 -0
- package/dist/ts/mapping.js.map +1 -0
- package/dist/util/asyncFs.d.ts +103 -0
- package/dist/util/asyncFs.d.ts.map +1 -0
- package/dist/util/asyncFs.js +133 -0
- package/dist/util/asyncFs.js.map +1 -0
- package/dist/util/concurrency.d.ts +77 -0
- package/dist/util/concurrency.d.ts.map +1 -0
- package/dist/util/concurrency.js +146 -0
- package/dist/util/concurrency.js.map +1 -0
- package/dist/util/depLabels.d.ts +3 -0
- package/dist/util/depLabels.d.ts.map +1 -0
- package/dist/util/depLabels.js +19 -0
- package/dist/util/depLabels.js.map +1 -0
- package/dist/util/findPackageRoot.d.ts +7 -0
- package/dist/util/findPackageRoot.d.ts.map +1 -0
- package/dist/util/findPackageRoot.js +21 -0
- package/dist/util/findPackageRoot.js.map +1 -0
- package/dist/util/hashing.d.ts +9 -0
- package/dist/util/hashing.d.ts.map +1 -0
- package/dist/util/hashing.js +37 -0
- package/dist/util/hashing.js.map +1 -0
- package/dist/util/logger.d.ts +14 -0
- package/dist/util/logger.d.ts.map +1 -0
- package/dist/util/logger.js +51 -0
- package/dist/util/logger.js.map +1 -0
- package/dist/util/paths.d.ts +6 -0
- package/dist/util/paths.d.ts.map +1 -0
- package/dist/util/paths.js +79 -0
- package/dist/util/paths.js.map +1 -0
- package/dist/util/time.d.ts +4 -0
- package/dist/util/time.d.ts.map +1 -0
- package/dist/util/time.js +20 -0
- package/dist/util/time.js.map +1 -0
- package/dist/util/tokenize.d.ts +5 -0
- package/dist/util/tokenize.d.ts.map +1 -0
- package/dist/util/tokenize.js +30 -0
- package/dist/util/tokenize.js.map +1 -0
- package/dist/util/truncation.d.ts +38 -0
- package/dist/util/truncation.d.ts.map +1 -0
- package/dist/util/truncation.js +259 -0
- package/dist/util/truncation.js.map +1 -0
- package/migrations/.gitkeep +1 -0
- package/migrations/0001_init.sql +61 -0
- package/migrations/0002_edges_indexes.sql +2 -0
- package/migrations/0003_versions.sql +22 -0
- package/migrations/0004_metrics_audit.sql +23 -0
- package/migrations/0005_slice_handles.sql +15 -0
- package/migrations/0006_content_addressed.sql +29 -0
- package/migrations/0007_add_language_to_symbols.sql +28 -0
- package/migrations/0008_performance_indexes.sql +21 -0
- package/migrations/0009_fix_edge_fks.sql +37 -0
- package/migrations/0010_standardize_fks.sql +35 -0
- package/migrations/0011_add_directory_column.sql +20 -0
- package/migrations/0012_symbol_references.sql +16 -0
- package/migrations/0013_sync_artifacts.sql +17 -0
- package/package.json +107 -0
- package/templates/CLAUDE.md.template +179 -0
- package/templates/README.md +228 -0
- package/templates/claude-code.json +54 -0
- package/templates/codex.json +55 -0
- package/templates/gemini.json +66 -0
- package/templates/opencode.json +90 -0
- package/templates/plugin-template/LICENSE +21 -0
- package/templates/plugin-template/README.md +309 -0
- package/templates/plugin-template/index.ts +160 -0
- package/templates/plugin-template/package.json +31 -0
- package/templates/plugin-template/test/plugin.test.ts +186 -0
- package/templates/plugin-template/tsconfig.json +21 -0
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
export type TaskType = "debug" | "review" | "implement" | "explain";
|
|
2
|
+
export type RungType = "card" | "skeleton" | "hotPath" | "raw";
|
|
3
|
+
export type ActionStatus = "pending" | "inProgress" | "completed" | "failed";
|
|
4
|
+
export interface AgentTask {
|
|
5
|
+
taskType: TaskType;
|
|
6
|
+
taskText: string;
|
|
7
|
+
repoId: string;
|
|
8
|
+
budget?: BudgetOptions;
|
|
9
|
+
options?: TaskOptions;
|
|
10
|
+
}
|
|
11
|
+
export interface BudgetOptions {
|
|
12
|
+
maxTokens?: number;
|
|
13
|
+
maxActions?: number;
|
|
14
|
+
maxDurationMs?: number;
|
|
15
|
+
}
|
|
16
|
+
export interface TaskOptions {
|
|
17
|
+
focusSymbols?: string[];
|
|
18
|
+
focusPaths?: string[];
|
|
19
|
+
includeTests?: boolean;
|
|
20
|
+
requireDiagnostics?: boolean;
|
|
21
|
+
}
|
|
22
|
+
export interface RungPath {
|
|
23
|
+
rungs: RungType[];
|
|
24
|
+
estimatedTokens: number;
|
|
25
|
+
estimatedDurationMs: number;
|
|
26
|
+
reasoning: string;
|
|
27
|
+
}
|
|
28
|
+
export interface PlannedExecution {
|
|
29
|
+
task: AgentTask;
|
|
30
|
+
path: RungPath;
|
|
31
|
+
sequence: Action[];
|
|
32
|
+
}
|
|
33
|
+
export interface Action {
|
|
34
|
+
id: string;
|
|
35
|
+
type: "getCard" | "getSkeleton" | "getHotPath" | "needWindow" | "search" | "analyze";
|
|
36
|
+
status: ActionStatus;
|
|
37
|
+
input: Record<string, unknown>;
|
|
38
|
+
output?: unknown;
|
|
39
|
+
error?: string;
|
|
40
|
+
timestamp: number;
|
|
41
|
+
durationMs: number;
|
|
42
|
+
evidence: Evidence[];
|
|
43
|
+
}
|
|
44
|
+
export interface Evidence {
|
|
45
|
+
type: "symbolCard" | "skeleton" | "hotPath" | "codeWindow" | "delta" | "diagnostic" | "searchResult";
|
|
46
|
+
reference: string;
|
|
47
|
+
summary: string;
|
|
48
|
+
timestamp: number;
|
|
49
|
+
}
|
|
50
|
+
export interface OrchestrationResult {
|
|
51
|
+
taskId: string;
|
|
52
|
+
taskType: TaskType;
|
|
53
|
+
actionsTaken: Action[];
|
|
54
|
+
path: RungPath;
|
|
55
|
+
finalEvidence: Evidence[];
|
|
56
|
+
summary: string;
|
|
57
|
+
success: boolean;
|
|
58
|
+
error?: string;
|
|
59
|
+
metrics: ExecutionMetrics;
|
|
60
|
+
answer?: string;
|
|
61
|
+
nextBestAction?: string;
|
|
62
|
+
}
|
|
63
|
+
export interface ExecutionMetrics {
|
|
64
|
+
totalDurationMs: number;
|
|
65
|
+
totalTokens: number;
|
|
66
|
+
totalActions: number;
|
|
67
|
+
successfulActions: number;
|
|
68
|
+
failedActions: number;
|
|
69
|
+
cacheHits: number;
|
|
70
|
+
}
|
|
71
|
+
export interface AgentContext {
|
|
72
|
+
repoId: string;
|
|
73
|
+
symbolIds: string[];
|
|
74
|
+
filePaths: string[];
|
|
75
|
+
diagnostics?: Diagnostic[];
|
|
76
|
+
}
|
|
77
|
+
export interface Diagnostic {
|
|
78
|
+
symbolId?: string;
|
|
79
|
+
filePath: string;
|
|
80
|
+
line: number;
|
|
81
|
+
column: number;
|
|
82
|
+
severity: "error" | "warning" | "info";
|
|
83
|
+
message: string;
|
|
84
|
+
code?: string;
|
|
85
|
+
}
|
|
86
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/agent/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/agent/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { ThresholdEvaluator, loadThresholdConfig, loadBaselineMetrics, saveBaselineMetrics, type BenchmarkThresholds, type MetricThreshold, type ThresholdEvaluation, type ThresholdEvaluationResult, } from "./threshold.js";
|
|
2
|
+
export { RegressionReportGenerator, type RegressionReportData, type RegressionDelta, type RegressionReport, } from "./regression.js";
|
|
3
|
+
export { MetricSmoothing, runBenchmarkWithSmoothing, type SmoothingConfig, type MetricMeasurement, type SmoothingResult, } from "./smoothing.js";
|
|
4
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/benchmark/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,EACnB,KAAK,mBAAmB,EACxB,KAAK,eAAe,EACpB,KAAK,mBAAmB,EACxB,KAAK,yBAAyB,GAC/B,MAAM,gBAAgB,CAAC;AAExB,OAAO,EACL,yBAAyB,EACzB,KAAK,oBAAoB,EACzB,KAAK,eAAe,EACpB,KAAK,gBAAgB,GACtB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EACL,eAAe,EACf,yBAAyB,EACzB,KAAK,eAAe,EACpB,KAAK,iBAAiB,EACtB,KAAK,eAAe,GACrB,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { ThresholdEvaluator, loadThresholdConfig, loadBaselineMetrics, saveBaselineMetrics, } from "./threshold.js";
|
|
2
|
+
export { RegressionReportGenerator, } from "./regression.js";
|
|
3
|
+
export { MetricSmoothing, runBenchmarkWithSmoothing, } from "./smoothing.js";
|
|
4
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/benchmark/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,kBAAkB,EAClB,mBAAmB,EACnB,mBAAmB,EACnB,mBAAmB,GAKpB,MAAM,gBAAgB,CAAC;AAExB,OAAO,EACL,yBAAyB,GAI1B,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EACL,eAAe,EACf,yBAAyB,GAI1B,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export interface RegressionReportData {
|
|
2
|
+
timestamp: string;
|
|
3
|
+
repoId: string;
|
|
4
|
+
currentMetrics: Record<string, number>;
|
|
5
|
+
baselineMetrics?: Record<string, number>;
|
|
6
|
+
thresholds: Record<string, unknown>;
|
|
7
|
+
evaluations: import("./threshold.js").ThresholdEvaluation[];
|
|
8
|
+
}
|
|
9
|
+
export interface RegressionDelta {
|
|
10
|
+
metricName: string;
|
|
11
|
+
category: string;
|
|
12
|
+
currentValue: number;
|
|
13
|
+
baselineValue?: number;
|
|
14
|
+
delta?: number;
|
|
15
|
+
deltaPercent?: number;
|
|
16
|
+
trend: "improved" | "degraded" | "neutral" | "unknown";
|
|
17
|
+
impact: "high" | "medium" | "low" | "none";
|
|
18
|
+
description: string;
|
|
19
|
+
}
|
|
20
|
+
export interface RegressionReport {
|
|
21
|
+
summary: {
|
|
22
|
+
passed: boolean;
|
|
23
|
+
totalMetrics: number;
|
|
24
|
+
improved: number;
|
|
25
|
+
degraded: number;
|
|
26
|
+
neutral: number;
|
|
27
|
+
unknown: number;
|
|
28
|
+
};
|
|
29
|
+
deltas: RegressionDelta[];
|
|
30
|
+
failingThresholds: string[];
|
|
31
|
+
recommendations: string[];
|
|
32
|
+
}
|
|
33
|
+
export declare class RegressionReportGenerator {
|
|
34
|
+
generate(data: RegressionReportData): RegressionReport;
|
|
35
|
+
private generateDelta;
|
|
36
|
+
private generateRecommendations;
|
|
37
|
+
generateMarkdownReport(report: RegressionReport): string;
|
|
38
|
+
generateJsonReport(report: RegressionReport): string;
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=regression.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"regression.d.ts","sourceRoot":"","sources":["../../src/benchmark/regression.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,oBAAoB;IACnC,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACvC,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACzC,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACpC,WAAW,EAAE,OAAO,gBAAgB,EAAE,mBAAmB,EAAE,CAAC;CAC7D;AAED,MAAM,WAAW,eAAe;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,KAAK,EAAE,UAAU,GAAG,UAAU,GAAG,SAAS,GAAG,SAAS,CAAC;IACvD,MAAM,EAAE,MAAM,GAAG,QAAQ,GAAG,KAAK,GAAG,MAAM,CAAC;IAC3C,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE;QACP,MAAM,EAAE,OAAO,CAAC;QAChB,YAAY,EAAE,MAAM,CAAC;QACrB,QAAQ,EAAE,MAAM,CAAC;QACjB,QAAQ,EAAE,MAAM,CAAC;QACjB,OAAO,EAAE,MAAM,CAAC;QAChB,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC;IACF,MAAM,EAAE,eAAe,EAAE,CAAC;IAC1B,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAC5B,eAAe,EAAE,MAAM,EAAE,CAAC;CAC3B;AAED,qBAAa,yBAAyB;IACpC,QAAQ,CAAC,IAAI,EAAE,oBAAoB,GAAG,gBAAgB;IAwCtD,OAAO,CAAC,aAAa;IAmErB,OAAO,CAAC,uBAAuB;IA4F/B,sBAAsB,CAAC,MAAM,EAAE,gBAAgB,GAAG,MAAM;IAqFxD,kBAAkB,CAAC,MAAM,EAAE,gBAAgB,GAAG,MAAM;CAGrD"}
|
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
export class RegressionReportGenerator {
|
|
2
|
+
generate(data) {
|
|
3
|
+
const deltas = [];
|
|
4
|
+
const failingThresholds = [];
|
|
5
|
+
const recommendations = [];
|
|
6
|
+
for (const evaluation of data.evaluations) {
|
|
7
|
+
const delta = this.generateDelta(evaluation);
|
|
8
|
+
deltas.push(delta);
|
|
9
|
+
if (!evaluation.passed) {
|
|
10
|
+
failingThresholds.push(`${evaluation.category}.${evaluation.metricName}`);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
const improved = deltas.filter((d) => d.trend === "improved").length;
|
|
14
|
+
const degraded = deltas.filter((d) => d.trend === "degraded").length;
|
|
15
|
+
const neutral = deltas.filter((d) => d.trend === "neutral").length;
|
|
16
|
+
const unknown = deltas.filter((d) => d.trend === "unknown").length;
|
|
17
|
+
recommendations.push(...this.generateRecommendations(deltas, data.evaluations));
|
|
18
|
+
return {
|
|
19
|
+
summary: {
|
|
20
|
+
passed: failingThresholds.length === 0,
|
|
21
|
+
totalMetrics: deltas.length,
|
|
22
|
+
improved,
|
|
23
|
+
degraded,
|
|
24
|
+
neutral,
|
|
25
|
+
unknown,
|
|
26
|
+
},
|
|
27
|
+
deltas,
|
|
28
|
+
failingThresholds,
|
|
29
|
+
recommendations,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
generateDelta(evaluation) {
|
|
33
|
+
const { metricName, category, currentValue, baselineValue, delta, deltaPercent, threshold, passed, } = evaluation;
|
|
34
|
+
let trend = "unknown";
|
|
35
|
+
let impact = "none";
|
|
36
|
+
let description = "";
|
|
37
|
+
if (baselineValue !== undefined &&
|
|
38
|
+
deltaPercent !== undefined &&
|
|
39
|
+
delta !== undefined) {
|
|
40
|
+
if (threshold.trend === "lower-is-better") {
|
|
41
|
+
trend = delta < 0 ? "improved" : delta > 0 ? "degraded" : "neutral";
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
trend = delta > 0 ? "improved" : delta < 0 ? "degraded" : "neutral";
|
|
45
|
+
}
|
|
46
|
+
const absDeltaPercent = Math.abs(deltaPercent);
|
|
47
|
+
if (absDeltaPercent > 20) {
|
|
48
|
+
impact = "high";
|
|
49
|
+
}
|
|
50
|
+
else if (absDeltaPercent > 10) {
|
|
51
|
+
impact = "medium";
|
|
52
|
+
}
|
|
53
|
+
else if (absDeltaPercent > 5) {
|
|
54
|
+
impact = "low";
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
description = "No baseline available for comparison";
|
|
59
|
+
}
|
|
60
|
+
if (!passed) {
|
|
61
|
+
impact = impact === "none" ? "low" : impact;
|
|
62
|
+
description = evaluation.message;
|
|
63
|
+
}
|
|
64
|
+
else if (impact !== "none" && trend !== "neutral") {
|
|
65
|
+
const trendStr = trend === "improved" ? "improved" : "degraded";
|
|
66
|
+
const direction = trend === "improved" ? "↓" : "↑";
|
|
67
|
+
description = `${trendStr} by ${Math.abs(deltaPercent ?? 0).toFixed(1)}% ${direction}`;
|
|
68
|
+
}
|
|
69
|
+
else if (baselineValue !== undefined) {
|
|
70
|
+
description = `${currentValue.toFixed(2)} (baseline: ${baselineValue.toFixed(2)})`;
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
description = `${currentValue.toFixed(2)} (no baseline)`;
|
|
74
|
+
}
|
|
75
|
+
return {
|
|
76
|
+
metricName,
|
|
77
|
+
category,
|
|
78
|
+
currentValue,
|
|
79
|
+
baselineValue,
|
|
80
|
+
delta,
|
|
81
|
+
deltaPercent,
|
|
82
|
+
trend,
|
|
83
|
+
impact,
|
|
84
|
+
description,
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
generateRecommendations(deltas, evaluations) {
|
|
88
|
+
const recommendations = [];
|
|
89
|
+
const highImpactDegraded = deltas.filter((d) => d.impact === "high" && d.trend === "degraded");
|
|
90
|
+
if (highImpactDegraded.length > 0) {
|
|
91
|
+
recommendations.push(`CRITICAL: ${highImpactDegraded.length} metrics have high-impact degradation:`, ...highImpactDegraded.map((d) => ` - ${d.metricName}: ${d.description}`));
|
|
92
|
+
}
|
|
93
|
+
const mediumImpactDegraded = deltas.filter((d) => d.impact === "medium" && d.trend === "degraded");
|
|
94
|
+
if (mediumImpactDegraded.length > 0) {
|
|
95
|
+
recommendations.push(`WARNING: ${mediumImpactDegraded.length} metrics have medium-impact degradation:`, ...mediumImpactDegraded.map((d) => ` - ${d.metricName}: ${d.description}`));
|
|
96
|
+
}
|
|
97
|
+
const failingEvaluations = evaluations.filter((e) => !e.passed);
|
|
98
|
+
if (failingEvaluations.length > 0) {
|
|
99
|
+
const indexFailures = failingEvaluations.filter((e) => e.category === "indexing");
|
|
100
|
+
if (indexFailures.length > 0) {
|
|
101
|
+
recommendations.push("Indexing performance issues detected. Consider:", " - Increasing indexing concurrency", " - Adding large generated files to ignore list", " - Reducing maxFileBytes threshold", " - Checking for tree-sitter query performance issues");
|
|
102
|
+
}
|
|
103
|
+
const qualityFailures = failingEvaluations.filter((e) => e.category === "quality");
|
|
104
|
+
if (qualityFailures.length > 0) {
|
|
105
|
+
recommendations.push("Quality metrics degraded. This may indicate:", " - Changes in symbol extraction logic", " - Modifications to tree-sitter queries", " - Regression in edge detection algorithms");
|
|
106
|
+
}
|
|
107
|
+
const performanceFailures = failingEvaluations.filter((e) => e.category === "performance");
|
|
108
|
+
if (performanceFailures.length > 0) {
|
|
109
|
+
recommendations.push("Runtime performance degraded. Consider:", " - Reviewing recent database query changes", " - Checking for N+1 query patterns", " - Optimizing graph traversal algorithms");
|
|
110
|
+
}
|
|
111
|
+
const coverageFailures = failingEvaluations.filter((e) => e.category === "coverage");
|
|
112
|
+
if (coverageFailures.length > 0) {
|
|
113
|
+
recommendations.push("Edge coverage degraded. Verify:", " - Call edge extraction queries are working correctly", " - Import resolution hasn't regressed", " - New code patterns are properly supported");
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
const improvedMetrics = deltas.filter((d) => d.trend === "improved");
|
|
117
|
+
if (improvedMetrics.length > 0 && recommendations.length === 0) {
|
|
118
|
+
recommendations.push(`All metrics passed! ${improvedMetrics.length} metrics improved.`);
|
|
119
|
+
}
|
|
120
|
+
return recommendations;
|
|
121
|
+
}
|
|
122
|
+
generateMarkdownReport(report) {
|
|
123
|
+
const lines = [];
|
|
124
|
+
lines.push("# Benchmark Regression Report");
|
|
125
|
+
lines.push("");
|
|
126
|
+
lines.push(`Generated: ${new Date().toISOString()}`);
|
|
127
|
+
lines.push("");
|
|
128
|
+
const statusEmoji = report.summary.passed ? "✅" : "❌";
|
|
129
|
+
lines.push(`## Summary ${statusEmoji}`);
|
|
130
|
+
lines.push("");
|
|
131
|
+
lines.push(`- **Status**: ${report.summary.passed ? "PASSED" : "FAILED"}`);
|
|
132
|
+
lines.push(`- **Total Metrics**: ${report.summary.totalMetrics}`);
|
|
133
|
+
lines.push(`- **Improved**: ${report.summary.improved}`);
|
|
134
|
+
lines.push(`- **Degraded**: ${report.summary.degraded}`);
|
|
135
|
+
lines.push(`- **Neutral**: ${report.summary.neutral}`);
|
|
136
|
+
lines.push(`- **Unknown**: ${report.summary.unknown}`);
|
|
137
|
+
lines.push("");
|
|
138
|
+
if (report.failingThresholds.length > 0) {
|
|
139
|
+
lines.push("## Failed Thresholds");
|
|
140
|
+
lines.push("");
|
|
141
|
+
for (const threshold of report.failingThresholds) {
|
|
142
|
+
lines.push(`- ❌ \`${threshold}\``);
|
|
143
|
+
}
|
|
144
|
+
lines.push("");
|
|
145
|
+
}
|
|
146
|
+
lines.push("## Metric Deltas");
|
|
147
|
+
lines.push("");
|
|
148
|
+
const categorized = new Map();
|
|
149
|
+
for (const delta of report.deltas) {
|
|
150
|
+
if (!categorized.has(delta.category)) {
|
|
151
|
+
categorized.set(delta.category, []);
|
|
152
|
+
}
|
|
153
|
+
categorized.get(delta.category).push(delta);
|
|
154
|
+
}
|
|
155
|
+
for (const [category, deltas] of categorized) {
|
|
156
|
+
lines.push(`### ${category}`);
|
|
157
|
+
lines.push("");
|
|
158
|
+
for (const delta of deltas) {
|
|
159
|
+
const impactEmoji = {
|
|
160
|
+
high: "🔴",
|
|
161
|
+
medium: "🟡",
|
|
162
|
+
low: "🟢",
|
|
163
|
+
none: "⚪",
|
|
164
|
+
}[delta.impact];
|
|
165
|
+
const trendEmoji = {
|
|
166
|
+
improved: "✓",
|
|
167
|
+
degraded: "✗",
|
|
168
|
+
neutral: "−",
|
|
169
|
+
unknown: "?",
|
|
170
|
+
}[delta.trend];
|
|
171
|
+
lines.push(`#### ${delta.metricName} ${impactEmoji} ${trendEmoji}`);
|
|
172
|
+
lines.push("");
|
|
173
|
+
lines.push(`- **Current**: ${delta.currentValue.toFixed(2)}`);
|
|
174
|
+
if (delta.baselineValue !== undefined) {
|
|
175
|
+
lines.push(`- **Baseline**: ${delta.baselineValue.toFixed(2)}`);
|
|
176
|
+
}
|
|
177
|
+
if (delta.deltaPercent !== undefined) {
|
|
178
|
+
lines.push(`- **Change**: ${delta.deltaPercent.toFixed(2)}%`);
|
|
179
|
+
}
|
|
180
|
+
lines.push(`- **Impact**: ${delta.impact}`);
|
|
181
|
+
lines.push(`- **Description**: ${delta.description}`);
|
|
182
|
+
lines.push("");
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
if (report.recommendations.length > 0) {
|
|
186
|
+
lines.push("## Recommendations");
|
|
187
|
+
lines.push("");
|
|
188
|
+
for (const recommendation of report.recommendations) {
|
|
189
|
+
lines.push(recommendation);
|
|
190
|
+
}
|
|
191
|
+
lines.push("");
|
|
192
|
+
}
|
|
193
|
+
return lines.join("\n");
|
|
194
|
+
}
|
|
195
|
+
generateJsonReport(report) {
|
|
196
|
+
return JSON.stringify(report, null, 2);
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
//# sourceMappingURL=regression.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"regression.js","sourceRoot":"","sources":["../../src/benchmark/regression.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export interface SmoothingConfig {
|
|
2
|
+
warmupRuns: number;
|
|
3
|
+
sampleRuns: number;
|
|
4
|
+
outlierMethod: "iqr" | "stddev" | "none";
|
|
5
|
+
iqrMultiplier: number;
|
|
6
|
+
}
|
|
7
|
+
export interface MetricMeasurement {
|
|
8
|
+
metricName: string;
|
|
9
|
+
values: number[];
|
|
10
|
+
}
|
|
11
|
+
export interface SmoothingResult {
|
|
12
|
+
metricName: string;
|
|
13
|
+
originalValues: number[];
|
|
14
|
+
smoothedValue: number;
|
|
15
|
+
outliersRemoved: number[];
|
|
16
|
+
stats: {
|
|
17
|
+
mean: number;
|
|
18
|
+
median: number;
|
|
19
|
+
stddev: number;
|
|
20
|
+
min: number;
|
|
21
|
+
max: number;
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
export declare class MetricSmoothing {
|
|
25
|
+
private config;
|
|
26
|
+
constructor(config: SmoothingConfig);
|
|
27
|
+
filterWarmup(measurements: Record<string, number[]>): Record<string, number[]>;
|
|
28
|
+
detectOutliers(values: number[]): number[];
|
|
29
|
+
private detectIQROutliers;
|
|
30
|
+
private detectStdDevOutliers;
|
|
31
|
+
private percentile;
|
|
32
|
+
smooth(measurements: Record<string, number[]>): Record<string, number>;
|
|
33
|
+
smoothMetric(metricName: string, values: number[]): SmoothingResult;
|
|
34
|
+
private calculateStats;
|
|
35
|
+
}
|
|
36
|
+
export declare function runBenchmarkWithSmoothing(config: SmoothingConfig, benchmarkFn: () => Promise<Record<string, number>>): Promise<{
|
|
37
|
+
smoothed: Record<string, number>;
|
|
38
|
+
raw: Record<string, number[]>;
|
|
39
|
+
}>;
|
|
40
|
+
//# sourceMappingURL=smoothing.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"smoothing.d.ts","sourceRoot":"","sources":["../../src/benchmark/smoothing.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,eAAe;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,CAAC;IACzC,aAAa,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,iBAAiB;IAChC,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB;AAED,MAAM,WAAW,eAAe;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,cAAc,EAAE,MAAM,EAAE,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,KAAK,EAAE;QACL,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC;QACf,GAAG,EAAE,MAAM,CAAC;QACZ,GAAG,EAAE,MAAM,CAAC;KACb,CAAC;CACH;AAED,qBAAa,eAAe;IAC1B,OAAO,CAAC,MAAM,CAAkB;gBAEpB,MAAM,EAAE,eAAe;IAInC,YAAY,CACV,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,GACrC,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC;IAc3B,cAAc,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE;IAkB1C,OAAO,CAAC,iBAAiB;IAYzB,OAAO,CAAC,oBAAoB;IAU5B,OAAO,CAAC,UAAU;IAalB,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC;IAWtE,YAAY,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,eAAe;IAenE,OAAO,CAAC,cAAc;CAyBvB;AAED,wBAAsB,yBAAyB,CAC7C,MAAM,EAAE,eAAe,EACvB,WAAW,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,GACjD,OAAO,CAAC;IACT,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;CAC/B,CAAC,CAsBD"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
export class MetricSmoothing {
|
|
2
|
+
config;
|
|
3
|
+
constructor(config) {
|
|
4
|
+
this.config = config;
|
|
5
|
+
}
|
|
6
|
+
filterWarmup(measurements) {
|
|
7
|
+
const filtered = {};
|
|
8
|
+
for (const [metricName, values] of Object.entries(measurements)) {
|
|
9
|
+
if (values.length > this.config.warmupRuns) {
|
|
10
|
+
filtered[metricName] = values.slice(this.config.warmupRuns);
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
filtered[metricName] = values;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
return filtered;
|
|
17
|
+
}
|
|
18
|
+
detectOutliers(values) {
|
|
19
|
+
if (this.config.outlierMethod === "none") {
|
|
20
|
+
return [];
|
|
21
|
+
}
|
|
22
|
+
if (values.length < 3) {
|
|
23
|
+
return [];
|
|
24
|
+
}
|
|
25
|
+
if (this.config.outlierMethod === "iqr") {
|
|
26
|
+
return this.detectIQROutliers(values);
|
|
27
|
+
}
|
|
28
|
+
else if (this.config.outlierMethod === "stddev") {
|
|
29
|
+
return this.detectStdDevOutliers(values);
|
|
30
|
+
}
|
|
31
|
+
return [];
|
|
32
|
+
}
|
|
33
|
+
detectIQROutliers(values) {
|
|
34
|
+
const sorted = [...values].sort((a, b) => a - b);
|
|
35
|
+
const q1 = this.percentile(sorted, 25);
|
|
36
|
+
const q3 = this.percentile(sorted, 75);
|
|
37
|
+
const iqr = q3 - q1;
|
|
38
|
+
const lowerBound = q1 - this.config.iqrMultiplier * iqr;
|
|
39
|
+
const upperBound = q3 + this.config.iqrMultiplier * iqr;
|
|
40
|
+
return values.filter((v) => v < lowerBound || v > upperBound);
|
|
41
|
+
}
|
|
42
|
+
detectStdDevOutliers(values) {
|
|
43
|
+
const mean = values.reduce((sum, v) => sum + v, 0) / values.length;
|
|
44
|
+
const variance = values.reduce((sum, v) => sum + Math.pow(v - mean, 2), 0) / values.length;
|
|
45
|
+
const stddev = Math.sqrt(variance);
|
|
46
|
+
const threshold = 2 * stddev;
|
|
47
|
+
return values.filter((v) => Math.abs(v - mean) > threshold);
|
|
48
|
+
}
|
|
49
|
+
percentile(sorted, p) {
|
|
50
|
+
const index = (p / 100) * (sorted.length - 1);
|
|
51
|
+
const lower = Math.floor(index);
|
|
52
|
+
const upper = Math.ceil(index);
|
|
53
|
+
const weight = index - lower;
|
|
54
|
+
if (upper >= sorted.length) {
|
|
55
|
+
return sorted[sorted.length - 1];
|
|
56
|
+
}
|
|
57
|
+
return sorted[lower] * (1 - weight) + sorted[upper] * weight;
|
|
58
|
+
}
|
|
59
|
+
smooth(measurements) {
|
|
60
|
+
const results = {};
|
|
61
|
+
for (const [metricName, values] of Object.entries(measurements)) {
|
|
62
|
+
const result = this.smoothMetric(metricName, values);
|
|
63
|
+
results[metricName] = result.smoothedValue;
|
|
64
|
+
}
|
|
65
|
+
return results;
|
|
66
|
+
}
|
|
67
|
+
smoothMetric(metricName, values) {
|
|
68
|
+
const outliers = this.detectOutliers(values);
|
|
69
|
+
const filteredValues = values.filter((v) => !outliers.includes(v));
|
|
70
|
+
const stats = this.calculateStats(filteredValues);
|
|
71
|
+
return {
|
|
72
|
+
metricName,
|
|
73
|
+
originalValues: values,
|
|
74
|
+
smoothedValue: stats.median,
|
|
75
|
+
outliersRemoved: outliers,
|
|
76
|
+
stats,
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
calculateStats(values) {
|
|
80
|
+
if (values.length === 0) {
|
|
81
|
+
return {
|
|
82
|
+
mean: 0,
|
|
83
|
+
median: 0,
|
|
84
|
+
stddev: 0,
|
|
85
|
+
min: 0,
|
|
86
|
+
max: 0,
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
const sorted = [...values].sort((a, b) => a - b);
|
|
90
|
+
const sum = values.reduce((acc, v) => acc + v, 0);
|
|
91
|
+
const mean = sum / values.length;
|
|
92
|
+
const variance = values.reduce((acc, v) => acc + Math.pow(v - mean, 2), 0) / values.length;
|
|
93
|
+
return {
|
|
94
|
+
mean,
|
|
95
|
+
median: this.percentile(sorted, 50),
|
|
96
|
+
stddev: Math.sqrt(variance),
|
|
97
|
+
min: sorted[0],
|
|
98
|
+
max: sorted[sorted.length - 1],
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
export async function runBenchmarkWithSmoothing(config, benchmarkFn) {
|
|
103
|
+
const measurements = {};
|
|
104
|
+
for (let i = 0; i < config.warmupRuns + config.sampleRuns; i++) {
|
|
105
|
+
const result = await benchmarkFn();
|
|
106
|
+
for (const [metricName, value] of Object.entries(result)) {
|
|
107
|
+
if (!measurements[metricName]) {
|
|
108
|
+
measurements[metricName] = [];
|
|
109
|
+
}
|
|
110
|
+
measurements[metricName].push(value);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
const smoother = new MetricSmoothing(config);
|
|
114
|
+
const filtered = smoother.filterWarmup(measurements);
|
|
115
|
+
const smoothed = smoother.smooth(filtered);
|
|
116
|
+
return {
|
|
117
|
+
smoothed,
|
|
118
|
+
raw: measurements,
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
//# sourceMappingURL=smoothing.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"smoothing.js","sourceRoot":"","sources":["../../src/benchmark/smoothing.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
export interface MetricThreshold {
|
|
2
|
+
minValue?: number;
|
|
3
|
+
maxMs?: number;
|
|
4
|
+
maxTokens?: number;
|
|
5
|
+
minPercent?: number;
|
|
6
|
+
trend: "higher-is-better" | "lower-is-better";
|
|
7
|
+
allowableIncreasePercent?: number;
|
|
8
|
+
allowableDecreasePercent?: number;
|
|
9
|
+
}
|
|
10
|
+
export interface ThresholdCategory {
|
|
11
|
+
[metricName: string]: MetricThreshold;
|
|
12
|
+
}
|
|
13
|
+
export interface BenchmarkThresholds {
|
|
14
|
+
version: string;
|
|
15
|
+
description: string;
|
|
16
|
+
thresholds: {
|
|
17
|
+
indexing: ThresholdCategory;
|
|
18
|
+
quality: ThresholdCategory;
|
|
19
|
+
performance: ThresholdCategory;
|
|
20
|
+
tokenEfficiency: ThresholdCategory;
|
|
21
|
+
coverage: ThresholdCategory;
|
|
22
|
+
};
|
|
23
|
+
smoothing: {
|
|
24
|
+
warmupRuns: number;
|
|
25
|
+
sampleRuns: number;
|
|
26
|
+
outlierMethod: "iqr" | "stddev" | "none";
|
|
27
|
+
iqrMultiplier: number;
|
|
28
|
+
};
|
|
29
|
+
baseline: {
|
|
30
|
+
filePath: string;
|
|
31
|
+
autoUpdateOnPass: boolean;
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
export interface ThresholdEvaluation {
|
|
35
|
+
metricName: string;
|
|
36
|
+
category: string;
|
|
37
|
+
currentValue: number;
|
|
38
|
+
baselineValue?: number;
|
|
39
|
+
threshold: MetricThreshold;
|
|
40
|
+
passed: boolean;
|
|
41
|
+
delta?: number;
|
|
42
|
+
deltaPercent?: number;
|
|
43
|
+
message: string;
|
|
44
|
+
}
|
|
45
|
+
export interface ThresholdEvaluationResult {
|
|
46
|
+
passed: boolean;
|
|
47
|
+
evaluations: ThresholdEvaluation[];
|
|
48
|
+
summary: {
|
|
49
|
+
total: number;
|
|
50
|
+
passed: number;
|
|
51
|
+
failed: number;
|
|
52
|
+
warnings: number;
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
export declare class ThresholdEvaluator {
|
|
56
|
+
private thresholds;
|
|
57
|
+
constructor(thresholds: BenchmarkThresholds);
|
|
58
|
+
evaluate(currentMetrics: Record<string, number>, baselineMetrics?: Record<string, number>): ThresholdEvaluationResult;
|
|
59
|
+
private evaluateMetric;
|
|
60
|
+
}
|
|
61
|
+
export declare function loadThresholdConfig(configPath: string): BenchmarkThresholds;
|
|
62
|
+
export declare function loadBaselineMetrics(baselinePath: string): Record<string, number> | undefined;
|
|
63
|
+
export declare function saveBaselineMetrics(baselinePath: string, results: unknown): void;
|
|
64
|
+
//# sourceMappingURL=threshold.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"threshold.d.ts","sourceRoot":"","sources":["../../src/benchmark/threshold.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,kBAAkB,GAAG,iBAAiB,CAAC;IAC9C,wBAAwB,CAAC,EAAE,MAAM,CAAC;IAClC,wBAAwB,CAAC,EAAE,MAAM,CAAC;CACnC;AAED,MAAM,WAAW,iBAAiB;IAChC,CAAC,UAAU,EAAE,MAAM,GAAG,eAAe,CAAC;CACvC;AAED,MAAM,WAAW,mBAAmB;IAClC,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE;QACV,QAAQ,EAAE,iBAAiB,CAAC;QAC5B,OAAO,EAAE,iBAAiB,CAAC;QAC3B,WAAW,EAAE,iBAAiB,CAAC;QAC/B,eAAe,EAAE,iBAAiB,CAAC;QACnC,QAAQ,EAAE,iBAAiB,CAAC;KAC7B,CAAC;IACF,SAAS,EAAE;QACT,UAAU,EAAE,MAAM,CAAC;QACnB,UAAU,EAAE,MAAM,CAAC;QACnB,aAAa,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,CAAC;QACzC,aAAa,EAAE,MAAM,CAAC;KACvB,CAAC;IACF,QAAQ,EAAE;QACR,QAAQ,EAAE,MAAM,CAAC;QACjB,gBAAgB,EAAE,OAAO,CAAC;KAC3B,CAAC;CACH;AAED,MAAM,WAAW,mBAAmB;IAClC,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,eAAe,CAAC;IAC3B,MAAM,EAAE,OAAO,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,yBAAyB;IACxC,MAAM,EAAE,OAAO,CAAC;IAChB,WAAW,EAAE,mBAAmB,EAAE,CAAC;IACnC,OAAO,EAAE;QACP,KAAK,EAAE,MAAM,CAAC;QACd,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC;QACf,QAAQ,EAAE,MAAM,CAAC;KAClB,CAAC;CACH;AAED,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,UAAU,CAAsB;gBAE5B,UAAU,EAAE,mBAAmB;IAI3C,QAAQ,CACN,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACtC,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GACvC,yBAAyB;IAuC5B,OAAO,CAAC,cAAc;CAyGvB;AAED,wBAAgB,mBAAmB,CAAC,UAAU,EAAE,MAAM,GAAG,mBAAmB,CAG3E;AAED,wBAAgB,mBAAmB,CACjC,YAAY,EAAE,MAAM,GACnB,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,SAAS,CAmDpC;AAED,wBAAgB,mBAAmB,CACjC,YAAY,EAAE,MAAM,EACpB,OAAO,EAAE,OAAO,GACf,IAAI,CAON"}
|