Output Contracts と Quality Gates の実装 + 未使用コード検出ポリシー厳格化

Output Contracts を report 配下のネスト構造に変更し、Quality Gates をスキーマ・パーサーに追加。
未使用コード検出ポリシーから公開API例外ルールを削除し、AIが未使用コードを許容する抜け道を塞ぐ。
This commit is contained in:
nrslib 2026-02-07 22:26:35 +09:00
parent 487b8bf235
commit 7ae4a78831
42 changed files with 492 additions and 340 deletions

View File

@ -42,8 +42,9 @@ movements:
next: ABORT
instruction: plan
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: implement
edit: true
persona: coder
@ -76,8 +77,9 @@ movements:
interactive_only: true
instruction: implement
output_contracts:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
report:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
- name: reviewers
parallel:
- name: ai_review
@ -97,8 +99,9 @@ movements:
- condition: AI-specific issues found
instruction: ai-review
output_contracts:
- name: 04-ai-review.md
format: ai-review
report:
- name: 04-ai-review.md
format: ai-review
- name: arch-review
edit: false
persona: architecture-reviewer
@ -115,8 +118,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 05-architect-review.md
format: architecture-review
report:
- name: 05-architect-review.md
format: architecture-review
rules:
- condition: all("No AI-specific issues", "approved")
next: COMPLETE

View File

@ -40,8 +40,9 @@ movements:
next: ABORT
instruction: plan
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: implement
edit: true
persona: coder
@ -73,8 +74,9 @@ movements:
interactive_only: true
instruction: implement
output_contracts:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
report:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
- name: reviewers
parallel:
- name: ai_review
@ -94,8 +96,9 @@ movements:
- condition: AI-specific issues found
instruction: ai-review
output_contracts:
- name: 04-ai-review.md
format: ai-review
report:
- name: 04-ai-review.md
format: ai-review
- name: arch-review
edit: false
persona: architecture-reviewer
@ -112,8 +115,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 05-architect-review.md
format: architecture-review
report:
- name: 05-architect-review.md
format: architecture-review
rules:
- condition: all("No AI-specific issues", "approved")
next: COMPLETE

View File

@ -84,8 +84,9 @@ movements:
- {Question 2}
instruction: plan
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: architect
edit: false
persona: architect-planner
@ -104,8 +105,9 @@ movements:
next: ABORT
instruction: architect
output_contracts:
- name: 01-architecture.md
format: architecture-design
report:
- name: 01-architecture.md
format: architecture-design
- name: implement
edit: true
persona: coder
@ -140,8 +142,9 @@ movements:
interactive_only: true
instruction: implement
output_contracts:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
report:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
- name: ai_review
edit: false
persona: ai-antipattern-reviewer
@ -161,8 +164,9 @@ movements:
next: ai_fix
instruction: ai-review
output_contracts:
- name: 04-ai-review.md
format: ai-review
report:
- name: 04-ai-review.md
format: ai-review
- name: ai_fix
edit: true
persona: coder
@ -226,8 +230,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 05-architect-review.md
format: architecture-review
report:
- name: 05-architect-review.md
format: architecture-review
- name: qa-review
edit: false
persona: qa-reviewer
@ -245,8 +250,9 @@ movements:
- condition: needs_fix
instruction: review-qa
output_contracts:
- name: 06-qa-review.md
format: qa-review
report:
- name: 06-qa-review.md
format: qa-review
rules:
- condition: all("approved")
next: supervise
@ -296,8 +302,9 @@ movements:
next: plan
instruction: supervise
output_contracts:
- Validation: 07-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 07-supervisor-validation.md
- Summary: summary.md
policies:
coding: ../policies/coding.md
review: ../policies/review.md

View File

@ -79,8 +79,9 @@ movements:
- {Question 2}
instruction: plan
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: architect
edit: false
persona: architect-planner
@ -99,8 +100,9 @@ movements:
next: ABORT
instruction: architect
output_contracts:
- name: 01-architecture.md
format: architecture-design
report:
- name: 01-architecture.md
format: architecture-design
- name: implement
edit: true
persona: coder
@ -134,8 +136,9 @@ movements:
interactive_only: true
instruction: implement
output_contracts:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
report:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
- name: ai_review
edit: false
persona: ai-antipattern-reviewer
@ -155,8 +158,9 @@ movements:
next: ai_fix
instruction: ai-review
output_contracts:
- name: 04-ai-review.md
format: ai-review
report:
- name: 04-ai-review.md
format: ai-review
- name: ai_fix
edit: true
persona: coder
@ -219,8 +223,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 05-architect-review.md
format: architecture-review
report:
- name: 05-architect-review.md
format: architecture-review
- name: qa-review
edit: false
persona: qa-reviewer
@ -238,8 +243,9 @@ movements:
- condition: needs_fix
instruction: review-qa
output_contracts:
- name: 06-qa-review.md
format: qa-review
report:
- name: 06-qa-review.md
format: qa-review
rules:
- condition: all("approved")
next: supervise
@ -288,8 +294,9 @@ movements:
next: plan
instruction: supervise
output_contracts:
- Validation: 07-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 07-supervisor-validation.md
- Summary: summary.md
report_formats:
plan: ../output-contracts/plan.md
architecture-design: ../output-contracts/architecture-design.md

