@k2works/claude-code-booster 4.4.1 → 4.4.2

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 (96) hide show
  1. package/bin/claude-code-booster +2 -2
  2. package/lib/assets/.claude/agents/xp-architect.md +250 -250
  3. package/lib/assets/.claude/agents/xp-executive.md +207 -207
  4. package/lib/assets/.claude/agents/xp-interaction-designer.md +239 -239
  5. package/lib/assets/.claude/agents/xp-product-manager.md +245 -245
  6. package/lib/assets/.claude/agents/xp-programmer.md +268 -268
  7. package/lib/assets/.claude/agents/xp-project-manager.md +229 -229
  8. package/lib/assets/.claude/agents/xp-technical-writer.md +224 -224
  9. package/lib/assets/.claude/agents/xp-tester.md +265 -265
  10. package/lib/assets/.claude/agents/xp-user-representative.md +204 -204
  11. package/lib/assets/.claude/skills/analyzing-business-case/SKILL.md +148 -148
  12. package/lib/assets/.claude/skills/analyzing-business-strategy/SKILL.md +277 -277
  13. package/lib/assets/.claude/skills/analyzing-review/SKILL.md +174 -174
  14. package/lib/assets/.claude/skills/creating-iteration-report/SKILL.md +210 -210
  15. package/lib/assets/.claude/skills/creating-release-report/SKILL.md +161 -161
  16. package/lib/assets/.claude/skills/developing-review/SKILL.md +175 -175
  17. package/lib/assets/.claude/skills/developing-uiux-review/SKILL.md +207 -207
  18. package/lib/assets/.claude/skills/generating-bmc/SKILL.md +123 -123
  19. package/lib/assets/.claude/skills/operating-qt/SKILL.md +147 -147
  20. package/lib/assets/.claude/skills/operating-review/SKILL.md +171 -171
  21. package/lib/assets/.claude/skills/operating-script/SKILL.md +145 -145
  22. package/lib/assets/.claude/skills/orchestrating-development/SKILL.md +168 -168
  23. package/lib/assets/.claude/skills/practicing-getting-start-tdd/SKILL.md +266 -266
  24. package/lib/assets/.claude/skills/validating-iteration-plan/SKILL.md +54 -54
  25. package/lib/assets/.devcontainer/devcontainer.json +1 -1
  26. package/lib/assets/.gitattributes +0 -2
  27. package/lib/assets/CLAUDE.md +193 -193
  28. package/lib/assets/Dockerfile +1 -6
  29. package/lib/assets/README.md +0 -16
  30. package/lib/assets/docs/article/functional-desgin-ppp/clojure/01-immutability-and-data-transformation.md +1 -1
  31. package/lib/assets/docs/article/functional-desgin-ppp/clojure/15-gossiping-bus-drivers.md +1 -1
  32. package/lib/assets/docs/article/functional-desgin-ppp/clojure/20-pattern-interactions.md +1 -1
  33. package/lib/assets/docs/article/functional-desgin-ppp/clojure/21-best-practices.md +6 -6
  34. package/lib/assets/docs/article/functional-desgin-ppp/clojure/22-oo-to-fp-migration.md +3 -3
  35. package/lib/assets/docs/article/functional-desgin-ppp/clojure/index.md +22 -22
  36. package/lib/assets/docs/article/functional-desgin-ppp/elixir/01-immutability-and-data-transformation.md +1 -1
  37. package/lib/assets/docs/article/functional-desgin-ppp/elixir/index.md +22 -22
  38. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/01-immutability-and-data-transformation.md +1 -1
  39. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/15-gossiping-bus-drivers.md +1 -1
  40. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/17-video-rental-system.md +1 -1
  41. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/19-wator-simulation.md +1 -1
  42. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/21-best-practices.md +2 -2
  43. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/22-oo-to-fp-migration.md +5 -5
  44. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/index.md +22 -22
  45. package/lib/assets/docs/article/functional-desgin-ppp/haskell/15-gossiping-bus-drivers.md +1 -1
  46. package/lib/assets/docs/article/functional-desgin-ppp/haskell/20-pattern-interactions.md +1 -1
  47. package/lib/assets/docs/article/functional-desgin-ppp/rust/01-immutability-and-data-transformation.md +1 -1
  48. package/lib/assets/docs/article/functional-desgin-ppp/rust/index.md +22 -22
  49. package/lib/assets/docs/article/functional-desgin-ppp/scala/01-immutability-and-data-transformation.md +1 -1
  50. package/lib/assets/docs/article/functional-desgin-ppp/scala/15-gossiping-bus-drivers.md +1 -1
  51. package/lib/assets/docs/article/functional-desgin-ppp/scala/21-best-practices.md +3 -3
  52. package/lib/assets/docs/article/functional-desgin-ppp/scala/22-oo-to-fp-migration.md +3 -3
  53. package/lib/assets/docs/article/functional-desgin-ppp/scala/index.md +22 -22
  54. package/lib/assets/docs/article/getting-start-tdd/integration/04-type-system-comparison.md +2 -2
  55. package/lib/assets/docs/article/getting-start-tdd/integration/06-learning-roadmap.md +8 -8
  56. package/lib/assets/docs/article/getting-start-tdd/ruby/11-immutable-data-and-pipeline.md +2 -2
  57. package/lib/assets/docs/article/grokkingfp/all/part-2-ch03-immutable-data.md +3 -3
  58. package/lib/assets/docs/article/grokkingfp/all/part-3-ch06-option.md +4 -4
  59. package/lib/assets/docs/article/grokkingfp/all/writing-plan.md +8 -8
  60. package/lib/assets/docs/article/grokkingfp/elixir/part-1.md +1 -1
  61. package/lib/assets/docs/article/grokkingfp/elixir/part-5.md +1 -1
  62. package/lib/assets/docs/article/grokkingfp/elixir/part-6.md +1 -1
  63. package/lib/assets/docs/article/grokkingfp/fsharp/part-6.md +1 -1
  64. package/lib/assets/docs/article/grokkingfp/haskell/part-4.md +1 -1
  65. package/lib/assets/docs/article/grokkingfp/haskell/part-6.md +1 -1
  66. package/lib/assets/docs/article/grokkingfp/java/part-1.md +1 -1
  67. package/lib/assets/docs/article/grokkingfp/java/part-2.md +4 -4
  68. package/lib/assets/docs/article/grokkingfp/java/part-6.md +2 -2
  69. package/lib/assets/docs/article/grokkingfp/python/part-1.md +3 -3
  70. package/lib/assets/docs/article/grokkingfp/ruby/part-1.md +1 -1
  71. package/lib/assets/docs/article/grokkingfp/ruby/part-6.md +1 -1
  72. package/lib/assets/docs/article/grokkingfp/rust/part-4.md +1 -1
  73. package/lib/assets/docs/article/grokkingfp/scala/part-1.md +1 -1
  74. package/lib/assets/docs/article/grokkingfp/scala/part-3.md +1 -1
  75. package/lib/assets/docs/article/grokkingfp/scala/part-6.md +1 -1
  76. package/lib/assets/docs/article/grokkingfp/typescript/part-1.md +1 -1
  77. package/lib/assets/docs/article/grokkingfp/typescript/part-4.md +1 -1
  78. package/lib/assets/docs/article/grokkingfp/typescript/part-6.md +1 -1
  79. package/lib/assets/docs/article/index.md +39 -39
  80. package/lib/assets/docs/design/index.md +44 -44
  81. package/lib/assets/docs/index.md +33 -33
  82. package/lib/assets/docs/operation/index.md +16 -16
  83. package/lib/assets/docs/reference/CodexCLIMCP/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/351/226/213/347/231/272/343/203/225/343/203/255/343/203/274.md +546 -546
  84. package/lib/assets/docs/reference/SonarQube/343/203/255/343/203/274/343/202/253/343/203/253/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +1 -1
  85. package/lib/assets/docs/reference/UI/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +1 -1
  86. package/lib/assets/docs/reference/images/BMC.drawio.svg +3 -3
  87. package/lib/assets/docs/reference//347/265/214/345/226/266/346/210/246/347/225/245/345/210/206/346/236/220/343/202/254/343/202/244/343/203/211.md +566 -566
  88. package/lib/assets/docs/requirements/index.md +17 -17
  89. package/lib/assets/docs/strategy/index.md +17 -17
  90. package/lib/assets/docs/template//343/202/244/343/203/206/343/203/254/343/203/274/343/202/267/343/203/247/343/203/263/350/250/210/347/224/273.md +327 -327
  91. package/lib/assets/docs/template//343/203/252/343/203/252/343/203/274/343/202/271/345/256/214/344/272/206/345/240/261/345/221/212/346/233/270.md +275 -275
  92. package/lib/assets/docs/template//344/272/213/344/276/213/345/210/206/346/236/220.md +513 -513
  93. package/lib/assets/ops/docker/sonarqube-local/docker-compose.yml +57 -57
  94. package/lib/assets/ops/nix/shells/.tmux.conf +2 -2
  95. package/package.json +1 -1
  96. package/lib/assets/.envrc +0 -1
