@vpxa/kb 0.1.15 → 0.1.16

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.
Files changed (449) hide show
  1. package/README.md +62 -15
  2. package/package.json +5 -1
  3. package/packages/analyzers/dist/blast-radius-analyzer.d.ts +1 -2
  4. package/packages/analyzers/dist/blast-radius-analyzer.js +1 -2
  5. package/packages/analyzers/dist/dependency-analyzer.d.ts +2 -3
  6. package/packages/analyzers/dist/dependency-analyzer.js +3 -4
  7. package/packages/analyzers/dist/diagram-generator.d.ts +1 -2
  8. package/packages/analyzers/dist/diagram-generator.js +1 -2
  9. package/packages/analyzers/dist/entry-point-analyzer.d.ts +1 -2
  10. package/packages/analyzers/dist/entry-point-analyzer.js +3 -4
  11. package/packages/analyzers/dist/knowledge-producer.d.ts +6 -2
  12. package/packages/analyzers/dist/knowledge-producer.js +4 -3
  13. package/packages/analyzers/dist/pattern-analyzer.d.ts +1 -2
  14. package/packages/analyzers/dist/pattern-analyzer.js +2 -3
  15. package/packages/analyzers/dist/regex-call-graph.d.ts +1 -2
  16. package/packages/analyzers/dist/regex-call-graph.js +1 -2
  17. package/packages/analyzers/dist/structure-analyzer.d.ts +1 -2
  18. package/packages/analyzers/dist/structure-analyzer.js +1 -2
  19. package/packages/analyzers/dist/symbol-analyzer.d.ts +3 -3
  20. package/packages/analyzers/dist/symbol-analyzer.js +8 -7
  21. package/packages/analyzers/dist/ts-call-graph.d.ts +1 -2
  22. package/packages/analyzers/dist/ts-call-graph.js +1 -2
  23. package/packages/analyzers/dist/types.d.ts +1 -2
  24. package/packages/chunker/dist/call-graph-extractor.d.ts +3 -3
  25. package/packages/chunker/dist/call-graph-extractor.js +1 -2
  26. package/packages/chunker/dist/chunker-factory.d.ts +12 -4
  27. package/packages/chunker/dist/chunker-factory.js +1 -2
  28. package/packages/chunker/dist/chunker.interface.d.ts +1 -2
  29. package/packages/chunker/dist/code-chunker.d.ts +1 -2
  30. package/packages/chunker/dist/code-chunker.js +1 -2
  31. package/packages/chunker/dist/extractors/call-extractor.d.ts +24 -0
  32. package/packages/chunker/dist/extractors/call-extractor.js +1 -0
  33. package/packages/chunker/dist/extractors/entry-point-detector.d.ts +14 -0
  34. package/packages/chunker/dist/extractors/entry-point-detector.js +1 -0
  35. package/packages/chunker/dist/extractors/import-extractor.d.ts +14 -0
  36. package/packages/chunker/dist/extractors/import-extractor.js +1 -0
  37. package/packages/chunker/dist/extractors/pattern-detector.d.ts +14 -0
  38. package/packages/chunker/dist/extractors/pattern-detector.js +1 -0
  39. package/packages/chunker/dist/extractors/scope-resolver.d.ts +26 -0
  40. package/packages/chunker/dist/extractors/scope-resolver.js +1 -0
  41. package/packages/chunker/dist/extractors/symbol-extractor.d.ts +14 -0
  42. package/packages/chunker/dist/extractors/symbol-extractor.js +1 -0
  43. package/packages/chunker/dist/extractors/types.d.ts +36 -0
  44. package/packages/chunker/dist/extractors/types.js +1 -0
  45. package/packages/chunker/dist/generic-chunker.d.ts +1 -2
  46. package/packages/chunker/dist/generic-chunker.js +1 -2
  47. package/packages/chunker/dist/index.d.ts +15 -4
  48. package/packages/chunker/dist/index.js +1 -1
  49. package/packages/chunker/dist/markdown-chunker.d.ts +1 -2
  50. package/packages/chunker/dist/markdown-chunker.js +1 -2
  51. package/packages/chunker/dist/wasm/languages.d.ts +18 -0
  52. package/packages/chunker/dist/wasm/languages.js +1 -0
  53. package/packages/chunker/dist/wasm/query-executor.d.ts +70 -0
  54. package/packages/chunker/dist/wasm/query-executor.js +1 -0
  55. package/packages/chunker/dist/wasm/runtime.d.ts +44 -0
  56. package/packages/chunker/dist/wasm/runtime.js +1 -0
  57. package/packages/chunker/dist/wasm/types.d.ts +84 -0
  58. package/packages/chunker/dist/wasm/types.js +1 -0
  59. package/packages/chunker/dist/wasm-chunker.d.ts +23 -0
  60. package/packages/chunker/dist/wasm-chunker.js +6 -0
  61. package/packages/chunker/src/queries/go/calls.scm +11 -0
  62. package/packages/chunker/src/queries/go/entry-points.scm +20 -0
  63. package/packages/chunker/src/queries/go/imports.scm +6 -0
  64. package/packages/chunker/src/queries/go/patterns.scm +25 -0
  65. package/packages/chunker/src/queries/go/symbols.scm +26 -0
  66. package/packages/chunker/src/queries/java/calls.scm +10 -0
  67. package/packages/chunker/src/queries/java/entry-points.scm +27 -0
  68. package/packages/chunker/src/queries/java/imports.scm +11 -0
  69. package/packages/chunker/src/queries/java/patterns.scm +27 -0
  70. package/packages/chunker/src/queries/java/symbols.scm +28 -0
  71. package/packages/chunker/src/queries/javascript/calls.scm +21 -0
  72. package/packages/chunker/src/queries/javascript/entry-points.scm +31 -0
  73. package/packages/chunker/src/queries/javascript/imports.scm +32 -0
  74. package/packages/chunker/src/queries/javascript/patterns.scm +28 -0
  75. package/packages/chunker/src/queries/javascript/symbols.scm +52 -0
  76. package/packages/chunker/src/queries/python/calls.scm +11 -0
  77. package/packages/chunker/src/queries/python/entry-points.scm +21 -0
  78. package/packages/chunker/src/queries/python/imports.scm +14 -0
  79. package/packages/chunker/src/queries/python/patterns.scm +25 -0
  80. package/packages/chunker/src/queries/python/symbols.scm +17 -0
  81. package/packages/chunker/src/queries/rust/calls.scm +20 -0
  82. package/packages/chunker/src/queries/rust/entry-points.scm +7 -0
  83. package/packages/chunker/src/queries/rust/imports.scm +26 -0
  84. package/packages/chunker/src/queries/rust/patterns.scm +18 -0
  85. package/packages/chunker/src/queries/rust/symbols.scm +73 -0
  86. package/packages/chunker/src/queries/typescript/calls.scm +21 -0
  87. package/packages/chunker/src/queries/typescript/entry-points.scm +48 -0
  88. package/packages/chunker/src/queries/typescript/imports.scm +35 -0
  89. package/packages/chunker/src/queries/typescript/patterns.scm +47 -0
  90. package/packages/chunker/src/queries/typescript/symbols.scm +79 -0
  91. package/packages/chunker/wasm/tree-sitter-go.wasm +0 -0
  92. package/packages/chunker/wasm/tree-sitter-java.wasm +0 -0
  93. package/packages/chunker/wasm/tree-sitter-javascript.wasm +0 -0
  94. package/packages/chunker/wasm/tree-sitter-python.wasm +0 -0
  95. package/packages/chunker/wasm/tree-sitter-rust.wasm +0 -0
  96. package/packages/chunker/wasm/tree-sitter-typescript.wasm +0 -0
  97. package/packages/chunker/wasm/tree-sitter.wasm +0 -0
  98. package/packages/cli/dist/commands/analyze.d.ts +1 -2
  99. package/packages/cli/dist/commands/analyze.js +1 -2
  100. package/packages/cli/dist/commands/context-cmds.d.ts +1 -2
  101. package/packages/cli/dist/commands/context-cmds.js +1 -2
  102. package/packages/cli/dist/commands/environment.d.ts +1 -2
  103. package/packages/cli/dist/commands/environment.js +1 -2
  104. package/packages/cli/dist/commands/execution.d.ts +1 -2
  105. package/packages/cli/dist/commands/execution.js +1 -2
  106. package/packages/cli/dist/commands/graph.d.ts +1 -2
  107. package/packages/cli/dist/commands/graph.js +1 -2
  108. package/packages/cli/dist/commands/init/adapters.d.ts +4 -3
  109. package/packages/cli/dist/commands/init/adapters.js +1 -2
  110. package/packages/cli/dist/commands/init/config.d.ts +1 -2
  111. package/packages/cli/dist/commands/init/config.js +3 -4
  112. package/packages/cli/dist/commands/init/constants.d.ts +18 -0
  113. package/packages/cli/dist/commands/init/constants.js +1 -0
  114. package/packages/cli/dist/commands/init/curated.d.ts +1 -2
  115. package/packages/cli/dist/commands/init/curated.js +1 -2
  116. package/packages/cli/dist/commands/init/global.d.ts +34 -0
  117. package/packages/cli/dist/commands/init/global.js +5 -0
  118. package/packages/cli/dist/commands/init/index.d.ts +7 -2
  119. package/packages/cli/dist/commands/init/index.js +5 -3
  120. package/packages/cli/dist/commands/init/scaffold.d.ts +1 -2
  121. package/packages/cli/dist/commands/init/scaffold.js +1 -2
  122. package/packages/cli/dist/commands/init/templates.d.ts +3 -4
  123. package/packages/cli/dist/commands/init/templates.js +106 -243
  124. package/packages/cli/dist/commands/knowledge.d.ts +1 -2
  125. package/packages/cli/dist/commands/knowledge.js +1 -2
  126. package/packages/cli/dist/commands/search.d.ts +1 -2
  127. package/packages/cli/dist/commands/search.js +1 -2
  128. package/packages/cli/dist/commands/system.d.ts +1 -2
  129. package/packages/cli/dist/commands/system.js +3 -4
  130. package/packages/cli/dist/commands/workspace.d.ts +1 -2
  131. package/packages/cli/dist/commands/workspace.js +1 -2
  132. package/packages/cli/dist/context.d.ts +1 -2
  133. package/packages/cli/dist/context.js +1 -2
  134. package/packages/cli/dist/helpers.d.ts +1 -2
  135. package/packages/cli/dist/helpers.js +1 -2
  136. package/packages/cli/dist/index.d.ts +1 -2
  137. package/packages/cli/dist/index.js +1 -2
  138. package/packages/cli/dist/kb-init.d.ts +1 -2
  139. package/packages/cli/dist/kb-init.js +1 -2
  140. package/packages/cli/dist/types.d.ts +1 -2
  141. package/packages/core/dist/constants.d.ts +23 -2
  142. package/packages/core/dist/constants.js +1 -2
  143. package/packages/core/dist/content-detector.d.ts +1 -2
  144. package/packages/core/dist/content-detector.js +1 -2
  145. package/packages/core/dist/errors.d.ts +1 -2
  146. package/packages/core/dist/errors.js +1 -2
  147. package/packages/core/dist/global-registry.d.ts +62 -0
  148. package/packages/core/dist/global-registry.js +1 -0
  149. package/packages/core/dist/index.d.ts +4 -3
  150. package/packages/core/dist/index.js +1 -1
  151. package/packages/core/dist/logger.d.ts +4 -2
  152. package/packages/core/dist/logger.js +1 -2
  153. package/packages/core/dist/types.d.ts +1 -2
  154. package/packages/core/dist/types.js +1 -2
  155. package/packages/embeddings/dist/embedder.interface.d.ts +1 -2
  156. package/packages/embeddings/dist/onnx-embedder.d.ts +1 -2
  157. package/packages/embeddings/dist/onnx-embedder.js +1 -2
  158. package/packages/enterprise-bridge/dist/cache.d.ts +1 -2
  159. package/packages/enterprise-bridge/dist/cache.js +1 -2
  160. package/packages/enterprise-bridge/dist/er-client.d.ts +1 -2
  161. package/packages/enterprise-bridge/dist/er-client.js +1 -2
  162. package/packages/enterprise-bridge/dist/evolution-collector.d.ts +1 -2
  163. package/packages/enterprise-bridge/dist/evolution-collector.js +1 -2
  164. package/packages/enterprise-bridge/dist/policy-store.d.ts +1 -2
  165. package/packages/enterprise-bridge/dist/policy-store.js +1 -2
  166. package/packages/enterprise-bridge/dist/push-adapter.d.ts +1 -2
  167. package/packages/enterprise-bridge/dist/push-adapter.js +1 -2
  168. package/packages/enterprise-bridge/dist/result-merger.d.ts +1 -2
  169. package/packages/enterprise-bridge/dist/result-merger.js +1 -2
  170. package/packages/enterprise-bridge/dist/types.d.ts +1 -2
  171. package/packages/enterprise-bridge/dist/types.js +1 -2
  172. package/packages/indexer/dist/file-hasher.d.ts +1 -2
  173. package/packages/indexer/dist/file-hasher.js +1 -2
  174. package/packages/indexer/dist/filesystem-crawler.d.ts +1 -2
  175. package/packages/indexer/dist/filesystem-crawler.js +1 -2
  176. package/packages/indexer/dist/graph-extractor.d.ts +1 -2
  177. package/packages/indexer/dist/graph-extractor.js +1 -2
  178. package/packages/indexer/dist/incremental-indexer.d.ts +1 -2
  179. package/packages/indexer/dist/incremental-indexer.js +1 -2
  180. package/packages/server/dist/config.d.ts +1 -2
  181. package/packages/server/dist/config.js +1 -2
  182. package/packages/server/dist/cross-workspace.d.ts +43 -0
  183. package/packages/server/dist/cross-workspace.js +1 -0
  184. package/packages/server/dist/curated-manager.d.ts +2 -3
  185. package/packages/server/dist/curated-manager.js +4 -5
  186. package/packages/server/dist/index.js +1 -2
  187. package/packages/server/dist/replay-interceptor.d.ts +1 -2
  188. package/packages/server/dist/replay-interceptor.js +1 -2
  189. package/packages/server/dist/resources/resources.d.ts +1 -2
  190. package/packages/server/dist/resources/resources.js +1 -2
  191. package/packages/server/dist/server.d.ts +4 -2
  192. package/packages/server/dist/server.js +1 -2
  193. package/packages/server/dist/tools/analyze.tools.d.ts +1 -2
  194. package/packages/server/dist/tools/analyze.tools.js +1 -2
  195. package/packages/server/dist/tools/audit.tool.d.ts +1 -2
  196. package/packages/server/dist/tools/audit.tool.js +1 -2
  197. package/packages/server/dist/tools/bridge.tools.d.ts +1 -2
  198. package/packages/server/dist/tools/bridge.tools.js +1 -2
  199. package/packages/server/dist/tools/evolution.tools.d.ts +1 -2
  200. package/packages/server/dist/tools/evolution.tools.js +1 -2
  201. package/packages/server/dist/tools/forge.tools.d.ts +1 -2
  202. package/packages/server/dist/tools/forge.tools.js +5 -6
  203. package/packages/server/dist/tools/forget.tool.d.ts +1 -2
  204. package/packages/server/dist/tools/forget.tool.js +1 -2
  205. package/packages/server/dist/tools/graph.tool.d.ts +1 -2
  206. package/packages/server/dist/tools/graph.tool.js +1 -2
  207. package/packages/server/dist/tools/list.tool.d.ts +1 -2
  208. package/packages/server/dist/tools/list.tool.js +1 -2
  209. package/packages/server/dist/tools/lookup.tool.d.ts +1 -2
  210. package/packages/server/dist/tools/lookup.tool.js +1 -2
  211. package/packages/server/dist/tools/onboard.tool.d.ts +1 -2
  212. package/packages/server/dist/tools/onboard.tool.js +1 -2
  213. package/packages/server/dist/tools/policy.tools.d.ts +1 -2
  214. package/packages/server/dist/tools/policy.tools.js +1 -2
  215. package/packages/server/dist/tools/produce.tool.d.ts +1 -2
  216. package/packages/server/dist/tools/produce.tool.js +1 -2
  217. package/packages/server/dist/tools/read.tool.d.ts +1 -2
  218. package/packages/server/dist/tools/read.tool.js +2 -3
  219. package/packages/server/dist/tools/reindex.tool.d.ts +1 -2
  220. package/packages/server/dist/tools/reindex.tool.js +3 -3
  221. package/packages/server/dist/tools/remember.tool.d.ts +1 -2
  222. package/packages/server/dist/tools/remember.tool.js +1 -2
  223. package/packages/server/dist/tools/replay.tool.d.ts +1 -2
  224. package/packages/server/dist/tools/replay.tool.js +1 -2
  225. package/packages/server/dist/tools/search.tool.d.ts +1 -2
  226. package/packages/server/dist/tools/search.tool.js +4 -5
  227. package/packages/server/dist/tools/status.tool.d.ts +7 -3
  228. package/packages/server/dist/tools/status.tool.js +2 -3
  229. package/packages/server/dist/tools/toolkit.tools.d.ts +1 -2
  230. package/packages/server/dist/tools/toolkit.tools.js +19 -19
  231. package/packages/server/dist/tools/update.tool.d.ts +1 -2
  232. package/packages/server/dist/tools/update.tool.js +1 -2
  233. package/packages/server/dist/tools/utility.tools.d.ts +1 -2
  234. package/packages/server/dist/tools/utility.tools.js +2 -3
  235. package/packages/server/dist/version-check.d.ts +1 -2
  236. package/packages/server/dist/version-check.js +1 -2
  237. package/packages/store/dist/graph-store.interface.d.ts +1 -2
  238. package/packages/store/dist/lance-store.d.ts +1 -2
  239. package/packages/store/dist/lance-store.js +1 -2
  240. package/packages/store/dist/sqlite-graph-store.d.ts +1 -2
  241. package/packages/store/dist/sqlite-graph-store.js +6 -7
  242. package/packages/store/dist/store-factory.d.ts +1 -2
  243. package/packages/store/dist/store-factory.js +1 -2
  244. package/packages/store/dist/store.interface.d.ts +1 -2
  245. package/packages/tools/dist/audit.d.ts +1 -2
  246. package/packages/tools/dist/audit.js +1 -2
  247. package/packages/tools/dist/batch.d.ts +1 -2
  248. package/packages/tools/dist/batch.js +1 -2
  249. package/packages/tools/dist/changelog.d.ts +1 -2
  250. package/packages/tools/dist/changelog.js +2 -3
  251. package/packages/tools/dist/check.d.ts +1 -2
  252. package/packages/tools/dist/check.js +2 -3
  253. package/packages/tools/dist/checkpoint.d.ts +1 -2
  254. package/packages/tools/dist/checkpoint.js +1 -2
  255. package/packages/tools/dist/codemod.d.ts +1 -2
  256. package/packages/tools/dist/codemod.js +1 -2
  257. package/packages/tools/dist/compact.d.ts +1 -2
  258. package/packages/tools/dist/compact.js +1 -2
  259. package/packages/tools/dist/data-transform.d.ts +1 -2
  260. package/packages/tools/dist/data-transform.js +1 -2
  261. package/packages/tools/dist/dead-symbols.d.ts +1 -2
  262. package/packages/tools/dist/dead-symbols.js +2 -3
  263. package/packages/tools/dist/delegate.d.ts +1 -2
  264. package/packages/tools/dist/delegate.js +1 -2
  265. package/packages/tools/dist/diff-parse.d.ts +1 -2
  266. package/packages/tools/dist/diff-parse.js +1 -2
  267. package/packages/tools/dist/digest.d.ts +1 -2
  268. package/packages/tools/dist/digest.js +1 -2
  269. package/packages/tools/dist/dogfood-log.d.ts +49 -0
  270. package/packages/tools/dist/dogfood-log.js +2 -0
  271. package/packages/tools/dist/encode.d.ts +1 -2
  272. package/packages/tools/dist/encode.js +1 -2
  273. package/packages/tools/dist/env-info.d.ts +1 -2
  274. package/packages/tools/dist/env-info.js +1 -2
  275. package/packages/tools/dist/eval.d.ts +1 -2
  276. package/packages/tools/dist/eval.js +1 -2
  277. package/packages/tools/dist/evidence-map.d.ts +1 -2
  278. package/packages/tools/dist/evidence-map.js +2 -3
  279. package/packages/tools/dist/file-cache.d.ts +1 -2
  280. package/packages/tools/dist/file-cache.js +1 -2
  281. package/packages/tools/dist/file-summary.d.ts +17 -2
  282. package/packages/tools/dist/file-summary.js +2 -3
  283. package/packages/tools/dist/file-walk.d.ts +1 -2
  284. package/packages/tools/dist/file-walk.js +1 -2
  285. package/packages/tools/dist/find-examples.d.ts +1 -2
  286. package/packages/tools/dist/find-examples.js +1 -2
  287. package/packages/tools/dist/find.d.ts +1 -2
  288. package/packages/tools/dist/find.js +1 -2
  289. package/packages/tools/dist/forge-classify.d.ts +1 -2
  290. package/packages/tools/dist/forge-classify.js +2 -3
  291. package/packages/tools/dist/forge-ground.d.ts +1 -2
  292. package/packages/tools/dist/forge-ground.js +1 -2
  293. package/packages/tools/dist/git-context.d.ts +1 -2
  294. package/packages/tools/dist/git-context.js +1 -2
  295. package/packages/tools/dist/graph-query.d.ts +1 -2
  296. package/packages/tools/dist/graph-query.js +1 -2
  297. package/packages/tools/dist/guide.d.ts +1 -2
  298. package/packages/tools/dist/guide.js +1 -2
  299. package/packages/tools/dist/health.d.ts +1 -2
  300. package/packages/tools/dist/health.js +1 -2
  301. package/packages/tools/dist/http-request.d.ts +1 -2
  302. package/packages/tools/dist/http-request.js +1 -2
  303. package/packages/tools/dist/index.d.ts +2 -1
  304. package/packages/tools/dist/index.js +1 -1
  305. package/packages/tools/dist/lane.d.ts +1 -2
  306. package/packages/tools/dist/lane.js +3 -4
  307. package/packages/tools/dist/measure.d.ts +4 -3
  308. package/packages/tools/dist/measure.js +2 -3
  309. package/packages/tools/dist/onboard.d.ts +1 -2
  310. package/packages/tools/dist/onboard.js +14 -15
  311. package/packages/tools/dist/parse-output.d.ts +1 -2
  312. package/packages/tools/dist/parse-output.js +2 -3
  313. package/packages/tools/dist/path-resolver.d.ts +1 -2
  314. package/packages/tools/dist/path-resolver.js +1 -2
  315. package/packages/tools/dist/process-manager.d.ts +1 -2
  316. package/packages/tools/dist/process-manager.js +1 -2
  317. package/packages/tools/dist/queue.d.ts +1 -2
  318. package/packages/tools/dist/queue.js +1 -2
  319. package/packages/tools/dist/regex-test.d.ts +1 -2
  320. package/packages/tools/dist/regex-test.js +1 -2
  321. package/packages/tools/dist/rename.d.ts +1 -2
  322. package/packages/tools/dist/rename.js +1 -2
  323. package/packages/tools/dist/replay.d.ts +2 -3
  324. package/packages/tools/dist/replay.js +4 -5
  325. package/packages/tools/dist/response-envelope.d.ts +1 -2
  326. package/packages/tools/dist/response-envelope.js +1 -2
  327. package/packages/tools/dist/schema-validate.d.ts +1 -2
  328. package/packages/tools/dist/schema-validate.js +1 -2
  329. package/packages/tools/dist/scope-map.d.ts +1 -2
  330. package/packages/tools/dist/scope-map.js +1 -2
  331. package/packages/tools/dist/snippet.d.ts +1 -2
  332. package/packages/tools/dist/snippet.js +1 -2
  333. package/packages/tools/dist/stash.d.ts +1 -2
  334. package/packages/tools/dist/stash.js +1 -2
  335. package/packages/tools/dist/stratum-card.d.ts +1 -2
  336. package/packages/tools/dist/stratum-card.js +1 -2
  337. package/packages/tools/dist/symbol.d.ts +3 -2
  338. package/packages/tools/dist/symbol.js +3 -4
  339. package/packages/tools/dist/test-run.d.ts +1 -2
  340. package/packages/tools/dist/test-run.js +2 -3
  341. package/packages/tools/dist/text-utils.d.ts +1 -2
  342. package/packages/tools/dist/text-utils.js +1 -2
  343. package/packages/tools/dist/time-utils.d.ts +1 -2
  344. package/packages/tools/dist/time-utils.js +1 -2
  345. package/packages/tools/dist/trace.d.ts +3 -2
  346. package/packages/tools/dist/trace.js +2 -3
  347. package/packages/tools/dist/truncation.d.ts +1 -2
  348. package/packages/tools/dist/truncation.js +1 -2
  349. package/packages/tools/dist/watch.d.ts +1 -2
  350. package/packages/tools/dist/watch.js +1 -2
  351. package/packages/tools/dist/web-fetch.d.ts +1 -2
  352. package/packages/tools/dist/web-fetch.js +1 -2
  353. package/packages/tools/dist/web-search.d.ts +1 -2
  354. package/packages/tools/dist/web-search.js +1 -2
  355. package/packages/tools/dist/workset.d.ts +1 -2
  356. package/packages/tools/dist/workset.js +1 -2
  357. package/packages/tui/dist/{App-BAlmxCCw.js → App-CYLNJLr6.js} +1 -2
  358. package/packages/tui/dist/App.d.ts +1 -2
  359. package/packages/tui/dist/App.js +1 -1
  360. package/packages/tui/dist/CuratedPanel-sYdZAICX.js +1 -2
  361. package/packages/tui/dist/LogPanel-DtMnoyXT.js +3 -0
  362. package/packages/tui/dist/SearchPanel-DREo6zgt.js +1 -2
  363. package/packages/tui/dist/StatusPanel-2ex8fLOO.js +1 -2
  364. package/packages/tui/dist/devtools-DUyj952l.js +1 -2
  365. package/packages/tui/dist/embedder.interface-D4ew0HPW.d.ts +1 -2
  366. package/packages/tui/dist/index-B9VpfVPP.d.ts +1 -2
  367. package/packages/tui/dist/index.js +1 -2
  368. package/packages/tui/dist/jsx-runtime-Cof-kwFn.js +1 -2
  369. package/packages/tui/dist/panels/CuratedPanel.d.ts +1 -2
  370. package/packages/tui/dist/panels/LogPanel.d.ts +1 -2
  371. package/packages/tui/dist/panels/LogPanel.js +1 -1
  372. package/packages/tui/dist/panels/SearchPanel.d.ts +1 -2
  373. package/packages/tui/dist/panels/StatusPanel.d.ts +1 -2
  374. package/packages/tui/dist/store.interface-CnY6SPOH.d.ts +1 -2
  375. package/scaffold/copilot/agents/Architect-Reviewer-Alpha.agent.md +7 -0
  376. package/scaffold/copilot/agents/Architect-Reviewer-Beta.agent.md +7 -0
  377. package/scaffold/copilot/agents/Documenter.agent.md +7 -0
  378. package/scaffold/copilot/agents/Orchestrator.agent.md +8 -0
  379. package/scaffold/copilot/agents/Planner.agent.md +9 -0
  380. package/scaffold/copilot/agents/Refactor.agent.md +6 -0
  381. package/scaffold/copilot/agents/Researcher-Alpha.agent.md +8 -0
  382. package/scaffold/copilot/agents/Researcher-Beta.agent.md +8 -0
  383. package/scaffold/copilot/agents/Researcher-Delta.agent.md +8 -0
  384. package/scaffold/copilot/agents/Researcher-Gamma.agent.md +8 -0
  385. package/scaffold/general/agents/Architect-Reviewer-Alpha.agent.md +21 -0
  386. package/scaffold/general/agents/Architect-Reviewer-Beta.agent.md +21 -0
  387. package/scaffold/general/agents/Documenter.agent.md +42 -0
  388. package/scaffold/general/agents/Orchestrator.agent.md +104 -0
  389. package/scaffold/general/agents/Planner.agent.md +55 -0
  390. package/scaffold/general/agents/Refactor.agent.md +36 -0
  391. package/scaffold/general/agents/Researcher-Alpha.agent.md +20 -0
  392. package/scaffold/general/agents/Researcher-Beta.agent.md +20 -0
  393. package/scaffold/general/agents/Researcher-Delta.agent.md +20 -0
  394. package/scaffold/general/agents/Researcher-Gamma.agent.md +20 -0
  395. package/scaffold/{copilot → general}/agents/_shared/code-agent-base.md +18 -0
  396. package/skills/adr-skill/SKILL.md +329 -0
  397. package/skills/adr-skill/assets/templates/adr-madr.md +89 -0
  398. package/skills/adr-skill/assets/templates/adr-readme.md +20 -0
  399. package/skills/adr-skill/assets/templates/adr-simple.md +46 -0
  400. package/skills/adr-skill/references/adr-conventions.md +95 -0
  401. package/skills/adr-skill/references/examples.md +193 -0
  402. package/skills/adr-skill/references/review-checklist.md +77 -0
  403. package/skills/adr-skill/references/template-variants.md +52 -0
  404. package/skills/adr-skill/scripts/bootstrap_adr.js +259 -0
  405. package/skills/adr-skill/scripts/new_adr.js +391 -0
  406. package/skills/adr-skill/scripts/set_adr_status.js +169 -0
  407. package/skills/c4-architecture/SKILL.md +295 -0
  408. package/skills/c4-architecture/references/advanced-patterns.md +552 -0
  409. package/skills/c4-architecture/references/c4-syntax.md +492 -0
  410. package/skills/c4-architecture/references/common-mistakes.md +437 -0
  411. package/skills/knowledge-base/SKILL.md +78 -1
  412. package/skills/lesson-learned/SKILL.md +105 -0
  413. package/skills/lesson-learned/references/anti-patterns.md +55 -0
  414. package/skills/lesson-learned/references/se-principles.md +109 -0
  415. package/skills/requirements-clarity/SKILL.md +324 -0
  416. package/skills/session-handoff/SKILL.md +189 -0
  417. package/skills/session-handoff/references/handoff-template.md +139 -0
  418. package/skills/session-handoff/references/resume-checklist.md +80 -0
  419. package/skills/session-handoff/scripts/check_staleness.js +269 -0
  420. package/skills/session-handoff/scripts/create_handoff.js +299 -0
  421. package/skills/session-handoff/scripts/list_handoffs.js +113 -0
  422. package/skills/session-handoff/scripts/validate_handoff.js +241 -0
  423. package/packages/chunker/dist/treesitter-chunker.d.ts +0 -44
  424. package/packages/chunker/dist/treesitter-chunker.js +0 -7
  425. package/packages/cli/dist/commands/init.d.ts +0 -15
  426. package/packages/cli/dist/commands/init.js +0 -305
  427. package/packages/tui/dist/LogPanel-DVB8Sv46.js +0 -4
  428. /package/scaffold/{copilot → general}/agents/Code-Reviewer-Alpha.agent.md +0 -0
  429. /package/scaffold/{copilot → general}/agents/Code-Reviewer-Beta.agent.md +0 -0
  430. /package/scaffold/{copilot → general}/agents/Debugger.agent.md +0 -0
  431. /package/scaffold/{copilot → general}/agents/Explorer.agent.md +0 -0
  432. /package/scaffold/{copilot → general}/agents/Frontend.agent.md +0 -0
  433. /package/scaffold/{copilot → general}/agents/Implementer.agent.md +0 -0
  434. /package/scaffold/{copilot → general}/agents/README.md +0 -0
  435. /package/scaffold/{copilot → general}/agents/Security.agent.md +0 -0
  436. /package/scaffold/{copilot → general}/agents/_shared/adr-protocol.md +0 -0
  437. /package/scaffold/{copilot → general}/agents/_shared/architect-reviewer-base.md +0 -0
  438. /package/scaffold/{copilot → general}/agents/_shared/code-reviewer-base.md +0 -0
  439. /package/scaffold/{copilot → general}/agents/_shared/decision-protocol.md +0 -0
  440. /package/scaffold/{copilot → general}/agents/_shared/forge-protocol.md +0 -0
  441. /package/scaffold/{copilot → general}/agents/_shared/researcher-base.md +0 -0
  442. /package/scaffold/{copilot → general}/agents/templates/adr-template.md +0 -0
  443. /package/scaffold/{copilot → general}/agents/templates/execution-state.md +0 -0
  444. /package/scaffold/{copilot → general}/prompts/ask.prompt.md +0 -0
  445. /package/scaffold/{copilot → general}/prompts/debug.prompt.md +0 -0
  446. /package/scaffold/{copilot → general}/prompts/design.prompt.md +0 -0
  447. /package/scaffold/{copilot → general}/prompts/implement.prompt.md +0 -0
  448. /package/scaffold/{copilot → general}/prompts/plan.prompt.md +0 -0
  449. /package/scaffold/{copilot → general}/prompts/review.prompt.md +0 -0