View File

@ -61,8 +61,9 @@ movements:
- condition: Requirements are unclear and planning cannot proceed
next: ABORT
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: implement
edit: true
persona: coder
@ -99,8 +100,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: ai_review
edit: false
persona: ai-antipattern-reviewer
@ -120,8 +122,9 @@ movements:
- condition: AI-specific issues detected
next: ai_fix
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: ai_fix
edit: true
persona: coder
@ -187,8 +190,9 @@ movements:
- condition: needs_fix
instruction: review-cqrs-es
output_contracts:
- name: 04-cqrs-es-review.md
format: cqrs-es-review
report:
- name: 04-cqrs-es-review.md
format: cqrs-es-review
- name: frontend-review
edit: false
persona: frontend-reviewer
@ -205,8 +209,9 @@ movements:
- condition: needs_fix
instruction: review-frontend
output_contracts:
- name: 05-frontend-review.md
format: frontend-review
report:
- name: 05-frontend-review.md
format: frontend-review
- name: security-review
edit: false
persona: security-reviewer
@ -223,8 +228,9 @@ movements:
- condition: needs_fix
instruction: review-security
output_contracts:
- name: 06-security-review.md
format: security-review
report:
- name: 06-security-review.md
format: security-review
- name: qa-review
edit: false
persona: qa-reviewer
@ -242,8 +248,9 @@ movements:
- condition: needs_fix
instruction: review-qa
output_contracts:
- name: 07-qa-review.md
format: qa-review
report:
- name: 07-qa-review.md
format: qa-review
rules:
- condition: all("approved")
next: supervise
@ -295,8 +302,9 @@ movements:
- condition: Issues detected during final review
next: fix_supervisor
output_contracts:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
- name: fix_supervisor
edit: true
persona: coder

View File

@ -55,8 +55,9 @@ movements:
- condition: Requirements are unclear and planning cannot proceed
next: ABORT
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: implement
edit: true
persona: coder
@ -92,8 +93,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: ai_review
edit: false
persona: ai-antipattern-reviewer
@ -113,8 +115,9 @@ movements:
- condition: AI-specific issues detected
next: ai_fix
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: ai_fix
edit: true
persona: coder
@ -179,8 +182,9 @@ movements:
- condition: needs_fix
instruction: review-cqrs-es
output_contracts:
- name: 04-cqrs-es-review.md
format: cqrs-es-review
report:
- name: 04-cqrs-es-review.md
format: cqrs-es-review
- name: frontend-review
edit: false
persona: frontend-reviewer
@ -197,8 +201,9 @@ movements:
- condition: needs_fix
instruction: review-frontend
output_contracts:
- name: 05-frontend-review.md
format: frontend-review
report:
- name: 05-frontend-review.md
format: frontend-review
- name: security-review
edit: false
persona: security-reviewer
@ -215,8 +220,9 @@ movements:
- condition: needs_fix
instruction: review-security
output_contracts:
- name: 06-security-review.md
format: security-review
report:
- name: 06-security-review.md
format: security-review
- name: qa-review
edit: false
persona: qa-reviewer
@ -234,8 +240,9 @@ movements:
- condition: needs_fix
instruction: review-qa
output_contracts:
- name: 07-qa-review.md
format: qa-review
report:
- name: 07-qa-review.md
format: qa-review
rules:
- condition: all("approved")
next: supervise
@ -286,8 +293,9 @@ movements:
- condition: Issues detected during final review
next: fix_supervisor
output_contracts:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
- name: fix_supervisor
edit: true
persona: coder

View File

@ -59,8 +59,9 @@ movements:
- condition: Requirements are unclear and planning cannot proceed
next: ABORT
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: implement
edit: true
persona: coder
@ -96,8 +97,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: ai_review
edit: false
persona: ai-antipattern-reviewer
@ -117,8 +119,9 @@ movements:
- condition: AI-specific issues detected
next: ai_fix
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: ai_fix
edit: true
persona: coder
@ -183,8 +186,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 04-architect-review.md
format: architecture-review
report:
- name: 04-architect-review.md
format: architecture-review
- name: frontend-review
edit: false
persona: frontend-reviewer
@ -201,8 +205,9 @@ movements:
- condition: needs_fix
instruction: review-frontend
output_contracts:
- name: 05-frontend-review.md
format: frontend-review
report:
- name: 05-frontend-review.md
format: frontend-review
- name: security-review
edit: false
persona: security-reviewer
@ -219,8 +224,9 @@ movements:
- condition: needs_fix
instruction: review-security
output_contracts:
- name: 06-security-review.md
format: security-review
report:
- name: 06-security-review.md
format: security-review
- name: qa-review
edit: false
persona: qa-reviewer
@ -238,8 +244,9 @@ movements:
- condition: needs_fix
instruction: review-qa
output_contracts:
- name: 07-qa-review.md
format: qa-review
report:
- name: 07-qa-review.md
format: qa-review
rules:
- condition: all("approved")
next: supervise
@ -290,8 +297,9 @@ movements:
- condition: Issues detected during final review
next: fix_supervisor
output_contracts:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
- name: fix_supervisor
edit: true
persona: coder

