maestro-flow 0.5.3 → 0.5.31

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 (259) hide show
  1. package/.agents/skills/learn-follow/SKILL.md +114 -114
  2. package/.agents/skills/learn-investigate/SKILL.md +138 -139
  3. package/.agents/skills/learn-second-opinion/SKILL.md +105 -109
  4. package/.agents/skills/maestro/SKILL.md +2 -10
  5. package/.agents/skills/maestro-amend/SKILL.md +152 -152
  6. package/.agents/skills/maestro-analyze/SKILL.md +201 -252
  7. package/.agents/skills/maestro-blueprint/SKILL.md +175 -190
  8. package/.agents/skills/maestro-brainstorm/SKILL.md +196 -200
  9. package/.agents/skills/maestro-collab/SKILL.md +159 -159
  10. package/.agents/skills/maestro-companion/SKILL.md +517 -517
  11. package/.agents/skills/maestro-composer/SKILL.md +173 -164
  12. package/.agents/skills/maestro-execute/SKILL.md +169 -170
  13. package/.agents/skills/maestro-fork/SKILL.md +97 -96
  14. package/.agents/skills/maestro-grill/SKILL.md +161 -162
  15. package/.agents/skills/maestro-guard/SKILL.md +93 -92
  16. package/.agents/skills/maestro-impeccable/SKILL.md +296 -253
  17. package/.agents/skills/maestro-init/SKILL.md +117 -118
  18. package/.agents/skills/maestro-merge/SKILL.md +73 -66
  19. package/.agents/skills/maestro-milestone-audit/SKILL.md +4 -10
  20. package/.agents/skills/maestro-milestone-complete/SKILL.md +6 -7
  21. package/.agents/skills/maestro-milestone-release/SKILL.md +122 -131
  22. package/.agents/skills/maestro-next/SKILL.md +241 -245
  23. package/.agents/skills/maestro-overlay/SKILL.md +176 -166
  24. package/.agents/skills/maestro-plan/SKILL.md +211 -197
  25. package/.agents/skills/maestro-player/SKILL.md +167 -167
  26. package/.agents/skills/maestro-quick/SKILL.md +69 -63
  27. package/.agents/skills/maestro-ralph/SKILL.md +2 -36
  28. package/.agents/skills/maestro-ralph-beta/SKILL.md +861 -872
  29. package/.agents/skills/maestro-ralph-execute/SKILL.md +234 -234
  30. package/.agents/skills/maestro-roadmap/SKILL.md +159 -172
  31. package/.agents/skills/maestro-swarm-workflow/SKILL.md +229 -250
  32. package/.agents/skills/maestro-tools-execute/SKILL.md +108 -103
  33. package/.agents/skills/maestro-tools-register/SKILL.md +148 -143
  34. package/.agents/skills/maestro-ui-codify/SKILL.md +103 -86
  35. package/.agents/skills/maestro-universal-workflow/SKILL.md +534 -547
  36. package/.agents/skills/maestro-update/SKILL.md +109 -106
  37. package/.agents/skills/manage-codebase-rebuild/SKILL.md +73 -71
  38. package/.agents/skills/manage-harvest/SKILL.md +83 -81
  39. package/.agents/skills/manage-issue/SKILL.md +59 -60
  40. package/.agents/skills/manage-issue-discover/SKILL.md +70 -68
  41. package/.agents/skills/manage-kg-extractors/SKILL.md +130 -0
  42. package/.agents/skills/manage-knowhow/SKILL.md +70 -66
  43. package/.agents/skills/manage-knowhow-capture/SKILL.md +79 -69
  44. package/.agents/skills/manage-knowledge-audit/SKILL.md +91 -74
  45. package/.agents/skills/manage-status/SKILL.md +52 -42
  46. package/.agents/skills/manage-wiki/SKILL.md +69 -58
  47. package/.agents/skills/odyssey-debug/SKILL.md +445 -459
  48. package/.agents/skills/odyssey-improve/SKILL.md +477 -491
  49. package/.agents/skills/odyssey-planex/SKILL.md +576 -587
  50. package/.agents/skills/odyssey-review-test-fix/SKILL.md +400 -413
  51. package/.agents/skills/odyssey-ui/SKILL.md +431 -448
  52. package/.agents/skills/quality-auto-test/SKILL.md +140 -123
  53. package/.agents/skills/quality-debug/SKILL.md +145 -106
  54. package/.agents/skills/quality-refactor/SKILL.md +91 -53
  55. package/.agents/skills/quality-retrospective/SKILL.md +109 -63
  56. package/.agents/skills/quality-review/SKILL.md +141 -114
  57. package/.agents/skills/quality-sync/SKILL.md +74 -38
  58. package/.agents/skills/quality-test/SKILL.md +133 -103
  59. package/.agents/skills/security-audit/SKILL.md +217 -166
  60. package/.agents/skills/spec-add/SKILL.md +66 -59
  61. package/.agents/skills/spec-load/SKILL.md +68 -68
  62. package/.agents/skills/spec-remove/SKILL.md +42 -42
  63. package/.agents/skills/spec-setup/SKILL.md +38 -41
  64. package/.agy/skills/learn-follow/SKILL.md +114 -114
  65. package/.agy/skills/learn-investigate/SKILL.md +138 -139
  66. package/.agy/skills/learn-second-opinion/SKILL.md +105 -109
  67. package/.agy/skills/maestro/SKILL.md +2 -10
  68. package/.agy/skills/maestro-amend/SKILL.md +152 -152
  69. package/.agy/skills/maestro-analyze/SKILL.md +201 -252
  70. package/.agy/skills/maestro-blueprint/SKILL.md +175 -190
  71. package/.agy/skills/maestro-brainstorm/SKILL.md +196 -200
  72. package/.agy/skills/maestro-collab/SKILL.md +159 -159
  73. package/.agy/skills/maestro-companion/SKILL.md +517 -517
  74. package/.agy/skills/maestro-composer/SKILL.md +173 -164
  75. package/.agy/skills/maestro-execute/SKILL.md +169 -170
  76. package/.agy/skills/maestro-fork/SKILL.md +97 -96
  77. package/.agy/skills/maestro-grill/SKILL.md +161 -162
  78. package/.agy/skills/maestro-guard/SKILL.md +93 -92
  79. package/.agy/skills/maestro-impeccable/SKILL.md +296 -253
  80. package/.agy/skills/maestro-init/SKILL.md +117 -118
  81. package/.agy/skills/maestro-merge/SKILL.md +73 -66
  82. package/.agy/skills/maestro-milestone-audit/SKILL.md +4 -10
  83. package/.agy/skills/maestro-milestone-complete/SKILL.md +6 -7
  84. package/.agy/skills/maestro-milestone-release/SKILL.md +122 -131
  85. package/.agy/skills/maestro-next/SKILL.md +241 -245
  86. package/.agy/skills/maestro-overlay/SKILL.md +176 -166
  87. package/.agy/skills/maestro-plan/SKILL.md +211 -197
  88. package/.agy/skills/maestro-player/SKILL.md +167 -167
  89. package/.agy/skills/maestro-quick/SKILL.md +69 -63
  90. package/.agy/skills/maestro-ralph/SKILL.md +2 -36
  91. package/.agy/skills/maestro-ralph-beta/SKILL.md +861 -872
  92. package/.agy/skills/maestro-ralph-execute/SKILL.md +234 -234
  93. package/.agy/skills/maestro-roadmap/SKILL.md +159 -172
  94. package/.agy/skills/maestro-swarm-workflow/SKILL.md +229 -250
  95. package/.agy/skills/maestro-tools-execute/SKILL.md +108 -103
  96. package/.agy/skills/maestro-tools-register/SKILL.md +148 -143
  97. package/.agy/skills/maestro-ui-codify/SKILL.md +103 -86
  98. package/.agy/skills/maestro-universal-workflow/SKILL.md +534 -547
  99. package/.agy/skills/maestro-update/SKILL.md +109 -106
  100. package/.agy/skills/manage-codebase-rebuild/SKILL.md +73 -71
  101. package/.agy/skills/manage-harvest/SKILL.md +83 -81
  102. package/.agy/skills/manage-issue/SKILL.md +59 -60
  103. package/.agy/skills/manage-issue-discover/SKILL.md +70 -68
  104. package/.agy/skills/manage-kg-extractors/SKILL.md +130 -0
  105. package/.agy/skills/manage-knowhow/SKILL.md +70 -66
  106. package/.agy/skills/manage-knowhow-capture/SKILL.md +79 -69
  107. package/.agy/skills/manage-knowledge-audit/SKILL.md +91 -74
  108. package/.agy/skills/manage-status/SKILL.md +52 -42
  109. package/.agy/skills/manage-wiki/SKILL.md +69 -58
  110. package/.agy/skills/odyssey-debug/SKILL.md +445 -459
  111. package/.agy/skills/odyssey-improve/SKILL.md +477 -491
  112. package/.agy/skills/odyssey-planex/SKILL.md +576 -587
  113. package/.agy/skills/odyssey-review-test-fix/SKILL.md +400 -413
  114. package/.agy/skills/odyssey-ui/SKILL.md +431 -448
  115. package/.agy/skills/quality-auto-test/SKILL.md +140 -123
  116. package/.agy/skills/quality-debug/SKILL.md +145 -106
  117. package/.agy/skills/quality-refactor/SKILL.md +91 -53
  118. package/.agy/skills/quality-retrospective/SKILL.md +109 -63
  119. package/.agy/skills/quality-review/SKILL.md +141 -114
  120. package/.agy/skills/quality-sync/SKILL.md +74 -38
  121. package/.agy/skills/quality-test/SKILL.md +133 -103
  122. package/.agy/skills/security-audit/SKILL.md +217 -166
  123. package/.agy/skills/spec-add/SKILL.md +66 -59
  124. package/.agy/skills/spec-load/SKILL.md +68 -68
  125. package/.agy/skills/spec-remove/SKILL.md +42 -42
  126. package/.agy/skills/spec-setup/SKILL.md +38 -41
  127. package/.claude/commands/learn-follow.md +127 -127
  128. package/.claude/commands/learn-investigate.md +151 -152
  129. package/.claude/commands/learn-second-opinion.md +118 -122
  130. package/.claude/commands/maestro-amend.md +164 -164
  131. package/.claude/commands/maestro-analyze.md +215 -266
  132. package/.claude/commands/maestro-blueprint.md +189 -204
  133. package/.claude/commands/maestro-brainstorm.md +209 -213
  134. package/.claude/commands/maestro-collab.md +172 -172
  135. package/.claude/commands/maestro-companion.md +531 -531
  136. package/.claude/commands/maestro-composer.md +188 -179
  137. package/.claude/commands/maestro-execute.md +183 -184
  138. package/.claude/commands/maestro-fork.md +111 -110
  139. package/.claude/commands/maestro-grill.md +175 -176
  140. package/.claude/commands/maestro-guard.md +103 -102
  141. package/.claude/commands/maestro-impeccable.md +311 -268
  142. package/.claude/commands/maestro-init.md +130 -131
  143. package/.claude/commands/maestro-merge.md +87 -80
  144. package/.claude/commands/maestro-milestone-audit.md +4 -10
  145. package/.claude/commands/maestro-milestone-complete.md +6 -7
  146. package/.claude/commands/maestro-milestone-release.md +136 -145
  147. package/.claude/commands/maestro-next.md +253 -257
  148. package/.claude/commands/maestro-overlay.md +188 -178
  149. package/.claude/commands/maestro-plan.md +225 -211
  150. package/.claude/commands/maestro-player.md +182 -182
  151. package/.claude/commands/maestro-quick.md +83 -77
  152. package/.claude/commands/maestro-ralph-beta.md +875 -886
  153. package/.claude/commands/maestro-ralph-execute.md +247 -247
  154. package/.claude/commands/maestro-ralph.md +2 -36
  155. package/.claude/commands/maestro-roadmap.md +173 -186
  156. package/.claude/commands/maestro-swarm-workflow.md +243 -264
  157. package/.claude/commands/maestro-tools-execute.md +122 -117
  158. package/.claude/commands/maestro-tools-register.md +162 -157
  159. package/.claude/commands/maestro-ui-codify.md +117 -100
  160. package/.claude/commands/maestro-universal-workflow.md +548 -561
  161. package/.claude/commands/maestro-update.md +122 -119
  162. package/.claude/commands/maestro.md +2 -10
  163. package/.claude/commands/manage-codebase-rebuild.md +87 -85
  164. package/.claude/commands/manage-harvest.md +97 -95
  165. package/.claude/commands/manage-issue-discover.md +83 -81
  166. package/.claude/commands/manage-issue.md +72 -73
  167. package/.claude/commands/manage-kg-extractors.md +128 -0
  168. package/.claude/commands/manage-knowhow-capture.md +92 -82
  169. package/.claude/commands/manage-knowhow.md +83 -79
  170. package/.claude/commands/manage-knowledge-audit.md +105 -88
  171. package/.claude/commands/manage-status.md +62 -52
  172. package/.claude/commands/manage-wiki.md +82 -71
  173. package/.claude/commands/odyssey-debug.md +459 -473
  174. package/.claude/commands/odyssey-improve.md +491 -505
  175. package/.claude/commands/odyssey-planex.md +590 -601
  176. package/.claude/commands/odyssey-review-test-fix.md +414 -427
  177. package/.claude/commands/odyssey-ui.md +445 -462
  178. package/.claude/commands/quality-auto-test.md +153 -136
  179. package/.claude/commands/quality-debug.md +159 -120
  180. package/.claude/commands/quality-refactor.md +105 -67
  181. package/.claude/commands/quality-retrospective.md +123 -77
  182. package/.claude/commands/quality-review.md +155 -128
  183. package/.claude/commands/quality-sync.md +88 -52
  184. package/.claude/commands/quality-test.md +147 -117
  185. package/.claude/commands/security-audit.md +230 -179
  186. package/.claude/commands/spec-add.md +77 -70
  187. package/.claude/commands/spec-load.md +78 -78
  188. package/.claude/commands/spec-remove.md +55 -55
  189. package/.claude/commands/spec-setup.md +49 -52
  190. package/dist/src/cli.js +1 -1
  191. package/dist/src/cli.js.map +1 -1
  192. package/dist/src/commands/kg.d.ts.map +1 -1
  193. package/dist/src/commands/kg.js +11 -5
  194. package/dist/src/commands/kg.js.map +1 -1
  195. package/dist/src/graph/kg/extraction/code/code-extractor.d.ts +2 -0
  196. package/dist/src/graph/kg/extraction/code/code-extractor.d.ts.map +1 -1
  197. package/dist/src/graph/kg/extraction/code/code-extractor.js +32 -3
  198. package/dist/src/graph/kg/extraction/code/code-extractor.js.map +1 -1
  199. package/dist/src/graph/kg/extraction/code/plugin-engine.d.ts +35 -0
  200. package/dist/src/graph/kg/extraction/code/plugin-engine.d.ts.map +1 -0
  201. package/dist/src/graph/kg/extraction/code/plugin-engine.js +573 -0
  202. package/dist/src/graph/kg/extraction/code/plugin-engine.js.map +1 -0
  203. package/dist/src/graph/kg/extraction/code/plugin-types.d.ts +95 -0
  204. package/dist/src/graph/kg/extraction/code/plugin-types.d.ts.map +1 -0
  205. package/dist/src/graph/kg/extraction/code/plugin-types.js +5 -0
  206. package/dist/src/graph/kg/extraction/code/plugin-types.js.map +1 -0
  207. package/dist/src/graph/kg/extraction/orchestrator.d.ts.map +1 -1
  208. package/dist/src/graph/kg/extraction/orchestrator.js +17 -5
  209. package/dist/src/graph/kg/extraction/orchestrator.js.map +1 -1
  210. package/dist/src/graph/kg/schema.sql +16 -11
  211. package/dist/src/graph/kg/surface/cli.d.ts.map +1 -1
  212. package/dist/src/graph/kg/surface/cli.js +153 -56
  213. package/dist/src/graph/kg/surface/cli.js.map +1 -1
  214. package/dist/src/hooks/workspace.d.ts +4 -2
  215. package/dist/src/hooks/workspace.d.ts.map +1 -1
  216. package/dist/src/hooks/workspace.js +6 -2
  217. package/dist/src/hooks/workspace.js.map +1 -1
  218. package/package.json +91 -91
  219. package/workflows/analyze.md +25 -49
  220. package/workflows/auto-test.md +699 -699
  221. package/workflows/blueprint.md +403 -431
  222. package/workflows/brainstorm.md +54 -195
  223. package/workflows/business-test.md +570 -570
  224. package/workflows/claude-instructions.md +23 -51
  225. package/workflows/codex-instructions.md +27 -77
  226. package/workflows/coding-philosophy.md +69 -69
  227. package/workflows/command-authoring.md +823 -823
  228. package/workflows/debug.md +43 -98
  229. package/workflows/delegate-usage.md +39 -241
  230. package/workflows/execute.md +4 -53
  231. package/workflows/grill.md +12 -56
  232. package/workflows/harvest.md +22 -68
  233. package/workflows/init.md +148 -148
  234. package/workflows/instruction-authoring-guide.md +97 -0
  235. package/workflows/issue-execute.md +110 -110
  236. package/workflows/issue-gaps-analyze.codex.md +260 -260
  237. package/workflows/issue-gaps-analyze.md +216 -216
  238. package/workflows/issue-plan.md +110 -110
  239. package/workflows/issue.md +338 -346
  240. package/workflows/knowhow.md +0 -32
  241. package/workflows/learn.md +277 -277
  242. package/workflows/maestro-chain-execute.md +20 -20
  243. package/workflows/refactor.md +22 -44
  244. package/workflows/retrospective.md +16 -65
  245. package/workflows/review.md +446 -486
  246. package/workflows/roadmap.md +35 -132
  247. package/workflows/skill-authoring.md +265 -265
  248. package/workflows/spec-generate.md +470 -470
  249. package/workflows/specs-remove.md +104 -104
  250. package/workflows/sync.md +11 -41
  251. package/workflows/test-gen.md +226 -226
  252. package/workflows/test.md +385 -475
  253. package/workflows/ui-design.md +391 -391
  254. package/workflows/ui-style.md +199 -199
  255. package/workflows/wiki-connect.md +151 -151
  256. package/workflows/wiki-digest.md +178 -178
  257. package/workflows/wiki-manage.md +109 -109
  258. package/workflows/cli-tools-usage.md +0 -252
  259. package/workflows/delegate-protocol.codex.md +0 -65