@@ -1,226 +1,143 @@
1
- function e(e,t){let n=e=>e;return`# ${e} — Copilot Instructions
1
+ function e(e,t){return`# ${e} — Copilot Instructions
2
2
 
3
- This project uses **@vpxa/kb** as an MCP knowledge base server. The KB provides search, context compression, persistent memory, and validation tools that **MUST** be used to maintain quality and performance.
3
+ This project has an MCP server (\`${t}\`) providing 64 tools for search, analysis, memory, and validation.
4
+ **These tools REPLACE most native IDE tools.** You MUST use them.
4
5
 
5
- ## Mandatory Rules
6
+ ## Step 0: Load KB Tools
6
7
 
7
- ### 1. ALWAYS search before acting
8
- Before writing or modifying code, you MUST recall prior decisions and understand the affected area:
8
+ Before doing ANYTHING else, load the KB MCP tools. They are deferred — you must load them first.
9
+ Search for tools matching the server name (e.g. \`knowledge-bas\`):
9
10
  \`\`\`
10
- ${n(`search`)}({ query: "<task keywords>" })
11
- ${n(`scope_map`)}({ task: "<what you are doing>" })
11
+ tool_search_tool_regex({ pattern: "knowledge-bas" }) // loads all 64 KB tools
12
12
  \`\`\`
13
+ Once loaded, KB tools appear as \`mcp_<server>_<tool>\` (e.g. \`mcp_knowledge-bas_search\`).
13
14
 
14
- ### 2. ALWAYS compress context before reading large files
15
- Do NOT read entire files into context. Use these tools to reduce tokens and focus on what matters:
15
+ ## FORBIDDEN: Native Tools When KB Alternative Exists
16
16
 
17
- | Situation | Tool | Why |
18
- |-----------|------|-----|
19
- | Need relevant sections of a large file | \`${n(`compact`)}\` | Extracts only semantically relevant chunks 5-20x reduction |
20
- | Need to summarize multiple sources | \`${n(`digest`)}\` | Compresses multiple text blocks into a token-budgeted summary |
21
- | Need a quick structural overview of a file | \`${n(`file_summary`)}\` | Returns exports, imports, functions without reading the full file |
22
- | Need a reusable context card | \`${n(`stratum_card`)}\` | Generates T1/T2 cards 10-100x token reduction |
17
+ | NEVER use this | USE THIS KB TOOL INSTEAD | Why |
18
+ |---|---|---|
19
+ | \`read_file\` to understand a file | \`file_summary({ path })\` | Structure, exports, imports 10x fewer tokens |
20
+ | \`read_file\` to find specific code | \`compact({ path, query })\` | Server-side read + semantic extract 5-20x reduction |
21
+ | Multiple \`read_file\` calls | \`digest({ sources })\` | Compresses multiple files into token-budgeted summary |
22
+ | \`grep_search\` / \`semantic_search\` | \`search({ query })\` | Hybrid search across all indexed + curated content |
23
+ | \`grep_search\` for a symbol name | \`symbol({ name })\` | Definition + references with scope and call context |
24
+ | \`run_in_terminal\` for find/grep | \`find({ pattern })\` or \`search()\` | No shell needed, richer results |
25
+ | \`run_in_terminal\` for tsc/lint | \`check({})\` | Typecheck + lint combined, summary output |
26
+ | \`run_in_terminal\` for test | \`test_run({})\` | Run tests with structured output |
27
+ | Manual code tracing | \`trace({ symbol, direction })\` | AST call-graph traversal |
28
+ | Line counting / wc | \`measure({ path })\` | Lines, functions, cognitive complexity |
23
29
 
24
- **Example reading a 400-line file:**
25
- \`\`\`
26
- # BAD: read_file entire file (wastes ~3000 tokens)
27
- # GOOD: get structure first, then compact only what you need
28
- ${n(`file_summary`)}({ path: "src/http-client.ts" })
29
- ${n(`compact`)}({ path: "src/http-client.ts", query: "retry logic" })
30
- \`\`\`
31
-
32
- ### 3. ALWAYS use persistent memory
33
- - **Start of session**: Read prior knowledge with \`${n(`list`)}()\` and \`${n(`search`)}({ query: "SESSION CHECKPOINT", origin: "curated" })\`
34
- - **During session**: Use \`${n(`stash`)}\` for temporary working data, \`${n(`checkpoint`)}\` to save progress
35
- - **End of session**: MUST call \`${n(`remember`)}\` to persist decisions, patterns, and lessons learned
36
- - **Before proposing a new approach**: MUST \`${n(`search`)}\` to check if a decision already exists
37
-
38
- | Tool | When | Persistence |
39
- |------|------|-------------|
40
- | \`${n(`stash`)}\` | Temporary data within a session (intermediate results, scratch notes) | Session only |
41
- | \`${n(`checkpoint`)}\` | Save/restore session progress (resumable work) | Session only |
42
- | \`${n(`remember`)}\` | Architecture decisions, conventions, patterns, troubleshooting | Permanent (survives reindex) |
30
+ **\`read_file\` is ONLY acceptable when you need exact line content FOR EDITING (before \`replace_string_in_file\`).**
31
+ Even then, use \`file_summary\` first to identify which lines to read.
43
32
 
44
- ### 4. ALWAYS validate before committing
45
- \`\`\`
46
- ${n(`check`)}({}) # Typecheck + lint (returns summary by default)
47
- ${n(`test_run`)}({}) # Run tests
48
- ${n(`blast_radius`)}({ changed_files: ["..."] }) # Impact analysis
49
- ${n(`audit`)}({}) # Unified project audit with score and recommendations
50
- \`\`\`
33
+ ## Core Rules
51
34
 
52
- ### 5. Use FORGE for complex tasks
53
- For tasks involving multiple files or architectural decisions:
54
- \`\`\`
55
- ${n(`forge_classify`)}({ task: "<description>" }) # Classify complexity tier
56
- ${n(`forge_ground`)}({ task: "<description>" }) # Full analysis: scope + constraints + evidence
57
- ${n(`evidence_map`)}({ claims: [...] }) # Track verified vs assumed claims
58
- \`\`\`
35
+ 1. **Search before acting** — \`search({ query })\` then \`scope_map({ task })\` before ANY code change. If a prior decision exists, follow it.
36
+ 2. **Compress, don't read** \`file_summary\` \`compact\` → \`digest\`. NEVER raw-read a file to "understand" it.
37
+ 3. **Remember** — \`search({ query: "SESSION CHECKPOINT", origin: "curated" })\` at session start. \`remember()\` decisions at session end.
38
+ 4. **Validate** — \`check({})\` + \`test_run({})\` before presenting changes. \`blast_radius({ changed_files })\` for impact.
39
+ 5. **Lifecycle** — Check \`status({})\` first. If onboard not run, run \`onboard({ path: "." })\`. After implementation, \`reindex({})\` + \`produce_knowledge({})\`. At session end, \`remember()\` checkpoint.
59
40
 
60
- ## Quick Workflow
61
-
62
- \`\`\`
63
- # 1. Orient
64
- ${n(`search`)}({ query: "task keywords" })
65
- ${n(`scope_map`)}({ task: "what you are doing" })
66
-
67
- # 2. Read efficiently (NEVER raw-read large files)
68
- ${n(`file_summary`)}({ path: "relevant-file.ts" })
69
- ${n(`compact`)}({ path: "relevant-file.ts", query: "specific concern" })
70
-
71
- # 3. Do the work
72
-
73
- # 4. Validate
74
- ${n(`check`)}({})
75
- ${n(`test_run`)}({})
76
-
77
- # 5. Persist
78
- ${n(`remember`)}({ title: "What I learned", content: "...", category: "decisions" })
79
- \`\`\`
41
+ ## Custom Agents
80
42
 
81
- ## Context Budget Rules
43
+ This project has specialized agents in \`.github/agents/\`. Use them instead of built-in modes:
44
+ - **Planner** — for planning and research before implementation
45
+ - **Implementer** — for coding tasks following TDD practices
46
+ - **Researcher** — for deep investigation and context gathering
47
+ - **Explorer** — for rapid codebase navigation
82
48
 
83
- - **Prefer \`${n(`file_summary`)}\` over \`read_file\`** for understanding file structure
84
- - **Prefer \`${n(`compact`)}\` over full file reads** when you need specific sections (use \`path\` param to avoid read_file round-trip)
85
- - **Prefer \`${n(`search`)}\` over \`grep_search\`** for semantic/conceptual queries
86
- - **Prefer \`${n(`symbol`)}\` over manual grep** for finding definitions and references
87
- - **Use \`${n(`digest`)}\`** when combining information from 3+ sources
88
- - **Use \`${n(`stratum_card`)}\`** to create reusable compressed context for repeated reference
89
- `}function t(e,t){let n=e=>e;return`# ${e} — Agent Instructions
49
+ Check \`.github/agents/\` for the full list of available agents.
50
+ `}function t(e,t){return`# ${e} Agent Instructions
90
51
 
91
- ## KB Knowledge Base
52
+ ## KB MCP Server (\`${t}\`)
92
53
 
93
- This project has a **@vpxa/kb** MCP server providing search, analysis, memory, and developer tools.
54
+ 64 tools for search, code analysis, persistent memory, validation, and context compression.
55
+ Load them: \`tool_search_tool_regex({ pattern: "knowledge-bas" })\`
94
56
 
95
57
  ### Skills Reference
96
58
 
97
- | Context | Skill | Details |
98
- |---------|-------|--------|
99
- | KB search, analysis, memory | \`kb\` | See [.github/skills/knowledge-base/SKILL.md](.github/skills/knowledge-base/SKILL.md) or run \`${n(`status`)}({})\` |
100
- | Brainstorming & design | \`brainstorming\` | See [.github/skills/brainstorming/SKILL.md](.github/skills/brainstorming/SKILL.md) |
59
+ | Context | Skill | Load when |
60
+ |---------|-------|----------|
61
+ | KB search, analysis, memory | \`knowledge-base\` | **Always load at session start.** Tool signatures, workflows, session protocol. |
62
+ | Brainstorming & design | \`brainstorming\` | Before any creative/design work — new features, components, behavior changes. |
63
+ | Session context preservation | \`session-handoff\` | Context window filling up, session ending, or major milestone completed. |
64
+ | Requirements scoring | \`requirements-clarity\` | Before planning vague or complex features — score 0-100 until \u2265 90. |
65
+ | Engineering lessons | \`lesson-learned\` | After completing work — extract principles from git diffs. |
66
+ | Architecture diagrams | \`c4-architecture\` | When documenting or reviewing architecture — C4 Mermaid diagrams. |
67
+ | Architecture decisions | \`adr-skill\` | When making non-trivial technical decisions — executable ADRs. |
101
68
 
102
- ### Available Tool Categories
69
+ ### Tool Categories
103
70
 
104
71
  | Category | Tools | Purpose |
105
72
  |----------|-------|---------|
106
- | Search & Discovery | \`${n(`search`)}\`, \`${n(`find`)}\`, \`${n(`symbol`)}\`, \`${n(`trace`)}\`, \`${n(`scope_map`)}\`, \`${n(`lookup`)}\`, \`${n(`dead_symbols`)}\`, \`${n(`file_summary`)}\` | Find code, symbols, data flow, reading plans |
107
- | Code Analysis | \`${n(`analyze_structure`)}\`, \`${n(`analyze_dependencies`)}\`, \`${n(`analyze_symbols`)}\`, \`${n(`analyze_patterns`)}\`, \`${n(`analyze_entry_points`)}\`, \`${n(`analyze_diagram`)}\`, \`${n(`blast_radius`)}\` | Structure, deps, patterns, impact, diagrams |
108
- | Knowledge | \`${n(`remember`)}\`, \`${n(`read`)}\`, \`${n(`update`)}\`, \`${n(`forget`)}\`, \`${n(`list`)}\`, \`${n(`produce_knowledge`)}\` | Persistent cross-session memory |
109
- | Execution | \`${n(`check`)}\`, \`${n(`test_run`)}\`, \`${n(`eval`)}\`, \`${n(`batch`)}\`, \`${n(`audit`)}\` | Typecheck, lint, test, run code, unified audit. \`check\` defaults to summary output (~300 tokens) |
110
- | Code Manipulation | \`${n(`rename`)}\`, \`${n(`codemod`)}\`, \`${n(`diff_parse`)}\`, \`${n(`data_transform`)}\` | Safe renames, transforms, diff parsing |
111
- | Context | \`${n(`compact`)}\`, \`${n(`workset`)}\`, \`${n(`stash`)}\`, \`${n(`checkpoint`)}\`, \`${n(`parse_output`)}\` | Manage working sets, save progress. \`compact\` accepts \`path\` for server-side file read |
112
- | FORGE | \`${n(`forge_ground`)}\`, \`${n(`forge_classify`)}\`, \`${n(`evidence_map`)}\`, \`${n(`digest`)}\`, \`${n(`stratum_card`)}\` | Quality gates, context compression |
113
- | Web & API | \`${n(`web_fetch`)}\`, \`${n(`web_search`)}\`, \`${n(`http`)}\` | Fetch pages, search web, test APIs |
114
- | Lanes | \`${n(`lane`)}\` | Isolated file copies for parallel exploration (create/list/status/diff/merge/discard) |
115
- | Git & Environment | \`${n(`git_context`)}\`, \`${n(`process`)}\`, \`${n(`watch`)}\`, \`${n(`delegate`)}\` | Git info, process management |
116
- | Utilities | \`${n(`regex_test`)}\`, \`${n(`encode`)}\`, \`${n(`measure`)}\`, \`${n(`changelog`)}\`, \`${n(`schema_validate`)}\`, \`${n(`snippet`)}\`, \`${n(`env`)}\`, \`${n(`time`)}\` | Regex, encoding, metrics, validation |
117
- | System | \`${n(`status`)}\`, \`${n(`reindex`)}\`, \`${n(`health`)}\`, \`${n(`guide`)}\`, \`${n(`onboard`)}\`, \`${n(`graph`)}\`, \`${n(`queue`)}\`, \`${n(`replay`)}\` | Index management, health checks, tool discovery, knowledge graph |
73
+ | Search & Discovery | \`search\`, \`find\`, \`symbol\`, \`trace\`, \`scope_map\`, \`lookup\`, \`dead_symbols\`, \`file_summary\` | Find code, symbols, data flow, reading plans |
74
+ | Code Analysis | \`analyze_structure\`, \`analyze_dependencies\`, \`analyze_symbols\`, \`analyze_patterns\`, \`analyze_entry_points\`, \`analyze_diagram\`, \`blast_radius\` | Structure, deps, patterns, impact |
75
+ | Knowledge | \`remember\`, \`read\`, \`update\`, \`forget\`, \`list\`, \`produce_knowledge\` | Persistent cross-session memory |
76
+ | Execution | \`check\`, \`test_run\`, \`eval\`, \`batch\`, \`audit\` | Typecheck, lint, test, run code |
77
+ | Context Compression | \`compact\`, \`digest\`, \`stratum_card\`, \`workset\`, \`stash\`, \`checkpoint\` | Reduce tokens, manage working sets |
78
+ | FORGE | \`forge_ground\`, \`forge_classify\`, \`evidence_map\` | Quality gates for complex tasks |
79
+ | Code Manipulation | \`rename\`, \`codemod\`, \`diff_parse\`, \`data_transform\` | Safe renames, transforms |
80
+ | Web & API | \`web_fetch\`, \`web_search\`, \`http\` | Fetch pages, search web |
81
+ | Lanes | \`lane\` | Isolated file copies for parallel exploration |
82
+ | Git & Environment | \`git_context\`, \`process\`, \`watch\`, \`delegate\` | Git info, process management |
83
+ | Utilities | \`regex_test\`, \`encode\`, \`measure\`, \`changelog\`, \`schema_validate\`, \`snippet\`, \`env\`, \`time\` | Regex, encoding, metrics |
84
+ | System | \`status\`, \`reindex\`, \`health\`, \`guide\`, \`onboard\`, \`graph\`, \`queue\`, \`replay\` | Index management, knowledge graph |
118
85
 
119
86
  ---
120
87
 
121
- ## MANDATORY: Context Reduction Protocol
122
-
123
- **Every agent interaction MUST minimize context window usage.** Raw file reads waste tokens and degrade LLM output quality. Use these tools instead:
124
-
125
- ### Decision Tree — How to Read Code
88
+ ## How to Read Code (Decision Tree)
126
89
 
127
90
  \`\`\`
128
91
  Need to understand a file?
129
- ├─ Just structure? → ${n(`file_summary`)} (exports, imports, functions ~50 tokens)
130
- ├─ Specific section? → ${n(`compact`)}({ path: "file.ts", query: "topic" }) 5-20x reduction
131
- ├─ Multiple files? → ${n(`digest`)} (multi-source compression — token-budgeted)
132
- ├─ Repeated reference? ${n(`stratum_card`)} (T1/T2 card — 10-100x reduction)
133
- └─ Full file needed? ONLY as last resort, and compact it after reading
134
- \`\`\`
135
-
136
- ### Rules
137
- 1. **NEVER read a file >100 lines without compressing it first**
138
- 2. **ALWAYS use \`${n(`file_summary`)}\` before \`read_file\`** — often the summary is sufficient
139
- 3. **ALWAYS use \`${n(`compact`)}\` when you only need specific sections** of a file (use \`path\` param to read server-side)
140
- 4. **Use \`${n(`digest`)}\` when synthesizing from 3+ sources** — don't accumulate raw text
141
- 5. **Use \`${n(`stratum_card`)}\` for files you'll reference repeatedly** in a session
142
-
143
- ---
144
-
145
- ## MANDATORY: Memory Protocol
146
-
147
- **Every session MUST read and write persistent memory.** Without this, every conversation starts from zero.
148
-
149
- ### Session Start (MUST do ALL of these)
150
- \`\`\`
151
- ${n(`status`)}({}) # Verify KB is ready
152
- ${n(`list`)}() # See what knowledge exists
153
- ${n(`search`)}({ query: "SESSION CHECKPOINT", origin: "curated" }) # Resume prior work
92
+ \u251C\u2500 Just structure? \u2192 file_summary (exports, imports, functions \u2014 ~50 tokens)
93
+ \u251C\u2500 Specific section? \u2192 compact({ path, query }) \u2014 5-20x token reduction
94
+ \u251C\u2500 Multiple files? \u2192 digest (multi-source compression)
95
+ \u251C\u2500 Repeated reference? \u2192 stratum_card (reusable T1/T2 card)
96
+ \u2514\u2500 Need exact lines to EDIT? \u2192 read_file (ONLY acceptable use)
154
97
  \`\`\`
155
98
 
156
- ### During Session
157
- | Situation | Action |
158
- |-----------|--------|
159
- | Found a useful intermediate result | \`${n(`stash`)}({ key: "name", value: "data" })\` |
160
- | Completed a milestone | \`${n(`checkpoint`)}({ action: "save", name: "milestone" })\` |
161
- | Made an architecture decision | \`${n(`remember`)}({ title: "...", category: "decisions" })\` |
162
- | Discovered a pattern or convention | \`${n(`remember`)}({ title: "...", category: "patterns" })\` |
163
- | Found a non-obvious solution | \`${n(`remember`)}({ title: "...", category: "troubleshooting" })\` |
164
- | About to propose a new approach | \`${n(`search`)}({ query: "..." })\` — check if decided before |
165
-
166
- ### Session End (MUST do this)
167
- \`\`\`
168
- ${n(`remember`)}({
169
- title: "Session checkpoint: <topic>",
170
- content: "<what was done, decisions made, blockers, next steps>",
171
- category: "conventions"
172
- })
173
- \`\`\`
174
-
175
- ### Memory Decision Tree
176
- \`\`\`
177
- Is this data temporary (scratch, intermediate)?
178
- ├─ Yes → ${n(`stash`)} (session-scoped key-value)
179
- └─ No → Is it resumable progress?
180
- ├─ Yes → ${n(`checkpoint`)} (session-scoped snapshot)
181
- └─ No → ${n(`remember`)} (permanent, survives reindex)
182
- Categories: decisions | patterns | conventions | troubleshooting
183
- \`\`\`
99
+ **Rules:**
100
+ 1. NEVER \`read_file\` a file >50 lines to "understand" it — use \`file_summary\` or \`compact\`
101
+ 2. NEVER \`grep_search\` or \`semantic_search\` — use \`search\` (hybrid across >12k indexed records)
102
+ 3. NEVER \`run_in_terminal\` for tsc/lint/test use \`check\` / \`test_run\`
103
+ 4. \`read_file\` is ONLY for getting exact lines before \`replace_string_in_file\`
184
104
 
185
105
  ---
186
106
 
187
- ## MANDATORY: Search-Before-Act Protocol
188
-
189
- **NEVER write or modify code without first searching for context.**
107
+ ## Session Protocol
190
108
 
109
+ ### Start (do ALL)
191
110
  \`\`\`
192
- # Before ANY code change:
193
- ${n(`search`)}({ query: "<what you're about to change>" }) # Prior decisions?
194
- ${n(`scope_map`)}({ task: "<description>" }) # What files to read?
195
- ${n(`symbol`)}({ name: "<key symbol>" }) # Where is it defined/used?
111
+ status({}) # Check KB health + onboard state
112
+ # If onboard not run onboard({ path: "." }) # First-time codebase analysis
113
+ list() # See stored knowledge
114
+ search({ query: "SESSION CHECKPOINT", origin: "curated" }) # Resume prior work
196
115
  \`\`\`
197
116
 
198
- If \`${n(`search`)}\` returns a prior decision about the topic, you MUST follow it or explicitly explain why you're deviating.
199
-
200
- ---
201
-
202
- ## MANDATORY: Validation Protocol
203
-
204
- **NEVER commit or present code without validation.**
117
+ ### During
118
+ | Situation | Tool |
119
+ |-----------|------|
120
+ | Intermediate result | \`stash({ key, value })\` |
121
+ | Milestone completed | \`checkpoint({ action: "save", name })\` |
122
+ | Architecture decision made | \`remember({ title, content, category: "decisions" })\` |
123
+ | Pattern discovered | \`remember({ title, content, category: "patterns" })\` |
124
+ | About to propose new approach | \`search({ query })\` — check if already decided |
205
125
 
126
+ ### After Implementation (do ALL)
206
127
  \`\`\`
207
- ${n(`check`)}({}) # Typecheck + lint (tsc + biome)
208
- ${n(`test_run`)}({}) # Run tests
209
- ${n(`blast_radius`)}({ changed_files: ["..."] }) # Impact analysis
210
- ${n(`audit`)}({}) # Unified project audit (structure, deps, patterns, health, dead symbols, entry points)
128
+ check({}) # Typecheck + lint
129
+ test_run({}) # Run tests
130
+ blast_radius({ changed_files: ["..."] }) # Impact analysis
131
+ reindex({}) # Background refresh (non-blocking)
132
+ produce_knowledge({ path: "." }) # Regenerate codebase analysis
133
+ remember({ title: "Session checkpoint: ...", ... }) # Persist decisions
211
134
  \`\`\`
212
135
 
213
- ---
214
-
215
- ## FORGE Protocol (for complex tasks)
216
-
217
- For tasks touching 3+ files or involving architectural decisions:
218
-
136
+ ### End (MUST do)
219
137
  \`\`\`
220
- ${n(`forge_classify`)}({ task: "<description>" }) # Quick: Floor/Standard/Critical tier
221
- ${n(`forge_ground`)}({ task: "<description>" }) # Full: scope + constraints + evidence
222
- ${n(`evidence_map`)}({ claims: ["claim1", "claim2"] }) # Track verified vs assumed
138
+ remember({ title: "Session checkpoint: <topic>", content: "<decisions, blockers, next steps>", category: "conventions" })
223
139
  \`\`\`
140
+ For long sessions or context approaching capacity, use the \`session-handoff\` skill to create a structured handoff document.
224
141
 
225
142
  ---
226
143
 
@@ -228,75 +145,21 @@ ${n(`evidence_map`)}({ claims: ["claim1", "claim2"] }) # Track verified vs ass
228
145
 
229
146
  | Mode | When | Example |
230
147
  |------|------|---------|
231
- | \`hybrid\` (default) | General queries | \`${n(`search`)}({ query: "error handling" })\` |
232
- | \`semantic\` | Conceptual/meaning-based | \`${n(`search`)}({ query: "retry with backoff", search_mode: "semantic" })\` |
233
- | \`keyword\` | Exact identifiers | \`${n(`search`)}({ query: "CircuitBreaker", search_mode: "keyword" })\` |
234
-
235
- Filters: \`origin\` (\`indexed\`/\`curated\`/\`produced\`), \`category\`, \`content_type\`, \`tags\`, \`min_score\`.
148
+ | \`hybrid\` (default) | General queries | \`search({ query: "error handling" })\` |
149
+ | \`semantic\` | Conceptual | \`search({ query: "retry with backoff", search_mode: "semantic" })\` |
150
+ | \`keyword\` | Exact identifiers | \`search({ query: "CircuitBreaker", search_mode: "keyword" })\` |
236
151
 
237
152
  ---
238
153
 
239
154
  ## Workflow Chains
240
155
 
241
- **Codebase onboarding:**
242
- \`\`\`
243
- ${n(`onboard`)}({ path: "." }) → ${n(`produce_knowledge`)}({ path: "src/" }) → ${n(`remember`)}(...)
244
- \`\`\`
156
+ **Planning:** \`search\` → \`scope_map\` → \`file_summary\` per file → \`compact\` for detail → \`workset({ action: "save" })\`
245
157
 
246
- **Planning a task:**
247
- \`\`\`
248
- ${n(`search`)}({ query: "task keywords" })
249
- → ${n(`scope_map`)}({ task: "description" })
250
- → ${n(`file_summary`)} for each file in scope
251
- → ${n(`compact`)}({ path: "relevant-file.ts", query: "detail needed" }) for files needing detail
252
- → ${n(`workset`)}({ action: "save", name: "task", files: [...] })
253
- \`\`\`
158
+ **Bug investigation:** \`parse_output\` → \`symbol\` → \`trace({ direction: "backward" })\` → \`blast_radius\`
254
159
 
255
- **Bug investigation:**
256
- \`\`\`
257
- ${n(`parse_output`)}({ output: "<error>" })
258
- → ${n(`symbol`)}({ name: "failingFn" })
259
- → ${n(`trace`)}({ symbol: "failingFn", direction: "backward" })
260
- → ${n(`blast_radius`)}({ changed_files: ["suspect.ts"] })
261
- \`\`\`
262
-
263
- **Safe refactor with lanes:**
264
- \`\`\`
265
- ${n(`lane`)}({ action: "create", name: "refactor", files: [...] })
266
- → [make changes]
267
- → ${n(`lane`)}({ action: "diff", name: "refactor" })
268
- → ${n(`check`)}({}) → ${n(`test_run`)}({})
269
- → ${n(`lane`)}({ action: "merge", name: "refactor" })
270
- \`\`\`
271
-
272
- **After making changes:**
273
- \`\`\`
274
- ${n(`blast_radius`)}({ changed_files: ["src/file.ts"] })
275
- → ${n(`check`)}({}) → ${n(`test_run`)}({})
276
- → ${n(`reindex`)}({})
277
- → ${n(`remember`)}(...)
278
- \`\`\`
279
-
280
- ---
281
-
282
- ## Knowledge Categories
283
-
284
- | Category | What to store |
285
- |----------|---------------|
286
- | \`decisions\` | Architecture choices, trade-offs, rejected alternatives |
287
- | \`patterns\` | Code patterns, naming conventions, structural patterns |
288
- | \`conventions\` | Session checkpoints, workflow conventions, team agreements |
289
- | \`troubleshooting\` | Non-obvious fixes, debugging strategies, workarounds |
290
-
291
- ---
160
+ **Codebase onboarding:** \`onboard({ path: "." })\` → \`produce_knowledge({ path: "src/" })\` → \`remember\`
292
161
 
293
- ## Core Rules Summary
162
+ **After implementation:** \`check\` → \`test_run\` → \`blast_radius\` → \`reindex\` → \`produce_knowledge\` → \`remember\`
294
163
 
295
- 1. **Search KB before proposing anything new** prior decisions exist
296
- 2. **Compress context aggressively** — \`file_summary\` → \`compact\` → \`digest\`
297
- 3. **Use persistent memory** — \`remember\` decisions, \`stash\` temporary data
298
- 4. **Validate before committing** — \`check\` + \`test_run\` + \`blast_radius\`
299
- 5. **Follow \`_Next:\` hints** in tool responses for guided workflow
300
- 6. **Use FORGE for complex tasks** — \`forge_classify\` → \`forge_ground\` → \`evidence_map\`
301
- `}export{t as buildAgentsMd,e as buildCopilotInstructions};
302
- //# sourceMappingURL=templates.js.map
164
+ **Complex tasks (FORGE):** \`forge_classify({ task })\` \`forge_ground({ task })\` → \`evidence_map({ claims })\`
165
+ `}export{t as buildAgentsMd,e as buildCopilotInstructions};
@@ -3,5 +3,4 @@ import { Command } from "../types.js";
3
3
  //#region packages/cli/src/commands/knowledge.d.ts
