takt 0.1.6 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (68) hide show
  1. package/README.md +136 -40
  2. package/dist/cli.js +11 -2
  3. package/dist/cli.js.map +1 -1
  4. package/dist/commands/addTask.d.ts +15 -0
  5. package/dist/commands/addTask.d.ts.map +1 -0
  6. package/dist/commands/addTask.js +101 -0
  7. package/dist/commands/addTask.js.map +1 -0
  8. package/dist/commands/help.d.ts.map +1 -1
  9. package/dist/commands/help.js +16 -5
  10. package/dist/commands/help.js.map +1 -1
  11. package/dist/commands/index.d.ts +3 -0
  12. package/dist/commands/index.d.ts.map +1 -1
  13. package/dist/commands/index.js +3 -0
  14. package/dist/commands/index.js.map +1 -1
  15. package/dist/commands/refreshBuiltin.d.ts +11 -0
  16. package/dist/commands/refreshBuiltin.d.ts.map +1 -0
  17. package/dist/commands/refreshBuiltin.js +37 -0
  18. package/dist/commands/refreshBuiltin.js.map +1 -0
  19. package/dist/commands/taskExecution.d.ts +9 -0
  20. package/dist/commands/taskExecution.d.ts.map +1 -1
  21. package/dist/commands/taskExecution.js +30 -2
  22. package/dist/commands/taskExecution.js.map +1 -1
  23. package/dist/commands/watchTasks.d.ts +12 -0
  24. package/dist/commands/watchTasks.d.ts.map +1 -0
  25. package/dist/commands/watchTasks.js +98 -0
  26. package/dist/commands/watchTasks.js.map +1 -0
  27. package/dist/models/schemas.js +5 -5
  28. package/dist/models/schemas.js.map +1 -1
  29. package/dist/resources/index.d.ts +5 -0
  30. package/dist/resources/index.d.ts.map +1 -1
  31. package/dist/resources/index.js +33 -9
  32. package/dist/resources/index.js.map +1 -1
  33. package/dist/task/display.d.ts.map +1 -1
  34. package/dist/task/display.js +19 -1
  35. package/dist/task/display.js.map +1 -1
  36. package/dist/task/index.d.ts +4 -0
  37. package/dist/task/index.d.ts.map +1 -1
  38. package/dist/task/index.js +4 -0
  39. package/dist/task/index.js.map +1 -1
  40. package/dist/task/parser.d.ts +33 -0
  41. package/dist/task/parser.d.ts.map +1 -0
  42. package/dist/task/parser.js +86 -0
  43. package/dist/task/parser.js.map +1 -0
  44. package/dist/task/runner.d.ts +6 -0
  45. package/dist/task/runner.d.ts.map +1 -1
  46. package/dist/task/runner.js +33 -42
  47. package/dist/task/runner.js.map +1 -1
  48. package/dist/task/schema.d.ts +32 -0
  49. package/dist/task/schema.d.ts.map +1 -0
  50. package/dist/task/schema.js +31 -0
  51. package/dist/task/schema.js.map +1 -0
  52. package/dist/task/watcher.d.ts +33 -0
  53. package/dist/task/watcher.d.ts.map +1 -0
  54. package/dist/task/watcher.js +69 -0
  55. package/dist/task/watcher.js.map +1 -0
  56. package/dist/task/worktree.d.ts +31 -0
  57. package/dist/task/worktree.d.ts.map +1 -0
  58. package/dist/task/worktree.js +112 -0
  59. package/dist/task/worktree.js.map +1 -0
  60. package/dist/utils/slug.d.ts +12 -0
  61. package/dist/utils/slug.d.ts.map +1 -0
  62. package/dist/utils/slug.js +18 -0
  63. package/dist/utils/slug.js.map +1 -0
  64. package/package.json +3 -2
  65. package/resources/global/en/workflows/simple.yaml +594 -0
  66. package/resources/global/ja/agents/default/architect.md +120 -0
  67. package/resources/global/ja/workflows/default.yaml +12 -0
  68. package/resources/global/ja/workflows/simple.yaml +594 -0
