@lumenflow/cli 3.1.2 → 3.1.3

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 (389) hide show
  1. package/README.md +36 -35
  2. package/dist/agent-issues-query.js +13 -8
  3. package/dist/agent-log-issue.js +15 -4
  4. package/dist/agent-session-end.js +15 -4
  5. package/dist/agent-session.js +18 -6
  6. package/dist/backlog-prune.js +1 -1
  7. package/dist/commands/integrate.js +32 -18
  8. package/dist/config-get.js +27 -15
  9. package/dist/config-set.js +104 -37
  10. package/dist/delegation-list.js +1 -1
  11. package/dist/doctor.js +19 -13
  12. package/dist/file-delete.js +1 -1
  13. package/dist/file-edit.js +1 -1
  14. package/dist/file-read.js +1 -1
  15. package/dist/file-write.js +1 -1
  16. package/dist/flow-bottlenecks.js +1 -1
  17. package/dist/flow-report.js +10 -9
  18. package/dist/gates.js +3 -2
  19. package/dist/git-branch.js +1 -1
  20. package/dist/git-diff.js +1 -1
  21. package/dist/git-log.js +1 -1
  22. package/dist/init.js +238 -42
  23. package/dist/initiative-add-wu.js +1 -1
  24. package/dist/initiative-bulk-assign-wus.js +1 -1
  25. package/dist/initiative-create.js +2 -2
  26. package/dist/initiative-edit.js +1 -1
  27. package/dist/initiative-list.js +1 -1
  28. package/dist/initiative-plan.js +1 -3
  29. package/dist/initiative-status.js +47 -6
  30. package/dist/lane-edit.js +19 -10
  31. package/dist/lane-health.js +13 -24
  32. package/dist/lane-lock.js +4 -5
  33. package/dist/lane-setup.js +5 -5
  34. package/dist/lane-status.js +4 -5
  35. package/dist/lane-suggest.js +9 -7
  36. package/dist/lane-validate.js +4 -5
  37. package/dist/lumenflow-upgrade.js +17 -11
  38. package/dist/mem-checkpoint.js +1 -1
  39. package/dist/mem-cleanup.js +6 -23
  40. package/dist/mem-context.js +1 -1
  41. package/dist/mem-create.js +1 -1
  42. package/dist/mem-delete.js +1 -1
  43. package/dist/mem-export.js +1 -1
  44. package/dist/mem-inbox.js +1 -1
  45. package/dist/mem-init.js +1 -1
  46. package/dist/mem-ready.js +1 -1
  47. package/dist/mem-recover.js +1 -1
  48. package/dist/mem-signal.js +1 -1
  49. package/dist/mem-start.js +1 -1
  50. package/dist/mem-summarize.js +8 -7
  51. package/dist/mem-triage.js +7 -5
  52. package/dist/metrics-cli.js +1 -1
  53. package/dist/metrics-snapshot.js +1 -1
  54. package/dist/onboard.js +295 -120
  55. package/dist/orchestrate-init-status.js +12 -7
  56. package/dist/orchestrate-initiative.js +23 -12
  57. package/dist/orchestrate-monitor.js +20 -8
  58. package/dist/pack-scaffold.js +1 -1
  59. package/dist/plan-create.js +1 -3
  60. package/dist/plan-edit.js +1 -3
  61. package/dist/plan-link.js +1 -3
  62. package/dist/plan-promote.js +1 -3
  63. package/dist/release.js +1 -3
  64. package/dist/signal-cleanup.js +4 -18
  65. package/dist/state-bootstrap.js +11 -8
  66. package/dist/state-cleanup.js +5 -19
  67. package/dist/state-doctor.js +213 -9
  68. package/dist/task-claim.js +1 -1
  69. package/dist/validate.js +1 -1
  70. package/dist/workspace-init.js +61 -61
  71. package/dist/wu-block.js +1 -1
  72. package/dist/wu-brief.js +1 -1
  73. package/dist/wu-claim.js +1 -1
  74. package/dist/wu-cleanup.js +1 -1
  75. package/dist/wu-create.js +3 -3
  76. package/dist/wu-delegate.js +1 -1
  77. package/dist/wu-deps.js +1 -1
  78. package/dist/wu-done.js +66 -34
  79. package/dist/wu-edit.js +1 -1
  80. package/dist/wu-infer-lane.js +1 -1
  81. package/dist/wu-preflight.js +1 -1
  82. package/dist/wu-prep.js +1 -1
  83. package/dist/wu-proto.js +1 -1
  84. package/dist/wu-prune.js +1 -1
  85. package/dist/wu-recover.js +1 -1
  86. package/dist/wu-release.js +1 -1
  87. package/dist/wu-repair.js +1 -1
  88. package/dist/wu-sandbox.js +40 -27
  89. package/dist/wu-status.js +1 -1
  90. package/dist/wu-unblock.js +1 -1
  91. package/dist/wu-unlock-lane.js +1 -1
  92. package/dist/wu-validate.js +1 -1
  93. package/package.json +12 -8
  94. package/packs/software-delivery/constants.ts +10 -0
  95. package/packs/software-delivery/extensions.ts +140 -0
  96. package/packs/software-delivery/gate-policies.ts +134 -0
  97. package/packs/software-delivery/index.ts +8 -0
  98. package/packs/software-delivery/manifest-schema.ts +236 -0
  99. package/packs/software-delivery/manifest.ts +417 -0
  100. package/packs/software-delivery/manifest.yaml +711 -0
  101. package/packs/software-delivery/pack-registration.ts +113 -0
  102. package/packs/software-delivery/tool-impl/agent-tools.ts +263 -0
  103. package/packs/software-delivery/tool-impl/delegation-tools.ts +66 -0
  104. package/packs/software-delivery/tool-impl/flow-metrics-tools.ts +219 -0
  105. package/packs/software-delivery/tool-impl/git-runner.ts +113 -0
  106. package/packs/software-delivery/tool-impl/git-tools.ts +316 -0
  107. package/packs/software-delivery/tool-impl/index.ts +15 -0
  108. package/packs/software-delivery/tool-impl/initiative-orchestration-tools.ts +720 -0
  109. package/packs/software-delivery/tool-impl/lane-lock.ts +246 -0
  110. package/packs/software-delivery/tool-impl/memory-tools.ts +415 -0
  111. package/packs/software-delivery/tool-impl/pending-runtime-tools.ts +21 -0
  112. package/packs/software-delivery/tool-impl/runtime-cli-adapter.ts +328 -0
  113. package/packs/software-delivery/tool-impl/runtime-native-tools.ts +687 -0
  114. package/packs/software-delivery/tool-impl/worker-loader.ts +52 -0
  115. package/packs/software-delivery/tool-impl/worktree-tools.ts +46 -0
  116. package/packs/software-delivery/tool-impl/wu-lifecycle-tools.ts +759 -0
  117. package/packs/software-delivery/tools/delegation-tools.ts +23 -0
  118. package/packs/software-delivery/tools/git-tools.ts +55 -0
  119. package/packs/software-delivery/tools/index.ts +8 -0
  120. package/packs/software-delivery/tools/lane-lock-tool.ts +37 -0
  121. package/packs/software-delivery/tools/types.ts +71 -0
  122. package/packs/software-delivery/tools/worktree-tools.ts +49 -0
  123. package/templates/core/LUMENFLOW.md.template +3 -3
  124. package/templates/core/ai/onboarding/agent-invocation-guide.md.template +1 -1
  125. package/templates/core/ai/onboarding/lumenflow-force-usage.md.template +1 -1
  126. package/templates/core/ai/onboarding/quick-ref-commands.md.template +5 -5
  127. package/templates/core/ai/onboarding/starting-prompt.md.template +3 -3
  128. package/templates/core/ai/onboarding/vendor-support.md.template +1 -1
  129. package/templates/core/ai/onboarding/wu-create-checklist.md.template +1 -1
  130. package/dist/agent-issues-query.js.map +0 -1
  131. package/dist/agent-log-issue.js.map +0 -1
  132. package/dist/agent-session-end.js.map +0 -1
  133. package/dist/agent-session.js.map +0 -1
  134. package/dist/backlog-prune.js.map +0 -1
  135. package/dist/cli-entry-point.js +0 -149
  136. package/dist/cli-entry-point.js.map +0 -1
  137. package/dist/commands/integrate.js.map +0 -1
  138. package/dist/commands.js.map +0 -1
  139. package/dist/config-get.js.map +0 -1
  140. package/dist/config-set.js.map +0 -1
  141. package/dist/delegation-list.js.map +0 -1
  142. package/dist/deps-add.js +0 -259
  143. package/dist/deps-add.js.map +0 -1
  144. package/dist/deps-remove.js +0 -105
  145. package/dist/deps-remove.js.map +0 -1
  146. package/dist/docs-sync.js.map +0 -1
  147. package/dist/doctor.js.map +0 -1
  148. package/dist/file-delete.js.map +0 -1
  149. package/dist/file-edit.js.map +0 -1
  150. package/dist/file-read.js.map +0 -1
  151. package/dist/file-write.js.map +0 -1
  152. package/dist/flow-bottlenecks.js.map +0 -1
  153. package/dist/flow-report.js.map +0 -1
  154. package/dist/formatters.js +0 -151
  155. package/dist/formatters.js.map +0 -1
  156. package/dist/gate-defaults.js +0 -131
  157. package/dist/gate-defaults.js.map +0 -1
  158. package/dist/gate-registry.js +0 -73
  159. package/dist/gate-registry.js.map +0 -1
  160. package/dist/gates-graceful-degradation.js +0 -153
  161. package/dist/gates-graceful-degradation.js.map +0 -1
  162. package/dist/gates-plan-resolvers.js +0 -152
  163. package/dist/gates-plan-resolvers.js.map +0 -1
  164. package/dist/gates-runners.js +0 -509
  165. package/dist/gates-runners.js.map +0 -1
  166. package/dist/gates-types.js +0 -4
  167. package/dist/gates-types.js.map +0 -1
  168. package/dist/gates-utils.js +0 -323
  169. package/dist/gates-utils.js.map +0 -1
  170. package/dist/gates.js.map +0 -1
  171. package/dist/git-branch.js.map +0 -1
  172. package/dist/git-diff.js.map +0 -1
  173. package/dist/git-log.js.map +0 -1
  174. package/dist/git-status.js.map +0 -1
  175. package/dist/guard-locked.js +0 -172
  176. package/dist/guard-locked.js.map +0 -1
  177. package/dist/guard-main-branch.js +0 -217
  178. package/dist/guard-main-branch.js.map +0 -1
  179. package/dist/guard-worktree-commit.js +0 -163
  180. package/dist/guard-worktree-commit.js.map +0 -1
  181. package/dist/hooks/auto-checkpoint-utils.js +0 -54
  182. package/dist/hooks/auto-checkpoint-utils.js.map +0 -1
  183. package/dist/hooks/enforcement-checks.js +0 -399
  184. package/dist/hooks/enforcement-checks.js.map +0 -1
  185. package/dist/hooks/enforcement-generator.js +0 -139
  186. package/dist/hooks/enforcement-generator.js.map +0 -1
  187. package/dist/hooks/enforcement-sync.js +0 -385
  188. package/dist/hooks/enforcement-sync.js.map +0 -1
  189. package/dist/hooks/generators/auto-checkpoint.js +0 -125
  190. package/dist/hooks/generators/auto-checkpoint.js.map +0 -1
  191. package/dist/hooks/generators/enforce-worktree.js +0 -190
  192. package/dist/hooks/generators/enforce-worktree.js.map +0 -1
  193. package/dist/hooks/generators/index.js +0 -18
  194. package/dist/hooks/generators/index.js.map +0 -1
  195. package/dist/hooks/generators/pre-compact-checkpoint.js +0 -136
  196. package/dist/hooks/generators/pre-compact-checkpoint.js.map +0 -1
  197. package/dist/hooks/generators/require-wu.js +0 -117
  198. package/dist/hooks/generators/require-wu.js.map +0 -1
  199. package/dist/hooks/generators/session-start-recovery.js +0 -103
  200. package/dist/hooks/generators/session-start-recovery.js.map +0 -1
  201. package/dist/hooks/generators/signal-utils.js +0 -54
  202. package/dist/hooks/generators/signal-utils.js.map +0 -1
  203. package/dist/hooks/generators/warn-incomplete.js +0 -67
  204. package/dist/hooks/generators/warn-incomplete.js.map +0 -1
  205. package/dist/hooks/index.js +0 -10
  206. package/dist/hooks/index.js.map +0 -1
  207. package/dist/index.js.map +0 -1
  208. package/dist/init-detection.js +0 -232
  209. package/dist/init-detection.js.map +0 -1
  210. package/dist/init-lane-validation.js +0 -143
  211. package/dist/init-lane-validation.js.map +0 -1
  212. package/dist/init-scaffolding.js +0 -158
  213. package/dist/init-scaffolding.js.map +0 -1
  214. package/dist/init-templates.js +0 -1982
  215. package/dist/init-templates.js.map +0 -1
  216. package/dist/init.js.map +0 -1
  217. package/dist/initiative-add-wu.js.map +0 -1
  218. package/dist/initiative-bulk-assign-wus.js.map +0 -1
  219. package/dist/initiative-create.js.map +0 -1
  220. package/dist/initiative-edit.js.map +0 -1
  221. package/dist/initiative-list.js.map +0 -1
  222. package/dist/initiative-plan.js.map +0 -1
  223. package/dist/initiative-remove-wu.js.map +0 -1
  224. package/dist/initiative-status.js.map +0 -1
  225. package/dist/lane-edit.js.map +0 -1
  226. package/dist/lane-health.js.map +0 -1
  227. package/dist/lane-lifecycle-process.js +0 -366
  228. package/dist/lane-lifecycle-process.js.map +0 -1
  229. package/dist/lane-lock.js.map +0 -1
  230. package/dist/lane-setup.js.map +0 -1
  231. package/dist/lane-status.js.map +0 -1
  232. package/dist/lane-suggest.js.map +0 -1
  233. package/dist/lane-validate.js.map +0 -1
  234. package/dist/lifecycle-regression-harness.js +0 -181
  235. package/dist/lifecycle-regression-harness.js.map +0 -1
  236. package/dist/lumenflow-upgrade.js.map +0 -1
  237. package/dist/mem-checkpoint.js.map +0 -1
  238. package/dist/mem-cleanup.js.map +0 -1
  239. package/dist/mem-context.js.map +0 -1
  240. package/dist/mem-create.js.map +0 -1
  241. package/dist/mem-delete.js.map +0 -1
  242. package/dist/mem-export.js.map +0 -1
  243. package/dist/mem-inbox.js.map +0 -1
  244. package/dist/mem-index.js +0 -214
  245. package/dist/mem-index.js.map +0 -1
  246. package/dist/mem-init.js.map +0 -1
  247. package/dist/mem-profile.js +0 -210
  248. package/dist/mem-profile.js.map +0 -1
  249. package/dist/mem-promote.js +0 -257
  250. package/dist/mem-promote.js.map +0 -1
  251. package/dist/mem-ready.js.map +0 -1
  252. package/dist/mem-recover.js.map +0 -1
  253. package/dist/mem-signal.js.map +0 -1
  254. package/dist/mem-start.js.map +0 -1
  255. package/dist/mem-summarize.js.map +0 -1
  256. package/dist/mem-triage.js.map +0 -1
  257. package/dist/merge-block.js +0 -225
  258. package/dist/merge-block.js.map +0 -1
  259. package/dist/metrics-cli.js.map +0 -1
  260. package/dist/metrics-snapshot.js.map +0 -1
  261. package/dist/onboard.js.map +0 -1
  262. package/dist/onboarding-smoke-test.js +0 -418
  263. package/dist/onboarding-smoke-test.js.map +0 -1
  264. package/dist/orchestrate-init-status.js.map +0 -1
  265. package/dist/orchestrate-initiative.js.map +0 -1
  266. package/dist/orchestrate-monitor.js.map +0 -1
  267. package/dist/pack-author.js.map +0 -1
  268. package/dist/pack-hash.js.map +0 -1
  269. package/dist/pack-install.js.map +0 -1
  270. package/dist/pack-publish.js.map +0 -1
  271. package/dist/pack-scaffold.js.map +0 -1
  272. package/dist/pack-search.js.map +0 -1
  273. package/dist/pack-validate.js.map +0 -1
  274. package/dist/plan-create.js.map +0 -1
  275. package/dist/plan-edit.js.map +0 -1
  276. package/dist/plan-link.js.map +0 -1
  277. package/dist/plan-promote.js.map +0 -1
  278. package/dist/public-manifest.js +0 -920
  279. package/dist/public-manifest.js.map +0 -1
  280. package/dist/release.js.map +0 -1
  281. package/dist/rotate-progress.js +0 -253
  282. package/dist/rotate-progress.js.map +0 -1
  283. package/dist/session-coordinator.js +0 -303
  284. package/dist/session-coordinator.js.map +0 -1
  285. package/dist/shared-validators.js +0 -81
  286. package/dist/shared-validators.js.map +0 -1
  287. package/dist/signal-cleanup.js.map +0 -1
  288. package/dist/state-bootstrap.js.map +0 -1
  289. package/dist/state-cleanup.js.map +0 -1
  290. package/dist/state-doctor-fix.js +0 -226
  291. package/dist/state-doctor-fix.js.map +0 -1
  292. package/dist/state-doctor-stamps.js +0 -23
  293. package/dist/state-doctor-stamps.js.map +0 -1
  294. package/dist/state-doctor.js.map +0 -1
  295. package/dist/strict-progress.js +0 -255
  296. package/dist/strict-progress.js.map +0 -1
  297. package/dist/sync-templates.js.map +0 -1
  298. package/dist/task-claim.js.map +0 -1
  299. package/dist/trace-gen.js +0 -401
  300. package/dist/trace-gen.js.map +0 -1
  301. package/dist/validate-agent-skills.js +0 -223
  302. package/dist/validate-agent-skills.js.map +0 -1
  303. package/dist/validate-agent-sync.js +0 -151
  304. package/dist/validate-agent-sync.js.map +0 -1
  305. package/dist/validate-backlog-sync.js +0 -77
  306. package/dist/validate-backlog-sync.js.map +0 -1
  307. package/dist/validate-skills-spec.js +0 -211
  308. package/dist/validate-skills-spec.js.map +0 -1
  309. package/dist/validate.js.map +0 -1
  310. package/dist/validator-defaults.js +0 -107
  311. package/dist/validator-defaults.js.map +0 -1
  312. package/dist/validator-registry.js +0 -71
  313. package/dist/validator-registry.js.map +0 -1
  314. package/dist/workspace-init.js.map +0 -1
  315. package/dist/wu-block.js.map +0 -1
  316. package/dist/wu-brief.js.map +0 -1
  317. package/dist/wu-claim-branch.js +0 -123
  318. package/dist/wu-claim-branch.js.map +0 -1
  319. package/dist/wu-claim-cloud.js +0 -79
  320. package/dist/wu-claim-cloud.js.map +0 -1
  321. package/dist/wu-claim-mode.js +0 -82
  322. package/dist/wu-claim-mode.js.map +0 -1
  323. package/dist/wu-claim-output.js +0 -85
  324. package/dist/wu-claim-output.js.map +0 -1
  325. package/dist/wu-claim-repair-guidance.js +0 -12
  326. package/dist/wu-claim-repair-guidance.js.map +0 -1
  327. package/dist/wu-claim-resume-handler.js +0 -87
  328. package/dist/wu-claim-resume-handler.js.map +0 -1
  329. package/dist/wu-claim-state.js +0 -581
  330. package/dist/wu-claim-state.js.map +0 -1
  331. package/dist/wu-claim-validation.js +0 -457
  332. package/dist/wu-claim-validation.js.map +0 -1
  333. package/dist/wu-claim-worktree.js +0 -223
  334. package/dist/wu-claim-worktree.js.map +0 -1
  335. package/dist/wu-claim.js.map +0 -1
  336. package/dist/wu-cleanup-cloud.js +0 -78
  337. package/dist/wu-cleanup-cloud.js.map +0 -1
  338. package/dist/wu-cleanup.js.map +0 -1
  339. package/dist/wu-code-path-coverage.js +0 -83
  340. package/dist/wu-code-path-coverage.js.map +0 -1
  341. package/dist/wu-create-cloud.js +0 -30
  342. package/dist/wu-create-cloud.js.map +0 -1
  343. package/dist/wu-create-content.js +0 -264
  344. package/dist/wu-create-content.js.map +0 -1
  345. package/dist/wu-create-readiness.js +0 -59
  346. package/dist/wu-create-readiness.js.map +0 -1
  347. package/dist/wu-create-validation.js +0 -128
  348. package/dist/wu-create-validation.js.map +0 -1
  349. package/dist/wu-create.js.map +0 -1
  350. package/dist/wu-delegate.js.map +0 -1
  351. package/dist/wu-delete.js.map +0 -1
  352. package/dist/wu-deps.js.map +0 -1
  353. package/dist/wu-done-auto-cleanup.js +0 -203
  354. package/dist/wu-done-auto-cleanup.js.map +0 -1
  355. package/dist/wu-done-check.js +0 -38
  356. package/dist/wu-done-check.js.map +0 -1
  357. package/dist/wu-done-cloud.js +0 -48
  358. package/dist/wu-done-cloud.js.map +0 -1
  359. package/dist/wu-done-decay.js +0 -86
  360. package/dist/wu-done-decay.js.map +0 -1
  361. package/dist/wu-done.js.map +0 -1
  362. package/dist/wu-edit-operations.js +0 -399
  363. package/dist/wu-edit-operations.js.map +0 -1
  364. package/dist/wu-edit-validators.js +0 -282
  365. package/dist/wu-edit-validators.js.map +0 -1
  366. package/dist/wu-edit.js.map +0 -1
  367. package/dist/wu-infer-lane.js.map +0 -1
  368. package/dist/wu-preflight.js.map +0 -1
  369. package/dist/wu-prep.js.map +0 -1
  370. package/dist/wu-proto.js.map +0 -1
  371. package/dist/wu-prune.js.map +0 -1
  372. package/dist/wu-recover.js.map +0 -1
  373. package/dist/wu-release.js.map +0 -1
  374. package/dist/wu-repair.js.map +0 -1
  375. package/dist/wu-sandbox.js.map +0 -1
  376. package/dist/wu-spawn-completion.js +0 -33
  377. package/dist/wu-spawn-completion.js.map +0 -1
  378. package/dist/wu-spawn-prompt-builders.js +0 -1197
  379. package/dist/wu-spawn-prompt-builders.js.map +0 -1
  380. package/dist/wu-spawn-strategy-resolver.js +0 -322
  381. package/dist/wu-spawn-strategy-resolver.js.map +0 -1
  382. package/dist/wu-spawn.js +0 -59
  383. package/dist/wu-spawn.js.map +0 -1
  384. package/dist/wu-state-cloud.js +0 -41
  385. package/dist/wu-state-cloud.js.map +0 -1
  386. package/dist/wu-status.js.map +0 -1
  387. package/dist/wu-unblock.js.map +0 -1
  388. package/dist/wu-unlock-lane.js.map +0 -1
  389. package/dist/wu-validate.js.map +0 -1