4
4
  declare const knowledgeCommands: Command[];
5
5
  //#endregion
6
- export { knowledgeCommands };
7
- //# sourceMappingURL=knowledge.d.ts.map
6
+ export { knowledgeCommands };
@@ -1,2 +1 @@
1
- import{ctx as e}from"../context.js";import{extractNumFlag as t,extractStrFlag as n,readStdin as r,splitCsv as i}from"../helpers.js";import{compact as a}from"../../../tools/dist/index.js";const o=[{name:`remember`,description:`Store curated knowledge`,usage:`kb remember <title> --category <cat> [--tags tag1,tag2]`,run:async t=>{let a=n(t,`--category`,``).trim(),o=i(n(t,`--tags`,``)),s=t.shift()?.trim()??``,c=await r(),l=c.trim().length>0?c:t.join(` `).trim();(!s||!a||!l.trim())&&(console.error(`Usage: kb remember <title> --category <cat> [--tags tag1,tag2]`),process.exit(1));let{curated:u}=await e(),d=await u.remember(s,l,a,o);console.log(`Stored curated entry`),console.log(` Path: ${d.path}`),console.log(` Category: ${a}`),o.length>0&&console.log(` Tags: ${o.join(`, `)}`)}},{name:`forget`,description:`Remove a curated entry`,usage:`kb forget <path> --reason <reason>`,run:async t=>{let r=n(t,`--reason`,``).trim(),i=t.shift()?.trim()??``;(!i||!r)&&(console.error(`Usage: kb forget <path> --reason <reason>`),process.exit(1));let{curated:a}=await e(),o=await a.forget(i,r);console.log(`Removed curated entry: ${o.path}`)}},{name:`read`,description:`Read a curated entry`,usage:`kb read <path>`,run:async t=>{let n=t.shift()?.trim()??``;n||(console.error(`Usage: kb read <path>`),process.exit(1));let{curated:r}=await e(),i=await r.read(n);console.log(i.title),console.log(`─`.repeat(60)),console.log(`Path: ${i.path}`),console.log(`Category: ${i.category}`),console.log(`Version: ${i.version}`),console.log(`Tags: ${i.tags.length>0?i.tags.join(`, `):`None`}`),console.log(``),console.log(i.content)}},{name:`list`,description:`List curated entries`,usage:`kb list [--category <cat>] [--tag <tag>]`,run:async t=>{let r=n(t,`--category`,``).trim()||void 0,i=n(t,`--tag`,``).trim()||void 0,{curated:a}=await e(),o=await a.list({category:r,tag:i});if(o.length===0){console.log(`No curated entries found.`);return}console.log(`Curated entries (${o.length})`),console.log(`─`.repeat(60));for(let e of o){console.log(e.path),console.log(` ${e.title}`),console.log(` Category: ${e.category} | Version: ${e.version}`),console.log(` Tags: ${e.tags.length>0?e.tags.join(`, `):`None`}`);let t=e.contentPreview.replace(/\s+/g,` `).trim();t&&console.log(` Preview: ${t}`),console.log(``)}}},{name:`update`,description:`Update a curated entry`,usage:`kb update <path> --reason <reason>`,run:async t=>{let i=n(t,`--reason`,``).trim(),a=t.shift()?.trim()??``,o=await r();(!a||!i||!o.trim())&&(console.error(`Usage: kb update <path> --reason <reason>`),process.exit(1));let{curated:s}=await e(),c=await s.update(a,o,i);console.log(`Updated curated entry`),console.log(` Path: ${c.path}`),console.log(` Version: ${c.version}`)}},{name:`compact`,description:`Compress text for context`,usage:`kb compact <query> [--path <file>] [--max-chars N] [--segmentation paragraph|sentence|line]`,run:async i=>{let o=t(i,`--max-chars`,3e3),s=n(i,`--path`,``).trim()||void 0,c=n(i,`--segmentation`,`paragraph`),l=i.join(` `).trim(),u=s?void 0:await r();(!l||!s&&!u?.trim())&&(console.error(`Usage: kb compact <query> --path <file> OR cat file | kb compact <query>`),process.exit(1));let{embedder:d}=await e(),f=await a(d,{text:u,path:s,query:l,maxChars:o,segmentation:c});console.log(`Compressed ${f.originalChars} chars to ${f.compressedChars} chars`),console.log(`Ratio: ${(f.ratio*100).toFixed(1)}% | Segments: ${f.segmentsKept}/${f.segmentsTotal}`),console.log(``),console.log(f.text)}}];export{o as knowledgeCommands};
2
- //# sourceMappingURL=knowledge.js.map
1
+ import{ctx as e}from"../context.js";import{extractNumFlag as t,extractStrFlag as n,readStdin as r,splitCsv as i}from"../helpers.js";import{compact as a}from"../../../tools/dist/index.js";const o=[{name:`remember`,description:`Store curated knowledge`,usage:`kb remember <title> --category <cat> [--tags tag1,tag2]`,run:async t=>{let a=n(t,`--category`,``).trim(),o=i(n(t,`--tags`,``)),s=t.shift()?.trim()??``,c=await r(),l=c.trim().length>0?c:t.join(` `).trim();(!s||!a||!l.trim())&&(console.error(`Usage: kb remember <title> --category <cat> [--tags tag1,tag2]`),process.exit(1));let{curated:u}=await e(),d=await u.remember(s,l,a,o);console.log(`Stored curated entry`),console.log(` Path: ${d.path}`),console.log(` Category: ${a}`),o.length>0&&console.log(` Tags: ${o.join(`, `)}`)}},{name:`forget`,description:`Remove a curated entry`,usage:`kb forget <path> --reason <reason>`,run:async t=>{let r=n(t,`--reason`,``).trim(),i=t.shift()?.trim()??``;(!i||!r)&&(console.error(`Usage: kb forget <path> --reason <reason>`),process.exit(1));let{curated:a}=await e(),o=await a.forget(i,r);console.log(`Removed curated entry: ${o.path}`)}},{name:`read`,description:`Read a curated entry`,usage:`kb read <path>`,run:async t=>{let n=t.shift()?.trim()??``;n||(console.error(`Usage: kb read <path>`),process.exit(1));let{curated:r}=await e(),i=await r.read(n);console.log(i.title),console.log(`─`.repeat(60)),console.log(`Path: ${i.path}`),console.log(`Category: ${i.category}`),console.log(`Version: ${i.version}`),console.log(`Tags: ${i.tags.length>0?i.tags.join(`, `):`None`}`),console.log(``),console.log(i.content)}},{name:`list`,description:`List curated entries`,usage:`kb list [--category <cat>] [--tag <tag>]`,run:async t=>{let r=n(t,`--category`,``).trim()||void 0,i=n(t,`--tag`,``).trim()||void 0,{curated:a}=await e(),o=await a.list({category:r,tag:i});if(o.length===0){console.log(`No curated entries found.`);return}console.log(`Curated entries (${o.length})`),console.log(`─`.repeat(60));for(let e of o){console.log(e.path),console.log(` ${e.title}`),console.log(` Category: ${e.category} | Version: ${e.version}`),console.log(` Tags: ${e.tags.length>0?e.tags.join(`, `):`None`}`);let t=e.contentPreview.replace(/\s+/g,` `).trim();t&&console.log(` Preview: ${t}`),console.log(``)}}},{name:`update`,description:`Update a curated entry`,usage:`kb update <path> --reason <reason>`,run:async t=>{let i=n(t,`--reason`,``).trim(),a=t.shift()?.trim()??``,o=await r();(!a||!i||!o.trim())&&(console.error(`Usage: kb update <path> --reason <reason>`),process.exit(1));let{curated:s}=await e(),c=await s.update(a,o,i);console.log(`Updated curated entry`),console.log(` Path: ${c.path}`),console.log(` Version: ${c.version}`)}},{name:`compact`,description:`Compress text for context`,usage:`kb compact <query> [--path <file>] [--max-chars N] [--segmentation paragraph|sentence|line]`,run:async i=>{let o=t(i,`--max-chars`,3e3),s=n(i,`--path`,``).trim()||void 0,c=n(i,`--segmentation`,`paragraph`),l=i.join(` `).trim(),u=s?void 0:await r();(!l||!s&&!u?.trim())&&(console.error(`Usage: kb compact <query> --path <file> OR cat file | kb compact <query>`),process.exit(1));let{embedder:d}=await e(),f=await a(d,{text:u,path:s,query:l,maxChars:o,segmentation:c});console.log(`Compressed ${f.originalChars} chars to ${f.compressedChars} chars`),console.log(`Ratio: ${(f.ratio*100).toFixed(1)}% | Segments: ${f.segmentsKept}/${f.segmentsTotal}`),console.log(``),console.log(f.text)}}];export{o as knowledgeCommands};
@@ -3,5 +3,4 @@ import { Command } from "../types.js";
3
3
  //#region packages/cli/src/commands/search.d.ts