@@ -184,6 +184,11 @@ steps:
184
184
  planステップで立てた計画に従って実装してください。
185
185
  計画レポート(00-plan.md)を参照し、実装を進めてください。
186
186
 
187
+ **重要**: 実装と同時に単体テストを追加してください。
188
+ - 新規作成したクラス・関数には単体テストを追加
189
+ - 既存コードを変更した場合は該当するテストを更新
190
+ - テストファイルの配置: プロジェクトの規約に従う(例: `__tests__/`, `*.test.ts`)
191
+
187
192
  **レポート出力:** 上記の `Report Files` に出力してください。
188
193
  - ファイルが存在しない場合: 新規作成
189
194
  - ファイルが存在する場合: `## Iteration {step_iteration}` セクションを追記
@@ -310,6 +315,12 @@ steps:
310
315
 
311
316
  変更をレビューしてフィードバックを提供してください。
312
317
 
318
+ **レビュー観点:**
319
+ - 構造・設計の妥当性
320
+ - コード品質
321
+ - 変更スコープの適切性
322
+ - **テストカバレッジ**: 実装に対応する単体テストが追加されているか
323
+
313
324
  **レポート出力:** 上記の `Report File` に出力してください。
314
325
  - ファイルが存在しない場合: 新規作成
315
326
  - ファイルが存在する場合: `## Iteration {step_iteration}` セクションを追記
@@ -327,6 +338,7 @@ steps:
327
338
  - [x] 構造・設計
328
339
  - [x] コード品質
329
340
  - [x] 変更スコープ
341
+ - [x] テストカバレッジ
330
342
 
331
343
  ## 問題点(REJECTの場合)
332
344
  | # | 場所 | 問題 | 修正案 |