View File

@ -53,8 +53,9 @@ movements:
- condition: Requirements are unclear and planning cannot proceed
next: ABORT
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: implement
edit: true
persona: coder
@ -89,8 +90,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: ai_review
edit: false
persona: ai-antipattern-reviewer
@ -110,8 +112,9 @@ movements:
- condition: AI-specific issues detected
next: ai_fix
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: ai_fix
edit: true
persona: coder
@ -175,8 +178,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 04-architect-review.md
format: architecture-review
report:
- name: 04-architect-review.md
format: architecture-review
- name: frontend-review
edit: false
persona: frontend-reviewer
@ -193,8 +197,9 @@ movements:
- condition: needs_fix
instruction: review-frontend
output_contracts:
- name: 05-frontend-review.md
format: frontend-review
report:
- name: 05-frontend-review.md
format: frontend-review
- name: security-review
edit: false
persona: security-reviewer
@ -211,8 +216,9 @@ movements:
- condition: needs_fix
instruction: review-security
output_contracts:
- name: 06-security-review.md
format: security-review
report:
- name: 06-security-review.md
format: security-review
- name: qa-review
edit: false
persona: qa-reviewer
@ -230,8 +236,9 @@ movements:
- condition: needs_fix
instruction: review-qa
output_contracts:
- name: 07-qa-review.md
format: qa-review
report:
- name: 07-qa-review.md
format: qa-review
rules:
- condition: all("approved")
next: supervise
@ -281,8 +288,9 @@ movements:
- condition: Issues detected during final review
next: fix_supervisor
output_contracts:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
- name: fix_supervisor
edit: true
persona: coder

View File

@ -46,8 +46,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: reviewers
parallel:
- name: ai_review
@ -67,8 +68,9 @@ movements:
- condition: No AI-specific issues
- condition: AI-specific issues found
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: supervise
edit: false
persona: supervisor
@ -85,8 +87,9 @@ movements:
- condition: All checks passed
- condition: Requirements unmet, tests failing
output_contracts:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
rules:
- condition: all("No AI-specific issues", "All checks passed")
next: COMPLETE

View File

@ -45,8 +45,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: reviewers
parallel:
- name: ai_review
@ -66,8 +67,9 @@ movements:
- condition: No AI-specific issues
- condition: AI-specific issues found
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: supervise
edit: false
persona: supervisor
@ -84,8 +86,9 @@ movements:
- condition: All checks passed
- condition: Requirements unmet, tests failing
output_contracts:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
rules:
- condition: all("No AI-specific issues", "All checks passed")
next: COMPLETE

View File

@ -37,7 +37,8 @@ movements:
instruction_template: |
Do the task.
output_contracts:
- Summary: summary.md
report:
- Summary: summary.md
policies:
coding: ../policies/coding.md
testing: ../policies/testing.md

View File

@ -36,4 +36,5 @@ movements:
instruction_template: |
Do the task.
output_contracts:
- Summary: summary.md
report:
- Summary: summary.md

View File

@ -46,8 +46,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: reviewers
parallel:
- name: ai_review
@ -67,8 +68,9 @@ movements:
- condition: No AI-specific issues
- condition: AI-specific issues found
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: supervise
edit: false
persona: supervisor
@ -85,8 +87,9 @@ movements:
- condition: All checks passed
- condition: Requirements unmet, tests failing
output_contracts:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
rules:
- condition: all("No AI-specific issues", "All checks passed")
next: COMPLETE

View File

@ -45,8 +45,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: reviewers
parallel:
- name: ai_review
@ -66,8 +67,9 @@ movements:
- condition: No AI-specific issues
- condition: AI-specific issues found
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: supervise
edit: false
persona: supervisor
@ -84,8 +86,9 @@ movements:
- condition: All checks passed
- condition: Requirements unmet, tests failing
output_contracts:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
rules:
- condition: all("No AI-specific issues", "All checks passed")
next: COMPLETE

View File

