spec-implementation-plan
npx skills add https://github.com/zixun-github/aisdlc --skill spec-implementation-plan
Agent 安装分布
Skill 文档
spec-implementation-planï¼I1ï¼å®ç°è®¡å / plan.md SSOTï¼
æ¦è§
I1 çç®æ æ¯æ {FEATURE_DIR}/requirements/* ä¸ {FEATURE_DIR}/design/* 转æ¢ä¸ºå¯ç´æ¥æ§è¡çå®ç°è®¡å {FEATURE_DIR}/implementation/plan.mdï¼å¹¶å°å
¶ä½ä¸ºå¯ä¸æ§è¡æ¸
åä¸ç¶æ SSOTï¼checkbox ä»»å¡ + æ¯ä»»å¡æ¥éª¤ + æå°éªè¯ + æäº¤ç¹ + 审计信æ¯ï¼ã
å¼å§æ¶å®£å¸ï¼ãææ£å¨ä½¿ç¨ spec-implementation-plan æè½å建å®ç°è®¡åï¼plan.md SSOTï¼ãã
使¶ä½¿ç¨ / ä¸ä½¿ç¨
- ä½¿ç¨æ¶æº
- ä½ éè¦äº§åºææ´æ°
{FEATURE_DIR}/implementation/plan.mdï¼I1 å¿ åï¼ã - ä½ åå¤è¿å ¥ I2 æ§è¡ï¼ä½å½å没æâå¯å¾é + 坿§è¡âç任塿¸ åã
- ä½ éè¦äº§åºææ´æ°
- ä¸è¦ç¨å¨
spec-contextå¤±è´¥ãæ¿ä¸å°FEATURE_DIRï¼æ¤æ¶å¿ 须忢ï¼ã- è¾å
¥ä¾§ SSOT ä¸è¶³ï¼
requirements/solution.mdä¸requirements/prd.mdé½ä¸åå¨ï¼ä¸æ æ³è¿½æº¯èå´/éªæ¶ï¼å¿ é¡»å¨ plan.md æ æ³¨ NEEDS CLARIFICATION 并黿è¿å ¥ I2ï¼ã
é¨ç¦ / 忢ï¼ä¸¥æ ¼æ§è¡ï¼
REQUIRED SUB-SKILLï¼å
满足 spec-context é¨ç¦å¹¶å¨å¯¹è¯ä¸åæ¾ FEATURE_DIR=...ï¼å
许 (reuse)ï¼ã
$repoRoot = (git rev-parse --show-toplevel)
if ($null -ne $FEATURE_DIR -and (Test-Path $FEATURE_DIR) -and (Test-Path (Join-Path $FEATURE_DIR "requirements"))) {
Write-Host "FEATURE_DIR=$FEATURE_DIR (reuse)"
} else {
. (Join-Path $repoRoot "skills\spec-context\scripts\spec-common.ps1")
$context = Get-SpecContext
$FEATURE_DIR = $context.FEATURE_DIR
Write-Host "FEATURE_DIR=$FEATURE_DIR"
}
ç«å»åæ¢ï¼æ»¡è¶³å ¶ä¸å³å¯ï¼ï¼
- æªå¾å°
FEATURE_DIR - 忝/ç®å½ä¸ç¡®å®ï¼ä½ åç°èªå·±æ³âç
.aisdlc/specs/...è·¯å¾âï¼ requirements/solution.mdä¸requirements/prd.mdå缺失ï¼å¯¼è´ç®æ /èå´/éªæ¶å£å¾æ æ³è¿½æº¯- ä»»ä½å
³é®ä¸ç¡®å®æ§æ æ³å¨è¾å
¥ä¸è¯æ®åï¼å¿
é¡»åå
¥
plan.md/## NEEDS CLARIFICATIONï¼å¹¶æç¡®â黿è¿å ¥ I2âï¼
è¾å ¥ / è¾åºï¼è½ç约å®ï¼
- 读åï¼æ¸è¿å¼æ«é²ï¼æå°å¿
è¦ï¼
- 项ç®çº§ï¼å¿
读å
¶ç´¢å¼æå¿
è¦ç段ï¼ï¼
project/memory/*ãproject/contracts/ãproject/adr/ - Spec çº§ï¼æéæå°è¯»ï¼ï¼
{FEATURE_DIR}/requirements/solution.mdæ{FEATURE_DIR}/requirements/prd.mdï¼è³å°å ¶ä¸ï¼ - å½±ååæï¼å¼ºå¶ï¼è¥æ solution.mdï¼ï¼å¿
须读å
{FEATURE_DIR}/requirements/solution.md#impact-analysisï¼æåå影忍¡åæ¸ åä¸ééµå®çä¸åéï¼ä½ä¸º I1 ç约æè¾å ¥ï¼ç¼ºå¤±å忢并åå° R1 è¡¥é½ï¼ - Spec 级ï¼å¦åå¨ä¸ç¸å
³ï¼ï¼
{FEATURE_DIR}/design/design.mdã{FEATURE_DIR}/design/research.md
- 项ç®çº§ï¼å¿
读å
¶ç´¢å¼æå¿
è¦ç段ï¼ï¼
- åå
¥ï¼å¯ä¸ï¼
{FEATURE_DIR}/implementation/plan.md
å°åä»»å¡ç²åº¦ï¼éç¨ writing-plansï¼
æ¯ä¸æ¥æ¯ä¸ä¸ªå¨ä½ï¼2â5 åéï¼ï¼å¹¶å¨ plan.md ä¸åå°âä»»ä½äººç
§æå³å¯æ§è¡âï¼
- ãå失败æµè¯ãï¼å¦éç¨ï¼- 䏿¥
- ãè¿è¡ç¡®ä¿å¤±è´¥ã- 䏿¥
- ãå®ç°è®©æµè¯éè¿çæå°ä»£ç ã- 䏿¥
- ãè¿è¡éªè¯ç¡®ä¿éè¿ã- 䏿¥
- ãæäº¤ãï¼é¢ç¹æäº¤ï¼- 䏿¥
约æï¼I1 åªå计åï¼ä¸å代ç ï¼ä½æ¯ä¸ªä»»å¡å¿ 须声æå ¶æå°éªè¯æ¹å¼ï¼å½ä»¤ + ææä¿¡å·ï¼ã
plan.md 头é¨ï¼å¿
é¡»ï¼
å¿
须以该头é¨å¼å¤´ï¼æ¨¡æ¿è§ ./assets/plan-template.mdï¼ï¼
# [éæ±å] å®ç°è®¡åï¼SSOTï¼
> **å¿
éæè½ï¼** `spec-implementation-execute`ï¼ææ¹æ¬¡æ§è¡æ¬è®¡åï¼
> **ä¸ä¸æé¨ç¦ï¼** å¿
é¡»å
ç¨ `spec-context` å®ä½ `{FEATURE_DIR}`ï¼å¤±è´¥å³åæ¢
**ç®æ ï¼** [ä¸å¥è¯æè¿°è¦äº¤ä»ä»ä¹]
**èå´ï¼** In / Out
**æ¶æï¼** [2â3 奿¹æ³è¯´æ + å
³é®çº¦æ]
**éªæ¶å£å¾ï¼** [å¼ç¨ requirements/solution.md æ requirements/prd.md ç AC/éªæ¶ç¹]
**å½±åèå´ï¼** [å¼ç¨ requirements/solution.md#impact-analysis çå影忍¡åæ¸
å]
**ééµå®çä¸åéï¼** [ä» requirements/solution.md#impact-analysis æåçå
³é® API/Data å¥çº¦ä¸åé]
---
è®¡åæ£æï¼å¿ é¡»ï¼
- TL;DRï¼ä¸å¥è¯æ¦æ¬è®¡åç®æ ä¸èå´
- èå´ä¸è¾¹çï¼In/Outï¼å¯¹é½éæ±ä¸è®¾è®¡ï¼
- å½±åèå´ä¸çº¦æï¼å¿
å¡«ï¼ï¼
- å影忍¡åæ¸
ååå½±åç±»åï¼å¼ç¨
requirements/solution.md#impact-analysisï¼ - ééµå®ç API/Data å¥çº¦ä¸åéï¼éæ¡ååºï¼æ æ³¨æ¥æºæ¨¡å/éç¹ï¼
- 跨模åå½±åä¸åè°äºé¡¹ï¼åºäºä¾èµå ³ç³»å¾/å½±ååæï¼
- å影忍¡åæ¸
ååå½±åç±»åï¼å¼ç¨
- éç¨ç¢ä¸èå¥ï¼é¶æ®µæåãæ¶é´é¢ä¼°ã交ä»ç©æ¸ å
- ä¾èµä¸èµæºï¼å¤é¨ç³»ç»/å¢é/æé/ç¯å¢/æ°æ®ä¾èµ
- é£é©ä¸éªè¯ï¼é£é©æ¸ åãéªè¯æ¹å¼ãOwner
- éªæ¶å£å¾ï¼å¯¹åº PRD/æ¹æ¡çå ³é® AC ä¸éªæ¶äºº
- NEEDS CLARIFICATIONï¼å¿ é¡»æï¼ï¼ç»ä¸ååºæªæ¶é¤çä¸ç¡®å®é¡¹ï¼æªæ¶é¤åä¸å¾è¿å ¥ I2ï¼
ä»»å¡ç»æï¼éç¨ writing-plansï¼ä½å å ¥ SSOT/审计/é¨ç¦ï¼
plan.md å
å¿
é¡»å
å«å¯å¾éç任塿¸
åï¼ä½ä¸ºå¯ä¸çæ§è¡æ¸
åä¸ç¶ææ¥æºï¼- [ ]/- [x]ï¼ã
æ¯ä¸ªä»»å¡å¿ é¡»å å«ï¼
- 精确æä»¶è·¯å¾ï¼å建/ä¿®æ¹/æµè¯ï¼
- å¯éªè¯éªæ¶ç¹ï¼å¯æµè¯æ¡ä»¶ï¼
- 坿§è¡æ¥éª¤ï¼å½ä»¤ + ææè¾åº/ä¿¡å·ï¼
- æäº¤ç¹ä¸æå°å®¡è®¡ä¿¡æ¯ï¼
commit/pr/changed_filesï¼
任塿¨¡æ¿ï¼ç¤ºä¾éª¨æ¶ï¼ï¼
## 任塿¸
åï¼SSOTï¼
### Task T1: [任塿 é¢]
- [ ] **ç¶æ**ï¼æªå¼å§ / è¿è¡ä¸ / 宿 / é»å¡ï¼é»å¡å¿
é¡»åæåè¯è·¯å¾ï¼
**æä»¶ï¼**
- å建ï¼`exact/path/to/new.file`
- ä¿®æ¹ï¼`exact/path/to/existing.file`ï¼å¯éï¼ç²¾ç¡®å°æ®µè½/彿°ï¼
- æµè¯ï¼`tests/exact/path/to/test.file`ï¼å¦éç¨ï¼
**éªæ¶ç¹ï¼**
- [å¯éªè¯æ¡ä»¶ 1]
- [å¯éªè¯æ¡ä»¶ 2]
**æ¥éª¤ 1ï¼å失败æµè¯ï¼å¦éç¨ï¼**
- ä¿®æ¹ç¹ï¼`tests/...`
- Run: `[精确å½ä»¤]`
- Expected: FAILï¼ååºææçå°çå
³é®å¤±è´¥ä¿¡å·ï¼
**æ¥éª¤ 2ï¼åæå°å®ç°**
- ä¿®æ¹ç¹ï¼`path/to/file`
**æ¥éª¤ 3ï¼è¿è¡éªè¯**
- Run: `[精确å½ä»¤]`
- Expected: PASSï¼ååºææçå°çå
³é®éè¿ä¿¡å·ï¼
**æ¥éª¤ 4ï¼æäº¤ï¼é¢ç¹æäº¤ï¼commit message å¿
须䏿ï¼**
- Commit message: `[ä¸å¥è¯è¯´æ whyï¼ä¸æï¼]`
- 审计信æ¯ï¼`commit=<TBD>`ã`pr=<TBD>`ã`changed_files=<TBD>`
å½ä»¤ä¹¦å约å®ï¼é»è®¤é¢å PowerShellï¼åä¸è¡å¤å½ä»¤è¯·ç¨
;åéï¼ä¸è¦ç¨&&ï¼ã
I1-DoDï¼é¨ç¦ï¼ç¼ºä¸ä¸å¯ï¼
- 计åèå´ä¸
{FEATURE_DIR}/requirements/*ã{FEATURE_DIR}/design/*ä¸è´ä¸å¯è¿½æº¯ - éç¨ç¢æç¡®ä¸å¯éªæ¶ï¼æ¯ä¸é¡¹æå¯¹åºäº§ç©æå¯éªè¯æ åï¼
- ä¾èµä¸é£é©å·²ååºï¼å¹¶ææå°éªè¯/ç¼è§£å¨ä½ï¼å« Ownerï¼
- å
³é®éªæ¶å£å¾å¯è¿½æº¯ï¼è³å°å¼ç¨
requirements/prd.mdærequirements/solution.mdï¼ - å½±åèå´ä¸çº¦æå·²æ³¨å
¥ï¼
plan.mdå 嫔影åèå´ä¸çº¦æ”段è½ï¼å影忍¡åä¸ééµå®çä¸åéå·²ä»requirements/solution.md#impact-analysisæåå¹¶éæ¡ååº plan.mdå åå¨â任塿¸ åï¼SSOTï¼âï¼ä¸æ¯ä¸ªä»»å¡å å«ï¼æä»¶è·¯å¾ãéªæ¶ç¹ãæå°éªè¯æ¹å¼ãæäº¤ç¹ä¸å®¡è®¡ä¿¡æ¯- ä»»ä½ä¸ç¡®å®é¡¹åè¿å
¥
NEEDS CLARIFICATIONï¼ä¸æªæ¶é¤åä¸å¾è¿å ¥ I2
ç¢è®°ï¼é«é¢è§å鿥ï¼
- å§ç»å
spec-contextæ¿å°FEATURE_DIR=...ï¼å¤±è´¥å°±åæ¢ - å§ç»å精确路å¾ã精确å½ä»¤ä¸ææä¿¡å·
- ä¸è¦æä¸ç¡®å®æ§åæå·²ç¥ï¼ç»ä¸è¿å
¥
NEEDS CLARIFICATION并黿 I2 - DRYãYAGNIãTDDãé¢ç¹æäº¤ï¼è®¡åéä¹è¦ä½ç°æäº¤èå¥ï¼
æ§è¡äº¤æ¥ï¼åå® plan.md ä¹åï¼
ä¿å计ååï¼æ¬æè½ä¸åå³å®âä¸ä¸æ¥/æ§è¡æ¹å¼âãç»ä¸åæ³ï¼
- 宣å¸ï¼
{FEATURE_DIR}/implementation/plan.mdå·²è½çï¼ä¸æ¯å®ç°ä¾§å¯ä¸ SSOT - æç¤ºï¼åå°
using-aisdlcè¿è¡ä¸ä¸æ¥è·¯ç±ï¼é常路ç±å° I2ï¼spec-implementation-executeï¼åå° Finishï¼finishing-developmentï¼ - è¥ç¨æ·æç¡®è¦æ±âæ¬ä¼è¯ä½¿ç¨ subagent-driven-development å¹¶è¡æ§è¡âï¼ä¹åºå
åå°
using-aisdlcæç¡®è·¯ç±ç»è®ºååå¼å§æ§è¡ï¼é¿å åºç°ç¬¬äºä¸ªè·¯ç±æºï¼
宿åè¾åºï¼ä¾ using-aisdlc èªå¨æ¨è¿è¯»åï¼
å¨åçæ«å°¾è¿½å 以ä¸ä¸¤æ®µï¼ä¸è¦çç¥ï¼ï¼
- ãæ¬é¶æ®µäº§ç©å·²è½çã请åå°
using-aisdlcè¿è¡ä¸ä¸æ¥è·¯ç±ï¼å¦æªè§¦å人工é¨ç¦ï¼Router å¯èªå¨ç»è·ï¼ãã ROUTER_SUMMARYï¼
ROUTER_SUMMARY:
stage: I1
artifacts:
- "{FEATURE_DIR}/implementation/plan.md"
needs_human_review: true
blocked: false
block_reason: ""
notes: "plan.md 建议è¯å®¡ååè¿å
¥ I2 æ§è¡"