@@ -1,546 +1,546 @@
1
- # アプリケーション開発フロー
2
-
3
- ## 概要
4
-
5
- 本ドキュメントは、Claude(AI アシスタント)と Codex(実装エージェント)を活用した開発フローを定義します。計画・設計は Claude が担当し、実装は Codex に委譲することで、効率的かつ品質の高い開発を実現します。
6
-
7
- ---
8
-
9
- ## 開発フローの全体像
10
-
11
- ```plantuml
12
- @startuml
13
- title 開発フロー
14
-
15
- skinparam rectangle {
16
- BackgroundColor<<claude>> LightBlue
17
- BackgroundColor<<codex>> LightGreen
18
- }
19
-
20
- rectangle "1. 計画\n\n・要件分析\n・タスク分解\n・優先度決定" <<claude>> as plan
21
- rectangle "2. 設計\n\n・API設計\n・UI設計\n・データ設計" <<claude>> as design
22
- rectangle "3. 実装指示\n\n・コード実装\n・テスト作成\n・リファクタ" <<codex>> as impl
23
- rectangle "4. 受入\n\n・設計レビュー\n・E2Eテスト\n・品質確認" <<claude>> as accept
24
-
25
- plan --> design
26
- design --> impl
27
- impl --> accept
28
-
29
- note bottom of plan : Claude
30
- note bottom of design : Claude
31
- note bottom of impl : Codex
32
- note bottom of accept : Claude
33
-
34
- @enduml
35
- ```
36
-
37
- ```plantuml
38
- @startuml
39
- title 開発フロー シーケンス図
40
-
41
- actor ユーザー as user
42
- participant Claude as claude
43
- participant "Codex MCP" as codex
44
- database コードベース as code
45
-
46
- user -> claude : /dev US-103 開始
47
- activate claude
48
-
49
- == 計画フェーズ ==
50
- claude -> code : イテレーション計画読み込み
51
- claude -> code : 既存コード調査
52
- claude -> claude : タスク分解・優先度決定
53
-
54
- == 設計フェーズ ==
55
- claude -> code : 既存パターン確認
56
- claude -> claude : API/UI/データ設計
57
- claude -> claude : Codex指示作成
58
-
59
- == 実装フェーズ ==
60
- claude -> codex : 実装指示(MCP)
61
- activate codex
62
- codex -> code : コード実装
63
- codex -> code : ユニットテスト作成
64
- codex -> codex : Lint/テスト実行
65
- codex --> claude : 実装完了
66
- deactivate codex
67
-
68
- == 受入フェーズ ==
69
- claude -> code : 設計レビュー
70
- claude -> code : E2Eテスト作成
71
- claude -> code : E2Eテスト実行
72
- claude -> code : バグ修正(必要に応じて)
73
- claude --> user : 完了報告
74
-
75
- deactivate claude
76
-
77
- @enduml
78
- ```
79
-
80
- ### 役割分担
81
-
82
- | フェーズ | 担当 | 責務 |
83
- |---------|------|------|
84
- | 計画 | Claude | 要件分析、タスク分解、優先度決定 |
85
- | 設計 | Claude | API 設計、UI 設計、データモデル設計 |
86
- | 実装指示 | Codex | コード実装、ユニットテスト作成 |
87
- | 受入 | Claude | 設計レビュー、E2E テスト作成・実行、品質確認 |
88
-
89
- ---
90
-
91
- ## フェーズ 1: 計画
92
-
93
- ### 目的
94
-
95
- イテレーション計画とユーザーストーリーに基づき、実装すべきタスクを明確化する。
96
-
97
- ### 入力
98
-
99
- - イテレーション計画(`docs/development/iteration_plan-*.md`)
100
- - ユーザーストーリーと受入条件
101
-
102
- ### 活動
103
-
104
- 1. **要件分析**: ユーザーストーリーの受入条件を確認
105
- 2. **既存コード調査**: 関連する既存実装を確認
106
- 3. **タスク分解**: 実装タスクを細分化
107
- 4. **優先度決定**: 依存関係を考慮してタスク順序を決定
108
-
109
- ### 出力
110
-
111
- - タスクリスト(TODO)
112
- - 実装方針
113
-
114
- ### 例: US-103 お知らせ管理
115
-
116
- ```markdown
117
- ## タスクリスト
118
-
119
- 1. AuthContext に role と canManageAnnouncements を追加
120
- 2. API クライアントに CRUD 関数を追加(create/update/delete)
121
- 3. ConfirmDialog 汎用コンポーネント作成
122
- 4. AnnouncementForm コンポーネント作成
123
- 5. AnnouncementFormPage 作成(新規作成・編集兼用)
124
- 6. App.tsx にルーティング追加
125
- 7. AnnouncementsPage に新規作成ボタン追加
126
- 8. AnnouncementDetailPage に編集・削除ボタン追加
127
- 9. ユニットテスト作成
128
- ```
129
-
130
- ---
131
-
132
- ## フェーズ 2: 設計
133
-
134
- ### 目的
135
-
136
- 実装前に詳細な設計を行い、Codex への指示内容を明確化する。
137
-
138
- ### 入力
139
-
140
- - タスクリスト
141
- - 既存のアーキテクチャ・パターン
142
-
143
- ### 活動
144
-
145
- 1. **API 設計**: エンドポイント、リクエスト/レスポンス形式
146
- 2. **データモデル設計**: 型定義、バリデーションルール
147
- 3. **UI 設計**: コンポーネント構造、状態管理
148
- 4. **既存パターン確認**: プロジェクトの既存実装に合わせる
149
-
150
- ### 出力
151
-
152
- - 詳細設計仕様
153
- - Codex への実装指示
154
-
155
- ### 例: AnnouncementForm 設計
156
-
157
- ```typescript
158
- // 設計仕様
159
- type FormValues = {
160
- title: string // 必須、最大200文字
161
- content: string // 必須
162
- category: AnnouncementCategory // GENERAL | IMPORTANT | EVENT | HR
163
- publishedAt: string // datetime-local 形式
164
- }
165
-
166
- // バリデーション
167
- - title: z.string().min(1).max(200)
168
- - content: z.string().min(1)
169
- - category: z.enum(['GENERAL', 'IMPORTANT', 'EVENT', 'HR'])
170
- - publishedAt: z.string().min(1)
171
-
172
- // コンポーネント構造
173
- - AnnouncementForm
174
- - Input (タイトル)
175
- - TextArea (本文)
176
- - Select (カテゴリ)
177
- - DateTimeInput (公開日時)
178
- - Button (キャンセル/保存)
179
- ```
180
-
181
- ---
182
-
183
- ## フェーズ 3: 実装指示(Codex)
184
-
185
- ### 目的
186
-
187
- Codex MCP サーバーを通じて、設計に基づいた実装を委譲する。
188
-
189
- ### Codex MCP 呼び出し方法
190
-
191
- ```
192
- mcp__codex__codex ツールを使用
193
-
194
- パラメータ:
195
- - prompt: 実装指示(詳細な要件を含む)
196
- - sandbox: danger-full-access(workspace-write ではread-onlyエラーになることがある)
197
- - approval-policy: never(自動承認)
198
- - cwd: プロジェクトルート
199
- ```
200
-
201
- ### 指示サイズに関する注意
202
-
203
- > **重要**: ユーザーストーリー単位など大きな単位で Codex に指示を出すと、処理が長時間化しレスポンスがなくなることがあります。
204
-
205
- #### 推奨される指示の粒度
206
-
207
- | 粒度 | 推奨度 | 説明 |
208
- |------|--------|------|
209
- | タスク単位(1-3 ファイル) | ✅ 推奨 | 1 つのコンポーネントや機能単位 |
210
- | 機能単位(3-5 ファイル) | ⚠️ 注意 | 進捗確認を頻繁に行う |
211
- | ユーザーストーリー単位 | ❌ 非推奨 | タスクに分割して実行 |
212
-
213
- #### 大きなタスクの分割例
214
-
215
- ```
216
- ❌ 悪い例: ユーザーストーリー全体を一度に指示
217
- 「US-103 お知らせ管理機能を全て実装してください」
218
-
219
- ✅ 良い例: タスク単位で分割して指示
220
- 1. 「AuthContext に role と canManageAnnouncements を追加」
221
- 2. 「API クライアントに create/update/delete 関数を追加」
222
- 3. 「ConfirmDialog コンポーネントを作成」
223
- 4. 「AnnouncementForm コンポーネントを作成」
224
- 5. ...
225
- ```
226
-
227
- #### レスポンスがない場合の対処
228
-
229
- 1. `codex-reply` で進捗を確認
230
- 2. 長時間応答がない場合はタスクを中断
231
- 3. より小さな単位に分割して再実行
232
-
233
- #### Codex が既存コードを意図せず書き換える問題(重要)
234
-
235
- Codex は指示対象外のコードを勝手に書き換えることがある。IT1 で実際に発生した事例:
236
-
237
- - `localStorage` → `sessionStorage` への無断変更(authStore との整合性が崩れた)
238
- - headers マージ方式のスプレッド構文を `Object.assign` に書き換え
239
-
240
- **対策**:
241
-
242
- 1. **受入レビューで `git diff` を必ず確認** — 指示対象ファイル以外の変更がないか検証する
243
- 2. **既存テストを先に実行** — Codex の変更後に既存テストが壊れていないか即座に確認する
244
- 3. **指示にはコード全文を含める** — 曖昧な自然言語指示より、作成すべきファイルの完全なコードを渡す方が意図しない変更を防げる
245
- 4. **「既存コードは変更しないでください」を明記** — 既存ファイルへの追記指示時は必ず記載する
246
-
247
- #### Codex が書き込みできない場合の対処(重要)
248
-
249
- Codex が read-only 制限やファイルロック等で書き込みできなかった場合:
250
-
251
- 1. **Claude が勝手に直接編集を進めてはいけない**
252
- 2. ユーザーに状況を報告し、確認を待つ
253
- 3. ユーザーの許可を得てから代替手段(Claude による直接編集等)を実行
254
-
255
- ```
256
- ❌ 悪い例:
257
- Claude: 「Codex が read-only 制限で書き込みできませんでした。直接編集を行います。」
258
- → 勝手に進めている
259
-
260
- ✅ 良い例:
261
- Claude: 「Codex が read-only 制限で書き込みできませんでした。
262
- 以下の選択肢があります:
263
- 1. Claude が直接編集を行う
264
- 2. 環境の問題を解決してから Codex で再実行
265
- どちらで進めますか?」
266
- → ユーザーの確認を待っている
267
- ```
268
-
269
- ### 実装指示のベストプラクティス
270
-
271
- 1. **1 ファイル 1 指示**: 確実に完了する最小単位で指示する(複数ファイルの同時指示はタイムアウトリスクあり)
272
- 2. **コード全文を渡す**: 自然言語の説明より、作成すべきファイルの完全なコードを指示に含める方が確実
273
- 3. **既存パターン参照**: 既存ファイルを参照先として指定
274
- 4. **「既存コードは変更しない」を明記**: 追記指示時に Codex が他の箇所を書き換えるのを防ぐ
275
- 5. **受入で `git diff` 確認**: Codex の変更後は必ず差分を検証し、意図しない変更を検出する
276
-
277
- ### 例: Codex への実装指示
278
-
279
- ```
280
- prompt: |
281
- お知らせ管理機能を実装してください。
282
-
283
- ## タスク
284
- 1. AuthContext に role プロパティと canManageAnnouncements を追加
285
- 2. API クライアント(src/lib/api.ts)に以下を追加:
286
- - createAnnouncement(input: AnnouncementCreateInput)
287
- - updateAnnouncement(id, input)
288
- - deleteAnnouncement(id)
289
- 3. ConfirmDialog コンポーネントを作成(既存の Button を参考に)
290
- 4. AnnouncementForm コンポーネントを作成(React Hook Form + Zod)
291
- 5. AnnouncementFormPage を作成(/announcements/new と /announcements/:id/edit)
292
- 6. App.tsx にルーティングを追加
293
-
294
- ## 既存パターン参照
295
- - API クライアント: src/lib/api.ts
296
- - フォームコンポーネント: src/components/ui/Input.tsx
297
- - ページコンポーネント: src/pages/AnnouncementsPage.tsx
298
-
299
- ## 完了条件
300
- - ESLint エラーなし
301
- - 既存テストがパス
302
-
303
- sandbox: workspace-write
304
- approval-policy: never
305
- ```
306
-
307
- ### Codex 実行中の確認
308
-
309
- - Codex の進捗は `codex-reply` ツールで確認
310
- - 問題発生時は追加指示で修正を依頼
311
-
312
- ---
313
-
314
- ## フェーズ 4: 受入
315
-
316
- ### 目的
317
-
318
- 実装された機能が設計通りに動作することを確認する。
319
-
320
- ### 活動
321
-
322
- 1. **設計レビュー**: 実装が設計仕様に準拠しているか確認
323
- 2. **コード品質確認**: ESLint、テストカバレッジの確認
324
- 3. **E2E テスト作成**: 成功基準に基づくテストを作成
325
- 4. **E2E テスト実行**: 機能が正しく動作することを検証
326
- 5. **バグ修正**: 問題があれば修正
327
-
328
- ### E2E テスト作成のポイント
329
-
330
- ```typescript
331
- // 成功基準に対応するテストケース
332
- test.describe('お知らせ管理機能(管理者)', () => {
333
- test('管理者がお知らせを新規作成できる', async ({ page }) => {
334
- // 1. 新規作成ボタンをクリック
335
- // 2. フォームに入力
336
- // 3. 保存
337
- // 4. 詳細ページで確認
338
- })
339
-
340
- test('管理者がお知らせを編集できる', async ({ page }) => {
341
- // ...
342
- })
343
-
344
- test('管理者がお知らせを削除できる(確認ダイアログあり)', async ({ page }) => {
345
- // ...
346
- })
347
- })
348
- ```
349
-
350
- ### 受入基準
351
-
352
- - [ ] すべての受入条件が満たされている
353
- - [ ] E2E テストがすべてパス
354
- - [ ] ESLint エラーがない
355
- - [ ] 既存テストが壊れていない
356
-
357
- ---
358
-
359
- ## 実践例: US-103 お知らせ管理
360
-
361
- ```plantuml
362
- @startuml
363
- title US-103 お知らせ管理 開発フロー
364
-
365
- |Claude|
366
- start
367
- :イテレーション計画読み込み;
368
- :受入条件確認;
369
- :既存コード調査;
370
- :タスクリスト作成;
371
-
372
- |Claude|
373
- :API設計確認;
374
- :フロントエンド設計;
375
- :Codex指示作成;
376
-
377
- |Codex|
378
- :AuthContext拡張;
379
- :APIクライアント追加;
380
- :ConfirmDialog作成;
381
- :AnnouncementForm作成;
382
- :AnnouncementFormPage作成;
383
- :ルーティング追加;
384
- :既存ページ修正;
385
- :ユニットテスト実行;
386
-
387
- |Claude|
388
- :設計レビュー;
389
- :E2Eテスト作成;
390
- :E2Eテスト実行;
391
-
392
- if (テスト失敗?) then (yes)
393
- :バグ修正;
394
- :再テスト;
395
- else (no)
396
- endif
397
-
398
- :完了報告;
399
- stop
400
-
401
- @enduml
402
- ```
403
-
404
- ### 1. 計画フェーズ
405
-
406
- ```
407
- ユーザー: /dev iteration3 US-103: お知らせ管理 開始
408
- 計画・設計は claude 実装は codex が担当する
409
-
410
- Claude:
411
- 1. イテレーション計画を読み込み
412
- 2. 受入条件を確認
413
- 3. 既存コードを調査(API、フロントエンド構造)
414
- 4. タスクリストを作成
415
- ```
416
-
417
- ### 2. 設計フェーズ
418
-
419
- ```
420
- Claude:
421
- 1. API エンドポイント設計を確認(既に実装済み)
422
- 2. フロントエンドコンポーネント設計
423
- - AuthContext の拡張
424
- - AnnouncementForm コンポーネント
425
- - AnnouncementFormPage
426
- - 既存ページの修正
427
- 3. Codex への詳細指示を作成
428
- ```
429
-
430
- ### 3. 実装フェーズ
431
-
432
- ```
433
- Claude → Codex MCP:
434
- prompt: "お知らせ管理機能を実装..."
435
- sandbox: workspace-write
436
- approval-policy: never
437
-
438
- Codex:
439
- 1. AuthContext に role, canManageAnnouncements 追加
440
- 2. API クライアントに CRUD 関数追加
441
- 3. ConfirmDialog コンポーネント作成
442
- 4. AnnouncementForm コンポーネント作成
443
- 5. AnnouncementFormPage 作成
444
- 6. App.tsx ルーティング追加
445
- 7. AnnouncementsPage, AnnouncementDetailPage 修正
446
- 8. テスト作成・実行
447
- ```
448
-
449
- ### 4. 受入フェーズ
450
-
451
- ```
452
- Claude:
453
- 1. 設計レビュー
454
- - 実装が設計に準拠しているか確認
455
- - コード品質確認
456
-
457
- 2. E2E テスト作成
458
- - announcements.spec.ts に管理機能テストを追加
459
-
460
- 3. E2E テスト実行
461
- - npm run test:e2e -- --grep "お知らせ"
462
-
463
- 4. バグ修正
464
- - publishedAt の ISO 8601 形式変換を追加
465
- - テストの待機処理を追加
466
-
467
- 5. 最終確認
468
- - 15 tests passed
469
- ```
470
-
471
- ---
472
-
473
- ## コマンドリファレンス
474
-
475
- ### 開発開始
476
-
477
- ```bash
478
- # イテレーションのユーザーストーリー開始
479
- /dev iteration3 US-103: お知らせ管理 開始
480
- ```
481
-
482
- ### Codex MCP 呼び出し
483
-
484
- ```
485
- mcp__codex__codex
486
- prompt: "実装指示..."
487
- sandbox: workspace-write
488
- approval-policy: never
489
- cwd: /path/to/project
490
- ```
491
-
492
- ### テスト実行
493
-
494
- ```bash
495
- # ユニットテスト
496
- npm run test
497
-
498
- # E2E テスト(全体)
499
- npm run test:e2e
500
-
501
- # E2E テスト(特定機能)
502
- npm run test:e2e -- --grep "お知らせ"
503
- ```
504
-
505
- ### 品質チェック
506
-
507
- ```bash
508
- # Lint + Format + Test
509
- npm run check
510
- ```
511
-
512
- ---
513
-
514
- ## ベストプラクティス
515
-
516
- ### 計画・設計
517
-
518
- 1. **既存パターンを尊重**: プロジェクトの既存実装に合わせる
519
- 2. **受入条件を明確に**: テスト可能な条件を定義する
520
- 3. **依存関係を考慮**: タスクの実行順序を適切に設定
521
-
522
- ### 実装指示
523
-
524
- 1. **具体的な指示**: 曖昧さを排除した詳細な要件
525
- 2. **参照ファイルの明示**: 既存のパターンを参照先として指定
526
- 3. **完了条件の明示**: 何をもって完了とするか明確に
527
-
528
- ### 受入
529
-
530
- 1. **設計レビュー先行**: テスト前にコードを確認
531
- 2. **E2E テストで検証**: 成功基準に対応するテストを作成
532
- 3. **継続的なフィードバック**: 問題があれば即座に修正
533
-
534
- ---
535
-
536
- ## 関連ドキュメント
537
-
538
- - [開発環境セットアップ](dev_app_instruction.md)
539
- - [Codex CLI MCP サーバー設定](codex_instruction.md)
540
- - [イテレーション計画](../development/iteration_plan-3.md)
541
- - [コーディングとテストガイド](../reference/コーディングとテストガイド.md)
542
-
543
- ---
544
-
545
- **作成日**: 2026-01-19
546
- **更新日**: 2026-01-19
1
+ # アプリケーション開発フロー
2
+
3
+ ## 概要
4
+
5
+ 本ドキュメントは、Claude(AI アシスタント)と Codex(実装エージェント)を活用した開発フローを定義します。計画・設計は Claude が担当し、実装は Codex に委譲することで、効率的かつ品質の高い開発を実現します。
6
+
7
+ ---
8
+
9
+ ## 開発フローの全体像
10
+
11
+ ```plantuml
12
+ @startuml
13
+ title 開発フロー
14
+
15
+ skinparam rectangle {
16
+ BackgroundColor<<claude>> LightBlue
17
+ BackgroundColor<<codex>> LightGreen
18
+ }
19
+
20
+ rectangle "1. 計画\n\n・要件分析\n・タスク分解\n・優先度決定" <<claude>> as plan
21
+ rectangle "2. 設計\n\n・API設計\n・UI設計\n・データ設計" <<claude>> as design
22
+ rectangle "3. 実装指示\n\n・コード実装\n・テスト作成\n・リファクタ" <<codex>> as impl
23
+ rectangle "4. 受入\n\n・設計レビュー\n・E2Eテスト\n・品質確認" <<claude>> as accept
24
+
25
+ plan --> design
26
+ design --> impl
27
+ impl --> accept
28
+
29
+ note bottom of plan : Claude
30
+ note bottom of design : Claude
31
+ note bottom of impl : Codex
32
+ note bottom of accept : Claude
33
+
34
+ @enduml
35
+ ```
36
+
37
+ ```plantuml
38
+ @startuml
39
+ title 開発フロー シーケンス図
40
+
41
+ actor ユーザー as user
42
+ participant Claude as claude
43
+ participant "Codex MCP" as codex
44
+ database コードベース as code
45
+
46
+ user -> claude : /dev US-103 開始
47
+ activate claude
48
+
49
+ == 計画フェーズ ==
50
+ claude -> code : イテレーション計画読み込み
51
+ claude -> code : 既存コード調査
52
+ claude -> claude : タスク分解・優先度決定
53
+
54
+ == 設計フェーズ ==
55
+ claude -> code : 既存パターン確認
56
+ claude -> claude : API/UI/データ設計
57
+ claude -> claude : Codex指示作成
58
+
59
+ == 実装フェーズ ==
60
+ claude -> codex : 実装指示(MCP)
61
+ activate codex
62
+ codex -> code : コード実装
63
+ codex -> code : ユニットテスト作成
64
+ codex -> codex : Lint/テスト実行
65
+ codex --> claude : 実装完了
66
+ deactivate codex
67
+
68
+ == 受入フェーズ ==
69
+ claude -> code : 設計レビュー
70
+ claude -> code : E2Eテスト作成
71
+ claude -> code : E2Eテスト実行
72
+ claude -> code : バグ修正(必要に応じて)
73
+ claude --> user : 完了報告
74
+
75
+ deactivate claude
76
+
77
+ @enduml
78
+ ```
79
+
80
+ ### 役割分担
81
+
82
+ | フェーズ | 担当 | 責務 |
83
+ |---------|------|------|
84
+ | 計画 | Claude | 要件分析、タスク分解、優先度決定 |
85
+ | 設計 | Claude | API 設計、UI 設計、データモデル設計 |
86
+ | 実装指示 | Codex | コード実装、ユニットテスト作成 |
87
+ | 受入 | Claude | 設計レビュー、E2E テスト作成・実行、品質確認 |
88
+
89
+ ---
90
+
91
+ ## フェーズ 1: 計画
92
+
93
+ ### 目的
94
+
95
+ イテレーション計画とユーザーストーリーに基づき、実装すべきタスクを明確化する。
96
+
97
+ ### 入力
98
+
99
+ - イテレーション計画(`docs/development/iteration_plan-*.md`)
100
+ - ユーザーストーリーと受入条件
101
+
102
+ ### 活動
103
+
104
+ 1. **要件分析**: ユーザーストーリーの受入条件を確認
105
+ 2. **既存コード調査**: 関連する既存実装を確認
106
+ 3. **タスク分解**: 実装タスクを細分化
107
+ 4. **優先度決定**: 依存関係を考慮してタスク順序を決定
108
+
109
+ ### 出力
110
+
111
+ - タスクリスト(TODO)
112
+ - 実装方針
113
+
114
+ ### 例: US-103 お知らせ管理
115
+
116
+ ```markdown
117
+ ## タスクリスト
118
+
119
+ 1. AuthContext に role と canManageAnnouncements を追加
120
+ 2. API クライアントに CRUD 関数を追加(create/update/delete)
121
+ 3. ConfirmDialog 汎用コンポーネント作成
122
+ 4. AnnouncementForm コンポーネント作成
123
+ 5. AnnouncementFormPage 作成(新規作成・編集兼用)
124
+ 6. App.tsx にルーティング追加
125
+ 7. AnnouncementsPage に新規作成ボタン追加
126
+ 8. AnnouncementDetailPage に編集・削除ボタン追加
127
+ 9. ユニットテスト作成
128
+ ```
129
+
130
+ ---
131
+
132
+ ## フェーズ 2: 設計
133
+
134
+ ### 目的
135
+
136
+ 実装前に詳細な設計を行い、Codex への指示内容を明確化する。
137
+
138
+ ### 入力
139
+
140
+ - タスクリスト
141
+ - 既存のアーキテクチャ・パターン
142
+
143
+ ### 活動
144
+
145
+ 1. **API 設計**: エンドポイント、リクエスト/レスポンス形式
146
+ 2. **データモデル設計**: 型定義、バリデーションルール
147
+ 3. **UI 設計**: コンポーネント構造、状態管理
148
+ 4. **既存パターン確認**: プロジェクトの既存実装に合わせる
149
+
150
+ ### 出力
151
+
152
+ - 詳細設計仕様
153
+ - Codex への実装指示
154
+
155
+ ### 例: AnnouncementForm 設計
156
+
157
+ ```typescript
158
+ // 設計仕様
159
+ type FormValues = {
160
+ title: string // 必須、最大200文字
161
+ content: string // 必須
162
+ category: AnnouncementCategory // GENERAL | IMPORTANT | EVENT | HR
163
+ publishedAt: string // datetime-local 形式
164
+ }
165
+
166
+ // バリデーション
167
+ - title: z.string().min(1).max(200)
168
+ - content: z.string().min(1)
169
+ - category: z.enum(['GENERAL', 'IMPORTANT', 'EVENT', 'HR'])
170
+ - publishedAt: z.string().min(1)
171
+
172
+ // コンポーネント構造
173
+ - AnnouncementForm
174
+ - Input (タイトル)
175
+ - TextArea (本文)
176
+ - Select (カテゴリ)
177
+ - DateTimeInput (公開日時)
178
+ - Button (キャンセル/保存)
179
+ ```
180
+
181
+ ---
182
+
183
+ ## フェーズ 3: 実装指示(Codex)
184
+
185
+ ### 目的
186
+
187
+ Codex MCP サーバーを通じて、設計に基づいた実装を委譲する。
188
+
189
+ ### Codex MCP 呼び出し方法
190
+
191
+ ```
192
+ mcp__codex__codex ツールを使用
193
+
194
+ パラメータ:
195
+ - prompt: 実装指示(詳細な要件を含む)
196
+ - sandbox: danger-full-access(workspace-write ではread-onlyエラーになることがある)
197
+ - approval-policy: never(自動承認)
198
+ - cwd: プロジェクトルート
199
+ ```
200
+
201
+ ### 指示サイズに関する注意
202
+
203
+ > **重要**: ユーザーストーリー単位など大きな単位で Codex に指示を出すと、処理が長時間化しレスポンスがなくなることがあります。
204
+
205
+ #### 推奨される指示の粒度
206
+
207
+ | 粒度 | 推奨度 | 説明 |
208
+ |------|--------|------|
209
+ | タスク単位(1-3 ファイル) | ✅ 推奨 | 1 つのコンポーネントや機能単位 |
210
+ | 機能単位(3-5 ファイル) | ⚠️ 注意 | 進捗確認を頻繁に行う |
211
+ | ユーザーストーリー単位 | ❌ 非推奨 | タスクに分割して実行 |
212
+
213
+ #### 大きなタスクの分割例
214
+
215
+ ```
216
+ ❌ 悪い例: ユーザーストーリー全体を一度に指示
217
+ 「US-103 お知らせ管理機能を全て実装してください」
218
+
219
+ ✅ 良い例: タスク単位で分割して指示
220
+ 1. 「AuthContext に role と canManageAnnouncements を追加」
221
+ 2. 「API クライアントに create/update/delete 関数を追加」
222
+ 3. 「ConfirmDialog コンポーネントを作成」
223
+ 4. 「AnnouncementForm コンポーネントを作成」
224
+ 5. ...
225
+ ```
226
+
227
+ #### レスポンスがない場合の対処
228
+
229
+ 1. `codex-reply` で進捗を確認
230
+ 2. 長時間応答がない場合はタスクを中断
231
+ 3. より小さな単位に分割して再実行
232
+
233
+ #### Codex が既存コードを意図せず書き換える問題(重要)
234
+
235
+ Codex は指示対象外のコードを勝手に書き換えることがある。IT1 で実際に発生した事例:
236
+
237
+ - `localStorage` → `sessionStorage` への無断変更(authStore との整合性が崩れた)
238
+ - headers マージ方式のスプレッド構文を `Object.assign` に書き換え
239
+
240
+ **対策**:
241
+
242
+ 1. **受入レビューで `git diff` を必ず確認** — 指示対象ファイル以外の変更がないか検証する
243
+ 2. **既存テストを先に実行** — Codex の変更後に既存テストが壊れていないか即座に確認する
244
+ 3. **指示にはコード全文を含める** — 曖昧な自然言語指示より、作成すべきファイルの完全なコードを渡す方が意図しない変更を防げる
245
+ 4. **「既存コードは変更しないでください」を明記** — 既存ファイルへの追記指示時は必ず記載する
246
+
247
+ #### Codex が書き込みできない場合の対処(重要)
248
+
249
+ Codex が read-only 制限やファイルロック等で書き込みできなかった場合:
250
+
251
+ 1. **Claude が勝手に直接編集を進めてはいけない**
252
+ 2. ユーザーに状況を報告し、確認を待つ
253
+ 3. ユーザーの許可を得てから代替手段(Claude による直接編集等)を実行
254
+
255
+ ```
256
+ ❌ 悪い例:
257
+ Claude: 「Codex が read-only 制限で書き込みできませんでした。直接編集を行います。」
258
+ → 勝手に進めている
259
+
260
+ ✅ 良い例:
261
+ Claude: 「Codex が read-only 制限で書き込みできませんでした。
262
+ 以下の選択肢があります:
263
+ 1. Claude が直接編集を行う
264
+ 2. 環境の問題を解決してから Codex で再実行
265
+ どちらで進めますか?」
266
+ → ユーザーの確認を待っている
267
+ ```
268
+
269
+ ### 実装指示のベストプラクティス
270
+
271
+ 1. **1 ファイル 1 指示**: 確実に完了する最小単位で指示する(複数ファイルの同時指示はタイムアウトリスクあり)
272
+ 2. **コード全文を渡す**: 自然言語の説明より、作成すべきファイルの完全なコードを指示に含める方が確実
273
+ 3. **既存パターン参照**: 既存ファイルを参照先として指定
274
+ 4. **「既存コードは変更しない」を明記**: 追記指示時に Codex が他の箇所を書き換えるのを防ぐ
275
+ 5. **受入で `git diff` 確認**: Codex の変更後は必ず差分を検証し、意図しない変更を検出する
276
+
277
+ ### 例: Codex への実装指示
278
+
279
+ ```
280
+ prompt: |
281
+ お知らせ管理機能を実装してください。
282
+
283
+ ## タスク
284
+ 1. AuthContext に role プロパティと canManageAnnouncements を追加
285
+ 2. API クライアント(src/lib/api.ts)に以下を追加:
286
+ - createAnnouncement(input: AnnouncementCreateInput)
287
+ - updateAnnouncement(id, input)
288
+ - deleteAnnouncement(id)
289
+ 3. ConfirmDialog コンポーネントを作成(既存の Button を参考に)
290
+ 4. AnnouncementForm コンポーネントを作成(React Hook Form + Zod)
291
+ 5. AnnouncementFormPage を作成(/announcements/new と /announcements/:id/edit)
292
+ 6. App.tsx にルーティングを追加
293
+
294
+ ## 既存パターン参照
295
+ - API クライアント: src/lib/api.ts
296
+ - フォームコンポーネント: src/components/ui/Input.tsx
297
+ - ページコンポーネント: src/pages/AnnouncementsPage.tsx
298
+
299
+ ## 完了条件
300
+ - ESLint エラーなし
301
+ - 既存テストがパス
302
+
303
+ sandbox: workspace-write
304
+ approval-policy: never
305
+ ```
306
+
307
+ ### Codex 実行中の確認
308
+
309
+ - Codex の進捗は `codex-reply` ツールで確認
310
+ - 問題発生時は追加指示で修正を依頼
311
+
312
+ ---
313
+
314
+ ## フェーズ 4: 受入
315
+
316
+ ### 目的
317
+
318
+ 実装された機能が設計通りに動作することを確認する。
319
+
320
+ ### 活動
321
+
322
+ 1. **設計レビュー**: 実装が設計仕様に準拠しているか確認
323
+ 2. **コード品質確認**: ESLint、テストカバレッジの確認
324
+ 3. **E2E テスト作成**: 成功基準に基づくテストを作成
325
+ 4. **E2E テスト実行**: 機能が正しく動作することを検証
326
+ 5. **バグ修正**: 問題があれば修正
327
+
328
+ ### E2E テスト作成のポイント
329
+
330
+ ```typescript
331
+ // 成功基準に対応するテストケース
332
+ test.describe('お知らせ管理機能(管理者)', () => {
333
+ test('管理者がお知らせを新規作成できる', async ({ page }) => {
334
+ // 1. 新規作成ボタンをクリック
335
+ // 2. フォームに入力
336
+ // 3. 保存
337
+ // 4. 詳細ページで確認
338
+ })
339
+
340
+ test('管理者がお知らせを編集できる', async ({ page }) => {
341
+ // ...
342
+ })
343
+
344
+ test('管理者がお知らせを削除できる(確認ダイアログあり)', async ({ page }) => {
345
+ // ...
346
+ })
347
+ })
348
+ ```
349
+
350
+ ### 受入基準
351
+
352
+ - [ ] すべての受入条件が満たされている
353
+ - [ ] E2E テストがすべてパス
354
+ - [ ] ESLint エラーがない
355
+ - [ ] 既存テストが壊れていない
356
+
357
+ ---
358
+
359
+ ## 実践例: US-103 お知らせ管理
360
+
361
+ ```plantuml
362
+ @startuml
363
+ title US-103 お知らせ管理 開発フロー
364
+
365
+ |Claude|
366
+ start
367
+ :イテレーション計画読み込み;
368
+ :受入条件確認;
369
+ :既存コード調査;
370
+ :タスクリスト作成;
371
+
372
+ |Claude|
373
+ :API設計確認;
374
+ :フロントエンド設計;
375
+ :Codex指示作成;
376
+
377
+ |Codex|
378
+ :AuthContext拡張;
379
+ :APIクライアント追加;
380
+ :ConfirmDialog作成;
381
+ :AnnouncementForm作成;
382
+ :AnnouncementFormPage作成;
383
+ :ルーティング追加;
384
+ :既存ページ修正;
385
+ :ユニットテスト実行;
386
+
387
+ |Claude|
388
+ :設計レビュー;
389
+ :E2Eテスト作成;
390
+ :E2Eテスト実行;
391
+
392
+ if (テスト失敗?) then (yes)
393
+ :バグ修正;
394
+ :再テスト;
395
+ else (no)
396
+ endif
397
+
398
+ :完了報告;
399
+ stop
400
+
401
+ @enduml
402
+ ```
403
+
404
+ ### 1. 計画フェーズ
405
+
406
+ ```
407
+ ユーザー: /dev iteration3 US-103: お知らせ管理 開始
408
+ 計画・設計は claude 実装は codex が担当する
409
+
410
+ Claude:
411
+ 1. イテレーション計画を読み込み
412
+ 2. 受入条件を確認
413
+ 3. 既存コードを調査(API、フロントエンド構造)
414
+ 4. タスクリストを作成
415
+ ```
416
+
417
+ ### 2. 設計フェーズ
418
+
419
+ ```
420
+ Claude:
421
+ 1. API エンドポイント設計を確認(既に実装済み)
422
+ 2. フロントエンドコンポーネント設計
423
+ - AuthContext の拡張
424
+ - AnnouncementForm コンポーネント
425
+ - AnnouncementFormPage
426
+ - 既存ページの修正
427
+ 3. Codex への詳細指示を作成
428
+ ```
429
+
430
+ ### 3. 実装フェーズ
431
+
432
+ ```
433
+ Claude → Codex MCP:
434
+ prompt: "お知らせ管理機能を実装..."
435
+ sandbox: workspace-write
436
+ approval-policy: never
437
+
438
+ Codex:
439
+ 1. AuthContext に role, canManageAnnouncements 追加
440
+ 2. API クライアントに CRUD 関数追加
441
+ 3. ConfirmDialog コンポーネント作成
442
+ 4. AnnouncementForm コンポーネント作成
443
+ 5. AnnouncementFormPage 作成
444
+ 6. App.tsx ルーティング追加
445
+ 7. AnnouncementsPage, AnnouncementDetailPage 修正
446
+ 8. テスト作成・実行
447
+ ```
448
+
449
+ ### 4. 受入フェーズ
450
+
451
+ ```
452
+ Claude:
453
+ 1. 設計レビュー
454
+ - 実装が設計に準拠しているか確認
455
+ - コード品質確認
456
+
457
+ 2. E2E テスト作成
458
+ - announcements.spec.ts に管理機能テストを追加
459
+
460
+ 3. E2E テスト実行
461
+ - npm run test:e2e -- --grep "お知らせ"
462
+
463
+ 4. バグ修正
464
+ - publishedAt の ISO 8601 形式変換を追加
465
+ - テストの待機処理を追加
466
+
467
+ 5. 最終確認
468
+ - 15 tests passed
469
+ ```
470
+
471
+ ---
472
+
473
+ ## コマンドリファレンス
474
+
475
+ ### 開発開始
476
+
477
+ ```bash
478
+ # イテレーションのユーザーストーリー開始
479
+ /dev iteration3 US-103: お知らせ管理 開始
480
+ ```
481
+
482
+ ### Codex MCP 呼び出し
483
+
484
+ ```
485
+ mcp__codex__codex
486
+ prompt: "実装指示..."
487
+ sandbox: workspace-write
488
+ approval-policy: never
489
+ cwd: /path/to/project
490
+ ```
491
+
492
+ ### テスト実行
493
+
494
+ ```bash
495
+ # ユニットテスト
496
+ npm run test
497
+
498
+ # E2E テスト(全体)
499
+ npm run test:e2e
500
+
501
+ # E2E テスト(特定機能)
502
+ npm run test:e2e -- --grep "お知らせ"
503
+ ```
504
+
505
+ ### 品質チェック
506
+
507
+ ```bash
508
+ # Lint + Format + Test
509
+ npm run check
510
+ ```
511
+
512
+ ---
513
+
514
+ ## ベストプラクティス
515
+
516
+ ### 計画・設計
517
+
518
+ 1. **既存パターンを尊重**: プロジェクトの既存実装に合わせる
519
+ 2. **受入条件を明確に**: テスト可能な条件を定義する
520
+ 3. **依存関係を考慮**: タスクの実行順序を適切に設定
521
+
522
+ ### 実装指示
523
+
524
+ 1. **具体的な指示**: 曖昧さを排除した詳細な要件
525
+ 2. **参照ファイルの明示**: 既存のパターンを参照先として指定
526
+ 3. **完了条件の明示**: 何をもって完了とするか明確に
527
+
528
+ ### 受入
529
+
530
+ 1. **設計レビュー先行**: テスト前にコードを確認
531
+ 2. **E2E テストで検証**: 成功基準に対応するテストを作成
532
+ 3. **継続的なフィードバック**: 問題があれば即座に修正
533
+
534
+ ---
535
+
536
+ ## 関連ドキュメント
537
+
538
+ - [開発環境セットアップ](dev_app_instruction.md)
539
+ - [Codex CLI MCP サーバー設定](codex_instruction.md)
540
+ - [イテレーション計画](../development/iteration_plan-3.md)
541
+ - [コーディングとテストガイド](../reference/コーディングとテストガイド.md)
542
+
543
+ ---
544
+
545
+ **作成日**: 2026-01-19
546
+ **更新日**: 2026-01-19