@ -72,8 +72,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 01-architect-review.md
format: architecture-review
report:
- name: 01-architect-review.md
format: architecture-review
- name: security-review
edit: false
persona: security-reviewer
@ -90,8 +91,9 @@ movements:
- condition: needs_fix
instruction: review-security
output_contracts:
- name: 02-security-review.md
format: security-review
report:
- name: 02-security-review.md
format: security-review
- name: ai-review
edit: false
persona: ai-antipattern-reviewer
@ -109,8 +111,9 @@ movements:
- condition: needs_fix
instruction: review-ai
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
rules:
- condition: all("approved")
next: supervise
@ -175,7 +178,8 @@ movements:
- {Consolidated suggestions from all reviews}
```
output_contracts:
- Review Summary: 04-review-summary.md
report:
- Review Summary: 04-review-summary.md
- name: pr-comment
edit: false
persona: pr-commenter

View File

@ -156,7 +156,6 @@ AI tends to generate unnecessary code for "future extensibility", "symmetry", or
| REJECT | Interfaces or options prepared for future extension |
| REJECT | Exported but no usage found via grep |
| OK | Implicitly called by framework (lifecycle hooks, etc.) |
| OK | Intentionally exposed as public package API |
Verification approach:
1. Grep to confirm no references to changed/deleted code remain

View File

@ -42,8 +42,9 @@ movements:
next: ABORT
instruction: plan
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: implement
edit: true
persona: coder
@ -76,8 +77,9 @@ movements:
interactive_only: true
instruction: implement
output_contracts:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
report:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
- name: reviewers
parallel:
- name: ai_review
@ -97,8 +99,9 @@ movements:
- condition: AI特有の問題あり
instruction: ai-review
output_contracts:
- name: 04-ai-review.md
format: ai-review
report:
- name: 04-ai-review.md
format: ai-review
- name: arch-review
edit: false
persona: architecture-reviewer
@ -115,8 +118,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 05-architect-review.md
format: architecture-review
report:
- name: 05-architect-review.md
format: architecture-review
rules:
- condition: all("AI特有の問題なし", "approved")
next: COMPLETE

View File

@ -40,8 +40,9 @@ movements:
next: ABORT
instruction: plan
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: implement
edit: true
persona: coder
@ -73,8 +74,9 @@ movements:
interactive_only: true
instruction: implement
output_contracts:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
report:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
- name: reviewers
parallel:
- name: ai_review
@ -94,8 +96,9 @@ movements:
- condition: AI特有の問題あり
instruction: ai-review
output_contracts:
- name: 04-ai-review.md
format: ai-review
report:
- name: 04-ai-review.md
format: ai-review
- name: arch-review
edit: false
persona: architecture-reviewer
@ -112,8 +115,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 05-architect-review.md
format: architecture-review
report:
- name: 05-architect-review.md
format: architecture-review
rules:
- condition: all("AI特有の問題なし", "approved")
next: COMPLETE

View File

@ -84,8 +84,9 @@ movements:
- {質問2}
instruction: plan
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: architect
edit: false
persona: architect-planner
@ -104,8 +105,9 @@ movements:
next: ABORT
instruction: architect
output_contracts:
- name: 01-architecture.md
format: architecture-design
report:
- name: 01-architecture.md
format: architecture-design
- name: implement
edit: true
persona: coder
@ -140,8 +142,9 @@ movements:
interactive_only: true
instruction: implement
output_contracts:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
report:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
- name: ai_review
edit: false
persona: ai-antipattern-reviewer
@ -161,8 +164,9 @@ movements:
next: ai_fix
instruction: ai-review
output_contracts:
- name: 04-ai-review.md
format: ai-review
report:
- name: 04-ai-review.md
format: ai-review
- name: ai_fix
edit: true
persona: coder
@ -226,8 +230,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 05-architect-review.md
format: architecture-review
report:
- name: 05-architect-review.md
format: architecture-review
- name: qa-review
edit: false
persona: qa-reviewer
@ -245,8 +250,9 @@ movements:
- condition: needs_fix
instruction: review-qa
output_contracts:
- name: 06-qa-review.md
format: qa-review
report:
- name: 06-qa-review.md
format: qa-review
rules:
- condition: all("approved")
next: supervise
@ -296,8 +302,9 @@ movements:
next: plan
instruction: supervise
output_contracts:
- Validation: 07-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 07-supervisor-validation.md
- Summary: summary.md
policies:
coding: ../policies/coding.md
review: ../policies/review.md

View File

@ -79,8 +79,9 @@ movements:
- {質問2}
instruction: plan
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: architect
edit: false
persona: architect-planner
@ -99,8 +100,9 @@ movements:
next: ABORT
instruction: architect
output_contracts:
- name: 01-architecture.md
format: architecture-design
report:
- name: 01-architecture.md
format: architecture-design
- name: implement
edit: true
persona: coder
@ -134,8 +136,9 @@ movements:
interactive_only: true
instruction: implement
output_contracts:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
report:
- Scope: 02-coder-scope.md
- Decisions: 03-coder-decisions.md
- name: ai_review
edit: false
persona: ai-antipattern-reviewer
@ -155,8 +158,9 @@ movements:
next: ai_fix
instruction: ai-review
output_contracts:
- name: 04-ai-review.md
format: ai-review
report:
- name: 04-ai-review.md
format: ai-review
- name: ai_fix
edit: true
persona: coder
@ -219,8 +223,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 05-architect-review.md
format: architecture-review
report:
- name: 05-architect-review.md
format: architecture-review
- name: qa-review
edit: false
persona: qa-reviewer
@ -238,8 +243,9 @@ movements:
- condition: needs_fix
instruction: review-qa
output_contracts:
- name: 06-qa-review.md
format: qa-review
report:
- name: 06-qa-review.md
format: qa-review
rules:
- condition: all("approved")
next: supervise
@ -288,8 +294,9 @@ movements:
next: plan
instruction: supervise
output_contracts:
- Validation: 07-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 07-supervisor-validation.md
- Summary: summary.md
report_formats:
plan: ../output-contracts/plan.md
architecture-design: ../output-contracts/architecture-design.md

View File

@ -61,8 +61,9 @@ movements:
- condition: 要件が不明確で計画を立てられない
next: ABORT
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: implement
edit: true
persona: coder
@ -99,8 +100,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: ai_review
edit: false
persona: ai-antipattern-reviewer
@ -120,8 +122,9 @@ movements:
- condition: AI特有の問題が検出された
next: ai_fix
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: ai_fix
edit: true
persona: coder
@ -187,8 +190,9 @@ movements:
- condition: needs_fix
instruction: review-cqrs-es
output_contracts:
- name: 04-cqrs-es-review.md
format: cqrs-es-review
report:
- name: 04-cqrs-es-review.md
format: cqrs-es-review
- name: frontend-review
edit: false
persona: frontend-reviewer
@ -205,8 +209,9 @@ movements:
- condition: needs_fix
instruction: review-frontend
output_contracts:
- name: 05-frontend-review.md
format: frontend-review
report:
- name: 05-frontend-review.md
format: frontend-review
- name: security-review
edit: false
persona: security-reviewer
@ -223,8 +228,9 @@ movements:
- condition: needs_fix
instruction: review-security
output_contracts:
- name: 06-security-review.md
format: security-review
report:
- name: 06-security-review.md
format: security-review
- name: qa-review
edit: false
persona: qa-reviewer
@ -242,8 +248,9 @@ movements:
- condition: needs_fix
instruction: review-qa
output_contracts:
- name: 07-qa-review.md
format: qa-review
report:
- name: 07-qa-review.md
format: qa-review
rules:
- condition: all("approved")
next: supervise
@ -295,8 +302,9 @@ movements:
- condition: 問題が検出された
next: fix_supervisor
output_contracts:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
- name: fix_supervisor
edit: true
persona: coder

View File

@ -55,8 +55,9 @@ movements:
- condition: 要件が不明確で計画を立てられない
next: ABORT
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: implement
edit: true
persona: coder
@ -92,8 +93,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: ai_review
edit: false
persona: ai-antipattern-reviewer
@ -113,8 +115,9 @@ movements:
- condition: AI特有の問題が検出された
next: ai_fix
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: ai_fix
edit: true
persona: coder
@ -179,8 +182,9 @@ movements:
- condition: needs_fix
instruction: review-cqrs-es
output_contracts:
- name: 04-cqrs-es-review.md
format: cqrs-es-review
report:
- name: 04-cqrs-es-review.md
format: cqrs-es-review
- name: frontend-review
edit: false
persona: frontend-reviewer
@ -197,8 +201,9 @@ movements:
- condition: needs_fix
instruction: review-frontend
output_contracts:
- name: 05-frontend-review.md
format: frontend-review
report:
- name: 05-frontend-review.md
format: frontend-review
- name: security-review
edit: false
persona: security-reviewer
@ -215,8 +220,9 @@ movements:
- condition: needs_fix
instruction: review-security
output_contracts:
- name: 06-security-review.md
format: security-review
report:
- name: 06-security-review.md
format: security-review
- name: qa-review
edit: false
persona: qa-reviewer
@ -234,8 +240,9 @@ movements:
- condition: needs_fix
instruction: review-qa
output_contracts:
- name: 07-qa-review.md
format: qa-review
report:
- name: 07-qa-review.md
format: qa-review
rules:
- condition: all("approved")
next: supervise
@ -286,8 +293,9 @@ movements:
- condition: 問題が検出された
next: fix_supervisor
output_contracts:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
- name: fix_supervisor
edit: true
persona: coder

View File

@ -59,8 +59,9 @@ movements:
- condition: 要件が不明確で計画を立てられない
next: ABORT
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: implement
edit: true
persona: coder
@ -96,8 +97,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: ai_review
edit: false
persona: ai-antipattern-reviewer
@ -117,8 +119,9 @@ movements:
- condition: AI特有の問題が検出された
next: ai_fix
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: ai_fix
edit: true
persona: coder
@ -183,8 +186,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 04-architect-review.md
format: architecture-review
report:
- name: 04-architect-review.md
format: architecture-review
- name: frontend-review
edit: false
persona: frontend-reviewer
@ -201,8 +205,9 @@ movements:
- condition: needs_fix
instruction: review-frontend
output_contracts:
- name: 05-frontend-review.md
format: frontend-review
report:
- name: 05-frontend-review.md
format: frontend-review
- name: security-review
edit: false
persona: security-reviewer
@ -219,8 +224,9 @@ movements:
- condition: needs_fix
instruction: review-security
output_contracts:
- name: 06-security-review.md
format: security-review
report:
- name: 06-security-review.md
format: security-review
- name: qa-review
edit: false
persona: qa-reviewer
@ -238,8 +244,9 @@ movements:
- condition: needs_fix
instruction: review-qa
output_contracts:
- name: 07-qa-review.md
format: qa-review
report:
- name: 07-qa-review.md
format: qa-review
rules:
- condition: all("approved")
next: supervise
@ -290,8 +297,9 @@ movements:
- condition: 問題が検出された
next: fix_supervisor
output_contracts:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
- name: fix_supervisor
edit: true
persona: coder

View File

@ -53,8 +53,9 @@ movements:
- condition: 要件が不明確で計画を立てられない
next: ABORT
output_contracts:
- name: 00-plan.md
format: plan
report:
- name: 00-plan.md
format: plan
- name: implement
edit: true
persona: coder
@ -89,8 +90,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: ai_review
edit: false
persona: ai-antipattern-reviewer
@ -110,8 +112,9 @@ movements:
- condition: AI特有の問題が検出された
next: ai_fix
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: ai_fix
edit: true
persona: coder
@ -175,8 +178,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 04-architect-review.md
format: architecture-review
report:
- name: 04-architect-review.md
format: architecture-review
- name: frontend-review
edit: false
persona: frontend-reviewer
@ -193,8 +197,9 @@ movements:
- condition: needs_fix
instruction: review-frontend
output_contracts:
- name: 05-frontend-review.md
format: frontend-review
report:
- name: 05-frontend-review.md
format: frontend-review
- name: security-review
edit: false
persona: security-reviewer
@ -211,8 +216,9 @@ movements:
- condition: needs_fix
instruction: review-security
output_contracts:
- name: 06-security-review.md
format: security-review
report:
- name: 06-security-review.md
format: security-review
- name: qa-review
edit: false
persona: qa-reviewer
@ -230,8 +236,9 @@ movements:
- condition: needs_fix
instruction: review-qa
output_contracts:
- name: 07-qa-review.md
format: qa-review
report:
- name: 07-qa-review.md
format: qa-review
rules:
- condition: all("approved")
next: supervise
@ -281,8 +288,9 @@ movements:
- condition: 問題が検出された
next: fix_supervisor
output_contracts:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 08-supervisor-validation.md
- Summary: summary.md
- name: fix_supervisor
edit: true
persona: coder

View File

@ -46,8 +46,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: reviewers
parallel:
- name: ai_review
@ -67,8 +68,9 @@ movements:
- condition: AI特有の問題なし
- condition: AI特有の問題あり
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: supervise
edit: false
persona: supervisor
@ -85,8 +87,9 @@ movements:
- condition: すべて問題なし
- condition: 要求未達成、テスト失敗、ビルドエラー
output_contracts:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
rules:
- condition: all("AI特有の問題なし", "すべて問題なし")
next: COMPLETE

View File

@ -45,8 +45,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: reviewers
parallel:
- name: ai_review
@ -66,8 +67,9 @@ movements:
- condition: AI特有の問題なし
- condition: AI特有の問題あり
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: supervise
edit: false
persona: supervisor
@ -84,8 +86,9 @@ movements:
- condition: すべて問題なし
- condition: 要求未達成、テスト失敗、ビルドエラー
output_contracts:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
rules:
- condition: all("AI特有の問題なし", "すべて問題なし")
next: COMPLETE

View File

@ -37,7 +37,8 @@ movements:
instruction_template: |
タスクをこなしてください。
output_contracts:
- Summary: summary.md
report:
- Summary: summary.md
policies:
coding: ../policies/coding.md
testing: ../policies/testing.md

View File

@ -36,4 +36,5 @@ movements:
instruction_template: |
タスクをこなしてください。
output_contracts:
- Summary: summary.md
report:
- Summary: summary.md

View File

@ -46,8 +46,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: reviewers
parallel:
- name: ai_review
@ -67,8 +68,9 @@ movements:
- condition: AI特有の問題なし
- condition: AI特有の問題あり
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: supervise
edit: false
persona: supervisor
@ -85,8 +87,9 @@ movements:
- condition: すべて問題なし
- condition: 要求未達成、テスト失敗、ビルドエラー
output_contracts:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
rules:
- condition: all("AI特有の問題なし", "すべて問題なし")
next: COMPLETE

View File

@ -45,8 +45,9 @@ movements:
requires_user_input: true
interactive_only: true
output_contracts:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
report:
- Scope: 01-coder-scope.md
- Decisions: 02-coder-decisions.md
- name: reviewers
parallel:
- name: ai_review
@ -66,8 +67,9 @@ movements:
- condition: AI特有の問題なし
- condition: AI特有の問題あり
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
- name: supervise
edit: false
persona: supervisor
@ -84,8 +86,9 @@ movements:
- condition: すべて問題なし
- condition: 要求未達成、テスト失敗、ビルドエラー
output_contracts:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
report:
- Validation: 05-supervisor-validation.md
- Summary: summary.md
rules:
- condition: all("AI特有の問題なし", "すべて問題なし")
next: COMPLETE

View File

@ -72,8 +72,9 @@ movements:
- condition: needs_fix
instruction: review-arch
output_contracts:
- name: 01-architect-review.md
format: architecture-review
report:
- name: 01-architect-review.md
format: architecture-review
- name: security-review
edit: false
persona: security-reviewer
@ -90,8 +91,9 @@ movements:
- condition: needs_fix
instruction: review-security
output_contracts:
- name: 02-security-review.md
format: security-review
report:
- name: 02-security-review.md
format: security-review
- name: ai-review
edit: false
persona: ai-antipattern-reviewer
@ -109,8 +111,9 @@ movements:
- condition: needs_fix
instruction: review-ai
output_contracts:
- name: 03-ai-review.md
format: ai-review
report:
- name: 03-ai-review.md
format: ai-review
rules:
- condition: all("approved")
next: supervise
@ -176,7 +179,8 @@ movements:
- {全レビューからの統合提案}
```
output_contracts:
- Review Summary: 04-review-summary.md
report:
- Review Summary: 04-review-summary.md
- name: pr-comment
edit: false
persona: pr-commenter