@@ -15,170 +15,170 @@ allowed-tools:
15
15
  ---
16
16
  <!-- Open-standard mirror generated by scripts/build-agents-standard.mjs — do not edit; re-run after editing .claude/ source. -->
17
17
 
18
- <purpose>
19
- Load workflow template (from maestro-composer) → bind context variables → execute DAG nodes in topological order → persist state at checkpoints → support resume.
20
-
21
- Session: `.workflow/.maestro/player-{YYYYMMDD-HHmmss}/status.json`
22
- </purpose>
23
-
24
- <context>
25
- $ARGUMENTS — template slug/path, or flags.
26
-
27
- **Flags**:
28
- - `--context key=value`: Bind context variables (repeatable)
29
- - `-c [session-id]`: Resume paused/interrupted session
30
- - `--list`: List available templates from index.json
31
- - `--dry-run`: Show execution plan without executing
32
-
33
- **Node execution mechanisms**:
34
-
35
- | Node type | Mechanism | Blocking |
36
- |-----------|-----------|----------|
37
- | skill | `invoke_skill(skill, args)` | sync |
38
- | command | `invoke_skill(skill, args)` | sync |
39
- | cli | `maestro delegate --to tool --mode mode` via `shell(run_in_background: true)` | async, STOP + wait |
40
- | agent | `delegate_subagent(subagent_type, prompt)` | configurable |
41
- | checkpoint | State save + optional user pause | — |
42
-
43
- **Runtime reference resolution** in args_template:
44
-
45
- | Reference | Resolves to |
46
- |-----------|-------------|
47
- | `{variable}` | session context[variable] |
48
- | `{N-001.session_id}` | node's session_id |
49
- | `{N-001.output_path}` | node's output_path |
50
- | `{prev_session_id}` | previous non-checkpoint node's session_id |
51
- | `{prev_output_path}` | previous non-checkpoint node's output_path |
52
-
53
- **Session schema** (status.json — must align with maestro.md tracking):
54
- ```json
55
- {
56
- "session_id": "player-<YYYYMMDD>-<HHmmss>",
57
- "status": "running|paused|completed|failed|aborted",
58
- "template_id": "wft-<slug>-<date>",
59
- "template_path": "<path>",
60
- "auto_mode": false,
61
- "context": { "goal": "..." },
62
- "steps": [{
63
- "index": 0, "node_id": "N-001", "skill": "<executor>",
64
- "args": "<resolved>", "type": "skill|cli|agent|checkpoint",
65
- "status": "pending|running|completed|skipped|failed",
66
- "session_id": null, "output_path": null, "artifacts": []
67
- }],
68
- "current_step": 0,
69
- "last_checkpoint": null
70
- }
71
- ```
72
- </context>
73
-
74
- <state_machine>
75
-
76
- <states>
77
- S_ROUTE — 入口路由(list/resume/dry-run/normal) PERSIST: —
78
- S_RESUME — 恢复已暂停 session PERSIST: —
79
- S_LOAD — 加载模板、收集变量、绑定引用 PERSIST: —
80
- S_INIT — 创建 session、拓扑排序、初始化 steps PERSIST: status.json
81
- S_EXEC_LOOP — 逐步执行(核心循环) PERSIST: status.json (每步更新)
82
- S_COMPLETE — 标记完成、输出摘要 PERSIST: status.json (final)
83
- </states>
84
-
85
- <transitions>
86
-
87
- S_ROUTE:
88
- → handleList WHEN: --list DO: scan index.json, display templates
89
- → S_RESUME WHEN: -c flag
90
- → S_LOAD WHEN: template slug/path provided
91
- → handleList WHEN: no args DO: display templates + ask_user
92
-
93
- S_RESUME:
94
- → S_EXEC_LOOP WHEN: session found DO: A_RESUME_SESSION
95
- → ERROR(E004) WHEN: no session found
96
-
97
- S_LOAD:
98
- → S_INIT DO: A_LOAD_AND_BIND
99
-
100
- S_INIT:
101
- → END WHEN: --dry-run DO: display execution plan
102
- → S_EXEC_LOOP DO: A_INIT_SESSION (topological sort → steps[], write status.json, display banner)
103
-
104
- S_EXEC_LOOP:
105
- → S_EXEC_LOOP WHEN: step completed, more steps DO: A_EXECUTE_STEP → advance current_step
106
- → S_COMPLETE WHEN: all steps completed
107
- → END WHEN: checkpoint pause DO: set status=paused, display resume command
108
- → END WHEN: abort chosen DO: set status=aborted, save progress
109
- GUARD: cli nodes → shell(run_in_background: true) + STOP, wait for callback
110
- GUARD: on failure → on_fail: skip (log, advance) | retry (once) | abort (ask_user: Retry/Skip/Abort)
111
- GUARD: after step 3+ → display context hint "可随时 /maestro-player -c 恢复"
112
-
113
- S_COMPLETE:
114
- → END DO: A_COMPLETE_SESSION
115
-
116
- </transitions>
117
-
118
- <actions>
119
-
120
- ### A_RESUME_SESSION
121
-
122
- 1. If session-id: load status.json. If none: scan player-*/status.json for running|paused.
123
- 2. Reset any "running" steps to "pending" (interrupted mid-execution)
124
- 3. Set current_step to resume point after last_checkpoint
125
- 4. Enter S_EXEC_LOOP
126
-
127
- ### A_LOAD_AND_BIND
128
-
129
- 1. Resolve template: absolute path → as-is; relative → from cwd; slug → index.json lookup
130
- 2. Parse `--context key=value` pairs
131
- 3. Validate template (template_id, nodes, edges, context_schema required)
132
- 4. Collect missing required variables via ask_user
133
- 5. Bind {variable} placeholders (leave {N-xxx.field} and {prev_*} for runtime)
134
-
135
- ### A_INIT_SESSION
136
-
137
- 1. Generate session_id: player-{YYYYMMDD-HHmmss}
138
- 2. Topological sort (Kahn's algorithm) → flatten to steps[] (parallel nodes share batch index)
139
- 3. All steps status: "pending"
140
- 4. Write status.json
141
-
142
- ### A_EXECUTE_STEP
143
-
144
- 1. Resolve runtime references ({N-xxx.field}, {prev_*}) in args
145
- 2. Set step status="running", write status.json
146
- 3. Execute by type:
147
- - **skill/command**: `invoke_skill(skill, resolved_args)` → extract session_id, output_path, artifacts
148
- - **cli**: `shell(run_in_background: true)` → STOP, wait for callback → `maestro delegate output <id>`
149
- - **agent**: `delegate_subagent(subagent_type, resolved_args)`
150
- - **checkpoint**: write checkpoint snapshot. If auto_continue==false:
151
- ask_user (single-select, header: "Checkpoint"):
152
- - **Continue** — proceed to next step
153
- - **Pause** — save progress, exit (resume with `-c`)
154
- - **Abort** — stop workflow
155
- 4. Set step status="completed" (or "skipped"/"failed"), write status.json
156
-
157
- ### A_COMPLETE_SESSION
158
-
159
- Set status="completed", completed_at. Display summary: session, template, steps completed, context, per-step results, artifacts, session dir.
160
- ask_user (single-select, header: "完成"):
161
- - **Keep session** — preserve artifacts for reference
162
- - **Run again** — re-execute with same template
163
- - **Done** — clean up and exit
164
-
165
- </actions>
166
-
167
- </state_machine>
168
-
169
- <error_codes>
170
- | Code | Condition | Recovery |
171
- |------|-----------|----------|
172
- | E001 | Template not found | Show --list, suggest closest match |
173
- | E002 | Template JSON invalid (missing template_id/nodes/edges) | Point to template file for fix |
174
- | E004 | Resume session not found | List available player-*/ sessions |
175
- | E005 | DAG cycle in template | Point to template, suggest --edit |
176
- | E006 | Node execution failed + abort chosen | Save state, suggest `-c` resume |
177
- </error_codes>
178
-
179
- <success_criteria>
180
- - [ ] Template loaded, variables bound, session created with topological steps
181
- - [ ] status.json written after every step change (resume-safe)
182
- - [ ] CLI nodes use shell(run_in_background) + STOP pattern
183
- - [ ] Checkpoints saved, resume via -c works
184
- </success_criteria>
18
+ <purpose>
19
+ Load workflow template (from maestro-composer) → bind context variables → execute DAG nodes in topological order → persist state at checkpoints → support resume.
20
+
21
+ Session: `.workflow/.maestro/player-{YYYYMMDD-HHmmss}/status.json`
22
+ </purpose>
23
+
24
+ <context>
25
+ $ARGUMENTS — template slug/path, or flags.
26
+
27
+ **Flags**:
28
+ - `--context key=value`: Bind context variables (repeatable)
29
+ - `-c [session-id]`: Resume paused/interrupted session
30
+ - `--list`: List available templates from index.json
31
+ - `--dry-run`: Show execution plan without executing
32
+
33
+ **Node execution mechanisms**:
34
+
35
+ | Node type | Mechanism | Blocking |
36
+ |-----------|-----------|----------|
37
+ | skill | `invoke_skill(skill, args)` | sync |
38
+ | command | `invoke_skill(skill, args)` | sync |
39
+ | cli | `maestro delegate --to tool --mode mode` via `shell(run_in_background: true)` | async, STOP + wait |
40
+ | agent | `delegate_subagent(subagent_type, prompt)` | configurable |
41
+ | checkpoint | State save + optional user pause | — |
42
+
43
+ **Runtime reference resolution** in args_template:
44
+
45
+ | Reference | Resolves to |
46
+ |-----------|-------------|
47
+ | `{variable}` | session context[variable] |
48
+ | `{N-001.session_id}` | node's session_id |
49
+ | `{N-001.output_path}` | node's output_path |
50
+ | `{prev_session_id}` | previous non-checkpoint node's session_id |
51
+ | `{prev_output_path}` | previous non-checkpoint node's output_path |
52
+
53
+ **Session schema** (status.json — must align with maestro.md tracking):
54
+ ```json
55
+ {
56
+ "session_id": "player-<YYYYMMDD>-<HHmmss>",
57
+ "status": "running|paused|completed|failed|aborted",
58
+ "template_id": "wft-<slug>-<date>",
59
+ "template_path": "<path>",
60
+ "auto_mode": false,
61
+ "context": { "goal": "..." },
62
+ "steps": [{
63
+ "index": 0, "node_id": "N-001", "skill": "<executor>",
64
+ "args": "<resolved>", "type": "skill|cli|agent|checkpoint",
65
+ "status": "pending|running|completed|skipped|failed",
66
+ "session_id": null, "output_path": null, "artifacts": []
67
+ }],
68
+ "current_step": 0,
69
+ "last_checkpoint": null
70
+ }
71
+ ```
72
+ </context>
73
+
74
+ <state_machine>
75
+
76
+ <states>
77
+ S_ROUTE — 入口路由(list/resume/dry-run/normal) PERSIST: —
78
+ S_RESUME — 恢复已暂停 session PERSIST: —
79
+ S_LOAD — 加载模板、收集变量、绑定引用 PERSIST: —
80
+ S_INIT — 创建 session、拓扑排序、初始化 steps PERSIST: status.json
81
+ S_EXEC_LOOP — 逐步执行(核心循环) PERSIST: status.json (每步更新)
82
+ S_COMPLETE — 标记完成、输出摘要 PERSIST: status.json (final)
83
+ </states>
84
+
85
+ <transitions>
86
+
87
+ S_ROUTE:
88
+ → handleList WHEN: --list DO: scan index.json, display templates
89
+ → S_RESUME WHEN: -c flag
90
+ → S_LOAD WHEN: template slug/path provided
91
+ → handleList WHEN: no args DO: display templates + ask_user
92
+
93
+ S_RESUME:
94
+ → S_EXEC_LOOP WHEN: session found DO: A_RESUME_SESSION
95
+ → ERROR(E004) WHEN: no session found
96
+
97
+ S_LOAD:
98
+ → S_INIT DO: A_LOAD_AND_BIND
99
+
100
+ S_INIT:
101
+ → END WHEN: --dry-run DO: display execution plan
102
+ → S_EXEC_LOOP DO: A_INIT_SESSION (topological sort → steps[], write status.json, display banner)
103
+
104
+ S_EXEC_LOOP:
105
+ → S_EXEC_LOOP WHEN: step completed, more steps DO: A_EXECUTE_STEP → advance current_step
106
+ → S_COMPLETE WHEN: all steps completed
107
+ → END WHEN: checkpoint pause DO: set status=paused, display resume command
108
+ → END WHEN: abort chosen DO: set status=aborted, save progress
109
+ GUARD: cli nodes → shell(run_in_background: true) + STOP, wait for callback
110
+ GUARD: on failure → on_fail: skip (log, advance) | retry (once) | abort (ask_user: Retry/Skip/Abort)
111
+ GUARD: after step 3+ → display context hint "可随时 /maestro-player -c 恢复"
112
+
113
+ S_COMPLETE:
114
+ → END DO: A_COMPLETE_SESSION
115
+
116
+ </transitions>
117
+
118
+ <actions>
119
+
120
+ ### A_RESUME_SESSION
121
+
122
+ 1. If session-id: load status.json. If none: scan player-*/status.json for running|paused.
123
+ 2. Reset any "running" steps to "pending" (interrupted mid-execution)
124
+ 3. Set current_step to resume point after last_checkpoint
125
+ 4. Enter S_EXEC_LOOP
126
+
127
+ ### A_LOAD_AND_BIND
128
+
129
+ 1. Resolve template: absolute path → as-is; relative → from cwd; slug → index.json lookup
130
+ 2. Parse `--context key=value` pairs
131
+ 3. Validate template (template_id, nodes, edges, context_schema required)
132
+ 4. Collect missing required variables via ask_user
133
+ 5. Bind {variable} placeholders (leave {N-xxx.field} and {prev_*} for runtime)
134
+
135
+ ### A_INIT_SESSION
136
+
137
+ 1. Generate session_id: player-{YYYYMMDD-HHmmss}
138
+ 2. Topological sort (Kahn's algorithm) → flatten to steps[] (parallel nodes share batch index)
139
+ 3. All steps status: "pending"
140
+ 4. Write status.json
141
+
142
+ ### A_EXECUTE_STEP
143
+
144
+ 1. Resolve runtime references ({N-xxx.field}, {prev_*}) in args
145
+ 2. Set step status="running", write status.json
146
+ 3. Execute by type:
147
+ - **skill/command**: `invoke_skill(skill, resolved_args)` → extract session_id, output_path, artifacts
148
+ - **cli**: `shell(run_in_background: true)` → STOP, wait for callback → `maestro delegate output <id>`
149
+ - **agent**: `delegate_subagent(subagent_type, resolved_args)`
150
+ - **checkpoint**: write checkpoint snapshot. If auto_continue==false:
151
+ ask_user (single-select, header: "Checkpoint"):
152
+ - **Continue** — proceed to next step
153
+ - **Pause** — save progress, exit (resume with `-c`)
154
+ - **Abort** — stop workflow
155
+ 4. Set step status="completed" (or "skipped"/"failed"), write status.json
156
+
157
+ ### A_COMPLETE_SESSION
158
+
159
+ Set status="completed", completed_at. Display summary: session, template, steps completed, context, per-step results, artifacts, session dir.
160
+ ask_user (single-select, header: "完成"):
161
+ - **Keep session** — preserve artifacts for reference
162
+ - **Run again** — re-execute with same template
163
+ - **Done** — clean up and exit
164
+
165
+ </actions>
166
+
167
+ </state_machine>
168
+
169
+ <error_codes>
170
+ | Code | Condition | Recovery |
171
+ |------|-----------|----------|
172
+ | E001 | Template not found | Show --list, suggest closest match |
173
+ | E002 | Template JSON invalid (missing template_id/nodes/edges) | Point to template file for fix |
174
+ | E004 | Resume session not found | List available player-*/ sessions |
175
+ | E005 | DAG cycle in template | Point to template, suggest --edit |
176
+ | E006 | Node execution failed + abort chosen | Save state, suggest `-c` resume |
177
+ </error_codes>
178
+
179
+ <success_criteria>
180
+ - [ ] Template loaded, variables bound, session created with topological steps
181
+ - [ ] status.json written after every step change (resume-safe)
182
+ - [ ] CLI nodes use shell(run_in_background) + STOP pattern
183
+ - [ ] Checkpoints saved, resume via -c works
184
+ </success_criteria>
@@ -14,66 +14,72 @@ allowed-tools:
14
14
  ---
15
15
  <!-- Open-standard mirror generated by scripts/build-agents-standard.mjs — do not edit; re-run after editing .claude/ source. -->
16
16
 
17
- <purpose>
18
- Execute small, ad-hoc tasks with workflow guarantees (atomic commits, state tracking) using a shortened pipeline. Invoked for tasks that are well-understood and do not require full phase-level planning. Produces scratch task directory with plan, execution results, and optional verification. Flags --discuss and --full enable additional pipeline stages.
19
- </purpose>
20
-
21
- <required_reading>
22
- @~/.maestro/workflows/quick.md
23
- </required_reading>
24
-
25
- <context>
26
- $ARGUMENTS
27
-
28
- Parse for:
29
- - `--full` flag -- Enables plan-checking (max 2 iterations) and post-execution verification
30
- - `--discuss` flag -- Decision extraction before planning (gray areas, Locked/Free/Deferred classification)
31
- - Remaining text as task description
32
-
33
- ### Pre-load context
34
-
35
- 1. **Coding specs + tools**: Run `maestro spec load --category coding` to load coding conventions and discoverable tools. Apply to implementation.
36
- 2. **UI specs (conditional)**: If the task involves frontend/UI work (description contains component, page, style, layout, CSS, HTML, frontend), also run `maestro spec load --category ui`.
37
- 3. **Role Knowledge**:
38
- - Browse: `maestro search --category coding`
39
- - Load task-relevant entries: `maestro wiki load <id1> [id2...]`
40
- 3. All are optional proceed without if unavailable.
41
- </context>
42
-
43
- <execution>
44
- Follow '~/.maestro/workflows/quick.md' completely.
45
-
46
- ### Artifact Verification (before completion)
47
-
48
- ```
49
- REQUIRED_ARTIFACTS = [
50
- "plan.json", // Task definitions
51
- ".summaries/TASK-*-summary.md" (per task) // Execution results
52
- ]
53
- ```
54
- If any artifact is missing: DO NOT report completion. Complete the missing step first.
55
-
56
- Task summaries MUST include concrete evidence of completion (files changed, tests run, commands executed) — not just "task completed successfully."
57
-
58
- **Next-step routing on completion:**
59
- - Task done, --full verification passed → /manage-status
60
- - Task done, verification found gaps → /quality-debug {issue}
61
- - Task done, want to sync docs → /quality-sync
62
- - Need a full phase workflow instead → /maestro-plan {phase}
63
- </execution>
64
-
65
- <error_codes>
66
- | Code | Severity | Condition | Recovery |
67
- |------|----------|-----------|----------|
68
- | E001 | error | Task description required (no text provided) | Check arguments format, re-run with correct input |
69
- | E002 | error | Scratch directory creation failed | Check disk space and .workflow/ permissions |
70
- | W001 | warning | Verification found minor gaps | Review gaps and determine if they need fixing |
71
- </error_codes>
72
-
73
- <success_criteria>
74
- - [ ] Scratch task directory created under .workflow/scratch/
75
- - [ ] plan.json written with task definitions
76
- - [ ] All tasks executed with summaries written
77
- - [ ] state.json updated with scratch task entry
78
- - [ ] Commit created with task changes
79
- </success_criteria>
17
+ <purpose>
18
+ Execute small, ad-hoc tasks with workflow guarantees (atomic commits, state tracking) via a shortened pipeline.
19
+ Flags --discuss and --full enable additional pipeline stages.
20
+ </purpose>
21
+
22
+ <required_reading>
23
+ @~/.maestro/workflows/quick.md
24
+ </required_reading>
25
+
26
+ <context>
27
+ $ARGUMENTS
28
+
29
+ Parse for:
30
+ - `--full` flag -- Enables plan-checking (max 2 iterations) and post-execution verification
31
+ - `--discuss` flag -- Decision extraction before planning (gray areas, Locked/Free/Deferred classification)
32
+ - Remaining text as task description
33
+
34
+ ### Pre-load context
35
+
36
+ 1. **Coding specs + tools**: Run `maestro spec load --category coding` to load coding conventions and discoverable tools. Apply to implementation.
37
+ 2. **UI specs (conditional)**: If the task involves frontend/UI work (description contains component, page, style, layout, CSS, HTML, frontend), also run `maestro spec load --category ui`.
38
+ 3. **Role Knowledge**:
39
+ - Browse: `maestro search --category coding`
40
+ - Load task-relevant entries: `maestro wiki load <id1> [id2...]`
41
+ 3. All are optional — proceed without if unavailable.
42
+ </context>
43
+
44
+ <execution>
45
+ Follow '~/.maestro/workflows/quick.md' completely.
46
+
47
+ ### Artifact Verification (before completion)
48
+
49
+ ```
50
+ REQUIRED_ARTIFACTS = [
51
+ "plan.json", // Task definitions
52
+ ".summaries/TASK-*-summary.md" (per task) // Execution results
53
+ ]
54
+ ```
55
+ If any artifact is missing: DO NOT report completion. Complete the missing step first.
56
+
57
+ Task summaries MUST include concrete evidence of completion (files changed, tests run, commands executed) — not just "task completed successfully."
58
+
59
+ </execution>
60
+
61
+ <completion>
62
+ ### Next-step routing
63
+ | Condition | Suggestion |
64
+ |-----------|-----------|
65
+ | Task done, --full verification passed | `/manage-status` |
66
+ | Task done, verification found gaps | `/quality-debug {issue}` |
67
+ | Task done, want to sync docs | `/quality-sync` |
68
+ | Need a full phase workflow instead | `/maestro-plan {phase}` |
69
+ </completion>
70
+
71
+ <error_codes>
72
+ | Code | Severity | Condition | Recovery |
73
+ |------|----------|-----------|----------|
74
+ | E001 | error | Task description required (no text provided) | Check arguments format, re-run with correct input |
75
+ | E002 | error | Scratch directory creation failed | Check disk space and .workflow/ permissions |
76
+ | W001 | warning | Verification found minor gaps | Review gaps and determine if they need fixing |
77
+ </error_codes>
78
+
79
+ <success_criteria>
80
+ - [ ] Scratch task directory created under .workflow/scratch/
81
+ - [ ] plan.json written with task definitions
82
+ - [ ] All tasks executed with summaries written
83
+ - [ ] state.json updated with scratch task entry
84
+ - [ ] Commit created with task changes
85
+ </success_criteria>
@@ -15,42 +15,8 @@ allowed-tools:
15
15
  <!-- Open-standard mirror generated by scripts/build-agents-standard.mjs — do not edit; re-run after editing .claude/ source. -->
16
16
 
17
17
  <purpose>
18
- Closed-loop decision engine for the maestro workflow lifecycle.
19
- Reads project state → infers position → builds adaptive chain delegates execution.
20
-
21
- Entry points:
22
- - **`/maestro-ralph "intent"`** — New session: infer → decompose → build → emit /goal prompt(如有 decomposition)→ dispatch ralph-execute
23
- - **`/maestro-ralph continue`** — Wrapper; dispatches to ralph-execute(首选直接 `/maestro-ralph-execute` 推进 step)
24
- - **`/maestro-ralph status`** — Display session progress
25
-
26
- > 推进规则:**step 推进由 `/maestro-ralph-execute` 负责**;ralph 仅在 build / decision 评估时介入。decision 节点由 ralph-execute 自动 `invoke_skill("maestro-ralph")` handoff,无需用户手动切换。
27
-
28
- Initial decomposition (S_DECOMPOSE): boundary-clarified via ≤3 questions for broad intents (重构/全面/迁移/重写). 写入 status.json 的 `boundary_contract` / `execution_criteria` / `task_decomposition`,附 `/goal` prompt。
29
-
30
- Step kinds:
31
- - **执行 step**: ralph-execute 调 `shell("maestro ralph next")` 加载 command .md + required_reading 全文,按 stdout 内联执行
32
- - **decision step**: `step.decision` 字段非空;回 ralph 评估(CLI 只读分析)
33
-
34
- Key difference from maestro coordinator:
35
- - maestro: static chain → one-time selection → runs all steps
36
- - ralph: living chain → decision nodes re-evaluate → chain grows/shrinks dynamically
37
-
38
- Session: `.workflow/.maestro/ralph-{YYYYMMDD-HHmmss}/status.json`
39
- Mutual invocation with `/maestro-ralph-execute` forms a self-perpetuating work loop.
40
-
41
- ### Execution Flow
42
-
43
- ```
44
- /maestro-ralph "intent" ─▶ ralph infer → decompose → build chain
45
- │ resolves command_path per step
46
- │ writes status.json
47
- │ emits /goal prompt
48
-
49
- ralph-execute ◀─┐ 执行 step → `maestro ralph next` + inline + `ralph complete`
50
- │ │ decision step → invoke_skill("maestro-ralph")
51
- └─────────┘ CLI writes step.completion_confirmed
52
- loop until all completion_confirmed | paused
53
- ```
18
+ Closed-loop decision engine: read project state infer position → build adaptive chain → delegate execution.
19
+ Ralph builds/evaluates; ralph-execute runs steps. Session: `.workflow/.maestro/ralph-{YYYYMMDD-HHmmss}/status.json`.
54
20
  </purpose>
55
21
 
56
22
  <context>