doc-smith-create
npx skills add https://github.com/aigne-io/doc-smith-skills --skill doc-smith-create
Agent 安装分布
Skill 文档
DocSmith ææ¡£çæ
ä»å·¥ä½åºæ°æ®æºçæåæ´æ°ç»æåææ¡£ãææè¾åºåå»ºå¨ .aigne/doc-smith/ workspace ä¸ã
约æ
以ä¸çº¦æå¨ä»»ä½æä½ä¸é½å¿ 须满足ã
1. Workspace 约æ
- æææä½å workspace å¿ é¡»åå¨ä¸ææï¼config.yaml + sourcesï¼
- workspace æç¬ç« git ä»åºï¼ææ git æä½å¨
.aigne/doc-smith/䏿§è¡ - workspace ä¸å卿¶æä»¥ä¸æµç¨åå§åï¼
mkdir -p .aigne/doc-smith/{intent,planning,docs,assets,cache}cd .aigne/doc-smith && git init- å建 config.yamlï¼schema è§ä¸æ¹ï¼
- åå§ commit
config.yaml schemaï¼
workspaceVersion: "1.0"
createdAt: "2025-01-13T10:00:00Z" # ISO 8601
projectName: "my-project"
projectDesc: "é¡¹ç®æè¿°"
locale: "zh" # è¾åºè¯è¨ä»£ç ï¼åå§åæ¶å¿
é¡»åç¨æ·ç¡®è®¤
projectLogo: ""
translateLanguages: []
sources:
- type: local-path
path: "../../" # ç¸å¯¹äº workspace
url: "" # å¯é: git remote URL
branch: "" # å¯é: å½å忝
commit: "" # å¯é: å½å commit
locale 确认è§åï¼åå§å workspace æ¶ï¼è¥ç¨æ·æªæç¡®æå®è¯è¨ï¼å¿ é¡»ç¨ AskUserQuestion 确认è¾åºè¯è¨ï¼å¦ zhãenãjaï¼ï¼ä¸å¾é»è®¤åå ¥ã
2. ç»æçº¦æ
document-structure.yamlå¿ é¡»ç¬¦å䏿¹ schema- ç»æåæ´åå¿
é¡»éè¿
/doc-smith-check --structure - ç»æåæ´åå¿
é¡»é建 nav.jsï¼
node skills/doc-smith-build/scripts/build.mjs --nav --workspace .aigne/doc-smith --output .aigne/doc-smith/dist
document-structure.yaml schemaï¼
project:
title: "项ç®åç§°"
description: "é¡¹ç®æ¦è¿°"
documents:
- title: "ææ¡£æ é¢"
description: "ç®è¦æè¦"
path: "/filename" # å¿
须以 / å¼å¤´
sourcePaths: ["src/main.py"] # æºæä»¶è·¯å¾ï¼æ workspace: åç¼ï¼
icon: "lucide:book-open" # ä»
é¡¶å±ææ¡£å¿
é
children: # å¯éï¼åµå¥ææ¡£
- title: "åææ¡£"
description: "详ç»ä¿¡æ¯"
path: "/section/nested"
sourcePaths: ["src/utils.py"]
3. å 容约æ
- æ¯ç¯ææ¡£å¿
é¡»æ
docs/{path}/.meta.yamlï¼kind: doc, source, defaultï¼ - HTML å¿
é¡»çæå¨
dist/{lang}/docs/{path}.html docs/ç®å½ä¸ä¸å¾æ®ç.mdæä»¶ï¼æå»ºåå é¤ï¼- ææå
é¨é¾æ¥ä½¿ç¨ææ¡£ path æ ¼å¼ï¼å¦
/overview/doc-genï¼ï¼build.mjs èªå¨è½¬æ¢ä¸ºç¸å¯¹ HTML è·¯å¾ - èµæºå¼ç¨ä½¿ç¨
/assets/xxxç»å¯¹è·¯å¾æ ¼å¼ï¼build.mjs èªå¨è½¬æ¢ä¸ºç¸å¯¹è·¯å¾ï¼
4. 人类确认约æ
- ç¨æ·æå¾æ¨æåå¿ é¡»ç»ç¨æ·ç¡®è®¤ï¼ä½¿ç¨ AskUserQuestionï¼
- ææ¡£ç»æè§ååå¿ é¡»ç»ç¨æ·ç¡®è®¤ï¼ä½¿ç¨ AskUserQuestionï¼
- 确认åè¥æåæ´é忬¡ç¡®è®¤
5. ä¸ä¸æç®¡ç约æ
主 agent å¯ä»¥è¯»åé¡¹ç®æºæä»¶ï¼ä½å¿ 须为åç» Task ç»æé¢çä¸ä¸æç©ºé´ã
夿ååï¼ä¸» agent 读åçæºæä»¶é + åç»ææ Task è¿åçæè¦éï¼ä¸è½è¶ åºä¸ä¸æé¢ç®ãææ¡£è¶å¤ï¼Task ç»æè¶å¤ï¼ä¸» agent èªèº«è¯»åæºæä»¶ç空é´è¶å°ã
å®è·µè§åï¼
- ä¿®æ¹å°éå·²æææ¡£æ¶ï¼ç´æ¥è¯»åç¸å ³æºæä»¶æ²¡æé®é¢
- 馿¬¡çææ¶ï¼å
éè¿ç®å½ç»æï¼
ls/Globï¼è¯ä¼°é¡¹ç®è§æ¨¡ï¼åå³å®ç»æè§åæ¹å¼ï¼- å°é¡¹ç®ï¼æºæä»¶å°ãé¢è®¡ææ¡£ ⤠5 ç¯ï¼ï¼ä¸» agent å¯ç´æ¥è¯»åæºæä»¶å¹¶è§åç»æ
- 大项ç®ï¼æºæä»¶å¤ãé¢è®¡ææ¡£ > 5 ç¯ï¼ï¼å°ç»æè§åå§æ´¾ç» Taskï¼è§”å ³é®æµç¨”ï¼
6. Task åå约æ
Task ç±»åï¼
- ç»æè§å Taskï¼æéï¼ï¼å½é¡¹ç®è¾å¤§æ¶ï¼å§æ´¾ Task åææºæä»¶çæ
document-structure.yamlè稿 - å å®¹çæ Taskï¼æ”å¹¶è¡çæææ¡£å 容”ä¸ç prompt 模æ¿ååï¼æ¯ç¯ææ¡£ä¸ä¸ª Task
ååè§åï¼
- ææ¡£æ°é ⤠5 æ¶å¹¶è¡æ§è¡ï¼> 5 æ¶åæ¹ï¼æ¯æ¹ ⤠5 个ï¼ï¼å䏿¹å®æååå¯å¨ä¸ä¸æ¹
- å
容çæåå
æ§è¡åªä½èµæºæ«æï¼
Glob: **/*.{png,jpg,jpeg,gif,svg,mp4,webp}ï¼æé¤ .aigne/ å node_modules/ï¼ï¼å°ç»æä½ä¸º mediaFiles ä¼ éç»æ¯ä¸ª Task - ææ Task è¿åçæè¦å¿ é¡»ç®çï¼â¤ 10 è¡ï¼ï¼é¿å è¿åæä»¶å 容
7. å®æçº¦æ
/doc-smith-check --structureéè¿/doc-smith-check --contentéè¿dist/ç®å½å å«ææææ¡£ç HTMLnav.jså å«ææææ¡£æ¡ç®- èªå¨ git commitï¼å¨
.aigne/doc-smith/ç®å½ä¸ï¼
ç»ä¸å ¥å£
| åºæ¯ | 夿æ¡ä»¶ | è¡ä¸º |
|---|---|---|
| 馿¬¡çæ | docs/ ä¸åå¨æç¨æ·æç¡®è¦æ± |
宿´æµç¨ï¼æå¾ â ç»æ â çæ |
| ä¿®æ¹å·²æææ¡£ | docs/ å·²åå¨ |
AI ç解修æ¹è¯·æ±ï¼ç´æ¥ä¿®æ¹ï¼æ»¡è¶³çº¦æå³å¯ |
ä¿®æ¹åºæ¯ä¸éè¦ changeset/PATCH æºå¶ãç¨æ·ç¨èªç¶è¯è¨æè¿°ä¿®æ¹éæ±ï¼AI æ§è¡å¹¶æ»¡è¶³çº¦æã
ç¨æ·æå¾
æä»¶ï¼.aigne/doc-smith/intent/user-intent.md
åºäºé¡¹ç® README åç®å½ç»æï¼ls/Globï¼æ¨æç®æ ç¨æ·ã使ç¨åºæ¯ãææ¡£ä¾§éç¹ãçæåç¨ AskUserQuestion 确认ã
# ç¨æ·æå¾
## ç®æ ç¨æ·
[主è¦å伿¯è°]
## 使ç¨åºæ¯
- [åºæ¯ 1]
- [åºæ¯ 2]
## ææ¡£ä¾§éç¹
æ¬ææ¡£éç¨**[ææ¡£ç±»å]**çå½¢å¼ï¼
- [ä¾§éç¹ 1]
- [ä¾§éç¹ 2]
ç»æè§ååå
- è§åå¿ é¡»ä¾æ®ç¨æ·æå¾ï¼åªè§åæç¡®éè¦çææ¡£
- æå¹³ä¼äºåµå¥ï¼æçèæ¶éæ©æ´ç®åçç»æ
- æåæ¡ä»¶ï¼4+ ç« èãå 容ç¬ç«ãæ éå¤ãå¯ç¬ç«æ¥é
- 䏿åï¼å 容åèãé¡ºåºæ¥éª¤ãåå¨éå¤
- ç»æè§ååç¨ AskUserQuestion 确认ï¼å±ç¤ºææ¡£æ»æ°ã屿¬¡ãæ¯ä¸ªææ¡£çæ é¢åæè¿°
å 容ç»ç»åå
- 导èªé¾æ¥åªè½é¾æ¥å·²çæçææ¡£ï¼ä½¿ç¨ path æ ¼å¼ï¼ï¼ä¸é¾æ¥å·¥ä½ç®å½æä»¶
- ææ¡£å¼å¤´ï¼åç½®æ¡ä»¶ãç¶ä¸»é¢
- ææ¡£ç»å°¾ï¼ç¸å ³ä¸»é¢ãä¸ä¸æ¥ãåææ¡£
- æåææ¡£çæ¦è§ææ¡£ï¼ç®åï¼150-300 è¡ï¼ï¼æ¯ä¸ªåä¸»é¢ 2-4 段 + å¼å¯¼é¾æ¥
- æ åææ¡£çè¯¦ç»ææ¡£ï¼è¯¦åï¼300-500 è¡ï¼ï¼å®æ´å±å¼
å ³é®æµç¨
ç»æè§å
主 agent çæ user-intent.md å¹¶ç»ç¨æ·ç¡®è®¤åï¼æ ¹æ®é¡¹ç®è§æ¨¡éæ©ç»æè§åæ¹å¼ï¼
- å°é¡¹ç®ï¼ä¸» agent ç´æ¥è¯»åæºæä»¶ï¼åæåçæ
document-structure.yaml - 大项ç®ï¼å§æ´¾ Task åææºæä»¶å¹¶çæ
document-structure.yamlè稿ï¼Task è¿åæä»¶è·¯å¾ + ç»ææè¦ï¼â¤ 10 è¡ï¼
çæåç¨ AskUserQuestion åç¨æ·ç¡®è®¤ï¼å±ç¤ºææ¡£æ»æ°ã屿¬¡ãæ¯ä¸ªææ¡£çæ é¢åæè¿°ã
çæ nav.jsï¼ç»æç¡®è®¤åãå 容çæåï¼
node skills/doc-smith-build/scripts/build.mjs \
--nav --workspace .aigne/doc-smith --output .aigne/doc-smith/dist
å¹¶è¡çæææ¡£å 容
æ¯ç¯ææ¡£ä½¿ç¨åç¬ç Task tool çæï¼â¤ 5 ç¯å¹¶è¡ï¼> 5 ç¯åæ¹ï¼ãå¿ é¡»ä½¿ç¨ä»¥ä¸æ¨¡æ¿æé Task promptï¼ä¸å¾èªè¡æ¦æ¬ content.md å 容ï¼
ä½ æ¯ææ¡£å
容çæä»£çã请å
ç¨ Read å·¥å
·è¯»å {CONTENT_MD_PATH} ä½ä¸ºä½ ç宿´å·¥ä½æµç¨ï¼ç¶åä¸¥æ ¼æç
§å
¶ä¸çæ¥éª¤æ§è¡ã
åæ°ï¼
- ææ¡£è·¯å¾ï¼{docPath}
- workspaceï¼{WORKSPACE_PATH}
- å¯é¾æ¥ææ¡£å表ï¼{LINKABLE_DOCS}
- mediaFilesï¼{MEDIA_FILES}
- ç¨æ·æå¾æè¦ï¼{INTENT_SUMMARY}
å
³é®å·¥å
·è¯´æï¼
- ä½¿ç¨ Skill å·¥å
·è°ç¨ /doc-smith-images çæå¾çï¼æ¥éª¤ 5.5ï¼
- ä½¿ç¨ Skill å·¥å
·è°ç¨ /doc-smith-check æ ¡éªææ¡£ï¼æ¥éª¤ 7ï¼
å®ææ£æ¥æ¸
åï¼å¿
é¡»å¨è¿åæè¦åé项确认ï¼ï¼
â¡ æ¥éª¤ 5 å¾ç使ç¨ï¼ææ¡£ä¸å·²æéæ·»å å¾çå¼ç¨
â¡ æ¥éª¤ 5.5 å¾ççæï¼å·²æ«æå¹¶å¤çææ /assets/{key}/images/ å¼ç¨
â¡ æ¥éª¤ 6.5 HTML æå»ºï¼å·²æ§è¡ build.mjs --doc 并确认 HTML çæ
â¡ æ¥éª¤ 7 æ ¡éªï¼å·²è°ç¨ /doc-smith-check --content --path {docPath}
模æ¿åé说æï¼
{CONTENT_MD_PATH}ï¼references/content.mdçç»å¯¹è·¯å¾{WORKSPACE_PATH}ï¼.aigne/doc-smithçç»å¯¹è·¯å¾{docPath}ï¼ææ¡£è·¯å¾ï¼å¦/overview{LINKABLE_DOCS}ï¼ææææ¡£è·¯å¾å表ï¼ä» document-structure.yaml æåï¼{MEDIA_FILES}ï¼åªä½èµæºæ«æç»æ{INTENT_SUMMARY}ï¼user-intent.md ç 2-3 å¥è¯æè¦
AI å·¡æ£
æå»ºå®æåï¼è¯»å dist/ ä¸çæç HTML æä»¶ï¼æ¯ç§è¯è¨åæ½æ¥ 1-2 个页é¢ï¼ï¼æ£æ¥è¾åºæ¯å¦ç¬¦å颿ã妿é®é¢ç´æ¥ä¿®æ¹ HTML æä»¶ä¿®å¤ã
èªå¨æäº¤
cd .aigne/doc-smith && git add . && git commit -m "docsmith: xxx"
Workspace ç®å½ç»æ
.aigne/doc-smith/
âââ config.yaml
âââ intent/user-intent.md
âââ planning/document-structure.yaml
âââ docs/{path}/.meta.yaml
âââ dist/
â âââ index.html
â âââ {lang}/docs/{path}.html
â âââ assets/nav.js, docsmith.css, theme.css
âââ assets/{key}/.meta.yaml, images/{lang}.png
âââ glossary.yaml # å¯é
âââ cache/translation-cache.yaml # åå¸ç¨