@@ -0,0 +1,594 @@
1
+ # Simple TAKT Workflow
2
+ # Plan -> Coder -> Architect Review -> AI Review -> Supervisor Approval
3
+ # (defaultの簡略版 - improve, fix, ai_fix, security_review, security_fix を削除)
4
+ #
5
+ # Template Variables:
6
+ # {iteration} - Workflow-wide turn count (total steps executed across all agents)
7
+ # {max_iterations} - Maximum iterations allowed for the workflow
8
+ # {step_iteration} - Per-step iteration count (how many times THIS step has been executed)
9
+ # {task} - Original user request
10
+ # {previous_response} - Output from the previous step
11
+ # {git_diff} - Current uncommitted changes (git diff)
12
+ # {user_inputs} - Accumulated user inputs during workflow
13
+ # {report_dir} - Report directory name (e.g., "20250126-143052-task-summary")
14
+
15
+ name: simple
16
+ description: Simplified development workflow (plan -> implement -> review -> ai_review -> supervise)
17
+
18
+ max_iterations: 20
19
+
20
+ initial_step: plan
21
+
22
+ steps:
23
+ - name: plan
24
+ agent: ~/.takt/agents/default/planner.md
25
+ allowed_tools:
26
+ - Read
27
+ - Glob
28
+ - Grep
29
+ - Bash
30
+ - WebSearch
31
+ - WebFetch
32
+ status_rules_prompt: |
33
+ # ⚠️ 必須: ステータス出力ルール ⚠️
34
+
35
+ **このタグがないとワークフローが停止します。**
36
+ 最終出力には必ず以下のルールに従ったステータスタグを含めてください。
37
+
38
+ ## 判定基準
39
+
40
+ | 状況 | 判定 |
41
+ |------|------|
42
+ | 要件が明確で実装可能 | DONE |
43
+ | 要件が不明確、情報不足 | BLOCKED |
44
+
45
+ ## 出力フォーマット
46
+
47
+ | 状況 | タグ |
48
+ |------|------|
49
+ | 分析完了 | `[PLANNER:DONE]` |
50
+ | 情報不足 | `[PLANNER:BLOCKED]` |
51
+
52
+ ### 出力例
53
+
54
+ **DONE の場合:**
55
+ ```
56
+ [PLANNER:DONE]
57
+ ```
58
+
59
+ **BLOCKED の場合:**
60
+ ```
61
+ [PLANNER:BLOCKED]
62
+
63
+ 確認事項:
64
+ - {質問1}
65
+ - {質問2}
66
+ ```
67
+ instruction_template: |
68
+ ## Workflow Context
69
+ - Iteration: {iteration}/{max_iterations}(ワークフロー全体)
70
+ - Step Iteration: {step_iteration}(このステップの実行回数)
71
+ - Step: plan (タスク分析)
72
+ - Report Directory: .takt/reports/{report_dir}/
73
+ - Report File: .takt/reports/{report_dir}/00-plan.md
74
+
75
+ ## User Request
76
+ {task}
77
+
78
+ ## Previous Response (implementからの差し戻し時)
79
+ {previous_response}
80
+
81
+ ## Instructions
82
+ タスクを分析し、実装方針を立ててください。
83
+
84
+ **注意:** Previous Responseがある場合は差し戻しのため、
85
+ その内容を踏まえて計画を見直してください(replan)。
86
+
87
+ **やること:**
88
+ 1. タスクの要件を理解する
89
+ 2. 影響範囲を特定する
90
+ 3. 実装アプローチを決める
91
+
92
+ **レポート出力:** 上記の `Report File` に出力してください。
93
+ - ファイルが存在しない場合: 新規作成
94
+ - ファイルが存在する場合: `## Iteration {step_iteration}` セクションを追記
95
+
96
+ **レポートフォーマット:**
97
+ ```markdown
98
+ # タスク計画
99
+
100
+ ## 元の要求
101
+ {ユーザーの要求をそのまま記載}
102
+
103
+ ## 分析結果
104
+
105
+ ### 目的
106
+ {達成すべきこと}
107
+
108
+ ### スコープ
109
+ {影響範囲}
110
+
111
+ ### 実装アプローチ
112
+ {どう進めるか}
113
+
114
+ ## 確認事項(あれば)
115
+ - {不明点や確認が必要な点}
116
+ ```
117
+ pass_previous_response: true
118
+ transitions:
119
+ - condition: done
120
+ next_step: implement
121
+ - condition: blocked
122
+ next_step: ABORT
123
+
124
+ - name: implement
125
+ agent: ~/.takt/agents/default/coder.md
126
+ allowed_tools:
127
+ - Read
128
+ - Glob
129
+ - Grep
130
+ - Edit
131
+ - Write
132
+ - Bash
133
+ - WebSearch
134
+ - WebFetch
135
+ status_rules_prompt: |
136
+ # ⚠️ 必須: ステータス出力ルール ⚠️
137
+
138
+ **このタグがないとワークフローが停止します。**
139
+ 最終出力には必ず以下のルールに従ったステータスタグを含めてください。
140
+
141
+ ## 出力フォーマット
142
+
143
+ | 状況 | タグ |
144
+ |------|------|
145
+ | 実装完了 | `[CODER:DONE]` |
146
+ | 判断できない/情報不足 | `[CODER:BLOCKED]` |
147
+
148
+ **重要**: 迷ったら `[BLOCKED]`。勝手に判断しない。
149
+
150
+ ### 出力例
151
+
152
+ **DONE の場合:**
153
+ ```
154
+ 実装完了しました。
155
+ - 作成: `src/auth/service.ts`, `tests/auth.test.ts`
156
+ - 変更: `src/routes.ts`
157
+
158
+ [CODER:DONE]
159
+ ```
160
+
161
+ **BLOCKED の場合:**
162
+ ```
163
+ [CODER:BLOCKED]
164
+
165
+ 理由: DBスキーマが未定義のため実装できません
166
+ 必要な情報: usersテーブルの構造
167
+ ```
168
+ instruction_template: |
169
+ ## Workflow Context
170
+ - Iteration: {iteration}/{max_iterations}(ワークフロー全体)
171
+ - Step Iteration: {step_iteration}(このステップの実行回数)
172
+ - Step: implement
173
+ - Report Directory: .takt/reports/{report_dir}/
174
+ - Report Files:
175
+ - Scope: .takt/reports/{report_dir}/01-coder-scope.md
176
+ - Decisions: .takt/reports/{report_dir}/02-coder-decisions.md
177
+
178
+ ## User Request
179
+ {task}
180
+
181
+ ## Additional User Inputs
182
+ {user_inputs}
183
+
184
+ ## Instructions
185
+ planステップで立てた計画に従って実装してください。
186
+ 計画レポート(00-plan.md)を参照し、実装を進めてください。
187
+
188
+ **レポート出力:** 上記の `Report Files` に出力してください。
189
+ - ファイルが存在しない場合: 新規作成
190
+ - ファイルが存在する場合: `## Iteration {step_iteration}` セクションを追記
191
+
192
+ **Scopeレポートフォーマット(実装開始時に作成):**
193
+ ```markdown
194
+ # 変更スコープ宣言
195
+
196
+ ## タスク
197
+ {タスクの1行要約}
198
+
199
+ ## 変更予定
200
+ | 種別 | ファイル |
201
+ |------|---------|
202
+ | 作成 | `src/example.ts` |
203
+ | 変更 | `src/routes.ts` |
204
+
205
+ ## 推定規模
206
+ Small / Medium / Large
207
+
208
+ ## 影響範囲
209
+ - {影響するモジュールや機能}
210
+ ```
211
+
212
+ **Decisionsレポートフォーマット(実装完了時、決定がある場合のみ):**
213
+ ```markdown
214
+ # 決定ログ
215
+
216
+ ## 1. {決定内容}
217
+ - **背景**: {なぜ決定が必要だったか}
218
+ - **検討した選択肢**: {選択肢リスト}
219
+ - **理由**: {選んだ理由}
220
+ ```
221
+ transitions:
222
+ - condition: done
223
+ next_step: review
224
+ - condition: blocked
225
+ next_step: plan
226
+
227
+ - name: review
228
+ agent: ~/.takt/agents/default/architect.md
229
+ allowed_tools:
230
+ - Read
231
+ - Glob
232
+ - Grep
233
+ - WebSearch
234
+ - WebFetch
235
+ status_rules_prompt: |
236
+ # ⚠️ 必須: ステータス出力ルール ⚠️
237
+
238
+ **このタグがないとワークフローが停止します。**
239
+ 最終出力には必ず以下のルールに従ったステータスタグを含めてください。
240
+
241
+ ## 判定基準
242
+
243
+ | 状況 | 判定 |
244
+ |------|------|
245
+ | 構造に問題がある | REJECT |
246
+ | 設計原則違反がある | REJECT |
247
+ | セキュリティ問題がある | REJECT |
248
+ | テストが不十分 | REJECT |
249
+ | 問題なし | APPROVE |
250
+
251
+ **注意:** simpleワークフローでは IMPROVE は使用しません。
252
+ 軽微な問題もある場合は APPROVE + コメントとしてください。
253
+
254
+ ## 出力フォーマット
255
+
256
+ | 状況 | タグ |
257
+ |------|------|
258
+ | 問題なし | `[ARCHITECT:APPROVE]` |
259
+ | 構造的な修正必要 | `[ARCHITECT:REJECT]` |
260
+
261
+ ### 出力例
262
+
263
+ **APPROVE の場合:**
264
+ ```
265
+ [ARCHITECT:APPROVE]
266
+
267
+ 良い点:
268
+ - モジュール分割が適切
269
+ - 単一責務が守られている
270
+ ```
271
+
272
+ **REJECT の場合:**
273
+ ```
274
+ [ARCHITECT:REJECT]
275
+
276
+ 問題点:
277
+ 1. ファイルサイズ超過
278
+ - 場所: `src/services/user.ts` (523行)
279
+ - 修正案: 3ファイルに分割
280
+ ```
281
+ instruction_template: |
282
+ ## Workflow Context
283
+ - Iteration: {iteration}/{max_iterations}(ワークフロー全体)
284
+ - Step Iteration: {step_iteration}(このステップの実行回数)
285
+ - Step: review (アーキテクチャレビュー)
286
+ - Report Directory: .takt/reports/{report_dir}/
287
+ - Report File: .takt/reports/{report_dir}/03-architect-review.md
288
+
289
+ ## Original User Request (ワークフロー開始時の元の要求)
290
+ {task}
291
+
292
+ ## Git Diff
293
+ ```diff
294
+ {git_diff}
295
+ ```
296
+
297
+ ## Instructions
298
+ **アーキテクチャと設計**のレビューに集中してください。AI特有の問題はレビューしないでください(次のステップで行います)。
299
+
300
+ 変更をレビューしてフィードバックを提供してください。
301
+
302
+ **注意:** simpleワークフローではIMPROVE判定は使用しません。
303
+ 軽微な改善提案がある場合は APPROVE + コメントとしてください。
304
+
305
+ **レポート出力:** 上記の `Report File` に出力してください。
306
+ - ファイルが存在しない場合: 新規作成
307
+ - ファイルが存在する場合: `## Iteration {step_iteration}` セクションを追記
308
+
309
+ **レポートフォーマット:**
310
+ ```markdown
311
+ # アーキテクチャレビュー
312
+
313
+ ## 結果: APPROVE / REJECT
314
+
315
+ ## サマリー
316
+ {1-2文で結果を要約}
317
+
318
+ ## 確認した観点
319
+ - [x] 構造・設計
320
+ - [x] コード品質
321
+ - [x] 変更スコープ
322
+
323
+ ## 問題点(REJECTの場合)
324
+ | # | 場所 | 問題 | 修正案 |
325
+ |---|------|------|--------|
326
+ | 1 | `src/file.ts:42` | 問題の説明 | 修正方法 |
327
+
328
+ ## 改善提案(任意・ブロッキングではない)
329
+ - {将来的な改善提案}
330
+ ```
331
+
332
+ **認知負荷軽減ルール:**
333
+ - APPROVE + 問題なし → サマリーのみ(5行以内)
334
+ - APPROVE + 軽微な提案 → サマリー + 改善提案(15行以内)
335
+ - REJECT → 問題点を表形式で(30行以内)
336
+ transitions:
337
+ - condition: approved
338
+ next_step: ai_review
339
+ - condition: rejected
340
+ next_step: plan
341
+
342
+ - name: ai_review
343
+ agent: ~/.takt/agents/default/ai-reviewer.md
344
+ allowed_tools:
345
+ - Read
346
+ - Glob
347
+ - Grep
348
+ - WebSearch
349
+ - WebFetch
350
+ status_rules_prompt: |
351
+ # ⚠️ 必須: ステータス出力ルール ⚠️
352
+
353
+ **このタグがないとワークフローが停止します。**
354
+ 最終出力には必ず以下のルールに従ったステータスタグを含めてください。
355
+
356
+ ## 判定基準
357
+
358
+ | 状況 | 判定 |
359
+ |------|------|
360
+ | 仮定が間違っている(動作に影響) | REJECT |
361
+ | もっともらしいが間違っているコード | REJECT |
362
+ | コードベースの文脈に重大な不整合 | REJECT |
363
+ | スコープクリープ | APPROVE(警告を付記) |
364
+ | 軽微なスタイルの逸脱のみ | APPROVE |
365
+ | コードが文脈に合い動作する | APPROVE |
366
+
367
+ **注意:** スコープクリープは警告として記載するが、それだけでREJECTしない。
368
+
369
+ ## 出力フォーマット
370
+
371
+ | 状況 | タグ |
372
+ |------|------|
373
+ | AI特有の問題なし | `[AI_REVIEW:APPROVE]` |
374
+ | 問題あり | `[AI_REVIEW:REJECT]` |
375
+
376
+ ### 出力例
377
+
378
+ **APPROVE の場合:**
379
+ ```
380
+ [AI_REVIEW:APPROVE]
381
+
382
+ 検証結果: 問題なし
383
+ ```
384
+
385
+ **REJECT の場合:**
386
+ ```
387
+ [AI_REVIEW:REJECT]
388
+
389
+ 問題点:
390
+ 1. 存在しないAPIを使用: `fetch.json()` → `response.json()`
391
+ ```
392
+ instruction_template: |
393
+ ## Workflow Context
394
+ - Iteration: {iteration}/{max_iterations}(ワークフロー全体)
395
+ - Step Iteration: {step_iteration}(このステップの実行回数)
396
+ - Step: ai_review (AI生成コードレビュー)
397
+ - Report Directory: .takt/reports/{report_dir}/
398
+ - Report File: .takt/reports/{report_dir}/04-ai-review.md
399
+
400
+ ## Original User Request (ワークフロー開始時の元の要求)
401
+ {task}
402
+
403
+ ## Git Diff
404
+ ```diff
405
+ {git_diff}
406
+ ```
407
+
408
+ ## Instructions
409
+ AI特有の問題についてコードをレビューしてください:
410
+ - 仮定の検証
411
+ - もっともらしいが間違っているパターン
412
+ - 既存コードベースとの適合性
413
+ - スコープクリープの検出
414
+
415
+ **レポート出力:** 上記の `Report File` に出力してください。
416
+ - ファイルが存在しない場合: 新規作成
417
+ - ファイルが存在する場合: `## Iteration {step_iteration}` セクションを追記
418
+
419
+ **レポートフォーマット:**
420
+ ```markdown
421
+ # AI生成コードレビュー
422
+
423
+ ## 結果: APPROVE / REJECT
424
+
425
+ ## サマリー
426
+ {1文で結果を要約}
427
+
428
+ ## 検証した項目
429
+ | 観点 | 結果 | 備考 |
430
+ |------|------|------|
431
+ | 仮定の妥当性 | ✅ | - |
432
+ | API/ライブラリの実在 | ✅ | - |
433
+ | コンテキスト適合 | ✅ | - |
434
+ | スコープ | ✅ | - |
435
+
436
+ ## 問題点(REJECTの場合)
437
+ | # | カテゴリ | 場所 | 問題 |
438
+ |---|---------|------|------|
439
+ | 1 | 幻覚API | `src/file.ts:23` | 存在しないメソッド |
440
+ ```
441
+
442
+ **認知負荷軽減ルール:**
443
+ - 問題なし → サマリー1文 + チェック表のみ(10行以内)
444
+ - 問題あり → + 問題を表形式で(25行以内)
445
+ transitions:
446
+ - condition: approved
447
+ next_step: supervise
448
+ - condition: rejected
449
+ next_step: plan
450
+
451
+ - name: supervise
452
+ agent: ~/.takt/agents/default/supervisor.md
453
+ allowed_tools:
454
+ - Read
455
+ - Glob
456
+ - Grep
457
+ - Bash
458
+ - WebSearch
459
+ - WebFetch
460
+ status_rules_prompt: |
461
+ # ⚠️ 必須: ステータス出力ルール ⚠️
462
+
463
+ **このタグがないとワークフローが停止します。**
464
+ 最終出力には必ず以下のルールに従ったステータスタグを含めてください。
465
+
466
+ ## 判定基準
467
+
468
+ | 状況 | 判定 |
469
+ |------|------|
470
+ | 要求が満たされていない | REJECT |
471
+ | テストが失敗する | REJECT |
472
+ | ビルドが通らない | REJECT |
473
+ | その場しのぎが残っている | REJECT |
474
+ | すべて問題なし | APPROVE |
475
+
476
+ **原則**: 疑わしきは REJECT。曖昧な承認はしない。
477
+
478
+ ## 出力フォーマット
479
+
480
+ | 状況 | タグ |
481
+ |------|------|
482
+ | 最終承認 | `[SUPERVISOR:APPROVE]` |
483
+ | 差し戻し | `[SUPERVISOR:REJECT]` |
484
+
485
+ ### 出力例
486
+
487
+ **APPROVE の場合:**
488
+ ```
489
+ [SUPERVISOR:APPROVE]
490
+
491
+ 検証結果:
492
+ - テスト: ✅ 全件パス
493
+ - ビルド: ✅ 成功
494
+ - 要求充足: ✅
495
+ ```
496
+
497
+ **REJECT の場合:**
498
+ ```
499
+ [SUPERVISOR:REJECT]
500
+
501
+ 問題点:
502
+ 1. テストが失敗: `npm test` で 2 件失敗
503
+ 2. 元の要求を満たしていない: ログイン機能が未実装
504
+ ```
505
+ instruction_template: |
506
+ ## Workflow Context
507
+ - Iteration: {iteration}/{max_iterations}(ワークフロー全体)
508
+ - Step Iteration: {step_iteration}(このステップの実行回数)
509
+ - Step: supervise (final verification)
510
+ - Report Directory: .takt/reports/{report_dir}/
511
+ - Report Files:
512
+ - Validation: .takt/reports/{report_dir}/05-supervisor-validation.md
513
+ - Summary: .takt/reports/{report_dir}/summary.md
514
+
515
+ ## Original User Request
516
+ {task}
517
+
518
+ ## Git Diff
519
+ ```diff
520
+ {git_diff}
521
+ ```
522
+
523
+ ## Instructions
524
+ テスト実行、ビルド確認、最終承認を行ってください。
525
+
526
+ **ワークフロー全体の確認:**
527
+ 1. 計画(00-plan.md)と実装結果が一致しているか
528
+ 2. 各レビューステップの指摘が対応されているか
529
+ 3. 元のタスク目的が達成されているか
530
+
531
+ **レポートの確認:** Report Directory内の全レポートを読み、
532
+ 未対応の改善提案がないか確認してください。
533
+
534
+ **レポート出力:** 上記の `Report Files` に出力してください。
535
+ - ファイルが存在しない場合: 新規作成
536
+ - ファイルが存在する場合: `## Iteration {step_iteration}` セクションを追記
537
+
538
+ **Validationレポートフォーマット:**
539
+ ```markdown
540
+ # 最終検証結果
541
+
542
+ ## 結果: APPROVE / REJECT
543
+
544
+ ## 検証サマリー
545
+ | 項目 | 状態 | 確認方法 |
546
+ |------|------|---------|
547
+ | 要求充足 | ✅ | 要求リストと照合 |
548
+ | テスト | ✅ | `npm test` (N passed) |
549
+ | ビルド | ✅ | `npm run build` 成功 |
550
+ | 動作確認 | ✅ | 主要フロー確認 |
551
+
552
+ ## 成果物
553
+ - 作成: {作成したファイル}
554
+ - 変更: {変更したファイル}
555
+
556
+ ## 未完了項目(REJECTの場合)
557
+ | # | 項目 | 理由 |
558
+ |---|------|------|
559
+ | 1 | {項目} | {理由} |
560
+ ```
561
+
562
+ **Summaryレポートフォーマット(APPROVEの場合のみ):**
563
+ ```markdown
564
+ # タスク完了サマリー
565
+
566
+ ## タスク
567
+ {元の要求を1-2文で}
568
+
569
+ ## 結果
570
+ ✅ 完了
571
+
572
+ ## 変更内容
573
+ | 種別 | ファイル | 概要 |
574
+ |------|---------|------|
575
+ | 作成 | `src/file.ts` | 概要説明 |
576
+
577
+ ## レビュー結果
578
+ | レビュー | 結果 |
579
+ |---------|------|
580
+ | Architect | ✅ APPROVE |
581
+ | AI Review | ✅ APPROVE |
582
+ | Supervisor | ✅ APPROVE |
583
+
584
+ ## 確認コマンド
585
+ ```bash
586
+ npm test
587
+ npm run build
588
+ ```
589
+ ```
590
+ transitions:
591
+ - condition: approved
592
+ next_step: COMPLETE
593
+ - condition: rejected
594
+ next_step: plan