qfai 1.1.2 → 1.1.4
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.
- package/README.md +1 -4
- package/assets/init/.qfai/assistant/prompts/qfai-implement.md +12 -0
- package/assets/init/.qfai/assistant/prompts/qfai-spec.md +38 -0
- package/assets/init/.qfai/specs/README.md +36 -2
- package/assets/init/root/.claude/agents/README.md +13 -0
- package/assets/init/root/.claude/agents/architect.md +29 -0
- package/assets/init/root/.claude/agents/backend-engineer.md +29 -0
- package/assets/init/root/.claude/agents/code-reviewer.md +29 -0
- package/assets/init/root/.claude/agents/contract-designer.md +29 -0
- package/assets/init/root/.claude/agents/devops-ci-engineer.md +29 -0
- package/assets/init/root/.claude/agents/facilitator.md +29 -0
- package/assets/init/root/.claude/agents/frontend-engineer.md +29 -0
- package/assets/init/root/.claude/agents/interviewer.md +29 -0
- package/assets/init/root/.claude/agents/planner.md +29 -0
- package/assets/init/root/.claude/agents/qa-engineer.md +29 -0
- package/assets/init/root/.claude/agents/requirements-analyst.md +29 -0
- package/assets/init/root/.claude/agents/test-engineer.md +29 -0
- package/assets/init/root/.github/agents/README.md +13 -0
- package/assets/init/root/.github/agents/architect.agent.md +29 -0
- package/assets/init/root/.github/agents/backend-engineer.agent.md +29 -0
- package/assets/init/root/.github/agents/code-reviewer.agent.md +29 -0
- package/assets/init/root/.github/agents/contract-designer.agent.md +29 -0
- package/assets/init/root/.github/agents/devops-ci-engineer.agent.md +29 -0
- package/assets/init/root/.github/agents/facilitator.agent.md +29 -0
- package/assets/init/root/.github/agents/frontend-engineer.agent.md +29 -0
- package/assets/init/root/.github/agents/interviewer.agent.md +29 -0
- package/assets/init/root/.github/agents/planner.agent.md +29 -0
- package/assets/init/root/.github/agents/qa-engineer.agent.md +29 -0
- package/assets/init/root/.github/agents/requirements-analyst.agent.md +29 -0
- package/assets/init/root/.github/agents/test-engineer.agent.md +29 -0
- package/dist/cli/index.cjs +43 -2
- package/dist/cli/index.cjs.map +1 -1
- package/dist/cli/index.mjs +43 -2
- package/dist/cli/index.mjs.map +1 -1
- package/dist/index.cjs +43 -2
- package/dist/index.cjs.map +1 -1
- package/dist/index.mjs +43 -2
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
- package/assets/init/.qfai/samples/guardrails/delta_with_guardrails.md +0 -19
package/README.md
CHANGED
|
@@ -39,7 +39,7 @@ npx qfai report
|
|
|
39
39
|
- `npx qfai doctor`
|
|
40
40
|
- Diagnoses configuration discovery, path resolution, glob scanning, and `validate.json` inputs before running validate/report; use `--fail-on` to enforce failures in CI.
|
|
41
41
|
- `npx qfai guardrails`
|
|
42
|
-
- Lists, extracts, or checks Decision Guardrails in `delta.md` (`list` / `extract` / `check`); use `--path` to point at
|
|
42
|
+
- Lists, extracts, or checks Decision Guardrails in `delta.md` (`list` / `extract` / `check`); use `--path` to point at target files/directories or custom locations.
|
|
43
43
|
|
|
44
44
|
## Operating model (prompt-driven workflow)
|
|
45
45
|
|
|
@@ -354,9 +354,6 @@ Typical customizations.
|
|
|
354
354
|
│ │ └── require.md
|
|
355
355
|
│ ├── specs
|
|
356
356
|
│ │ └── README.md
|
|
357
|
-
│ ├── samples
|
|
358
|
-
│ │ ├── guardrails
|
|
359
|
-
│ │ │ └── delta_with_guardrails.md
|
|
360
357
|
│ └── README.md
|
|
361
358
|
└── qfai.config.yaml
|
|
362
359
|
```
|
|
@@ -162,6 +162,18 @@ QFAI expects `assistant/steering/` to contain **project‑specific facts** so al
|
|
|
162
162
|
|
|
163
163
|
## Step 1 — Confirm prerequisites
|
|
164
164
|
|
|
165
|
+
### 1.1 Read delta decision log (mandatory)
|
|
166
|
+
|
|
167
|
+
Before implementing, read `.qfai/specs/spec-XXXX/delta.md` and treat it as authoritative for:
|
|
168
|
+
|
|
169
|
+
- what options were considered (Decision Table)
|
|
170
|
+
- what options were rejected or deferred (Decision Guardrails)
|
|
171
|
+
|
|
172
|
+
Hard rule:
|
|
173
|
+
|
|
174
|
+
- Do not implement rejected/deferred options unless the spec/delta is explicitly updated.
|
|
175
|
+
- If you need an exception, raise an Open Question and propose a spec change first.
|
|
176
|
+
|
|
165
177
|
Must exist:
|
|
166
178
|
|
|
167
179
|
- `.qfai/specs/spec-XXXX/spec.md`
|
|
@@ -258,12 +258,50 @@ Tie each acceptance criterion to scenarios and/or tests.
|
|
|
258
258
|
|
|
259
259
|
### 2.2 `delta.md` template (Planner + QA)
|
|
260
260
|
|
|
261
|
+
`delta.md` is not only a change log. It is also a **decision log** that prevents accidental implementation of rejected options.
|
|
262
|
+
|
|
261
263
|
Use this structure:
|
|
262
264
|
|
|
263
265
|
# Delta
|
|
264
266
|
|
|
265
267
|
## Summary
|
|
266
268
|
|
|
269
|
+
## Decision Table (検討テーブル)
|
|
270
|
+
|
|
271
|
+
Record the options that were considered during spec discussion.
|
|
272
|
+
|
|
273
|
+
Rules:
|
|
274
|
+
|
|
275
|
+
- For each important design decision, list at least:
|
|
276
|
+
- the chosen option (Adopt)
|
|
277
|
+
- one plausible alternative (Reject or Defer)
|
|
278
|
+
- If ambiguity remains, explicitly mark it as `Defer` and raise an Open Question.
|
|
279
|
+
- For any rejected option that an implementer could accidentally pick, add a corresponding Decision Guardrail entry below.
|
|
280
|
+
|
|
281
|
+
Template:
|
|
282
|
+
|
|
283
|
+
| ID | Topic | Options | Decision | Rationale | Implementation note |
|
|
284
|
+
| ------- | ------- | ----------- | ----------------------------------- | --------- | --------------------------- |
|
|
285
|
+
| DT-0001 | <topic> | <A / B / C> | Adopt: <X>, Reject: <Y>, Defer: <Z> | <why> | <do / do not / constraints> |
|
|
286
|
+
|
|
287
|
+
## Decision Guardrails
|
|
288
|
+
|
|
289
|
+
Convert critical `Reject` / `Defer` items into short, machine-extractable guardrails.
|
|
290
|
+
|
|
291
|
+
Format (one entry per `### DG-` heading):
|
|
292
|
+
|
|
293
|
+
```md
|
|
294
|
+
### DG-0001: <title>
|
|
295
|
+
|
|
296
|
+
- Type: non-goal | not-now | trade-off
|
|
297
|
+
- Scope: <optional>
|
|
298
|
+
- Guardrail: <1 sentence. What must NOT be done / must be deferred>
|
|
299
|
+
- Reason: <1-3 sentences>
|
|
300
|
+
- Reconsider: <never or explicit condition>
|
|
301
|
+
- Related: <optional links/IDs>
|
|
302
|
+
- Keywords: <comma or space separated>
|
|
303
|
+
```
|
|
304
|
+
|
|
267
305
|
## User-visible changes
|
|
268
306
|
|
|
269
307
|
## Backward compatibility / migration notes
|
|
@@ -3,12 +3,46 @@
|
|
|
3
3
|
A **spec pack** lives under `specs/spec-XXXX/` and contains:
|
|
4
4
|
|
|
5
5
|
- `spec.md` : SDD spec (source of truth for behavior)
|
|
6
|
-
- `delta.md` : impact / migration / verification plan
|
|
6
|
+
- `delta.md` : change log / impact / migration / verification plan (and decision records)
|
|
7
7
|
- `scenario.feature` : Gherkin scenarios (ATDD skeleton)
|
|
8
8
|
|
|
9
9
|
Create/update spec packs with `/qfai-spec`.
|
|
10
10
|
|
|
11
|
-
Decision
|
|
11
|
+
## Decision records in `delta.md`
|
|
12
|
+
|
|
13
|
+
`delta.md` is not only "what changed", but also "what we decided".
|
|
14
|
+
This is critical for AI-assisted implementation: when `spec.md` is ambiguous, the implementer must avoid accidentally choosing a previously rejected option.
|
|
15
|
+
|
|
16
|
+
### Decision Table (recommended)
|
|
17
|
+
|
|
18
|
+
Record candidate options and outcomes in a compact table:
|
|
19
|
+
|
|
20
|
+
```md
|
|
21
|
+
## Decision Table
|
|
22
|
+
|
|
23
|
+
| ID | Topic | Candidates | Decision | Rationale | Implementation note |
|
|
24
|
+
| ------- | ------------- | ---------- | --------------------- | --------- | -------------------- |
|
|
25
|
+
| DT-0001 | Example topic | A / B / C | Adopt: B, Reject: A,C | Why B | Do NOT implement A,C |
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
### Decision Guardrails (DG)
|
|
29
|
+
|
|
30
|
+
Decision Guardrails can be stored under `delta.md` as `## Decision Guardrails`.
|
|
31
|
+
Keep each guardrail short and machine-extractable so `qfai guardrails extract` can pull the relevant constraints when needed.
|
|
32
|
+
|
|
33
|
+
```md
|
|
34
|
+
## Decision Guardrails
|
|
35
|
+
|
|
36
|
+
### DG-0001: Do not implement option A for <topic>
|
|
37
|
+
|
|
38
|
+
- Type: trade-off
|
|
39
|
+
- Scope: specs/spec-\*/
|
|
40
|
+
- Guardrail: Option A MUST NOT be implemented; prefer option B.
|
|
41
|
+
- Reason: Option A breaks compatibility.
|
|
42
|
+
- Reconsider: only if compatibility policy changes.
|
|
43
|
+
- Related: DT-0001
|
|
44
|
+
- Keywords: option-a, compatibility
|
|
45
|
+
```
|
|
12
46
|
|
|
13
47
|
Before writing a spec pack, read `.qfai/assistant/steering/manifest.md` to align on product-level decisions.
|
|
14
48
|
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
# Claude Code Project Sub-agents (QFAI wrappers)
|
|
2
|
+
|
|
3
|
+
## これは何?
|
|
4
|
+
|
|
5
|
+
このディレクトリの `*.md` は、Claude Code の **Project Sub-agents** をリポジトリに同梱するための設定です。
|
|
6
|
+
|
|
7
|
+
ただし、本プロジェクトではサブエージェント定義の正本を `.qfai/assistant/agents/` に置きます。
|
|
8
|
+
ここにある各 `*.md` は、Claude Code から呼び出された際に **.qfai の role card を参照して従う**ことだけを強制する「薄いラッパー」です。
|
|
9
|
+
|
|
10
|
+
## 重要
|
|
11
|
+
|
|
12
|
+
- 役割の中身を変えるときは、まず `.qfai/assistant/agents/*.md` を更新してください。
|
|
13
|
+
- ここ(`.claude/agents`)は **参照先を示すだけ**に留め、重複実装を避けてください。
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: architect
|
|
3
|
+
description: "QFAI sub-agent wrapper (project-level). Canonical role card lives under .qfai/assistant/agents/."
|
|
4
|
+
model: inherit
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **Claude Code Project Sub-agent**(`.claude/agents/`)向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このサブエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/architect.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/architect.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: backend-engineer
|
|
3
|
+
description: "QFAI sub-agent wrapper (project-level). Canonical role card lives under .qfai/assistant/agents/."
|
|
4
|
+
model: inherit
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **Claude Code Project Sub-agent**(`.claude/agents/`)向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このサブエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/backend-engineer.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/backend-engineer.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: code-reviewer
|
|
3
|
+
description: "QFAI sub-agent wrapper (project-level). Canonical role card lives under .qfai/assistant/agents/."
|
|
4
|
+
model: inherit
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **Claude Code Project Sub-agent**(`.claude/agents/`)向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このサブエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/code-reviewer.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/code-reviewer.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: contract-designer
|
|
3
|
+
description: "QFAI sub-agent wrapper (project-level). Canonical role card lives under .qfai/assistant/agents/."
|
|
4
|
+
model: inherit
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **Claude Code Project Sub-agent**(`.claude/agents/`)向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このサブエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/contract-designer.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/contract-designer.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: devops-ci-engineer
|
|
3
|
+
description: "QFAI sub-agent wrapper (project-level). Canonical role card lives under .qfai/assistant/agents/."
|
|
4
|
+
model: inherit
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **Claude Code Project Sub-agent**(`.claude/agents/`)向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このサブエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/devops-ci-engineer.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/devops-ci-engineer.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: facilitator
|
|
3
|
+
description: "QFAI sub-agent wrapper (project-level). Canonical role card lives under .qfai/assistant/agents/."
|
|
4
|
+
model: inherit
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **Claude Code Project Sub-agent**(`.claude/agents/`)向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このサブエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/facilitator.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/facilitator.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: frontend-engineer
|
|
3
|
+
description: "QFAI sub-agent wrapper (project-level). Canonical role card lives under .qfai/assistant/agents/."
|
|
4
|
+
model: inherit
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **Claude Code Project Sub-agent**(`.claude/agents/`)向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このサブエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/frontend-engineer.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/frontend-engineer.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: interviewer
|
|
3
|
+
description: "QFAI sub-agent wrapper (project-level). Canonical role card lives under .qfai/assistant/agents/."
|
|
4
|
+
model: inherit
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **Claude Code Project Sub-agent**(`.claude/agents/`)向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このサブエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/interviewer.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/interviewer.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: planner
|
|
3
|
+
description: "QFAI sub-agent wrapper (project-level). Canonical role card lives under .qfai/assistant/agents/."
|
|
4
|
+
model: inherit
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **Claude Code Project Sub-agent**(`.claude/agents/`)向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このサブエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/planner.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/planner.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: qa-engineer
|
|
3
|
+
description: "QFAI sub-agent wrapper (project-level). Canonical role card lives under .qfai/assistant/agents/."
|
|
4
|
+
model: inherit
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **Claude Code Project Sub-agent**(`.claude/agents/`)向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このサブエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/qa-engineer.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/qa-engineer.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: requirements-analyst
|
|
3
|
+
description: "QFAI sub-agent wrapper (project-level). Canonical role card lives under .qfai/assistant/agents/."
|
|
4
|
+
model: inherit
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **Claude Code Project Sub-agent**(`.claude/agents/`)向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このサブエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/requirements-analyst.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/requirements-analyst.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: test-engineer
|
|
3
|
+
description: "QFAI sub-agent wrapper (project-level). Canonical role card lives under .qfai/assistant/agents/."
|
|
4
|
+
model: inherit
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **Claude Code Project Sub-agent**(`.claude/agents/`)向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このサブエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/test-engineer.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/test-engineer.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
# GitHub Copilot Custom Agents (QFAI wrappers)
|
|
2
|
+
|
|
3
|
+
## これは何?
|
|
4
|
+
|
|
5
|
+
このディレクトリの `*.agent.md` は、GitHub Copilot の **Custom Agents** をリポジトリに同梱するための設定です。
|
|
6
|
+
|
|
7
|
+
ただし、本プロジェクトではサブエージェント定義の正本を `.qfai/assistant/agents/` に置きます。
|
|
8
|
+
ここにある各 `*.agent.md` は、Copilot から呼び出された際に **.qfai の role card を参照して従う**ことだけを強制する「薄いラッパー」です。
|
|
9
|
+
|
|
10
|
+
## 重要
|
|
11
|
+
|
|
12
|
+
- 役割の中身を変えるときは、まず `.qfai/assistant/agents/*.md` を更新してください。
|
|
13
|
+
- ここ(`.github/agents`)は **参照先を示すだけ**に留め、重複実装を避けてください。
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
description: "QFAI sub-agent wrapper. Canonical role card lives under .qfai/assistant/agents/."
|
|
3
|
+
target: github-copilot
|
|
4
|
+
infer: false
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **GitHub Copilot Custom Agents** 向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/architect.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/architect.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
description: "QFAI sub-agent wrapper. Canonical role card lives under .qfai/assistant/agents/."
|
|
3
|
+
target: github-copilot
|
|
4
|
+
infer: false
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **GitHub Copilot Custom Agents** 向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/backend-engineer.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/backend-engineer.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
description: "QFAI sub-agent wrapper. Canonical role card lives under .qfai/assistant/agents/."
|
|
3
|
+
target: github-copilot
|
|
4
|
+
infer: false
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **GitHub Copilot Custom Agents** 向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/code-reviewer.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/code-reviewer.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
description: "QFAI sub-agent wrapper. Canonical role card lives under .qfai/assistant/agents/."
|
|
3
|
+
target: github-copilot
|
|
4
|
+
infer: false
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# QFAI Sub-agent (Wrapper)
|
|
8
|
+
|
|
9
|
+
## 目的
|
|
10
|
+
|
|
11
|
+
このファイルは **GitHub Copilot Custom Agents** 向けの「薄いラッパー」です。
|
|
12
|
+
|
|
13
|
+
本リポジトリでは、サブエージェントの正本(Single Source of Truth)は `.qfai/assistant/agents/*.md` にあります。
|
|
14
|
+
このエージェントが呼び出されたら、**必ず最初に**以下を読んで、その指示に従ってください。
|
|
15
|
+
|
|
16
|
+
- `.qfai/assistant/agents/README.md`
|
|
17
|
+
- `.qfai/assistant/agents/contract-designer.md`
|
|
18
|
+
|
|
19
|
+
## 運用ルール(最重要)
|
|
20
|
+
|
|
21
|
+
- 役割定義・応答フォーマット・禁止事項は、上記の `.qfai` 配下の role card を **優先**します。
|
|
22
|
+
- このファイルに書かれた内容と `.qfai` の内容が矛盾する場合、**`.qfai` を正**とします。
|
|
23
|
+
- `.qfai` を読まずに推測で進めないでください。
|
|
24
|
+
|
|
25
|
+
## 実行指示(最小)
|
|
26
|
+
|
|
27
|
+
1. `.qfai/assistant/agents/contract-designer.md` を読み、期待されるアウトプット形式で回答する
|
|
28
|
+
2. `.qfai/assistant/steering/*.md` と `.qfai/assistant/instructions/*.md` を前提として扱う
|
|
29
|
+
3. 不明点は Open Questions として列挙し、確定事項と混ぜない
|