4
4
  declare const searchCommands: Command[];
5
5
  //#endregion
6
- export { searchCommands };
7
- //# sourceMappingURL=search.d.ts.map
6
+ export { searchCommands };
@@ -1,2 +1 @@
1
- import{ctx as e}from"../context.js";import{extractNumFlag as t,extractStrFlag as n,formatFocusRanges as r,printDeadSymbolsResult as i,printExamplesResult as a,printSymbolInfo as o,printTraceResult as s,rrf as c}from"../helpers.js";import{find as l,findDeadSymbols as u,findExamples as d,scopeMap as f,symbol as p,trace as m}from"../../../tools/dist/index.js";const h=[{name:`search`,description:`Search the knowledge base`,usage:`kb search <query> [--limit N] [--mode hybrid|semantic|keyword] [--graph-hops 0-3]`,run:async r=>{let i=t(r,`--limit`,5),a=n(r,`--mode`,`hybrid`),o=t(r,`--graph-hops`,0),s=r.join(` `).trim();s||(console.error(`Usage: kb search <query>`),process.exit(1));let{embedder:l,store:u,graphStore:d}=await e(),f=await l.embedQuery(s),p;if(a===`keyword`)p=await u.ftsSearch(s,{limit:i});else if(a===`semantic`)p=await u.search(f,{limit:i});else{let[e,t]=await Promise.all([u.search(f,{limit:i*2}),u.ftsSearch(s,{limit:i*2}).catch(()=>[])]);p=c(e,t).slice(0,i)}if(p.length===0){console.log(`No results found.`);return}for(let{record:e,score:t}of p){console.log(`\n${`─`.repeat(60)}`),console.log(`[${(t*100).toFixed(1)}%] ${e.sourcePath}:${e.startLine}-${e.endLine}`),console.log(` Type: ${e.contentType} | Origin: ${e.origin}`),e.tags.length>0&&console.log(` Tags: ${e.tags.join(`, `)}`),console.log(``);let n=e.content.length>500?`${e.content.slice(0,500)}...`:e.content;console.log(n)}if(console.log(`\n${`─`.repeat(60)}`),console.log(`${p.length} result(s) found.`),o>0&&p.length>0)try{let{graphAugmentSearch:e}=await import(`../../../tools/dist/index.js`),t=(await e(d,p.map(e=>({recordId:e.record.id,score:e.score,sourcePath:e.record.sourcePath})),{hops:o,maxPerHit:5})).filter(e=>e.graphContext.nodes.length>0);if(t.length>0){console.log(`\nGraph context (${o} hop${o>1?`s`:``}):\n`);for(let e of t){console.log(` ${e.sourcePath}:`);for(let t of e.graphContext.nodes.slice(0,5))console.log(` → ${t.name} (${t.type})`);for(let t of e.graphContext.edges.slice(0,5))console.log(` → ${t.fromId} --[${t.type}]--> ${t.toId}`)}}}catch(e){console.error(`[graph] augmentation failed: ${e.message}`)}}},{name:`find`,description:`Run federated search across indexed content and files`,usage:`kb find [query] [--glob <pattern>] [--pattern <regex>] [--limit N]`,run:async r=>{let i=t(r,`--limit`,10),a=n(r,`--glob`,``).trim()||void 0,o=n(r,`--pattern`,``).trim()||void 0,s=r.join(` `).trim()||void 0;!s&&!a&&!o&&(console.error(`Usage: kb find [query] [--glob <pattern>] [--pattern <regex>] [--limit N]`),process.exit(1));let{embedder:c,store:u}=await e(),d=await l(c,u,{query:s,glob:a,pattern:o,limit:i});if(d.results.length===0){console.log(`No matches found.`);return}console.log(`Strategies: ${d.strategies.join(`, `)}`),console.log(`Results: ${d.results.length} shown (${d.totalFound} total)`);for(let e of d.results){let t=e.lineRange?`:${e.lineRange.start}-${e.lineRange.end}`:``;console.log(`\n[${e.source}] ${e.path}${t}`),console.log(` Score: ${(e.score*100).toFixed(1)}%`),e.preview&&console.log(` ${e.preview.replace(/\s+/g,` `).trim()}`)}}},{name:`scope-map`,description:`Generate a reading plan for a task`,usage:`kb scope-map <task> [--max-files N]`,run:async n=>{let i=t(n,`--max-files`,15),a=n.join(` `).trim();a||(console.error(`Usage: kb scope-map <task> [--max-files N]`),process.exit(1));let{embedder:o,store:s}=await e(),c=await f(o,s,{task:a,maxFiles:i});console.log(`Task: ${c.task}`),console.log(`Files: ${c.files.length}`),console.log(`Estimated tokens: ${c.totalEstimatedTokens}`),console.log(``),console.log(`Reading order:`);for(let e of c.readingOrder)console.log(` ${e}`);for(let[e,t]of c.files.entries())console.log(`\n${e+1}. ${t.path}`),console.log(` Relevance: ${(t.relevance*100).toFixed(1)}% | Tokens: ${t.estimatedTokens}`),console.log(` Why: ${t.reason}`),t.focusRanges.length>0&&console.log(` Focus: ${r(t.focusRanges)}`)}},{name:`symbol`,description:`Resolve a symbol definition, imports, and references`,usage:`kb symbol <name> [--limit N]`,run:async n=>{let r=t(n,`--limit`,20),i=n.join(` `).trim();i||(console.error(`Usage: kb symbol <name> [--limit N]`),process.exit(1));let{embedder:a,store:s}=await e();o(await p(a,s,{name:i,limit:r}))}},{name:`trace`,description:`Trace forward/backward flow for a symbol or file location`,usage:`kb trace <start> [--direction forward|backward|both] [--max-depth N]`,run:async r=>{let i=n(r,`--direction`,`both`).trim()||`both`,a=t(r,`--max-depth`,3),o=r.join(` `).trim();(!o||![`forward`,`backward`,`both`].includes(i))&&(console.error(`Usage: kb trace <start> [--direction forward|backward|both] [--max-depth N]`),process.exit(1));let{embedder:c,store:l}=await e();s(await m(c,l,{start:o,direction:i,maxDepth:a}))}},{name:`examples`,description:`Find real code examples of a symbol or pattern`,usage:`kb examples <query> [--limit N] [--content-type type]`,run:async r=>{let i=t(r,`--limit`,5),o=n(r,`--content-type`,``).trim()||void 0,s=r.join(` `).trim();s||(console.error(`Usage: kb examples <query> [--limit N] [--content-type type]`),process.exit(1));let{embedder:c,store:l}=await e();a(await d(c,l,{query:s,limit:i,contentType:o}))}},{name:`dead-symbols`,description:`Find exported symbols that appear to be unused`,usage:`kb dead-symbols [--limit N]`,run:async n=>{let r=t(n,`--limit`,100),{embedder:a,store:o}=await e();i(await u(a,o,{limit:r}))}},{name:`lookup`,description:`Look up indexed content by record ID or source path`,usage:`kb lookup <id>`,run:async t=>{let n=t.join(` `).trim();n||(console.error(`Usage: kb lookup <id>`),process.exit(1));let{store:r}=await e(),i=await r.getById(n);if(i){console.log(i.id),console.log(`─`.repeat(60)),console.log(`Path: ${i.sourcePath}`),console.log(`Chunk: ${i.chunkIndex+1}/${i.totalChunks}`),console.log(`Lines: ${i.startLine}-${i.endLine}`),console.log(`Type: ${i.contentType} | Origin: ${i.origin}`),i.tags.length>0&&console.log(`Tags: ${i.tags.join(`, `)}`),console.log(``),console.log(i.content);return}let a=await r.getBySourcePath(n);if(a.length===0){console.log(`No indexed content found for: ${n}`);return}a.sort((e,t)=>e.chunkIndex-t.chunkIndex),console.log(n),console.log(`─`.repeat(60)),console.log(`Chunks: ${a.length} | Type: ${a[0].contentType}`);for(let e of a){let t=e.startLine?` (lines ${e.startLine}-${e.endLine})`:``;console.log(`\nChunk ${e.chunkIndex+1}/${e.totalChunks}${t}`),console.log(e.content)}}}];export{h as searchCommands};
2
- //# sourceMappingURL=search.js.map
1
+ import{ctx as e}from"../context.js";import{extractNumFlag as t,extractStrFlag as n,formatFocusRanges as r,printDeadSymbolsResult as i,printExamplesResult as a,printSymbolInfo as o,printTraceResult as s,rrf as c}from"../helpers.js";import{find as l,findDeadSymbols as u,findExamples as d,scopeMap as f,symbol as p,trace as m}from"../../../tools/dist/index.js";const h=[{name:`search`,description:`Search the knowledge base`,usage:`kb search <query> [--limit N] [--mode hybrid|semantic|keyword] [--graph-hops 0-3]`,run:async r=>{let i=t(r,`--limit`,5),a=n(r,`--mode`,`hybrid`),o=t(r,`--graph-hops`,0),s=r.join(` `).trim();s||(console.error(`Usage: kb search <query>`),process.exit(1));let{embedder:l,store:u,graphStore:d}=await e(),f=await l.embedQuery(s),p;if(a===`keyword`)p=await u.ftsSearch(s,{limit:i});else if(a===`semantic`)p=await u.search(f,{limit:i});else{let[e,t]=await Promise.all([u.search(f,{limit:i*2}),u.ftsSearch(s,{limit:i*2}).catch(()=>[])]);p=c(e,t).slice(0,i)}if(p.length===0){console.log(`No results found.`);return}for(let{record:e,score:t}of p){console.log(`\n${`─`.repeat(60)}`),console.log(`[${(t*100).toFixed(1)}%] ${e.sourcePath}:${e.startLine}-${e.endLine}`),console.log(` Type: ${e.contentType} | Origin: ${e.origin}`),e.tags.length>0&&console.log(` Tags: ${e.tags.join(`, `)}`),console.log(``);let n=e.content.length>500?`${e.content.slice(0,500)}...`:e.content;console.log(n)}if(console.log(`\n${`─`.repeat(60)}`),console.log(`${p.length} result(s) found.`),o>0&&p.length>0)try{let{graphAugmentSearch:e}=await import(`../../../tools/dist/index.js`),t=(await e(d,p.map(e=>({recordId:e.record.id,score:e.score,sourcePath:e.record.sourcePath})),{hops:o,maxPerHit:5})).filter(e=>e.graphContext.nodes.length>0);if(t.length>0){console.log(`\nGraph context (${o} hop${o>1?`s`:``}):\n`);for(let e of t){console.log(` ${e.sourcePath}:`);for(let t of e.graphContext.nodes.slice(0,5))console.log(` → ${t.name} (${t.type})`);for(let t of e.graphContext.edges.slice(0,5))console.log(` → ${t.fromId} --[${t.type}]--> ${t.toId}`)}}}catch(e){console.error(`[graph] augmentation failed: ${e.message}`)}}},{name:`find`,description:`Run federated search across indexed content and files`,usage:`kb find [query] [--glob <pattern>] [--pattern <regex>] [--limit N]`,run:async r=>{let i=t(r,`--limit`,10),a=n(r,`--glob`,``).trim()||void 0,o=n(r,`--pattern`,``).trim()||void 0,s=r.join(` `).trim()||void 0;!s&&!a&&!o&&(console.error(`Usage: kb find [query] [--glob <pattern>] [--pattern <regex>] [--limit N]`),process.exit(1));let{embedder:c,store:u}=await e(),d=await l(c,u,{query:s,glob:a,pattern:o,limit:i});if(d.results.length===0){console.log(`No matches found.`);return}console.log(`Strategies: ${d.strategies.join(`, `)}`),console.log(`Results: ${d.results.length} shown (${d.totalFound} total)`);for(let e of d.results){let t=e.lineRange?`:${e.lineRange.start}-${e.lineRange.end}`:``;console.log(`\n[${e.source}] ${e.path}${t}`),console.log(` Score: ${(e.score*100).toFixed(1)}%`),e.preview&&console.log(` ${e.preview.replace(/\s+/g,` `).trim()}`)}}},{name:`scope-map`,description:`Generate a reading plan for a task`,usage:`kb scope-map <task> [--max-files N]`,run:async n=>{let i=t(n,`--max-files`,15),a=n.join(` `).trim();a||(console.error(`Usage: kb scope-map <task> [--max-files N]`),process.exit(1));let{embedder:o,store:s}=await e(),c=await f(o,s,{task:a,maxFiles:i});console.log(`Task: ${c.task}`),console.log(`Files: ${c.files.length}`),console.log(`Estimated tokens: ${c.totalEstimatedTokens}`),console.log(``),console.log(`Reading order:`);for(let e of c.readingOrder)console.log(` ${e}`);for(let[e,t]of c.files.entries())console.log(`\n${e+1}. ${t.path}`),console.log(` Relevance: ${(t.relevance*100).toFixed(1)}% | Tokens: ${t.estimatedTokens}`),console.log(` Why: ${t.reason}`),t.focusRanges.length>0&&console.log(` Focus: ${r(t.focusRanges)}`)}},{name:`symbol`,description:`Resolve a symbol definition, imports, and references`,usage:`kb symbol <name> [--limit N]`,run:async n=>{let r=t(n,`--limit`,20),i=n.join(` `).trim();i||(console.error(`Usage: kb symbol <name> [--limit N]`),process.exit(1));let{embedder:a,store:s}=await e();o(await p(a,s,{name:i,limit:r}))}},{name:`trace`,description:`Trace forward/backward flow for a symbol or file location`,usage:`kb trace <start> [--direction forward|backward|both] [--max-depth N]`,run:async r=>{let i=n(r,`--direction`,`both`).trim()||`both`,a=t(r,`--max-depth`,3),o=r.join(` `).trim();(!o||![`forward`,`backward`,`both`].includes(i))&&(console.error(`Usage: kb trace <start> [--direction forward|backward|both] [--max-depth N]`),process.exit(1));let{embedder:c,store:l}=await e();s(await m(c,l,{start:o,direction:i,maxDepth:a}))}},{name:`examples`,description:`Find real code examples of a symbol or pattern`,usage:`kb examples <query> [--limit N] [--content-type type]`,run:async r=>{let i=t(r,`--limit`,5),o=n(r,`--content-type`,``).trim()||void 0,s=r.join(` `).trim();s||(console.error(`Usage: kb examples <query> [--limit N] [--content-type type]`),process.exit(1));let{embedder:c,store:l}=await e();a(await d(c,l,{query:s,limit:i,contentType:o}))}},{name:`dead-symbols`,description:`Find exported symbols that appear to be unused`,usage:`kb dead-symbols [--limit N]`,run:async n=>{let r=t(n,`--limit`,100),{embedder:a,store:o}=await e();i(await u(a,o,{limit:r}))}},{name:`lookup`,description:`Look up indexed content by record ID or source path`,usage:`kb lookup <id>`,run:async t=>{let n=t.join(` `).trim();n||(console.error(`Usage: kb lookup <id>`),process.exit(1));let{store:r}=await e(),i=await r.getById(n);if(i){console.log(i.id),console.log(`─`.repeat(60)),console.log(`Path: ${i.sourcePath}`),console.log(`Chunk: ${i.chunkIndex+1}/${i.totalChunks}`),console.log(`Lines: ${i.startLine}-${i.endLine}`),console.log(`Type: ${i.contentType} | Origin: ${i.origin}`),i.tags.length>0&&console.log(`Tags: ${i.tags.join(`, `)}`),console.log(``),console.log(i.content);return}let a=await r.getBySourcePath(n);if(a.length===0){console.log(`No indexed content found for: ${n}`);return}a.sort((e,t)=>e.chunkIndex-t.chunkIndex),console.log(n),console.log(`─`.repeat(60)),console.log(`Chunks: ${a.length} | Type: ${a[0].contentType}`);for(let e of a){let t=e.startLine?` (lines ${e.startLine}-${e.endLine})`:``;console.log(`\nChunk ${e.chunkIndex+1}/${e.totalChunks}${t}`),console.log(e.content)}}}];export{h as searchCommands};
@@ -3,5 +3,4 @@ import { Command } from "../types.js";
3
3
  //#region packages/cli/src/commands/system.d.ts
