@lumenflow/cli 5.5.0 → 5.7.12

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 (213) hide show
  1. package/README.md +42 -40
  2. package/dist/db-journal-recover.js +400 -0
  3. package/dist/db-journal-recover.js.map +1 -0
  4. package/dist/docs-sync.js +8 -3
  5. package/dist/docs-sync.js.map +1 -1
  6. package/dist/gate-defaults.js +37 -0
  7. package/dist/gate-defaults.js.map +1 -1
  8. package/dist/gates/monolithic-file-contention-guard.js +167 -0
  9. package/dist/gates/monolithic-file-contention-guard.js.map +1 -0
  10. package/dist/gates/prod-migration-drift.js +207 -0
  11. package/dist/gates/prod-migration-drift.js.map +1 -0
  12. package/dist/gates/test-over-deletion-guard.js +255 -0
  13. package/dist/gates/test-over-deletion-guard.js.map +1 -0
  14. package/dist/gates-runners.js +44 -3
  15. package/dist/gates-runners.js.map +1 -1
  16. package/dist/gates.js +3 -2
  17. package/dist/gates.js.map +1 -1
  18. package/dist/lumenflow-setup.js +144 -0
  19. package/dist/lumenflow-setup.js.map +1 -0
  20. package/dist/lumenflow-upgrade.js +2 -1
  21. package/dist/lumenflow-upgrade.js.map +1 -1
  22. package/dist/mem-create.js +10 -1
  23. package/dist/mem-create.js.map +1 -1
  24. package/dist/mem-signal.js +21 -4
  25. package/dist/mem-signal.js.map +1 -1
  26. package/dist/orchestrate-initiative.js +28 -3
  27. package/dist/orchestrate-initiative.js.map +1 -1
  28. package/dist/public-manifest.js +17 -0
  29. package/dist/public-manifest.js.map +1 -1
  30. package/dist/release.js +53 -18
  31. package/dist/release.js.map +1 -1
  32. package/dist/wu-done-gates.js +13 -9
  33. package/dist/wu-done-gates.js.map +1 -1
  34. package/dist/wu-edit-operations.js +74 -0
  35. package/dist/wu-edit-operations.js.map +1 -1
  36. package/dist/wu-edit-validators.js +58 -0
  37. package/dist/wu-edit-validators.js.map +1 -1
  38. package/dist/wu-edit.js +106 -4
  39. package/dist/wu-edit.js.map +1 -1
  40. package/dist/wu-prep.js +41 -7
  41. package/dist/wu-prep.js.map +1 -1
  42. package/dist/wu-recover.js +6 -0
  43. package/dist/wu-recover.js.map +1 -1
  44. package/dist/wu-release.js +120 -2
  45. package/dist/wu-release.js.map +1 -1
  46. package/dist/wu-sizing-validation.js +47 -17
  47. package/dist/wu-sizing-validation.js.map +1 -1
  48. package/dist/wu-status.js +33 -0
  49. package/dist/wu-status.js.map +1 -1
  50. package/package.json +13 -11
  51. package/packs/agent-runtime/package.json +1 -1
  52. package/packs/sidekick/package.json +1 -1
  53. package/packs/software-delivery/package.json +1 -1
  54. package/templates/core/AGENTS.md.template +67 -3
  55. package/templates/core/LUMENFLOW.md.template +197 -47
  56. package/packs/agent-runtime/agent-heartbeat.ts +0 -163
  57. package/packs/agent-runtime/auto-session-integration.ts +0 -888
  58. package/packs/agent-runtime/capability-factory.ts +0 -104
  59. package/packs/agent-runtime/constants.ts +0 -21
  60. package/packs/agent-runtime/delegation-registry-schema.ts +0 -220
  61. package/packs/agent-runtime/delegation-registry-store.ts +0 -269
  62. package/packs/agent-runtime/delegation-tree.ts +0 -328
  63. package/packs/agent-runtime/index.ts +0 -20
  64. package/packs/agent-runtime/manifest.ts +0 -348
  65. package/packs/agent-runtime/memory-coordination-contract.ts +0 -86
  66. package/packs/agent-runtime/orchestration.ts +0 -2027
  67. package/packs/agent-runtime/pack-registration.ts +0 -110
  68. package/packs/agent-runtime/policy-factory.ts +0 -165
  69. package/packs/agent-runtime/remote-controls/index.ts +0 -7
  70. package/packs/agent-runtime/remote-controls/operations.ts +0 -405
  71. package/packs/agent-runtime/remote-controls/port.ts +0 -48
  72. package/packs/agent-runtime/remote-controls/state-store.ts +0 -258
  73. package/packs/agent-runtime/remote-controls/types.ts +0 -105
  74. package/packs/agent-runtime/session-schema.ts +0 -467
  75. package/packs/agent-runtime/tool-impl/agent-turn-tools.ts +0 -793
  76. package/packs/agent-runtime/tool-impl/index.ts +0 -6
  77. package/packs/agent-runtime/tool-impl/provider-adapters.ts +0 -1245
  78. package/packs/agent-runtime/tool-impl/remote-controls.mock.ts +0 -256
  79. package/packs/agent-runtime/tool-impl/remote-controls.ts +0 -273
  80. package/packs/agent-runtime/tools/index.ts +0 -4
  81. package/packs/agent-runtime/tools/types.ts +0 -47
  82. package/packs/agent-runtime/turn-lifecycle-events.ts +0 -590
  83. package/packs/agent-runtime/types.ts +0 -128
  84. package/packs/agent-runtime/vitest.config.ts +0 -11
  85. package/packs/sidekick/channel-ingress.ts +0 -137
  86. package/packs/sidekick/constants.ts +0 -10
  87. package/packs/sidekick/index.ts +0 -8
  88. package/packs/sidekick/manifest-schema.ts +0 -49
  89. package/packs/sidekick/manifest.ts +0 -512
  90. package/packs/sidekick/pack-registration.ts +0 -110
  91. package/packs/sidekick/policy-factory.ts +0 -38
  92. package/packs/sidekick/sidekick-events.ts +0 -694
  93. package/packs/sidekick/src/adapters/cloud-queue.ts +0 -101
  94. package/packs/sidekick/src/adapters/control-plane-bridge.adapter.ts +0 -386
  95. package/packs/sidekick/src/adapters/filesystem-bridge.adapter.ts +0 -228
  96. package/packs/sidekick/src/domain/channel.types.ts +0 -64
  97. package/packs/sidekick/src/ports/channel-bridge.port.ts +0 -92
  98. package/packs/sidekick/src/routines/commit.ts +0 -74
  99. package/packs/sidekick/tool-impl/channel-tools.ts +0 -577
  100. package/packs/sidekick/tool-impl/channel-transports.ts +0 -75
  101. package/packs/sidekick/tool-impl/index.ts +0 -29
  102. package/packs/sidekick/tool-impl/memory-tools.ts +0 -290
  103. package/packs/sidekick/tool-impl/routine-commit.ts +0 -102
  104. package/packs/sidekick/tool-impl/routine-tools.ts +0 -440
  105. package/packs/sidekick/tool-impl/runtime-context.ts +0 -28
  106. package/packs/sidekick/tool-impl/shared.ts +0 -125
  107. package/packs/sidekick/tool-impl/storage.ts +0 -325
  108. package/packs/sidekick/tool-impl/system-tools.ts +0 -160
  109. package/packs/sidekick/tool-impl/task-tools.ts +0 -506
  110. package/packs/sidekick/tools/channel-tools.ts +0 -53
  111. package/packs/sidekick/tools/index.ts +0 -9
  112. package/packs/sidekick/tools/memory-tools.ts +0 -53
  113. package/packs/sidekick/tools/routine-tools.ts +0 -53
  114. package/packs/sidekick/tools/system-tools.ts +0 -47
  115. package/packs/sidekick/tools/task-tools.ts +0 -61
  116. package/packs/sidekick/tools/types.ts +0 -57
  117. package/packs/sidekick/vitest.config.ts +0 -11
  118. package/packs/software-delivery/constants.ts +0 -10
  119. package/packs/software-delivery/extensions.ts +0 -140
  120. package/packs/software-delivery/gate-policies.ts +0 -134
  121. package/packs/software-delivery/index.ts +0 -8
  122. package/packs/software-delivery/manifest-schema.ts +0 -268
  123. package/packs/software-delivery/manifest.ts +0 -657
  124. package/packs/software-delivery/pack-registration.ts +0 -113
  125. package/packs/software-delivery/src/commands/index.ts +0 -5
  126. package/packs/software-delivery/src/config/delivery-review-contract.ts +0 -256
  127. package/packs/software-delivery/src/config/env-accessors.ts +0 -66
  128. package/packs/software-delivery/src/config/index.ts +0 -8
  129. package/packs/software-delivery/src/config/normalize-config-keys.ts +0 -9
  130. package/packs/software-delivery/src/config/schemas/lumenflow-config-schema-types.ts +0 -460
  131. package/packs/software-delivery/src/config/workspace-reader.ts +0 -375
  132. package/packs/software-delivery/src/constants/backlog-patterns.ts +0 -31
  133. package/packs/software-delivery/src/constants/client-ids.ts +0 -19
  134. package/packs/software-delivery/src/constants/config-contract.ts +0 -7
  135. package/packs/software-delivery/src/constants/docs-layout-presets.ts +0 -50
  136. package/packs/software-delivery/src/constants/duration-constants.ts +0 -20
  137. package/packs/software-delivery/src/constants/gate-constants.ts +0 -32
  138. package/packs/software-delivery/src/constants/index.ts +0 -29
  139. package/packs/software-delivery/src/constants/lock-constants.ts +0 -35
  140. package/packs/software-delivery/src/constants/object-guards.ts +0 -12
  141. package/packs/software-delivery/src/constants/section-headings.ts +0 -107
  142. package/packs/software-delivery/src/constants/wu-cli-constants.ts +0 -500
  143. package/packs/software-delivery/src/constants/wu-domain-constants.ts +0 -466
  144. package/packs/software-delivery/src/constants/wu-git-constants.ts +0 -7
  145. package/packs/software-delivery/src/constants/wu-id-format.ts +0 -327
  146. package/packs/software-delivery/src/constants/wu-paths-constants.ts +0 -384
  147. package/packs/software-delivery/src/constants/wu-statuses.ts +0 -287
  148. package/packs/software-delivery/src/constants/wu-type-helpers.ts +0 -67
  149. package/packs/software-delivery/src/constants/wu-ui-constants.ts +0 -267
  150. package/packs/software-delivery/src/constants/wu-validation-constants.ts +0 -73
  151. package/packs/software-delivery/src/domain/index.ts +0 -5
  152. package/packs/software-delivery/src/domain/orchestration.constants.ts +0 -166
  153. package/packs/software-delivery/src/domain/orchestration.schemas.ts +0 -238
  154. package/packs/software-delivery/src/domain/orchestration.types.ts +0 -176
  155. package/packs/software-delivery/src/methodology/incremental-test.ts +0 -122
  156. package/packs/software-delivery/src/methodology/index.ts +0 -6
  157. package/packs/software-delivery/src/methodology/manual-test-validator.ts +0 -292
  158. package/packs/software-delivery/src/policy/coverage-gate.ts +0 -270
  159. package/packs/software-delivery/src/policy/gates-agent-mode.ts +0 -223
  160. package/packs/software-delivery/src/policy/gates-config-internal.ts +0 -121
  161. package/packs/software-delivery/src/policy/gates-config.ts +0 -300
  162. package/packs/software-delivery/src/policy/gates-coverage.ts +0 -356
  163. package/packs/software-delivery/src/policy/gates-presets.ts +0 -134
  164. package/packs/software-delivery/src/policy/gates-schemas.ts +0 -173
  165. package/packs/software-delivery/src/policy/index.ts +0 -22
  166. package/packs/software-delivery/src/policy/package-manager-resolver.ts +0 -319
  167. package/packs/software-delivery/src/policy/resolve-policy.ts +0 -601
  168. package/packs/software-delivery/src/ports/config.ports.ts +0 -90
  169. package/packs/software-delivery/src/ports/dashboard-renderer.port.ts +0 -125
  170. package/packs/software-delivery/src/ports/index.ts +0 -10
  171. package/packs/software-delivery/src/ports/sync-validator.ports.ts +0 -59
  172. package/packs/software-delivery/src/ports/wu-helpers.ports.ts +0 -168
  173. package/packs/software-delivery/src/ports/wu-state.ports.ts +0 -241
  174. package/packs/software-delivery/src/primitives/index.ts +0 -5
  175. package/packs/software-delivery/src/runtime/index.ts +0 -6
  176. package/packs/software-delivery/src/runtime/work-classifier.ts +0 -561
  177. package/packs/software-delivery/src/sandbox/index.ts +0 -10
  178. package/packs/software-delivery/src/sandbox/sandbox-allowlist.ts +0 -118
  179. package/packs/software-delivery/src/sandbox/sandbox-backend-linux.ts +0 -88
  180. package/packs/software-delivery/src/sandbox/sandbox-backend-macos.ts +0 -154
  181. package/packs/software-delivery/src/sandbox/sandbox-backend-windows.ts +0 -47
  182. package/packs/software-delivery/src/sandbox/sandbox-profile.ts +0 -153
  183. package/packs/software-delivery/src/schemas/index.ts +0 -5
  184. package/packs/software-delivery/src/state/date-utils.ts +0 -158
  185. package/packs/software-delivery/src/state/index.ts +0 -15
  186. package/packs/software-delivery/src/state/state-machine.ts +0 -119
  187. package/packs/software-delivery/src/state/wu-doc-types.ts +0 -51
  188. package/packs/software-delivery/src/state/wu-paths.ts +0 -381
  189. package/packs/software-delivery/src/state/wu-schema.ts +0 -1139
  190. package/packs/software-delivery/src/state/wu-state-schema.ts +0 -255
  191. package/packs/software-delivery/src/state/wu-yaml.ts +0 -338
  192. package/packs/software-delivery/tool-impl/agent-tools.ts +0 -263
  193. package/packs/software-delivery/tool-impl/delegation-tools.ts +0 -66
  194. package/packs/software-delivery/tool-impl/flow-metrics-tools.ts +0 -219
  195. package/packs/software-delivery/tool-impl/git-runner.ts +0 -113
  196. package/packs/software-delivery/tool-impl/git-tools.ts +0 -316
  197. package/packs/software-delivery/tool-impl/index.ts +0 -15
  198. package/packs/software-delivery/tool-impl/initiative-orchestration-tools.ts +0 -720
  199. package/packs/software-delivery/tool-impl/lane-lock.ts +0 -246
  200. package/packs/software-delivery/tool-impl/memory-tools.ts +0 -470
  201. package/packs/software-delivery/tool-impl/pending-runtime-tools.ts +0 -21
  202. package/packs/software-delivery/tool-impl/runtime-cli-adapter.ts +0 -329
  203. package/packs/software-delivery/tool-impl/runtime-native-tools.ts +0 -687
  204. package/packs/software-delivery/tool-impl/worker-loader.ts +0 -52
  205. package/packs/software-delivery/tool-impl/worktree-tools.ts +0 -46
  206. package/packs/software-delivery/tool-impl/wu-lifecycle-tools.ts +0 -807
  207. package/packs/software-delivery/tools/delegation-tools.ts +0 -23
  208. package/packs/software-delivery/tools/git-tools.ts +0 -55
  209. package/packs/software-delivery/tools/index.ts +0 -8
  210. package/packs/software-delivery/tools/lane-lock-tool.ts +0 -37
  211. package/packs/software-delivery/tools/types.ts +0 -71
  212. package/packs/software-delivery/tools/worktree-tools.ts +0 -49
  213. package/packs/software-delivery/vitest.config.ts +0 -11
@@ -1,687 +0,0 @@
1
- // Copyright (c) 2026 Hellmai Ltd
2
- // SPDX-License-Identifier: LicenseRef-LumenFlow-Proprietary
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
- }