View File

@ -156,7 +156,6 @@ AIは「将来の拡張性」「対称性」「念のため」で不要なコー
| REJECT | 将来の拡張のために用意されたインターフェースやオプション |
| REJECT | exportされているが、grep で使用箇所が見つからない |
| OK | フレームワークが暗黙的に呼び出す(ライフサイクルフック等) |
| OK | 公開パッケージのAPIとして意図的に公開している |
検証アプローチ:
1. 変更・削除されたコードを参照している箇所がないか grep で確認

View File

@ -76,8 +76,9 @@ movement 内では**キー名**で参照する(パスを直接書かない)
edit: false
instruction: review-arch
output_contracts:
- name: 05-architect-review.md
format: architecture-review
report:
- name: 05-architect-review.md
format: architecture-review
rules:
- condition: "approved"
- condition: "needs_fix"
@ -132,14 +133,15 @@ rules:
## Output Contracts 定義
Movement の出力契約(レポート定義)。配列形式で指定する。
Movement の出力契約(レポート定義)。`output_contracts.report` 配列形式で指定する。
### 形式1: name + formatフォーマット参照
```yaml
output_contracts:
- name: 01-plan.md
format: plan # report_formats マップのキーを参照
report:
- name: 01-plan.md
format: plan # report_formats マップのキーを参照
```
`format` がキー文字列の場合、トップレベル `report_formats:` セクションから対応する .md ファイルを読み込み、出力契約指示として使用する。
@ -148,20 +150,22 @@ output_contracts:
```yaml
output_contracts:
- name: 01-plan.md
format: | # インラインでフォーマットを記述
# レポートタイトル
## セクション
{内容}
report:
- name: 01-plan.md
format: | # インラインでフォーマットを記述
# レポートタイトル
## セクション
{内容}
```
### 形式2: label + pathラベル付きパス
```yaml
output_contracts:
- Summary: summary.md
- Scope: 01-scope.md
- Decisions: 02-decisions.md
report:
- Summary: summary.md
- Scope: 01-scope.md
- Decisions: 02-decisions.md
```
各要素のキーがレポート種別名(ラベル)、値がファイル名。