4
4
  declare const systemCommands: Command[];
5
5
  //#endregion
6
- export { systemCommands };
7
- //# sourceMappingURL=system.d.ts.map
6
+ export { systemCommands };
@@ -1,5 +1,4 @@
1
- import{ctx as e}from"../context.js";import{executeCliBatchOperation as t,extractStrFlag as n,parseBatchPayload as r,printCheckResult as i,readInput as a}from"../helpers.js";import{dirname as o,resolve as s}from"node:path";import{fileURLToPath as c}from"node:url";import{audit as l,batch as u,check as d,guide as f,health as p,replayClear as m,replayList as h,replayTrim as g}from"../../../tools/dist/index.js";import{fork as _}from"node:child_process";const v=o(c(import.meta.url)),y=[{name:`status`,description:`Show knowledge base index status and statistics`,run:async()=>{let{store:t}=await e(),n=await t.getStats(),r=await t.listSourcePaths();console.log(`Knowledge Base Status`),console.log(`─`.repeat(40)),console.log(` Records: ${n.totalRecords}`),console.log(` Files: ${n.totalFiles}`),console.log(` Indexed: ${n.lastIndexedAt??`Never`}`),console.log(` Backend: ${n.storeBackend}`),console.log(` Model: ${n.embeddingModel}`),console.log(``),console.log(`Content Types:`);for(let[e,t]of Object.entries(n.contentTypeBreakdown))console.log(` ${e}: ${t}`);if(r.length>0){console.log(``),console.log(`Files (${r.length} total):`);for(let e of r.slice(0,20))console.log(` ${e}`);r.length>20&&console.log(` ... and ${r.length-20} more`)}}},{name:`reindex`,description:`Re-index the knowledge base from configured sources`,usage:`kb reindex [--full]`,run:async t=>{let n=t.includes(`--full`),{store:r,indexer:i,curated:a,config:o}=await e();console.log(`Indexing sources...`);let s=e=>{e.phase===`chunking`&&e.currentFile&&process.stdout.write(`\r [${e.filesProcessed+1}/${e.filesTotal}] ${e.currentFile}`),e.phase===`done`&&process.stdout.write(`
2
- `)},c;n?(console.log(`Dropping existing index for full reindex...`),c=await i.reindexAll(o,s)):c=await i.index(o,s),console.log(`Done: ${c.filesProcessed} files, ${c.chunksCreated} chunks in ${(c.durationMs/1e3).toFixed(1)}s`),console.log(`Building FTS index...`),await r.createFtsIndex(),console.log(`Re-indexing curated entries...`);let l=await a.reindexAll();console.log(`Curated: ${l.indexed} entries restored`)}},{name:`serve`,description:`Start the MCP server (stdio or HTTP)`,usage:`kb serve [--transport stdio|http] [--port N]`,run:async e=>{let t=s(v,`..`,`..`,`..`,`server`,`dist`,`index.js`),r=n(e,`--transport`,`stdio`),i=n(e,`--port`,`3210`),a=_(t,[],{stdio:r===`stdio`?[`pipe`,`pipe`,`inherit`,`ipc`]:`inherit`,env:{...process.env,KB_TRANSPORT:r,KB_PORT:i}});r===`stdio`&&a.stdin&&a.stdout&&(process.stdin.pipe(a.stdin),a.stdout.pipe(process.stdout)),a.on(`exit`,e=>process.exit(e??0)),process.on(`SIGINT`,()=>a.kill(`SIGINT`)),process.on(`SIGTERM`,()=>a.kill(`SIGTERM`)),await new Promise(()=>{})}},{name:`init`,description:`Initialize a knowledge base in the current directory`,usage:`kb init [--force] [--guide]`,run:async e=>{if(e.includes(`--guide`)){let{guideProject:e}=await import(`./init/index.js`);await e();return}let t=e.includes(`--force`),{initProject:n}=await import(`./init/index.js`);await n({force:t})}},{name:`check`,description:`Run incremental typecheck and lint`,usage:`kb check [--cwd <dir>] [--files f1,f2] [--skip-types] [--skip-lint] [--detail summary|errors|full]`,run:async e=>{let t=n(e,`--cwd`,``).trim()||void 0,r=n(e,`--files`,``),a=n(e,`--detail`,`full`)||`full`,o=r.split(`,`).map(e=>e.trim()).filter(Boolean),s=!1;e.includes(`--skip-types`)&&(e.splice(e.indexOf(`--skip-types`),1),s=!0);let c=!1;e.includes(`--skip-lint`)&&(e.splice(e.indexOf(`--skip-lint`),1),c=!0);let l=await d({cwd:t,files:o.length>0?o:void 0,skipTypes:s,skipLint:c,detail:a});i(l),l.passed||(process.exitCode=1)}},{name:`batch`,description:`Execute built-in operations from JSON input`,usage:`kb batch [--file path] [--concurrency N]`,run:async i=>{let o=n(i,`--file`,``).trim()||void 0,s=(()=>{let e=i.indexOf(`--concurrency`);if(e===-1||e+1>=i.length)return 0;let t=Number.parseInt(i.splice(e,2)[1],10);return Number.isNaN(t)?0:t})(),c=await a(o);c.trim()||(console.error(`Usage: kb batch [--file path] [--concurrency N]`),process.exit(1));let l=r(c),d=s>0?s:l.concurrency,f=l.operations.some(e=>e.type!==`check`)?await e():null,p=await u(l.operations,async e=>t(e,f),{concurrency:d});console.log(JSON.stringify(p,null,2)),p.some(e=>e.status===`error`)&&(process.exitCode=1)}},{name:`health`,description:`Run project health checks on the current directory`,usage:`kb health [path]`,run:async e=>{let t=p(e.shift());console.log(`Project Health: ${t.path}`),console.log(`─`.repeat(50));for(let e of t.checks){let t=e.status===`pass`?`+`:e.status===`warn`?`~`:`X`;console.log(` [${t}] ${e.name}: ${e.message}`)}console.log(`─`.repeat(50)),console.log(`Score: ${t.score}% — ${t.summary}`)}},{name:`audit`,description:`Run a unified project audit (structure, deps, patterns, health, dead symbols, check)`,usage:`kb audit [path] [--checks structure,dependencies,patterns,health,dead_symbols,check,entry_points] [--detail summary|full]`,run:async t=>{let{store:r,embedder:i}=await e(),a=n(t,`--detail`,`summary`)||`summary`,o=n(t,`--checks`,``),s=o?o.split(`,`).map(e=>e.trim()):void 0,c=await l(r,i,{path:t.shift()||`.`,checks:s,detail:a});if(c.ok){if(console.log(c.summary),c.next&&c.next.length>0){console.log(`
1
+ import{ctx as e}from"../context.js";import{executeCliBatchOperation as t,extractStrFlag as n,parseBatchPayload as r,printCheckResult as i,readInput as a}from"../helpers.js";import{dirname as o,resolve as s}from"node:path";import{fileURLToPath as c}from"node:url";import{audit as l,batch as u,check as d,guide as f,health as p,replayClear as m,replayList as h,replayTrim as g}from"../../../tools/dist/index.js";import{fork as _}from"node:child_process";const v=o(c(import.meta.url)),y=[{name:`status`,description:`Show knowledge base index status and statistics`,run:async()=>{let{isGlobalInstalled:t,getGlobalDataDir:n,computePartitionKey:r,listWorkspaces:i}=await import(`../../../core/dist/index.js`),{existsSync:a}=await import(`node:fs`),o=process.cwd(),c=t(),l=a(s(o,`.vscode`,`mcp.json`)),u,d;if(c&&l)u=`local (overrides global for this workspace)`,d=s(o,`.kb-data`);else if(c){let e=r(o);u=a(s(o,`AGENTS.md`))?`global (workspace scaffolded)`:`global (workspace not scaffolded)`,d=s(n(),e)}else u=`local`,d=s(o,`.kb-data`);if(console.log(`Knowledge Base Status`),console.log(`─`.repeat(40)),console.log(` Mode: ${u}`),console.log(` Data: ${d}`),c&&!l){let e=i();console.log(` Registry: ${e.length} workspace(s) enrolled`)}try{let{store:t}=await e(),n=await t.getStats(),r=await t.listSourcePaths();console.log(` Records: ${n.totalRecords}`),console.log(` Files: ${n.totalFiles}`),console.log(` Indexed: ${n.lastIndexedAt??`Never`}`),console.log(` Backend: ${n.storeBackend}`),console.log(` Model: ${n.embeddingModel}`),console.log(``),console.log(`Content Types:`);for(let[e,t]of Object.entries(n.contentTypeBreakdown))console.log(` ${e}: ${t}`);if(r.length>0){console.log(``),console.log(`Files (${r.length} total):`);for(let e of r.slice(0,20))console.log(` ${e}`);r.length>20&&console.log(` ... and ${r.length-20} more`)}}catch{console.log(``),console.log(" Index not available — run `kb reindex` to index this workspace.")}c&&!l&&!a(s(o,`AGENTS.md`))&&(console.log(``),console.log(" Action: Run `npx @vpxa/kb init` to add AGENTS.md and copilot-instructions.md"))}},{name:`reindex`,description:`Re-index the knowledge base from configured sources`,usage:`kb reindex [--full]`,run:async t=>{let n=t.includes(`--full`),{store:r,indexer:i,curated:a,config:o}=await e();console.log(`Indexing sources...`);let s=e=>{e.phase===`chunking`&&e.currentFile&&process.stdout.write(`\r [${e.filesProcessed+1}/${e.filesTotal}] ${e.currentFile}`),e.phase===`done`&&process.stdout.write(`
2
+ `)},c;n?(console.log(`Dropping existing index for full reindex...`),c=await i.reindexAll(o,s)):c=await i.index(o,s),console.log(`Done: ${c.filesProcessed} files, ${c.chunksCreated} chunks in ${(c.durationMs/1e3).toFixed(1)}s`),console.log(`Building FTS index...`),await r.createFtsIndex(),console.log(`Re-indexing curated entries...`);let l=await a.reindexAll();console.log(`Curated: ${l.indexed} entries restored`)}},{name:`serve`,description:`Start the MCP server (stdio or HTTP)`,usage:`kb serve [--transport stdio|http] [--port N]`,run:async e=>{let t=s(v,`..`,`..`,`..`,`server`,`dist`,`index.js`),r=n(e,`--transport`,`stdio`),i=n(e,`--port`,`3210`),a=_(t,[],{stdio:r===`stdio`?[`pipe`,`pipe`,`inherit`,`ipc`]:`inherit`,env:{...process.env,KB_TRANSPORT:r,KB_PORT:i}});r===`stdio`&&a.stdin&&a.stdout&&(process.stdin.pipe(a.stdin),a.stdout.pipe(process.stdout)),a.on(`exit`,e=>process.exit(e??0)),process.on(`SIGINT`,()=>a.kill(`SIGINT`)),process.on(`SIGTERM`,()=>a.kill(`SIGTERM`)),await new Promise(()=>{})}},{name:`init`,description:`Initialize a knowledge base in the current directory`,usage:`kb init [--global|--local] [--force] [--guide]`,run:async e=>{let t=e.includes(`--global`),n=e.includes(`--local`),r=e.includes(`--guide`),i=e.includes(`--force`);if(t&&n&&(console.error(`Cannot use --global and --local together.`),process.exit(1)),r){let{guideProject:e}=await import(`./init/index.js`);await e();return}if(t){let{initGlobal:e}=await import(`./init/global.js`);await e({force:i})}else if(n){let{initProject:e}=await import(`./init/index.js`);await e({force:i})}else{let{initSmart:e}=await import(`./init/index.js`);await e({force:i})}}},{name:`check`,description:`Run incremental typecheck and lint`,usage:`kb check [--cwd <dir>] [--files f1,f2] [--skip-types] [--skip-lint] [--detail summary|errors|full]`,run:async e=>{let t=n(e,`--cwd`,``).trim()||void 0,r=n(e,`--files`,``),a=n(e,`--detail`,`full`)||`full`,o=r.split(`,`).map(e=>e.trim()).filter(Boolean),s=!1;e.includes(`--skip-types`)&&(e.splice(e.indexOf(`--skip-types`),1),s=!0);let c=!1;e.includes(`--skip-lint`)&&(e.splice(e.indexOf(`--skip-lint`),1),c=!0);let l=await d({cwd:t,files:o.length>0?o:void 0,skipTypes:s,skipLint:c,detail:a});i(l),l.passed||(process.exitCode=1)}},{name:`batch`,description:`Execute built-in operations from JSON input`,usage:`kb batch [--file path] [--concurrency N]`,run:async i=>{let o=n(i,`--file`,``).trim()||void 0,s=(()=>{let e=i.indexOf(`--concurrency`);if(e===-1||e+1>=i.length)return 0;let t=Number.parseInt(i.splice(e,2)[1],10);return Number.isNaN(t)?0:t})(),c=await a(o);c.trim()||(console.error(`Usage: kb batch [--file path] [--concurrency N]`),process.exit(1));let l=r(c),d=s>0?s:l.concurrency,f=l.operations.some(e=>e.type!==`check`)?await e():null,p=await u(l.operations,async e=>t(e,f),{concurrency:d});console.log(JSON.stringify(p,null,2)),p.some(e=>e.status===`error`)&&(process.exitCode=1)}},{name:`health`,description:`Run project health checks on the current directory`,usage:`kb health [path]`,run:async e=>{let t=p(e.shift());console.log(`Project Health: ${t.path}`),console.log(`─`.repeat(50));for(let e of t.checks){let t=e.status===`pass`?`+`:e.status===`warn`?`~`:`X`;console.log(` [${t}] ${e.name}: ${e.message}`)}console.log(`─`.repeat(50)),console.log(`Score: ${t.score}% — ${t.summary}`)}},{name:`audit`,description:`Run a unified project audit (structure, deps, patterns, health, dead symbols, check)`,usage:`kb audit [path] [--checks structure,dependencies,patterns,health,dead_symbols,check,entry_points] [--detail summary|full]`,run:async t=>{let{store:r,embedder:i}=await e(),a=n(t,`--detail`,`summary`)||`summary`,o=n(t,`--checks`,``),s=o?o.split(`,`).map(e=>e.trim()):void 0,c=await l(r,i,{path:t.shift()||`.`,checks:s,detail:a});if(c.ok){if(console.log(c.summary),c.next&&c.next.length>0){console.log(`
3
3
  Suggested next steps:`);for(let e of c.next)console.log(` → ${e.tool}: ${e.reason}`)}}else console.error(c.error?.message??`Audit failed`),process.exitCode=1}},{name:`guide`,description:`Tool discovery — recommend KB tools for a given goal`,usage:`kb guide <goal> [--max N]`,run:async e=>{let t=e.indexOf(`--max`),n=5;t!==-1&&t+1<e.length&&(n=Number.parseInt(e.splice(t,2)[1],10)||5);let r=e.join(` `).trim();r||(console.error(`Usage: kb guide <goal> [--max N]`),console.error(`Example: kb guide "audit this project"`),process.exit(1));let i=f(r,n);console.log(`Workflow: ${i.workflow}`),console.log(` ${i.description}\n`),console.log(`Recommended tools:`);for(let e of i.tools){let t=e.suggestedArgs?` ${JSON.stringify(e.suggestedArgs)}`:``;console.log(` ${e.order}. ${e.tool} — ${e.reason}${t}`)}i.alternativeWorkflows.length>0&&console.log(`\nAlternatives: ${i.alternativeWorkflows.join(`, `)}`)}},{name:`replay`,description:`Show recent tool invocation audit trail`,usage:`kb replay [--last N] [--tool <name>] [--source mcp|cli]`,run:async e=>{let t=h({last:Number.parseInt(e[e.indexOf(`--last`)+1],10)||20,tool:e.includes(`--tool`)?e[e.indexOf(`--tool`)+1]:void 0,source:e.includes(`--source`)?e[e.indexOf(`--source`)+1]:void 0});if(t.length===0){console.log(`No replay entries. Activity is logged when tools are invoked.`);return}console.log(`Replay Log (${t.length} entries)\n`);for(let e of t){let t=e.ts.split(`T`)[1]?.split(`.`)[0]??e.ts,n=e.status===`ok`?`✓`:`✗`;console.log(`${t} ${n} ${e.tool} (${e.durationMs}ms) [${e.source}]`),console.log(` in: ${e.input}`),console.log(` out: ${e.output}`)}g()}},{name:`replay-clear`,description:`Clear the replay audit trail`,run:async()=>{m(),console.log(`Replay log cleared.`)}},{name:`tui`,description:`Launch interactive terminal dashboard (human monitoring)`,run:async()=>{try{let{launch:t}=await import(`../../../tui/dist/index.js`),{store:n,embedder:r,config:i}=await e();t({store:n,embedder:r,config:i})}catch(e){throw e.code===`ERR_MODULE_NOT_FOUND`&&(console.error(`TUI requires ink and react. Install them with:
4
- pnpm add -D ink react @types/react`),process.exit(1)),e}}}];export{y as systemCommands};
5
- //# sourceMappingURL=system.js.map
4
+ pnpm add -D ink react @types/react`),process.exit(1)),e}}}];export{y as systemCommands};
@@ -3,5 +3,4 @@ import { Command } from "../types.js";
3
3
  //#region packages/cli/src/commands/workspace.d.ts