@@ -0,0 +1,687 @@
1
+ // Copyright (c) 2026 Hellmai Ltd
2
+ // SPDX-License-Identifier: AGPL-3.0-only
3
+
4
+ import type { ToolOutput } from '@lumenflow/kernel';
5
+ import { RUNTIME_CLI_COMMANDS, runtimeCliAdapter } from './runtime-cli-adapter.js';
6
+
7
+ const RUNTIME_NATIVE_TOOLS = {
8
+ WU_INFER_LANE: 'wu:infer-lane',
9
+ CONFIG_SET: 'config:set',
10
+ CONFIG_GET: 'config:get',
11
+ LANE_HEALTH: 'lane:health',
12
+ LANE_SUGGEST: 'lane:suggest',
13
+ FILE_READ: 'file:read',
14
+ FILE_WRITE: 'file:write',
15
+ FILE_EDIT: 'file:edit',
16
+ FILE_DELETE: 'file:delete',
17
+ GIT_BRANCH: 'git:branch',
18
+ GIT_DIFF: 'git:diff',
19
+ GIT_LOG: 'git:log',
20
+ STATE_BOOTSTRAP: 'state:bootstrap',
21
+ STATE_CLEANUP: 'state:cleanup',
22
+ STATE_DOCTOR: 'state:doctor',
23
+ BACKLOG_PRUNE: 'backlog:prune',
24
+ SIGNAL_CLEANUP: 'signal:cleanup',
25
+ LUMENFLOW_METRICS: 'lumenflow:metrics',
26
+ VALIDATE: 'validate',
27
+ VALIDATE_AGENT_SKILLS: 'validate:agent-skills',
28
+ VALIDATE_AGENT_SYNC: 'validate:agent-sync',
29
+ VALIDATE_BACKLOG_SYNC: 'validate:backlog-sync',
30
+ VALIDATE_SKILLS_SPEC: 'validate:skills-spec',
31
+ LUMENFLOW_VALIDATE: 'lumenflow:validate',
32
+ } as const;
33
+
34
+ type RuntimeNativeToolName = (typeof RUNTIME_NATIVE_TOOLS)[keyof typeof RUNTIME_NATIVE_TOOLS];
35
+
36
+ const RUNTIME_NATIVE_TOOL_ERROR_CODES: Record<RuntimeNativeToolName, string> = {
37
+ 'wu:infer-lane': 'WU_INFER_LANE_ERROR',
38
+ 'config:set': 'CONFIG_SET_ERROR',
39
+ 'config:get': 'CONFIG_GET_ERROR',
40
+ 'lane:health': 'LANE_HEALTH_ERROR',
41
+ 'lane:suggest': 'LANE_SUGGEST_ERROR',
42
+ 'file:read': 'FILE_READ_ERROR',
43
+ 'file:write': 'FILE_WRITE_ERROR',
44
+ 'file:edit': 'FILE_EDIT_ERROR',
45
+ 'file:delete': 'FILE_DELETE_ERROR',
46
+ 'git:branch': 'GIT_BRANCH_ERROR',
47
+ 'git:diff': 'GIT_DIFF_ERROR',
48
+ 'git:log': 'GIT_LOG_ERROR',
49
+ 'state:bootstrap': 'STATE_BOOTSTRAP_ERROR',
50
+ 'state:cleanup': 'STATE_CLEANUP_ERROR',
51
+ 'state:doctor': 'STATE_DOCTOR_ERROR',
52
+ 'backlog:prune': 'BACKLOG_PRUNE_ERROR',
53
+ 'signal:cleanup': 'SIGNAL_CLEANUP_ERROR',
54
+ 'lumenflow:metrics': 'LUMENFLOW_METRICS_ERROR',
55
+ validate: 'VALIDATE_ERROR',
56
+ 'validate:agent-skills': 'VALIDATE_AGENT_SKILLS_ERROR',
57
+ 'validate:agent-sync': 'VALIDATE_AGENT_SYNC_ERROR',
58
+ 'validate:backlog-sync': 'VALIDATE_BACKLOG_SYNC_ERROR',
59
+ 'validate:skills-spec': 'VALIDATE_SKILLS_SPEC_ERROR',
60
+ 'lumenflow:validate': 'LUMENFLOW_VALIDATE_ERROR',
61
+ };
62
+
63
+ const RUNTIME_NATIVE_TOOL_COMMANDS: Record<
64
+ RuntimeNativeToolName,
65
+ (typeof RUNTIME_CLI_COMMANDS)[keyof typeof RUNTIME_CLI_COMMANDS]
66
+ > = {
67
+ 'wu:infer-lane': RUNTIME_CLI_COMMANDS.WU_INFER_LANE,
68
+ 'config:set': RUNTIME_CLI_COMMANDS.CONFIG_SET,
69
+ 'config:get': RUNTIME_CLI_COMMANDS.CONFIG_GET,
70
+ 'lane:health': RUNTIME_CLI_COMMANDS.LANE_HEALTH,
71
+ 'lane:suggest': RUNTIME_CLI_COMMANDS.LANE_SUGGEST,
72
+ 'file:read': RUNTIME_CLI_COMMANDS.FILE_READ,
73
+ 'file:write': RUNTIME_CLI_COMMANDS.FILE_WRITE,
74
+ 'file:edit': RUNTIME_CLI_COMMANDS.FILE_EDIT,
75
+ 'file:delete': RUNTIME_CLI_COMMANDS.FILE_DELETE,
76
+ 'git:branch': RUNTIME_CLI_COMMANDS.GIT_BRANCH,
77
+ 'git:diff': RUNTIME_CLI_COMMANDS.GIT_DIFF,
78
+ 'git:log': RUNTIME_CLI_COMMANDS.GIT_LOG,
79
+ 'state:bootstrap': RUNTIME_CLI_COMMANDS.STATE_BOOTSTRAP,
80
+ 'state:cleanup': RUNTIME_CLI_COMMANDS.STATE_CLEANUP,
81
+ 'state:doctor': RUNTIME_CLI_COMMANDS.STATE_DOCTOR,
82
+ 'backlog:prune': RUNTIME_CLI_COMMANDS.BACKLOG_PRUNE,
83
+ 'signal:cleanup': RUNTIME_CLI_COMMANDS.SIGNAL_CLEANUP,
84
+ 'lumenflow:metrics': RUNTIME_CLI_COMMANDS.METRICS,
85
+ validate: RUNTIME_CLI_COMMANDS.VALIDATE,
86
+ 'validate:agent-skills': RUNTIME_CLI_COMMANDS.VALIDATE_AGENT_SKILLS,
87
+ 'validate:agent-sync': RUNTIME_CLI_COMMANDS.VALIDATE_AGENT_SYNC,
88
+ 'validate:backlog-sync': RUNTIME_CLI_COMMANDS.VALIDATE_BACKLOG_SYNC,
89
+ 'validate:skills-spec': RUNTIME_CLI_COMMANDS.VALIDATE_SKILLS_SPEC,
90
+ 'lumenflow:validate': RUNTIME_CLI_COMMANDS.VALIDATE,
91
+ };
92
+
93
+ const FLAG_NAMES = {
94
+ ALL: '--all',
95
+ ARCHIVE_DAYS: '--archive-days',
96
+ AUTHOR: '--author',
97
+ BASE_DIR: '--base-dir',
98
+ DAYS: '--days',
99
+ CONTAINS: '--contains',
100
+ CONTENT: '--content',
101
+ DESC: '--desc',
102
+ DONE_ONLY: '--done-only',
103
+ DRY_RUN: '--dry-run',
104
+ ENCODING: '--encoding',
105
+ EVENTS_ONLY: '--events-only',
106
+ EXECUTE: '--execute',
107
+ FIX: '--fix',
108
+ FORCE: '--force',
109
+ FORMAT: '--format',
110
+ ID: '--id',
111
+ INCLUDE_GIT: '--include-git',
112
+ INTERACTIVE: '--interactive',
113
+ JSON: '--json',
114
+ KEY: '--key',
115
+ MAX_COUNT: '--max-count',
116
+ MAX_ENTRIES: '--max-entries',
117
+ MAX_SIZE: '--max-size',
118
+ MEMORY_ONLY: '--memory-only',
119
+ NAME_ONLY: '--name-only',
120
+ NEW_STRING: '--new-string',
121
+ NO_COVERAGE: '--no-coverage',
122
+ NO_CREATE_DIRS: '--no-create-dirs',
123
+ NO_LLM: '--no-llm',
124
+ OLD_STRING: '--old-string',
125
+ ONELINE: '--oneline',
126
+ OUTPUT: '--output',
127
+ PATH: '--path',
128
+ PATHS: '--paths',
129
+ QUIET: '--quiet',
130
+ REF: '--ref',
131
+ REMOTES: '--remotes',
132
+ RECURSIVE: '--recursive',
133
+ REPLACE_ALL: '--replace-all',
134
+ SHOW_CURRENT: '--show-current',
135
+ SIGNALS_ONLY: '--signals-only',
136
+ SINCE: '--since',
137
+ SKILL: '--skill',
138
+ STAGED: '--staged',
139
+ STALE_DAYS_IN_PROGRESS: '--stale-days-in-progress',
140
+ STALE_DAYS_READY: '--stale-days-ready',
141
+ START_LINE: '--start-line',
142
+ STATUS: '--status',
143
+ STATE_DIR: '--state-dir',
144
+ STAT: '--stat',
145
+ STRICT: '--strict',
146
+ TTL: '--ttl',
147
+ UNREAD_TTL: '--unread-ttl',
148
+ VALUE: '--value',
149
+ VERBOSE: '--verbose',
150
+ WU_DIR: '--wu-dir',
151
+ } as const;
152
+
153
+ const MISSING_PARAMETER_MESSAGES = {
154
+ CONTENT_REQUIRED: 'content is required',
155
+ KEY_REQUIRED: 'key is required',
156
+ NEW_STRING_REQUIRED: 'new_string is required',
157
+ OLD_STRING_REQUIRED: 'old_string is required',
158
+ PATH_REQUIRED: 'path is required',
159
+ VALUE_REQUIRED: 'value is required',
160
+ } as const;
161
+
162
+ const CORE_RUNTIME_ERROR_CODES = {
163
+ CONTEXT_GET: 'CONTEXT_ERROR',
164
+ WU_LIST: 'WU_LIST_ERROR',
165
+ } as const;
166
+
167
+ interface CommandExecutionResult {
168
+ ok: boolean;
169
+ status: number;
170
+ stdout: string;
171
+ stderr: string;
172
+ executionError?: string;
173
+ }
174
+
175
+ function toRecord(input: unknown): Record<string, unknown> {
176
+ if (input && typeof input === 'object') {
177
+ return input as Record<string, unknown>;
178
+ }
179
+ return {};
180
+ }
181
+
182
+ interface CoreModuleLike {
183
+ computeWuContext: (options: { cwd: string }) => Promise<unknown>;
184
+ listWUs: (options: Record<string, unknown>) => Promise<unknown>;
185
+ }
186
+
187
+ const CORE_MODULE_ID = '@lumenflow/core';
188
+ let coreModule: CoreModuleLike | null = null;
189
+
190
+ async function getCoreLazy(): Promise<CoreModuleLike> {
191
+ if (!coreModule) {
192
+ coreModule = (await import(CORE_MODULE_ID)) as CoreModuleLike;
193
+ }
194
+ return coreModule;
195
+ }
196
+
197
+ function toStringValue(value: unknown): string | null {
198
+ if (typeof value !== 'string') {
199
+ return null;
200
+ }
201
+ const trimmed = value.trim();
202
+ return trimmed.length > 0 ? trimmed : null;
203
+ }
204
+
205
+ function toStringPreserveEmpty(value: unknown): string | null {
206
+ if (typeof value !== 'string') {
207
+ return null;
208
+ }
209
+ return value;
210
+ }
211
+
212
+ function toStringArray(value: unknown): string[] {
213
+ if (!Array.isArray(value)) {
214
+ return [];
215
+ }
216
+ return value.map((item) => toStringValue(item)).filter((item): item is string => item !== null);
217
+ }
218
+
219
+ function toIntegerString(value: unknown): string | null {
220
+ if (typeof value === 'number' && Number.isFinite(value)) {
221
+ return String(Math.trunc(value));
222
+ }
223
+ if (typeof value === 'string') {
224
+ const trimmed = value.trim();
225
+ return trimmed.length > 0 ? trimmed : null;
226
+ }
227
+ return null;
228
+ }
229
+
230
+ function appendFlagIfTrue(args: string[], enabled: unknown, flagName: string): void {
231
+ if (enabled === true) {
232
+ args.push(flagName);
233
+ }
234
+ }
235
+
236
+ function appendValueIfPresent(
237
+ args: string[],
238
+ flagName: string,
239
+ value: unknown,
240
+ converter: (value: unknown) => string | null = toStringValue,
241
+ ): void {
242
+ const converted = converter(value);
243
+ if (converted !== null) {
244
+ args.push(flagName, converted);
245
+ }
246
+ }
247
+
248
+ async function runRuntimeNativeCommand(
249
+ toolName: RuntimeNativeToolName,
250
+ args: string[],
251
+ ): Promise<CommandExecutionResult> {
252
+ return runtimeCliAdapter.run(RUNTIME_NATIVE_TOOL_COMMANDS[toolName], args);
253
+ }
254
+
255
+ function createMissingParameterOutput(message: string): ToolOutput {
256
+ return {
257
+ success: false,
258
+ error: {
259
+ code: 'MISSING_PARAMETER',
260
+ message,
261
+ },
262
+ };
263
+ }
264
+
265
+ function createFailureOutput(
266
+ toolName: RuntimeNativeToolName,
267
+ execution: CommandExecutionResult,
268
+ ): ToolOutput {
269
+ const stderrMessage = execution.stderr.trim();
270
+ const stdoutMessage = execution.stdout.trim();
271
+ const message =
272
+ execution.executionError ??
273
+ (stderrMessage.length > 0
274
+ ? stderrMessage
275
+ : stdoutMessage.length > 0
276
+ ? stdoutMessage
277
+ : `${toolName} failed`);
278
+
279
+ return {
280
+ success: false,
281
+ error: {
282
+ code: RUNTIME_NATIVE_TOOL_ERROR_CODES[toolName],
283
+ message,
284
+ details: {
285
+ exit_code: execution.status,
286
+ stdout: execution.stdout,
287
+ stderr: execution.stderr,
288
+ },
289
+ },
290
+ };
291
+ }
292
+
293
+ function createSuccessOutput(
294
+ toolName: RuntimeNativeToolName,
295
+ execution: CommandExecutionResult,
296
+ ): ToolOutput {
297
+ const message = execution.stdout.trim().length > 0 ? execution.stdout.trim() : `${toolName} ran`;
298
+ return {
299
+ success: true,
300
+ data: {
301
+ message,
302
+ },
303
+ };
304
+ }
305
+
306
+ function createCoreFailureOutput(code: string, error: unknown): ToolOutput {
307
+ return {
308
+ success: false,
309
+ error: {
310
+ code,
311
+ message: error instanceof Error ? error.message : String(error),
312
+ },
313
+ };
314
+ }
315
+
316
+ async function executeRuntimeNativeTool(
317
+ toolName: RuntimeNativeToolName,
318
+ args: string[],
319
+ ): Promise<ToolOutput> {
320
+ const execution = await runRuntimeNativeCommand(toolName, args);
321
+ if (!execution.ok) {
322
+ return createFailureOutput(toolName, execution);
323
+ }
324
+ return createSuccessOutput(toolName, execution);
325
+ }
326
+
327
+ export async function wuInferLaneTool(input: unknown): Promise<ToolOutput> {
328
+ const parsed = toRecord(input);
329
+ const args: string[] = [];
330
+
331
+ appendValueIfPresent(args, FLAG_NAMES.ID, parsed.id);
332
+ for (const pathValue of toStringArray(parsed.paths)) {
333
+ args.push(FLAG_NAMES.PATHS, pathValue);
334
+ }
335
+ appendValueIfPresent(args, FLAG_NAMES.DESC, parsed.desc);
336
+
337
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.WU_INFER_LANE, args);
338
+ }
339
+
340
+ export async function wuListTool(input: unknown): Promise<ToolOutput> {
341
+ const parsed = toRecord(input);
342
+ try {
343
+ const core = await getCoreLazy();
344
+ const options: Record<string, unknown> = { projectRoot: process.cwd() };
345
+ const status = toStringValue(parsed.status);
346
+ if (status) {
347
+ options.status = status;
348
+ }
349
+ const lane = toStringValue(parsed.lane);
350
+ if (lane) {
351
+ options.lane = lane;
352
+ }
353
+ const wus = await core.listWUs(options);
354
+ return {
355
+ success: true,
356
+ data: wus,
357
+ };
358
+ } catch (error) {
359
+ return createCoreFailureOutput(CORE_RUNTIME_ERROR_CODES.WU_LIST, error);
360
+ }
361
+ }
362
+
363
+ export async function contextGetTool(_input: unknown): Promise<ToolOutput> {
364
+ try {
365
+ const core = await getCoreLazy();
366
+ const context = await core.computeWuContext({ cwd: process.cwd() });
367
+ return {
368
+ success: true,
369
+ data: context,
370
+ };
371
+ } catch (error) {
372
+ return createCoreFailureOutput(CORE_RUNTIME_ERROR_CODES.CONTEXT_GET, error);
373
+ }
374
+ }
375
+
376
+ export async function configSetTool(input: unknown): Promise<ToolOutput> {
377
+ const parsed = toRecord(input);
378
+ const keyValue = toStringValue(parsed.key);
379
+ if (!keyValue) {
380
+ return createMissingParameterOutput(MISSING_PARAMETER_MESSAGES.KEY_REQUIRED);
381
+ }
382
+ if (parsed.value === undefined) {
383
+ return createMissingParameterOutput(MISSING_PARAMETER_MESSAGES.VALUE_REQUIRED);
384
+ }
385
+
386
+ const valueString = String(parsed.value);
387
+ const args: string[] = [FLAG_NAMES.KEY, keyValue, FLAG_NAMES.VALUE, valueString];
388
+
389
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.CONFIG_SET, args);
390
+ }
391
+
392
+ export async function configGetTool(input: unknown): Promise<ToolOutput> {
393
+ const parsed = toRecord(input);
394
+ const keyValue = toStringValue(parsed.key);
395
+ if (!keyValue) {
396
+ return createMissingParameterOutput(MISSING_PARAMETER_MESSAGES.KEY_REQUIRED);
397
+ }
398
+
399
+ const args: string[] = [FLAG_NAMES.KEY, keyValue];
400
+
401
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.CONFIG_GET, args);
402
+ }
403
+
404
+ export async function laneHealthTool(input: unknown): Promise<ToolOutput> {
405
+ const parsed = toRecord(input);
406
+ const args: string[] = [];
407
+
408
+ appendFlagIfTrue(args, parsed.json, FLAG_NAMES.JSON);
409
+ appendFlagIfTrue(args, parsed.verbose, FLAG_NAMES.VERBOSE);
410
+ appendFlagIfTrue(args, parsed.no_coverage, FLAG_NAMES.NO_COVERAGE);
411
+
412
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.LANE_HEALTH, args);
413
+ }
414
+
415
+ export async function laneSuggestTool(input: unknown): Promise<ToolOutput> {
416
+ const parsed = toRecord(input);
417
+ const args: string[] = [];
418
+
419
+ appendFlagIfTrue(args, parsed.dry_run, FLAG_NAMES.DRY_RUN);
420
+ appendFlagIfTrue(args, parsed.interactive, FLAG_NAMES.INTERACTIVE);
421
+ appendValueIfPresent(args, FLAG_NAMES.OUTPUT, parsed.output);
422
+ appendFlagIfTrue(args, parsed.json, FLAG_NAMES.JSON);
423
+ appendFlagIfTrue(args, parsed.no_llm, FLAG_NAMES.NO_LLM);
424
+ appendFlagIfTrue(args, parsed.include_git, FLAG_NAMES.INCLUDE_GIT);
425
+
426
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.LANE_SUGGEST, args);
427
+ }
428
+
429
+ export async function fileReadTool(input: unknown): Promise<ToolOutput> {
430
+ const parsed = toRecord(input);
431
+ const pathValue = toStringValue(parsed.path);
432
+ if (!pathValue) {
433
+ return createMissingParameterOutput(MISSING_PARAMETER_MESSAGES.PATH_REQUIRED);
434
+ }
435
+
436
+ const args: string[] = [FLAG_NAMES.PATH, pathValue];
437
+ appendValueIfPresent(args, FLAG_NAMES.ENCODING, parsed.encoding);
438
+ appendValueIfPresent(args, FLAG_NAMES.START_LINE, parsed.start_line, toIntegerString);
439
+ appendValueIfPresent(args, '--end-line', parsed.end_line, toIntegerString);
440
+ appendValueIfPresent(args, FLAG_NAMES.MAX_SIZE, parsed.max_size, toIntegerString);
441
+
442
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.FILE_READ, args);
443
+ }
444
+
445
+ export async function fileWriteTool(input: unknown): Promise<ToolOutput> {
446
+ const parsed = toRecord(input);
447
+ const pathValue = toStringValue(parsed.path);
448
+ if (!pathValue) {
449
+ return createMissingParameterOutput(MISSING_PARAMETER_MESSAGES.PATH_REQUIRED);
450
+ }
451
+ const contentValue = toStringPreserveEmpty(parsed.content);
452
+ if (contentValue === null) {
453
+ return createMissingParameterOutput(MISSING_PARAMETER_MESSAGES.CONTENT_REQUIRED);
454
+ }
455
+
456
+ const args: string[] = [FLAG_NAMES.PATH, pathValue, FLAG_NAMES.CONTENT, contentValue];
457
+ appendValueIfPresent(args, FLAG_NAMES.ENCODING, parsed.encoding);
458
+ appendFlagIfTrue(args, parsed.no_create_dirs, FLAG_NAMES.NO_CREATE_DIRS);
459
+
460
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.FILE_WRITE, args);
461
+ }
462
+
463
+ export async function fileEditTool(input: unknown): Promise<ToolOutput> {
464
+ const parsed = toRecord(input);
465
+ const pathValue = toStringValue(parsed.path);
466
+ if (!pathValue) {
467
+ return createMissingParameterOutput(MISSING_PARAMETER_MESSAGES.PATH_REQUIRED);
468
+ }
469
+ const oldStringValue = toStringValue(parsed.old_string);
470
+ if (oldStringValue === null) {
471
+ return createMissingParameterOutput(MISSING_PARAMETER_MESSAGES.OLD_STRING_REQUIRED);
472
+ }
473
+ const newStringValue = toStringPreserveEmpty(parsed.new_string);
474
+ if (newStringValue === null) {
475
+ return createMissingParameterOutput(MISSING_PARAMETER_MESSAGES.NEW_STRING_REQUIRED);
476
+ }
477
+
478
+ const args: string[] = [
479
+ FLAG_NAMES.PATH,
480
+ pathValue,
481
+ FLAG_NAMES.OLD_STRING,
482
+ oldStringValue,
483
+ FLAG_NAMES.NEW_STRING,
484
+ newStringValue,
485
+ ];
486
+ appendValueIfPresent(args, FLAG_NAMES.ENCODING, parsed.encoding);
487
+ appendFlagIfTrue(args, parsed.replace_all, FLAG_NAMES.REPLACE_ALL);
488
+
489
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.FILE_EDIT, args);
490
+ }
491
+
492
+ export async function fileDeleteTool(input: unknown): Promise<ToolOutput> {
493
+ const parsed = toRecord(input);
494
+ const pathValue = toStringValue(parsed.path);
495
+ if (!pathValue) {
496
+ return createMissingParameterOutput(MISSING_PARAMETER_MESSAGES.PATH_REQUIRED);
497
+ }
498
+
499
+ const args: string[] = [FLAG_NAMES.PATH, pathValue];
500
+ appendFlagIfTrue(args, parsed.recursive, FLAG_NAMES.RECURSIVE);
501
+ appendFlagIfTrue(args, parsed.force, FLAG_NAMES.FORCE);
502
+
503
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.FILE_DELETE, args);
504
+ }
505
+
506
+ export async function gitBranchTool(input: unknown): Promise<ToolOutput> {
507
+ const parsed = toRecord(input);
508
+ const args: string[] = [];
509
+
510
+ appendValueIfPresent(args, FLAG_NAMES.BASE_DIR, parsed.base_dir);
511
+ appendFlagIfTrue(args, parsed.list, '--list');
512
+ appendFlagIfTrue(args, parsed.all, FLAG_NAMES.ALL);
513
+ appendFlagIfTrue(args, parsed.remotes, FLAG_NAMES.REMOTES);
514
+ appendFlagIfTrue(args, parsed.show_current, FLAG_NAMES.SHOW_CURRENT);
515
+ appendValueIfPresent(args, FLAG_NAMES.CONTAINS, parsed.contains);
516
+
517
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.GIT_BRANCH, args);
518
+ }
519
+
520
+ export async function gitDiffTool(input: unknown): Promise<ToolOutput> {
521
+ const parsed = toRecord(input);
522
+ const args: string[] = [];
523
+
524
+ appendValueIfPresent(args, FLAG_NAMES.BASE_DIR, parsed.base_dir);
525
+ appendFlagIfTrue(args, parsed.staged, FLAG_NAMES.STAGED);
526
+ appendFlagIfTrue(args, parsed.name_only, FLAG_NAMES.NAME_ONLY);
527
+ appendFlagIfTrue(args, parsed.stat, FLAG_NAMES.STAT);
528
+ const refValue = toStringValue(parsed.ref);
529
+ if (refValue) {
530
+ args.push(refValue);
531
+ }
532
+ const pathValue = toStringValue(parsed.path);
533
+ if (pathValue) {
534
+ args.push('--', pathValue);
535
+ }
536
+
537
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.GIT_DIFF, args);
538
+ }
539
+
540
+ export async function gitLogTool(input: unknown): Promise<ToolOutput> {
541
+ const parsed = toRecord(input);
542
+ const args: string[] = [];
543
+
544
+ appendValueIfPresent(args, FLAG_NAMES.BASE_DIR, parsed.base_dir);
545
+ appendFlagIfTrue(args, parsed.oneline, FLAG_NAMES.ONELINE);
546
+ appendValueIfPresent(args, '-n', parsed.max_count, toIntegerString);
547
+ appendValueIfPresent(args, FLAG_NAMES.FORMAT, parsed.format);
548
+ appendValueIfPresent(args, FLAG_NAMES.SINCE, parsed.since);
549
+ appendValueIfPresent(args, FLAG_NAMES.AUTHOR, parsed.author);
550
+ const refValue = toStringValue(parsed.ref);
551
+ if (refValue) {
552
+ args.push(refValue);
553
+ }
554
+
555
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.GIT_LOG, args);
556
+ }
557
+
558
+ export async function stateBootstrapTool(input: unknown): Promise<ToolOutput> {
559
+ const parsed = toRecord(input);
560
+ const args: string[] = [];
561
+
562
+ appendFlagIfTrue(args, parsed.execute, FLAG_NAMES.EXECUTE);
563
+ appendFlagIfTrue(args, parsed.dry_run, FLAG_NAMES.DRY_RUN);
564
+ appendFlagIfTrue(args, parsed.force, FLAG_NAMES.FORCE);
565
+ appendValueIfPresent(args, FLAG_NAMES.WU_DIR, parsed.wu_dir);
566
+ appendValueIfPresent(args, FLAG_NAMES.STATE_DIR, parsed.state_dir);
567
+
568
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.STATE_BOOTSTRAP, args);
569
+ }
570
+
571
+ export async function stateCleanupTool(input: unknown): Promise<ToolOutput> {
572
+ const parsed = toRecord(input);
573
+ const args: string[] = [];
574
+
575
+ appendFlagIfTrue(args, parsed.dry_run, FLAG_NAMES.DRY_RUN);
576
+ appendFlagIfTrue(args, parsed.signals_only, FLAG_NAMES.SIGNALS_ONLY);
577
+ appendFlagIfTrue(args, parsed.memory_only, FLAG_NAMES.MEMORY_ONLY);
578
+ appendFlagIfTrue(args, parsed.events_only, FLAG_NAMES.EVENTS_ONLY);
579
+ appendFlagIfTrue(args, parsed.json, FLAG_NAMES.JSON);
580
+ appendFlagIfTrue(args, parsed.quiet, FLAG_NAMES.QUIET);
581
+ appendValueIfPresent(args, FLAG_NAMES.BASE_DIR, parsed.base_dir);
582
+
583
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.STATE_CLEANUP, args);
584
+ }
585
+
586
+ export async function stateDoctorTool(input: unknown): Promise<ToolOutput> {
587
+ const parsed = toRecord(input);
588
+ const args: string[] = [];
589
+
590
+ appendFlagIfTrue(args, parsed.fix, FLAG_NAMES.FIX);
591
+ appendFlagIfTrue(args, parsed.dry_run, FLAG_NAMES.DRY_RUN);
592
+ appendFlagIfTrue(args, parsed.json, FLAG_NAMES.JSON);
593
+ appendFlagIfTrue(args, parsed.quiet, FLAG_NAMES.QUIET);
594
+ appendValueIfPresent(args, FLAG_NAMES.BASE_DIR, parsed.base_dir);
595
+
596
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.STATE_DOCTOR, args);
597
+ }
598
+
599
+ export async function backlogPruneTool(input: unknown): Promise<ToolOutput> {
600
+ const parsed = toRecord(input);
601
+ const args: string[] = [];
602
+
603
+ appendFlagIfTrue(args, parsed.execute, FLAG_NAMES.EXECUTE);
604
+ appendFlagIfTrue(args, parsed.dry_run, FLAG_NAMES.DRY_RUN);
605
+ appendValueIfPresent(
606
+ args,
607
+ FLAG_NAMES.STALE_DAYS_IN_PROGRESS,
608
+ parsed.stale_days_in_progress,
609
+ toIntegerString,
610
+ );
611
+ appendValueIfPresent(args, FLAG_NAMES.STALE_DAYS_READY, parsed.stale_days_ready, toIntegerString);
612
+ appendValueIfPresent(args, FLAG_NAMES.ARCHIVE_DAYS, parsed.archive_days, toIntegerString);
613
+
614
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.BACKLOG_PRUNE, args);
615
+ }
616
+
617
+ export async function signalCleanupTool(input: unknown): Promise<ToolOutput> {
618
+ const parsed = toRecord(input);
619
+ const args: string[] = [];
620
+
621
+ appendFlagIfTrue(args, parsed.dry_run, FLAG_NAMES.DRY_RUN);
622
+ appendValueIfPresent(args, FLAG_NAMES.TTL, parsed.ttl);
623
+ appendValueIfPresent(args, FLAG_NAMES.UNREAD_TTL, parsed.unread_ttl);
624
+ appendValueIfPresent(args, FLAG_NAMES.MAX_ENTRIES, parsed.max_entries, toIntegerString);
625
+ appendFlagIfTrue(args, parsed.json, FLAG_NAMES.JSON);
626
+ appendFlagIfTrue(args, parsed.quiet, FLAG_NAMES.QUIET);
627
+ appendValueIfPresent(args, FLAG_NAMES.BASE_DIR, parsed.base_dir);
628
+
629
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.SIGNAL_CLEANUP, args);
630
+ }
631
+
632
+ export async function lumenflowMetricsTool(input: unknown): Promise<ToolOutput> {
633
+ const parsed = toRecord(input);
634
+ const args: string[] = [];
635
+
636
+ const subcommand = toStringValue(parsed.subcommand);
637
+ if (subcommand) {
638
+ args.push(subcommand);
639
+ }
640
+ appendValueIfPresent(args, FLAG_NAMES.DAYS, parsed.days, toIntegerString);
641
+ appendValueIfPresent(args, FLAG_NAMES.FORMAT, parsed.format);
642
+
643
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.LUMENFLOW_METRICS, args);
644
+ }
645
+
646
+ export async function validateTool(input: unknown): Promise<ToolOutput> {
647
+ const parsed = toRecord(input);
648
+ const args: string[] = [];
649
+
650
+ appendValueIfPresent(args, FLAG_NAMES.ID, parsed.id);
651
+ appendFlagIfTrue(args, parsed.strict, FLAG_NAMES.STRICT);
652
+ appendFlagIfTrue(args, parsed.done_only, FLAG_NAMES.DONE_ONLY);
653
+
654
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.VALIDATE, args);
655
+ }
656
+
657
+ export async function validateAgentSkillsTool(input: unknown): Promise<ToolOutput> {
658
+ const parsed = toRecord(input);
659
+ const args: string[] = [];
660
+
661
+ appendValueIfPresent(args, FLAG_NAMES.SKILL, parsed.skill);
662
+
663
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.VALIDATE_AGENT_SKILLS, args);
664
+ }
665
+
666
+ export async function validateAgentSyncTool(_input: unknown): Promise<ToolOutput> {
667
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.VALIDATE_AGENT_SYNC, []);
668
+ }
669
+
670
+ export async function validateBacklogSyncTool(_input: unknown): Promise<ToolOutput> {
671
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.VALIDATE_BACKLOG_SYNC, []);
672
+ }
673
+
674
+ export async function validateSkillsSpecTool(_input: unknown): Promise<ToolOutput> {
675
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.VALIDATE_SKILLS_SPEC, []);
676
+ }
677
+
678
+ export async function lumenflowValidateTool(input: unknown): Promise<ToolOutput> {
679
+ const parsed = toRecord(input);
680
+ const args: string[] = [];
681
+
682
+ appendValueIfPresent(args, FLAG_NAMES.ID, parsed.id);
683
+ appendFlagIfTrue(args, parsed.strict, FLAG_NAMES.STRICT);
684
+ appendFlagIfTrue(args, parsed.done_only, FLAG_NAMES.DONE_ONLY);
685
+
686
+ return executeRuntimeNativeTool(RUNTIME_NATIVE_TOOLS.LUMENFLOW_VALIDATE, args);
687
+ }