View File

@ -370,8 +370,9 @@ movements:
instruction: review # 異なる WHAT共有も可能
knowledge: architecture # 同じ CONTEXT — 再利用
output_contracts:
- name: review.md
format: review # OUTPUT — report_formats.review を参照
report:
- name: review.md
format: review # OUTPUT — report_formats.review を参照
edit: false
rules:
- condition: Approved

View File

@ -369,9 +369,10 @@ movements:
policy: review # Different RULES
instruction: review # Different WHAT (but could share)
knowledge: architecture # Same CONTEXT — reused
report:
name: review.md
format: review # OUTPUT — references output_contracts.review
output_contracts:
report:
- name: review.md
format: review # OUTPUT — references report_formats.review
edit: false
rules:
- condition: Approved

View File

@ -556,10 +556,12 @@ describe('section reference resolution', () => {
name: 'plan',
persona: 'planner',
instruction: '{task}',
output_contracts: [{
name: '00-plan.md',
format: 'plan',
}],
output_contracts: {
report: [{
name: '00-plan.md',
format: 'plan',
}],
},
}],
};

View File

@ -78,26 +78,35 @@ export const OutputContractItemSchema = z.object({
format: z.string().optional(),
});
/**
* Raw output contract entry array item in output_contracts.report
*
* Supports:
* - Label:path format: { Scope: "01-scope.md" }
* - Item format: { name, order?, format? }
*/
export const OutputContractEntrySchema = z.union([
z.record(z.string(), z.string()), // {Scope: "01-scope.md"} format
OutputContractItemSchema, // {name, order?, format?} format
]);
/**
* Output contracts field schema for movement-level definition.
*
* YAML formats:
* output_contracts: # array of label:path entries
* - Scope: 01-scope.md
* - Decisions: 02-decisions.md
* output_contracts: # array of objects (name + order + format)
* - name: 00-plan.md
* order: ...
* format: plan
*
* Array items can be single-key objects or full item objects.
* YAML format:
* output_contracts:
* report: # report array (required if output_contracts is specified)
* - Scope: 01-scope.md # label:path format
* - Decisions: 02-decisions.md
* output_contracts:
* report:
* - name: 00-plan.md # name + order + format format
* order: ...
* format: plan
*/
export const OutputContractsFieldSchema = z.array(
z.union([
z.record(z.string(), z.string()), // {Scope: "01-scope.md"} format
OutputContractItemSchema, // {name, order?, format?} format
])
).optional();
export const OutputContractsFieldSchema = z.object({
report: z.array(OutputContractEntrySchema).optional(),
}).optional();
/** Quality gates schema - AI directives for movement completion (string array) */
export const QualityGatesSchema = z.array(z.string()).optional();