4
4
  declare const workspaceCommands: Command[];
5
5
  //#endregion
6
- export { workspaceCommands };
7
- //# sourceMappingURL=workspace.d.ts.map
6
+ export { workspaceCommands };
@@ -1,2 +1 @@
1
- import{extractStrFlag as e,parseMaybeJsonString as t,printWorkset as n,readStdin as r,splitCsv as i}from"../helpers.js";import{addToWorkset as a,deleteWorkset as o,getWorkset as s,laneCreate as c,laneDiff as l,laneDiscard as u,laneList as d,laneMerge as f,laneStatus as p,listWorksets as m,queueClear as h,queueCreate as g,queueDelete as _,queueDone as v,queueFail as y,queueGet as b,queueList as x,queueNext as S,queuePush as C,removeFromWorkset as w,saveWorkset as T,stashClear as E,stashDelete as D,stashGet as O,stashList as k,stashSet as A}from"../../../tools/dist/index.js";const j=[{name:`workset`,description:`Manage saved file sets`,usage:`kb workset <action> [name] [--files f1,f2] [--description desc]`,run:async t=>{let r=t.shift()?.trim(),c=i(e(t,`--files`,``)),l=e(t,`--description`,``).trim()||void 0,u=t.shift()?.trim();switch(r||(console.error(`Usage: kb workset <action> [name] [--files f1,f2] [--description desc]`),console.error(`Actions: save, get, list, delete, add, remove`),process.exit(1)),r){case`save`:{(!u||c.length===0)&&(console.error(`Usage: kb workset save <name> --files f1,f2 [--description desc]`),process.exit(1));let e=T(u,c,{description:l});console.log(`Saved workset: ${e.name}`),n(e);return}case`get`:{u||(console.error(`Usage: kb workset get <name>`),process.exit(1));let e=s(u);if(!e){console.log(`No workset found: ${u}`);return}n(e);return}case`list`:{let e=m();if(e.length===0){console.log(`No worksets saved.`);return}console.log(`Worksets (${e.length})`),console.log(`─`.repeat(60));for(let t of e)n(t),console.log(``);return}case`delete`:{u||(console.error(`Usage: kb workset delete <name>`),process.exit(1));let e=o(u);console.log(e?`Deleted workset: ${u}`:`No workset found: ${u}`);return}case`add`:{(!u||c.length===0)&&(console.error(`Usage: kb workset add <name> --files f1,f2`),process.exit(1));let e=a(u,c);console.log(`Updated workset: ${e.name}`),n(e);return}case`remove`:{(!u||c.length===0)&&(console.error(`Usage: kb workset remove <name> --files f1,f2`),process.exit(1));let e=w(u,c);if(!e){console.log(`No workset found: ${u}`);return}console.log(`Updated workset: ${e.name}`),n(e);return}default:console.error(`Unknown workset action: ${r}`),console.error(`Actions: save, get, list, delete, add, remove`),process.exit(1)}}},{name:`stash`,description:`Persist and retrieve named intermediate values`,usage:`kb stash <set|get|list|delete|clear> [key] [value]`,run:async e=>{let n=e.shift()?.trim(),i=e.shift()?.trim();switch(n||(console.error(`Usage: kb stash <set|get|list|delete|clear> [key] [value]`),process.exit(1)),n){case`set`:{i||(console.error(`Usage: kb stash set <key> <value>`),process.exit(1));let n=e.join(` `),a=n.trim()?``:await r(),o=A(i,t(n||a));console.log(`Stored stash entry: ${o.key}`),console.log(` Type: ${o.type}`),console.log(` Stored: ${o.storedAt}`);return}case`get`:{i||(console.error(`Usage: kb stash get <key>`),process.exit(1));let e=O(i);if(!e){console.log(`No stash entry found: ${i}`);return}console.log(JSON.stringify(e,null,2));return}case`list`:{let e=k();if(e.length===0){console.log(`No stash entries saved.`);return}console.log(`Stash entries (${e.length})`),console.log(`─`.repeat(60));for(let t of e)console.log(`${t.key} (${t.type})`),console.log(` Stored: ${t.storedAt}`);return}case`delete`:{i||(console.error(`Usage: kb stash delete <key>`),process.exit(1));let e=D(i);console.log(e?`Deleted stash entry: ${i}`:`No stash entry found: ${i}`);return}case`clear`:{let e=E();console.log(`Cleared ${e} stash entr${e===1?`y`:`ies`}.`);return}default:console.error(`Unknown stash action: ${n}`),console.error(`Actions: set, get, list, delete, clear`),process.exit(1)}}},{name:`lane`,description:`Manage verified lanes — isolated file copies for parallel exploration`,usage:`kb lane <create|list|status|diff|merge|discard> [name] [--files f1,f2]`,run:async t=>{let n=t.shift();if((!n||![`create`,`list`,`status`,`diff`,`merge`,`discard`].includes(n))&&(console.error(`Usage: kb lane <create|list|status|diff|merge|discard> [name] [--files f1,f2]`),process.exit(1)),n===`list`){let e=d();if(e.length===0){console.log(`No active lanes.`);return}for(let t of e)console.log(`${t.name} (${t.sourceFiles.length} files, created ${t.createdAt})`);return}let r=t.shift();switch(r||(console.error(`Lane name is required for "${n}".`),process.exit(1)),n){case`create`:{let n=e(t,`--files`,``);n||(console.error(`Usage: kb lane create <name> --files file1.ts,file2.ts`),process.exit(1));let i=c(r,n.split(`,`).map(e=>e.trim()));console.log(`Lane "${i.name}" created with ${i.sourceFiles.length} files.`);break}case`status`:{let e=p(r);console.log(`Lane: ${e.name}`),console.log(`Modified: ${e.modified} | Added: ${e.added} | Deleted: ${e.deleted}`);for(let t of e.entries)console.log(` ${t.status.padEnd(10)} ${t.file}`);break}case`diff`:{let e=l(r);console.log(`Lane: ${e.name} — ${e.modified} modified, ${e.added} added, ${e.deleted} deleted`);for(let t of e.entries)t.diff&&(console.log(`\n--- ${t.file} (${t.status})`),console.log(t.diff));break}case`merge`:{let e=f(r);console.log(`Merged ${e.filesMerged} files from lane "${e.name}".`);for(let t of e.files)console.log(` ${t}`);break}case`discard`:{let e=u(r);console.log(e?`Lane "${r}" discarded.`:`Lane "${r}" not found.`);break}}}},{name:`queue`,description:`Manage task queues for sequential agent operations`,usage:`kb queue <create|push|next|done|fail|get|list|clear|delete> [name] [args]`,run:async e=>{let t=e.shift();if((!t||![`create`,`push`,`next`,`done`,`fail`,`get`,`list`,`clear`,`delete`].includes(t))&&(console.error(`Usage: kb queue <create|push|next|done|fail|get|list|clear|delete> [name] [args]`),process.exit(1)),t===`list`){let e=x();if(e.length===0){console.log(`No queues.`);return}for(let t of e)console.log(`${t.name} pending:${t.pending} done:${t.done} failed:${t.failed} total:${t.total}`);return}let n=e.shift();switch(n||(console.error(`Queue name is required for "${t}".`),process.exit(1)),t){case`create`:{let e=g(n);console.log(`Queue "${e.name}" created.`);break}case`push`:{let t=C(n,e.join(` `)||`Untitled task`);console.log(`Pushed "${t.title}" (${t.id}) to queue "${n}".`);break}case`next`:{let e=S(n);console.log(e?`Next: ${e.title} (${e.id})`:`No pending items in queue "${n}".`);break}case`done`:{let t=e.shift();t||(console.error(`Usage: kb queue done <name> <id>`),process.exit(1));let r=v(n,t);console.log(`Marked "${r.title}" as done.`);break}case`fail`:{let t=e.shift(),r=e.join(` `)||`Unknown error`;t||(console.error(`Usage: kb queue fail <name> <id> [error message]`),process.exit(1));let i=y(n,t,r);console.log(`Marked "${i.title}" as failed: ${r}`);break}case`get`:{let e=b(n);if(!e){console.log(`Queue "${n}" not found.`);return}console.log(`Queue: ${e.name} (${e.items.length} items)`);for(let t of e.items){let e=t.error?` — ${t.error}`:``;console.log(` ${t.status.padEnd(12)} ${t.id} ${t.title}${e}`)}break}case`clear`:{let e=h(n);console.log(`Cleared ${e} completed/failed items from queue "${n}".`);break}case`delete`:{let e=_(n);console.log(e?`Queue "${n}" deleted.`:`Queue "${n}" not found.`);break}}}}];export{j as workspaceCommands};
2
- //# sourceMappingURL=workspace.js.map
1
+ import{extractStrFlag as e,parseMaybeJsonString as t,printWorkset as n,readStdin as r,splitCsv as i}from"../helpers.js";import{addToWorkset as a,deleteWorkset as o,getWorkset as s,laneCreate as c,laneDiff as l,laneDiscard as u,laneList as d,laneMerge as f,laneStatus as p,listWorksets as m,queueClear as h,queueCreate as g,queueDelete as _,queueDone as v,queueFail as y,queueGet as b,queueList as x,queueNext as S,queuePush as C,removeFromWorkset as w,saveWorkset as T,stashClear as E,stashDelete as D,stashGet as O,stashList as k,stashSet as A}from"../../../tools/dist/index.js";const j=[{name:`workset`,description:`Manage saved file sets`,usage:`kb workset <action> [name] [--files f1,f2] [--description desc]`,run:async t=>{let r=t.shift()?.trim(),c=i(e(t,`--files`,``)),l=e(t,`--description`,``).trim()||void 0,u=t.shift()?.trim();switch(r||(console.error(`Usage: kb workset <action> [name] [--files f1,f2] [--description desc]`),console.error(`Actions: save, get, list, delete, add, remove`),process.exit(1)),r){case`save`:{(!u||c.length===0)&&(console.error(`Usage: kb workset save <name> --files f1,f2 [--description desc]`),process.exit(1));let e=T(u,c,{description:l});console.log(`Saved workset: ${e.name}`),n(e);return}case`get`:{u||(console.error(`Usage: kb workset get <name>`),process.exit(1));let e=s(u);if(!e){console.log(`No workset found: ${u}`);return}n(e);return}case`list`:{let e=m();if(e.length===0){console.log(`No worksets saved.`);return}console.log(`Worksets (${e.length})`),console.log(`─`.repeat(60));for(let t of e)n(t),console.log(``);return}case`delete`:{u||(console.error(`Usage: kb workset delete <name>`),process.exit(1));let e=o(u);console.log(e?`Deleted workset: ${u}`:`No workset found: ${u}`);return}case`add`:{(!u||c.length===0)&&(console.error(`Usage: kb workset add <name> --files f1,f2`),process.exit(1));let e=a(u,c);console.log(`Updated workset: ${e.name}`),n(e);return}case`remove`:{(!u||c.length===0)&&(console.error(`Usage: kb workset remove <name> --files f1,f2`),process.exit(1));let e=w(u,c);if(!e){console.log(`No workset found: ${u}`);return}console.log(`Updated workset: ${e.name}`),n(e);return}default:console.error(`Unknown workset action: ${r}`),console.error(`Actions: save, get, list, delete, add, remove`),process.exit(1)}}},{name:`stash`,description:`Persist and retrieve named intermediate values`,usage:`kb stash <set|get|list|delete|clear> [key] [value]`,run:async e=>{let n=e.shift()?.trim(),i=e.shift()?.trim();switch(n||(console.error(`Usage: kb stash <set|get|list|delete|clear> [key] [value]`),process.exit(1)),n){case`set`:{i||(console.error(`Usage: kb stash set <key> <value>`),process.exit(1));let n=e.join(` `),a=n.trim()?``:await r(),o=A(i,t(n||a));console.log(`Stored stash entry: ${o.key}`),console.log(` Type: ${o.type}`),console.log(` Stored: ${o.storedAt}`);return}case`get`:{i||(console.error(`Usage: kb stash get <key>`),process.exit(1));let e=O(i);if(!e){console.log(`No stash entry found: ${i}`);return}console.log(JSON.stringify(e,null,2));return}case`list`:{let e=k();if(e.length===0){console.log(`No stash entries saved.`);return}console.log(`Stash entries (${e.length})`),console.log(`─`.repeat(60));for(let t of e)console.log(`${t.key} (${t.type})`),console.log(` Stored: ${t.storedAt}`);return}case`delete`:{i||(console.error(`Usage: kb stash delete <key>`),process.exit(1));let e=D(i);console.log(e?`Deleted stash entry: ${i}`:`No stash entry found: ${i}`);return}case`clear`:{let e=E();console.log(`Cleared ${e} stash entr${e===1?`y`:`ies`}.`);return}default:console.error(`Unknown stash action: ${n}`),console.error(`Actions: set, get, list, delete, clear`),process.exit(1)}}},{name:`lane`,description:`Manage verified lanes — isolated file copies for parallel exploration`,usage:`kb lane <create|list|status|diff|merge|discard> [name] [--files f1,f2]`,run:async t=>{let n=t.shift();if((!n||![`create`,`list`,`status`,`diff`,`merge`,`discard`].includes(n))&&(console.error(`Usage: kb lane <create|list|status|diff|merge|discard> [name] [--files f1,f2]`),process.exit(1)),n===`list`){let e=d();if(e.length===0){console.log(`No active lanes.`);return}for(let t of e)console.log(`${t.name} (${t.sourceFiles.length} files, created ${t.createdAt})`);return}let r=t.shift();switch(r||(console.error(`Lane name is required for "${n}".`),process.exit(1)),n){case`create`:{let n=e(t,`--files`,``);n||(console.error(`Usage: kb lane create <name> --files file1.ts,file2.ts`),process.exit(1));let i=c(r,n.split(`,`).map(e=>e.trim()));console.log(`Lane "${i.name}" created with ${i.sourceFiles.length} files.`);break}case`status`:{let e=p(r);console.log(`Lane: ${e.name}`),console.log(`Modified: ${e.modified} | Added: ${e.added} | Deleted: ${e.deleted}`);for(let t of e.entries)console.log(` ${t.status.padEnd(10)} ${t.file}`);break}case`diff`:{let e=l(r);console.log(`Lane: ${e.name} — ${e.modified} modified, ${e.added} added, ${e.deleted} deleted`);for(let t of e.entries)t.diff&&(console.log(`\n--- ${t.file} (${t.status})`),console.log(t.diff));break}case`merge`:{let e=f(r);console.log(`Merged ${e.filesMerged} files from lane "${e.name}".`);for(let t of e.files)console.log(` ${t}`);break}case`discard`:{let e=u(r);console.log(e?`Lane "${r}" discarded.`:`Lane "${r}" not found.`);break}}}},{name:`queue`,description:`Manage task queues for sequential agent operations`,usage:`kb queue <create|push|next|done|fail|get|list|clear|delete> [name] [args]`,run:async e=>{let t=e.shift();if((!t||![`create`,`push`,`next`,`done`,`fail`,`get`,`list`,`clear`,`delete`].includes(t))&&(console.error(`Usage: kb queue <create|push|next|done|fail|get|list|clear|delete> [name] [args]`),process.exit(1)),t===`list`){let e=x();if(e.length===0){console.log(`No queues.`);return}for(let t of e)console.log(`${t.name} pending:${t.pending} done:${t.done} failed:${t.failed} total:${t.total}`);return}let n=e.shift();switch(n||(console.error(`Queue name is required for "${t}".`),process.exit(1)),t){case`create`:{let e=g(n);console.log(`Queue "${e.name}" created.`);break}case`push`:{let t=C(n,e.join(` `)||`Untitled task`);console.log(`Pushed "${t.title}" (${t.id}) to queue "${n}".`);break}case`next`:{let e=S(n);console.log(e?`Next: ${e.title} (${e.id})`:`No pending items in queue "${n}".`);break}case`done`:{let t=e.shift();t||(console.error(`Usage: kb queue done <name> <id>`),process.exit(1));let r=v(n,t);console.log(`Marked "${r.title}" as done.`);break}case`fail`:{let t=e.shift(),r=e.join(` `)||`Unknown error`;t||(console.error(`Usage: kb queue fail <name> <id> [error message]`),process.exit(1));let i=y(n,t,r);console.log(`Marked "${i.title}" as failed: ${r}`);break}case`get`:{let e=b(n);if(!e){console.log(`Queue "${n}" not found.`);return}console.log(`Queue: ${e.name} (${e.items.length} items)`);for(let t of e.items){let e=t.error?` — ${t.error}`:``;console.log(` ${t.status.padEnd(12)} ${t.id} ${t.title}${e}`)}break}case`clear`:{let e=h(n);console.log(`Cleared ${e} completed/failed items from queue "${n}".`);break}case`delete`:{let e=_(n);console.log(e?`Queue "${n}" deleted.`:`Queue "${n}" not found.`);break}}}}];export{j as workspaceCommands};
@@ -4,5 +4,4 @@ import { KBContext } from "./kb-init.js";
4
4
  declare function ctx(): Promise<KBContext>;
5
5
  declare function getCtx(): KBContext | null;
6
6
  //#endregion
7
- export { type KBContext, ctx, getCtx };
8
- //# sourceMappingURL=context.d.ts.map
7
+ export { type KBContext, ctx, getCtx };
@@ -1,2 +1 @@
1
- import{initKB as e}from"./kb-init.js";let t=null;async function n(){return t||=await e(),t}function r(){return t}export{n as ctx,r as getCtx};
2
- //# sourceMappingURL=context.js.map
1
+ import{initKB as e}from"./kb-init.js";let t=null;async function n(){return t||=await e(),t}function r(){return t}export{n as ctx,r as getCtx};
@@ -52,5 +52,4 @@ declare function parseRecordString(value: string): Record<string, unknown>;
52
52
  declare function rrf(vecResults: SearchResult[], ftsResults: SearchResult[], k?: number): SearchResult[];
53
53
  declare function executeCliBatchOperation(operation: BatchOperation, context: KBContext | null): Promise<unknown>;
54
54
  //#endregion
55
- export { executeCliBatchOperation, extractBoolFlag, extractNumFlag, extractStrFlag, formatFocusRanges, parseBatchPayload, parseMaybeJsonString, parseRecordString, printCheckResult, printCheckSection, printCheckpoint, printDeadSymbolsResult, printDiffFiles, printExamplesResult, printFileSummary, printGitContext, printManagedProcess, printParsedOutput, printSection, printSymbolInfo, printTestRunResult, printTraceResult, printWorkset, readInput, readStdin, rrf, splitCsv, validateBatchOperations };
56
- //# sourceMappingURL=helpers.d.ts.map
55
+ export { executeCliBatchOperation, extractBoolFlag, extractNumFlag, extractStrFlag, formatFocusRanges, parseBatchPayload, parseMaybeJsonString, parseRecordString, printCheckResult, printCheckSection, printCheckpoint, printDeadSymbolsResult, printDiffFiles, printExamplesResult, printFileSummary, printGitContext, printManagedProcess, printParsedOutput, printSection, printSymbolInfo, printTestRunResult, printTraceResult, printWorkset, readInput, readStdin, rrf, splitCsv, validateBatchOperations };