View File

@ -53,7 +53,7 @@ export { handleBlocked, type BlockedHandlerResult } from './engine/blocked-handl
export { ParallelLogger } from './engine/parallel-logger.js';
// Instruction building
export { InstructionBuilder, isOutputContractItem, isOutputContractLabelPath } from './instruction/InstructionBuilder.js';
export { InstructionBuilder, isOutputContractItem } from './instruction/InstructionBuilder.js';
export { ReportInstructionBuilder, type ReportInstructionContext } from './instruction/ReportInstructionBuilder.js';
export { StatusJudgmentBuilder, type StatusJudgmentContext } from './instruction/StatusJudgmentBuilder.js';
export { buildEditRule, type InstructionContext } from './instruction/instruction-context.js';

View File

@ -5,7 +5,7 @@
* Assembles template variables and renders a single complete template.
*/
import type { PieceMovement, Language, OutputContractLabelPath, OutputContractItem, OutputContractEntry } from '../../models/types.js';
import type { PieceMovement, Language, OutputContractItem, OutputContractEntry } from '../../models/types.js';
import type { InstructionContext } from './instruction-context.js';
import { buildEditRule } from './instruction-context.js';
import { escapeTemplateChars, replaceTemplatePlaceholders } from './escape.js';
@ -18,13 +18,6 @@ export function isOutputContractItem(entry: OutputContractEntry): entry is Outpu
return 'name' in entry;
}
/**
* Check if an output contract entry is the label-path form (OutputContractLabelPath).
*/
export function isOutputContractLabelPath(entry: OutputContractEntry): entry is OutputContractLabelPath {
return 'label' in entry && 'path' in entry;
}
/**
* Builds Phase 1 instructions for agent execution.
*

View File

@ -2,7 +2,7 @@
* Instruction builders - barrel exports
*/
export { InstructionBuilder, isOutputContractItem, isOutputContractLabelPath, renderReportContext, renderReportOutputInstruction } from './InstructionBuilder.js';
export { InstructionBuilder, isOutputContractItem, renderReportContext, renderReportOutputInstruction } from './InstructionBuilder.js';
export { ReportInstructionBuilder, type ReportInstructionContext } from './ReportInstructionBuilder.js';
export { StatusJudgmentBuilder, type StatusJudgmentContext } from './StatusJudgmentBuilder.js';
export { escapeTemplateChars, replaceTemplatePlaceholders } from './escape.js';

View File

@ -114,7 +114,6 @@ export {
ParallelLogger,
InstructionBuilder,
isOutputContractItem,
isOutputContractLabelPath,
ReportInstructionBuilder,
StatusJudgmentBuilder,
buildEditRule,

View File

@ -122,24 +122,25 @@ function isOutputContractItem(raw: unknown): raw is { name: string; order?: stri
/**
* Normalize the raw output_contracts field from YAML into internal format.
*
* Input formats (YAML):
* Input format (YAML):
* output_contracts:
* - Scope: 01-scope.md # label:path format
* - name: 00-plan.md # item format
* format: plan
* report:
* - Scope: 01-scope.md # label:path format
* - name: 00-plan.md # item format
* format: plan
*
* Output: OutputContractEntry[]
*/
function normalizeOutputContracts(
raw: Array<Record<string, string> | { name: string; order?: string; format?: string }> | undefined,
raw: { report?: Array<Record<string, string> | { name: string; order?: string; format?: string }> } | undefined,
pieceDir: string,
resolvedReportFormats?: Record<string, string>,
): OutputContractEntry[] | undefined {
if (raw == null || raw.length === 0) return undefined;
if (raw?.report == null || raw.report.length === 0) return undefined;
const result: OutputContractEntry[] = [];
for (const entry of raw) {
for (const entry of raw.report) {
if (isOutputContractItem(entry)) {
// Item format: {name, order?, format?}
const item: OutputContractItem = {