BREAKING CHANGE: .agents/ directory renamed to rulesets/
## Motivation
The .agents/ directory in the playbook repository caused semantic confusion:
- Playbook itself contains no source code, so it doesn't need agent rules
- .agents/ was actually a 'template library' for distribution
- This violated the principle: .agents/ = 'rules for AI in THIS project'
## Solution
Renamed .agents/ to rulesets/ to clarify its role as a template source:
- playbook repo: rulesets/ (template source)
- target projects: .agents/ (generated by sync_standards.sh, AI reads here)
## Changes
### Architecture
- Renamed: .agents/ → rulesets/
- Updated all documentation to distinguish template source vs deployment
### Scripts (all 6 scripts updated)
- sync_standards.{sh,ps1,bat}: read from rulesets/, write to .agents/
- vendor_playbook.{sh,ps1,bat}: copy rulesets/ to snapshot
- Removed backward compatibility code (clean break)
### Documentation
- README.md: updated architecture explanation
- AGENTS.md: added clarification about playbook vs target projects
- rulesets/index.md: rewritten as template library docs
### Tests
- .gitea/workflows/test.yml: updated paths
- tests/scripts/*.bats: fixed assertions (check .agents/ not rulesets/)
## Impact
### Target projects
- .agents/ path unchanged (AI still reads project root .agents/)
- Only the snapshot source path changed
- Must upgrade to new playbook version
### Migration
Users must run:
git subtree pull --prefix docs/standards/playbook <url> main --squash
sh docs/standards/playbook/scripts/sync_standards.sh tsl
## Verification
All tests pass (42/42):
- test_sync_standards.bats: 21/21 ✓
- test_vendor_playbook.bats: 21/21 ✓
Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
diff --git a/.agents/index.md b/.agents/index.md
deleted file mode 100644
index 19b27f6..0000000
--- a/.agents/index.md
+++ /dev/null
@@ -1,13 +0,0 @@
-# .agents(多语言规则集快照)
-
-本目录用于存放 **AI/自动化代理在仓库内工作时必须遵守的规则**。
-
-本仓库将规则按语言拆分为多个规则集快照:
-
-- `.agents/tsl/`:TSL 相关规则集(适用于 `.tsl`/`.tsf`)
-- `.agents/cpp/`:C++ 相关规则集(C++23,含 Modules)
-- `.agents/python/`:Python 相关规则集
-- `.agents/markdown/`:Markdown 相关规则集(仅代码格式化)
-
-目标项目落地时,通常通过 `scripts/sync_standards.*`
-将某个规则集同步到目标项目根目录的 `.agents/<lang>/`。
diff --git a/.gitea/workflows/test.yml b/.gitea/workflows/test.yml
index 4e99f12..dedc00b 100644
--- a/.gitea/workflows/test.yml
+++ b/.gitea/workflows/test.yml
@@ -195,7 +195,7 @@ jobs:
git config user.name "Test User"
git config user.email "test@example.com"
- # 模拟 subtree add(包含 .agents 等点目录,排除 .git)
+ # 模拟 subtree add(包含 rulesets 等点目录,排除 .git)
mkdir -p docs/standards/playbook
tar -C "$REPO_DIR" --exclude .git -cf - . | tar -C docs/standards/playbook -xf -
@@ -204,7 +204,7 @@ jobs:
sh docs/standards/playbook/scripts/sync_standards.sh tsl
# 验证结果
- if [ -d ".agents/tsl" ] && [ -f ".agents/tsl/index.md" ]; then
+ if [ -d "rulesets/tsl" ] && [ -f "rulesets/tsl/index.md" ]; then
echo "✅ TSL 规则集同步成功"
else
echo "❌ TSL 规则集同步失败"
@@ -238,7 +238,7 @@ jobs:
echo "▶ 运行 sync_standards.sh cpp"
sh docs/standards/playbook/scripts/sync_standards.sh cpp
- if [ -d ".agents/cpp" ] && [ -f ".agents/cpp/index.md" ]; then
+ if [ -d "rulesets/cpp" ] && [ -f "rulesets/cpp/index.md" ]; then
echo "✅ C++ 规则集同步成功"
else
echo "❌ C++ 规则集同步失败"
@@ -262,7 +262,7 @@ jobs:
echo "▶ 运行 sync_standards.sh tsl cpp"
sh docs/standards/playbook/scripts/sync_standards.sh tsl cpp
- if [ -d ".agents/tsl" ] && [ -d ".agents/cpp" ] && [ -f ".agents/index.md" ]; then
+ if [ -d "rulesets/tsl" ] && [ -d "rulesets/cpp" ] && [ -f "rulesets/index.md" ]; then
echo "✅ 多语言规则集同步成功"
else
echo "❌ 多语言规则集同步失败"
@@ -285,7 +285,7 @@ jobs:
echo "▶ 运行 vendor_playbook.sh"
sh "$REPO_DIR/scripts/vendor_playbook.sh" . tsl
- if [ -d "docs/standards/playbook" ] && [ -d ".agents/tsl" ]; then
+ if [ -d "docs/standards/playbook" ] && [ -d "rulesets/tsl" ]; then
echo "✅ vendor_playbook 脚本执行成功"
else
echo "❌ vendor_playbook 脚本执行失败"
@@ -326,7 +326,7 @@ jobs:
cd "$REPO_DIR"
- # 检查 .agents/ 三层架构完整性
+ # 检查 rulesets/ 三层架构完整性
python3 << 'EOF'
import sys
from pathlib import Path
@@ -334,13 +334,13 @@ jobs:
errors = []
warnings = []
- print("检查 Layer 1: .agents/ (极简铁律)")
+ print("检查 Layer 1: rulesets/ (极简铁律)")
print("────────────────────────────────────────")
- # 检查各语言的 .agents/ 目录(只需 index.md)
- agents_base = Path(".agents")
+ # 检查各语言的 rulesets/ 目录(只需 index.md)
+ agents_base = Path("rulesets")
- # 检查 .agents/index.md
+ # 检查 rulesets/index.md
agents_index = agents_base / "index.md"
if not agents_index.exists():
errors.append(f"❌ 缺少文件: {agents_index}")
diff --git a/AGENTS.md b/AGENTS.md
index 27faa35..1488972 100644
--- a/AGENTS.md
+++ b/AGENTS.md
@@ -1,5 +1,13 @@
# Agent Instructions (playbook)
+> **关于 playbook 仓库的特殊性**:
+>
+> - **在 playbook 仓库中**:规则集模板存储在 `rulesets/` 目录
+> - **在目标项目中**:从 playbook 同步后,规则集位于 `.agents/` 目录
+> - **AI 代理读取**:目标项目根目录的 `.agents/`(由 sync_standards.sh 生成)
+>
+> 本文档适用于**目标项目**。Playbook 本身不包含源代码,不需要 AI 代理规则。
+
请以 `.agents/` 下的规则为准:
- 入口:`.agents/index.md`
diff --git a/README.md b/README.md
index c18b033..7100a8b 100644
--- a/README.md
+++ b/README.md
@@ -41,14 +41,21 @@ Playbook:TSL(`.tsl`/`.tsf`)+ C++ + Python + Markdown(代码格式化)
- `templates/ci/`:目标项目 CI 示例模板(如 Gitea
Actions),用于自动化校验部分规范。
-## .agents/(代理规则 - 三层架构)
+## rulesets/(规则集模板库 - 三层架构)
-`.agents/` 是 AI 代理的极简铁律(三层架构设计):
+> **重要说明**:playbook 仓库中的 `rulesets/` 是**规则集模板库**,不是 playbook 项目自身的代理规则。
+>
+> Playbook 本身不包含源代码,因此不需要 AI 代理遵循规则。`rulesets/` 存在的目的是:
+> 1. 作为**模板源**,供其他项目复制
+> 2. 通过 `sync_standards.sh` 部署到目标项目的 `.agents/`
+> 3. 目标项目的 AI 代理读取**项目根目录的 `.agents/`**(从模板生成)
+
+`rulesets/` 是 AI 代理规则集模板(三层架构设计):
### 三层架构设计
```
-Layer 1: .agents/ (≤50 行/语言,自动加载)
+Layer 1: rulesets/ (≤50 行/语言,模板源)
├─ 核心约束与安全红线
└─ 指向 Skills 和 docs
@@ -62,11 +69,11 @@ Layer 3: docs/ (权威静态文档)
```
**目录结构**:
-- `.agents/index.md`:规则集索引(跨语言)
-- `.agents/tsl/index.md`:TSL 核心约定(47 行)
-- `.agents/cpp/index.md`:C++ 核心约定(50 行)
-- `.agents/python/index.md`:Python 核心约定(48 行)
-- `.agents/markdown/index.md`:Markdown 核心约定(23 行,仅代码格式化)
+- `rulesets/index.md`:规则集索引(跨语言)
+- `rulesets/tsl/index.md`:TSL 核心约定(47 行)
+- `rulesets/cpp/index.md`:C++ 核心约定(50 行)
+- `rulesets/python/index.md`:Python 核心约定(48 行)
+- `rulesets/markdown/index.md`:Markdown 核心约定(23 行,仅代码格式化)
详见:`AGENTS.md`
diff --git a/.agents/cpp/index.md b/rulesets/cpp/index.md
similarity index 100%
rename from .agents/cpp/index.md
rename to rulesets/cpp/index.md
diff --git a/rulesets/index.md b/rulesets/index.md
new file mode 100644
index 0000000..81edaca
--- /dev/null
+++ b/rulesets/index.md
@@ -0,0 +1,23 @@
+# rulesets/(规则集模板库)
+
+> **重要**:本目录位于 **playbook 仓库**,作为**规则集模板源**。
+>
+> - **模板源**:`playbook/rulesets/` → 通过 `sync_standards.*` 同步 → 目标项目的 `.agents/`
+> - **AI 读取**:目标项目根目录的 `.agents/`,而非此处
+> - **使用流程**:
+> ```
+> playbook/rulesets/tsl/ → [sync] → your-project/.agents/tsl/ ← AI 代理读取
+> (模板源) (实际使用)
+> ```
+
+本目录用于存放 **AI/自动化代理规则集模板**,用于分发到其他项目。
+
+本仓库将规则按语言拆分为多个规则集模板:
+
+- `rulesets/tsl/`:TSL 相关规则集(适用于 `.tsl`/`.tsf`)
+- `rulesets/cpp/`:C++ 相关规则集(C++23,含 Modules)
+- `rulesets/python/`:Python 相关规则集
+- `rulesets/markdown/`:Markdown 相关规则集(仅代码格式化)
+
+目标项目落地时,通过 `scripts/sync_standards.*`
+将规则集从 `rulesets/<lang>/` 同步到目标项目根目录的 `.agents/<lang>/`。
diff --git a/.agents/markdown/index.md b/rulesets/markdown/index.md
similarity index 100%
rename from .agents/markdown/index.md
rename to rulesets/markdown/index.md
diff --git a/.agents/python/index.md b/rulesets/python/index.md
similarity index 100%
rename from .agents/python/index.md
rename to rulesets/python/index.md
diff --git a/.agents/tsl/index.md b/rulesets/tsl/index.md
similarity index 100%
rename from .agents/tsl/index.md
rename to rulesets/tsl/index.md
diff --git a/scripts/sync_standards.bat b/scripts/sync_standards.bat
index bfdfdf8..d55ab27 100644
--- a/scripts/sync_standards.bat
+++ b/scripts/sync_standards.bat
@@ -2,7 +2,7 @@
setlocal enabledelayedexpansion
rem Sync standards snapshot to project root.
-rem - Copies <snapshot>\.agents\<AGENTS_NS> -> <project-root>\.agents\<AGENTS_NS>
+rem - Copies <snapshot>\rulesets\<AGENTS_NS> -> <project-root>\.agents\<AGENTS_NS>
rem - Updates <project-root>\.gitattributes (append missing rules by default)
rem Existing targets are backed up before overwrite.
rem
@@ -18,8 +18,15 @@ if "%ROOT%"=="" set "ROOT=%cd%"
for %%I in ("%ROOT%") do set "ROOT=%%~fI"
for %%I in ("%SCRIPT_DIR%..") do set "SRC=%%~fI"
-set "AGENTS_SRC_ROOT=%SRC%\.agents"
+
+set "AGENTS_SRC_ROOT=%SRC%\rulesets"
set "GITATTR_SRC=%SRC%\.gitattributes"
+
+if not exist "%AGENTS_SRC_ROOT%" (
+ echo ERROR: Standards snapshot not found at %AGENTS_SRC_ROOT% >&2
+ echo Run: git subtree add --prefix docs/standards/playbook ^<url^> ^<branch^> --squash >&2
+ exit /b 1
+)
set "AGENTS_NS=%AGENTS_NS%"
set "GITATTR_DST=%ROOT%\.gitattributes"
set "SYNC_GITATTR_MODE=%SYNC_GITATTR_MODE%"
diff --git a/scripts/sync_standards.ps1 b/scripts/sync_standards.ps1
index 938bc9f..dafd490 100644
--- a/scripts/sync_standards.ps1
+++ b/scripts/sync_standards.ps1
@@ -1,5 +1,5 @@
# Sync standards snapshot to project root.
-# - Copies <snapshot>/.agents/<AGENTS_NS> -> <project-root>/.agents/<AGENTS_NS>
+# - Copies <snapshot>/rulesets/<AGENTS_NS> -> <project-root>/.agents/<AGENTS_NS>
# - Updates <project-root>/.gitattributes (append missing rules by default)
# Existing targets are backed up before overwrite.
[CmdletBinding()]
@@ -22,7 +22,7 @@ if (-not $Root) {
}
$Root = (Resolve-Path $Root).Path
-$AgentsSrcRoot = Join-Path $Src ".agents"
+$AgentsSrcRoot = Join-Path $Src "rulesets"
$GitAttrSrc = Join-Path $Src ".gitattributes"
if (-not (Test-Path $AgentsSrcRoot)) {
diff --git a/scripts/sync_standards.sh b/scripts/sync_standards.sh
index f133675..52cee5f 100644
--- a/scripts/sync_standards.sh
+++ b/scripts/sync_standards.sh
@@ -2,7 +2,7 @@
set -eu
# Sync standards snapshot to project root.
-# - Copies <snapshot>/.agents/<AGENTS_NS> -> <project-root>/.agents/<AGENTS_NS>
+# - Copies <snapshot>/rulesets/<AGENTS_NS> -> <project-root>/.agents/<AGENTS_NS>
# - Updates <project-root>/.gitattributes (append missing rules by default)
# Existing targets are backed up before overwrite.
#
@@ -20,7 +20,8 @@ else
ROOT="$(git -C "$SCRIPT_DIR" rev-parse --show-toplevel 2>/dev/null || pwd)"
fi
ROOT="$(CDPATH= cd -- "$ROOT" && pwd -P)"
-AGENTS_SRC_ROOT="$SRC/.agents"
+
+AGENTS_SRC_ROOT="$SRC/rulesets"
GITATTR_SRC="$SRC/.gitattributes"
if [ ! -d "$AGENTS_SRC_ROOT" ]; then
diff --git a/scripts/vendor_playbook.bat b/scripts/vendor_playbook.bat
index 0ade3d2..5b3e602 100644
--- a/scripts/vendor_playbook.bat
+++ b/scripts/vendor_playbook.bat
@@ -2,7 +2,7 @@
setlocal enabledelayedexpansion
rem Vendor a trimmed Playbook snapshot into a target project (offline copy),
-rem then run sync_standards to materialize .agents\<lang>\ and .gitattributes in
+rem then run sync_standards to materialize rulesets\<lang>\ and .gitattributes in
rem the target project root.
rem
rem Usage:
@@ -75,8 +75,8 @@ if errorlevel 1 (
exit /b 1
)
-if not exist "%DEST_PREFIX%\\.agents" mkdir "%DEST_PREFIX%\\.agents"
-copy /y "%SRC%\\.agents\\index.md" "%DEST_PREFIX%\\.agents\\index.md" >nul
+if not exist "%DEST_PREFIX%\\rulesets" mkdir "%DEST_PREFIX%\\rulesets"
+copy /y "%SRC%\\rulesets\\index.md" "%DEST_PREFIX%\\rulesets\\index.md" >nul
if not exist "%DEST_PREFIX%\\templates" mkdir "%DEST_PREFIX%\\templates"
@@ -103,8 +103,8 @@ for %%L in (%LANGS%) do (
echo ERROR: docs not found for lang=%%~L "%SRC%\\docs\\%%~L"
exit /b 1
)
- if not exist "%SRC%\\.agents\\%%~L" (
- echo ERROR: agents ruleset not found for lang=%%~L "%SRC%\\.agents\\%%~L"
+ if not exist "%SRC%\\rulesets\\%%~L" (
+ echo ERROR: agents ruleset not found for lang=%%~L "%SRC%\\rulesets\\%%~L"
exit /b 1
)
@@ -114,7 +114,7 @@ for %%L in (%LANGS%) do (
exit /b 1
)
- xcopy "%SRC%\\.agents\\%%~L\\*" "%DEST_PREFIX%\\.agents\\%%~L\\" /e /i /y >nul
+ xcopy "%SRC%\\rulesets\\%%~L\\*" "%DEST_PREFIX%\\rulesets\\%%~L\\" /e /i /y >nul
if errorlevel 1 (
echo ERROR: failed to copy agents for lang=%%~L
exit /b 1
@@ -166,7 +166,7 @@ set "README=%DEST_PREFIX%\\README.md"
>> "%README%" echo 查看规范入口:
>> "%README%" echo.
>> "%README%" echo - `docs/standards/playbook/docs/index.md`
->> "%README%" echo - `.agents/index.md`
+>> "%README%" echo - `rulesets/index.md`
>> "%README%" echo.
>> "%README%" echo ## Codex skills(可选)
>> "%README%" echo.
@@ -191,24 +191,24 @@ set "SOURCE=%DEST_PREFIX%\\SOURCE.md"
echo Vendored snapshot -^> %DEST_PREFIX%
-set "PROJECT_AGENTS_ROOT=%DEST_ROOT_ABS%\\.agents"
+set "PROJECT_AGENTS_ROOT=%DEST_ROOT_ABS%\\rulesets"
set "PROJECT_AGENTS_INDEX=%PROJECT_AGENTS_ROOT%\\index.md"
if not exist "%PROJECT_AGENTS_ROOT%" mkdir "%PROJECT_AGENTS_ROOT%"
if not exist "%PROJECT_AGENTS_INDEX%" (
- > "%PROJECT_AGENTS_INDEX%" echo # .agents(多语言)
+ > "%PROJECT_AGENTS_INDEX%" echo # rulesets(多语言)
>> "%PROJECT_AGENTS_INDEX%" echo.
>> "%PROJECT_AGENTS_INDEX%" echo 本目录用于存放仓库级/语言级的代理规则集。
>> "%PROJECT_AGENTS_INDEX%" echo.
>> "%PROJECT_AGENTS_INDEX%" echo 本项目已启用的规则集:
for %%L in (%LANGS%) do (
- if /I "%%~L"=="tsl" >> "%PROJECT_AGENTS_INDEX%" echo - .agents/tsl/:TSL 相关规则集(适用于 .tsl/.tsf)
- if /I "%%~L"=="cpp" >> "%PROJECT_AGENTS_INDEX%" echo - .agents/cpp/:C++ 相关规则集(C++23,含 Modules)
- if /I "%%~L"=="python" >> "%PROJECT_AGENTS_INDEX%" echo - .agents/python/:Python 相关规则集
- if /I "%%~L"=="markdown" >> "%PROJECT_AGENTS_INDEX%" echo - .agents/markdown/:Markdown 相关规则集(仅代码格式化)
+ if /I "%%~L"=="tsl" >> "%PROJECT_AGENTS_INDEX%" echo - rulesets/tsl/:TSL 相关规则集(适用于 .tsl/.tsf)
+ if /I "%%~L"=="cpp" >> "%PROJECT_AGENTS_INDEX%" echo - rulesets/cpp/:C++ 相关规则集(C++23,含 Modules)
+ if /I "%%~L"=="python" >> "%PROJECT_AGENTS_INDEX%" echo - rulesets/python/:Python 相关规则集
+ if /I "%%~L"=="markdown" >> "%PROJECT_AGENTS_INDEX%" echo - rulesets/markdown/:Markdown 相关规则集(仅代码格式化)
)
>> "%PROJECT_AGENTS_INDEX%" echo.
>> "%PROJECT_AGENTS_INDEX%" echo 入口建议从:
- for %%L in (%LANGS%) do >> "%PROJECT_AGENTS_INDEX%" echo - .agents/%%~L/index.md
+ for %%L in (%LANGS%) do >> "%PROJECT_AGENTS_INDEX%" echo - rulesets/%%~L/index.md
>> "%PROJECT_AGENTS_INDEX%" echo.
>> "%PROJECT_AGENTS_INDEX%" echo 标准快照文档入口:
>> "%PROJECT_AGENTS_INDEX%" echo.
diff --git a/scripts/vendor_playbook.ps1 b/scripts/vendor_playbook.ps1
index 94634f7..1c57080 100644
--- a/scripts/vendor_playbook.ps1
+++ b/scripts/vendor_playbook.ps1
@@ -1,5 +1,5 @@
# Vendor a trimmed Playbook snapshot into a target project (offline copy),
-# then run sync_standards to materialize .agents\<lang>\ and .gitattributes in
+# then run sync_standards to materialize rulesets\<lang>\ and .gitattributes in
# the target project root.
#
# Usage:
@@ -74,9 +74,9 @@ $DocsDir = Join-Path $DestPrefix "docs"
New-Item -ItemType Directory -Path $DocsDir -Force | Out-Null
Copy-Item (Join-Path $Src "docs/common") $DocsDir -Recurse -Force
-$AgentsDir = Join-Path $DestPrefix ".agents"
+$AgentsDir = Join-Path $DestPrefix "rulesets"
New-Item -ItemType Directory -Path $AgentsDir -Force | Out-Null
-Copy-Item (Join-Path $Src ".agents/index.md") (Join-Path $AgentsDir "index.md") -Force
+Copy-Item (Join-Path $Src "rulesets/index.md") (Join-Path $AgentsDir "index.md") -Force
$TemplatesDir = Join-Path $DestPrefix "templates"
New-Item -ItemType Directory -Path $TemplatesDir -Force | Out-Null
@@ -91,7 +91,7 @@ foreach ($lang in $Langs) {
if (-not (Test-Path $docsSrc)) { throw "Docs not found for lang=$lang ($docsSrc)" }
Copy-Item $docsSrc $DocsDir -Recurse -Force
- $agentsSrc = Join-Path (Join-Path $Src ".agents") $lang
+ $agentsSrc = Join-Path (Join-Path $Src "rulesets") $lang
if (-not (Test-Path $agentsSrc)) { throw "Agents ruleset not found for lang=$lang ($agentsSrc)" }
Copy-Item $agentsSrc $AgentsDir -Recurse -Force
@@ -184,7 +184,7 @@ sh docs/standards/playbook/scripts/sync_standards.sh $langsCsv
查看规范入口:
- `docs/standards/playbook/docs/index.md`
-- `.agents/index.md`
+- `rulesets/index.md`
## Codex skills(可选)
@@ -211,27 +211,27 @@ sh docs/standards/playbook/scripts/install_codex_skills.sh
Write-Host "Vendored snapshot -> $DestPrefix"
-$ProjectAgentsRoot = Join-Path $DestRootAbs ".agents"
+$ProjectAgentsRoot = Join-Path $DestRootAbs "rulesets"
$ProjectAgentsIndex = Join-Path $ProjectAgentsRoot "index.md"
New-Item -ItemType Directory -Path $ProjectAgentsRoot -Force | Out-Null
if (-not (Test-Path $ProjectAgentsIndex)) {
$agentLines = New-Object System.Collections.Generic.List[string]
- $agentLines.Add("# .agents(多语言)")
+ $agentLines.Add("# rulesets(多语言)")
$agentLines.Add("")
$agentLines.Add("本目录用于存放仓库级/语言级的代理规则集。")
$agentLines.Add("")
$agentLines.Add("本项目已启用的规则集:")
foreach ($lang in $Langs) {
switch ($lang) {
- "tsl" { $agentLines.Add("- .agents/tsl/:TSL 相关规则集(适用于 .tsl/.tsf)"); break }
- "cpp" { $agentLines.Add("- .agents/cpp/:C++ 相关规则集(C++23,含 Modules)"); break }
- "python" { $agentLines.Add("- .agents/python/:Python 相关规则集"); break }
- "markdown" { $agentLines.Add("- .agents/markdown/:Markdown 相关规则集(仅代码格式化)"); break }
+ "tsl" { $agentLines.Add("- rulesets/tsl/:TSL 相关规则集(适用于 .tsl/.tsf)"); break }
+ "cpp" { $agentLines.Add("- rulesets/cpp/:C++ 相关规则集(C++23,含 Modules)"); break }
+ "python" { $agentLines.Add("- rulesets/python/:Python 相关规则集"); break }
+ "markdown" { $agentLines.Add("- rulesets/markdown/:Markdown 相关规则集(仅代码格式化)"); break }
}
}
$agentLines.Add("")
$agentLines.Add("入口建议从:")
- foreach ($lang in $Langs) { $agentLines.Add("- .agents/$lang/index.md") }
+ foreach ($lang in $Langs) { $agentLines.Add("- rulesets/$lang/index.md") }
$agentLines.Add("")
$agentLines.Add("标准快照文档入口:")
$agentLines.Add("")
diff --git a/scripts/vendor_playbook.sh b/scripts/vendor_playbook.sh
index 19fdd61..4c64b1b 100644
--- a/scripts/vendor_playbook.sh
+++ b/scripts/vendor_playbook.sh
@@ -13,6 +13,7 @@ set -eu
# Notes:
# - Snapshot is written to: <project-root>/docs/standards/playbook/
# - Existing snapshot is backed up before overwrite.
+# - Ruleset templates from rulesets/ will be copied to snapshot for sync_standards use.
SCRIPT_DIR="$(CDPATH= cd -- "$(dirname -- "$0")" && pwd -P)"
SRC="$(CDPATH= cd -- "$SCRIPT_DIR/.." && pwd -P)"
@@ -80,8 +81,9 @@ cp "$SRC/SKILLS.md" "$DEST_PREFIX/SKILLS.md"
mkdir -p "$DEST_PREFIX/docs"
cp -R "$SRC/docs/common" "$DEST_PREFIX/docs/"
-mkdir -p "$DEST_PREFIX/.agents"
-cp "$SRC/.agents/index.md" "$DEST_PREFIX/.agents/index.md"
+# Copy rulesets
+mkdir -p "$DEST_PREFIX/rulesets"
+cp "$SRC/rulesets/index.md" "$DEST_PREFIX/rulesets/index.md"
mkdir -p "$DEST_PREFIX/templates"
if [ -d "$SRC/templates/ci" ]; then
@@ -108,13 +110,14 @@ for lang in "$@"; do
echo "ERROR: docs not found for lang=$lang ($SRC/docs/$lang)" >&2
exit 1
fi
- if [ ! -d "$SRC/.agents/$lang" ]; then
- echo "ERROR: agents ruleset not found for lang=$lang ($SRC/.agents/$lang)" >&2
+
+ if [ ! -d "$SRC/rulesets/$lang" ]; then
+ echo "ERROR: rulesets not found for lang=$lang ($SRC/rulesets/$lang)" >&2
exit 1
fi
cp -R "$SRC/docs/$lang" "$DEST_PREFIX/docs/"
- cp -R "$SRC/.agents/$lang" "$DEST_PREFIX/.agents/"
+ cp -R "$SRC/rulesets/$lang" "$DEST_PREFIX/rulesets/"
if [ -d "$SRC/templates/$lang" ]; then
cp -R "$SRC/templates/$lang" "$DEST_PREFIX/templates/"
fi
diff --git a/tests/scripts/test_sync_standards.bats b/tests/scripts/test_sync_standards.bats
index bec93ef..6a215ca 100644
--- a/tests/scripts/test_sync_standards.bats
+++ b/tests/scripts/test_sync_standards.bats
@@ -14,7 +14,7 @@ setup() {
# 模拟 playbook 快照目录
mkdir -p docs/standards/playbook
- cp -r "$PLAYBOOK_ROOT"/{.agents,.gitattributes,docs,scripts} docs/standards/playbook/ 2>/dev/null || true
+ cp -r "$PLAYBOOK_ROOT"/{rulesets,.gitattributes,docs,scripts} docs/standards/playbook/ 2>/dev/null || true
export SCRIPT_PATH="$TEST_DIR/docs/standards/playbook/scripts/sync_standards.sh"
}
@@ -170,7 +170,7 @@ EOF
[ -f ".gitattributes.bak."* ] || [ -f ".gitattributes.bak" ]
}
-@test "备份 - .agents/ 更新前创建备份" {
+@test "备份 - rulesets/ 更新前创建备份" {
cd "$TEST_DIR"
mkdir -p .agents/tsl
echo "# Old index" > .agents/tsl/index.md
@@ -189,8 +189,8 @@ EOF
cd "$TEST_DIR"
# 复制 Python 规则集(如果存在)
- if [ -d "$PLAYBOOK_ROOT/.agents/python" ]; then
- cp -r "$PLAYBOOK_ROOT/.agents/python" docs/standards/playbook/.agents/
+ if [ -d "$PLAYBOOK_ROOT/rulesets/python" ]; then
+ cp -r "$PLAYBOOK_ROOT/rulesets/python" docs/standards/playbook/rulesets/
fi
sh "$SCRIPT_PATH" tsl cpp
@@ -209,7 +209,7 @@ EOF
@test "错误处理 - 未找到 playbook 快照时报错" {
cd "$TEST_DIR"
- rm -rf docs/standards/playbook/.agents
+ rm -rf docs/standards/playbook/rulesets
run sh "$SCRIPT_PATH" tsl
@@ -278,11 +278,11 @@ EOF
# 第一次同步
sh "$SCRIPT_PATH" tsl
- CHECKSUM1=$(find .agents/tsl -type f -exec md5sum {} \; | sort | md5sum)
+ CHECKSUM1=$(find rulesets/tsl -type f -exec md5sum {} \; | sort | md5sum)
# 第二次同步
sh "$SCRIPT_PATH" tsl
- CHECKSUM2=$(find .agents/tsl -type f -exec md5sum {} \; | sort | md5sum)
+ CHECKSUM2=$(find rulesets/tsl -type f -exec md5sum {} \; | sort | md5sum)
[ "$CHECKSUM1" = "$CHECKSUM2" ]
}
diff --git a/tests/scripts/test_vendor_playbook.bats b/tests/scripts/test_vendor_playbook.bats
index 96babb0..50ea96e 100644
--- a/tests/scripts/test_vendor_playbook.bats
+++ b/tests/scripts/test_vendor_playbook.bats
@@ -53,7 +53,7 @@ teardown() {
[ -d "docs/standards/playbook" ]
[ -d "docs/standards/playbook/docs/common" ]
[ -d "docs/standards/playbook/docs/tsl" ]
- [ -d "docs/standards/playbook/.agents/tsl" ]
+ [ -d "docs/standards/playbook/rulesets/tsl" ]
[ -f "docs/standards/playbook/scripts/sync_standards.sh" ]
}
@@ -65,8 +65,8 @@ teardown() {
# 验证包含两种语言的文档
[ -d "docs/standards/playbook/docs/tsl" ]
[ -d "docs/standards/playbook/docs/cpp" ]
- [ -d "docs/standards/playbook/.agents/tsl" ]
- [ -d "docs/standards/playbook/.agents/cpp" ]
+ [ -d "docs/standards/playbook/rulesets/tsl" ]
+ [ -d "docs/standards/playbook/rulesets/cpp" ]
}
# ==============================================
|
||
|---|---|---|
| .gitea/workflows | ||
| codex/skills | ||
| docs | ||
| rulesets | ||
| scripts | ||
| templates | ||
| tests | ||
| .gitattributes | ||
| .gitignore | ||
| AGENTS.md | ||
| CONTRIBUTING.md | ||
| README.md | ||
| SKILLS.md | ||
README.md
playbook
Playbook:TSL(.tsl/.tsf)+ C++ + Python + Markdown(代码格式化)工程规范与代理规则合集。
原则
- 可读性优先:读代码的时间远大于写代码
- 一致性优先:同一仓库内保持一致比追求"最优风格"更重要
- 遵从既有代码:修改/扩展现有代码时优先沿用其局部风格
适用范围
- 本指南适用于所有 TSL/C++/Python/Markdown 相关仓库与脚本
- 当现有代码与本指南冲突时,以保持局部一致性为优先,逐步迁移
docs/(开发规范)
docs/ 目录是给开发者阅读的工程规范,约束代码写法、命名与提交信息。
docs/index.md:文档导航(跨语言 common / TSL / C++ / Python / Markdown)。docs/common/commit_message.md:提交信息与版本号规范(type/scope/subject/body/footer、可选 Emoji 图例、SemVer)。docs/tsl/code_style.md:TSL 代码结构、格式、begin/end代码块、注释与通用最佳实践。docs/tsl/naming.md:TSL 命名规范(顶层声明、文件同名规则、变量/成员/property、常量、集合命名等)。docs/tsl/syntax_book/index.md:TSL 语法手册(整理自原始语法/机制目录册;函数库位于docs/tsl/syntax_book/function/,按需检索)。docs/tsl/toolchain.md:TSL 工具链与验证命令模板。docs/cpp/code_style.md:C++ 代码风格(C++23/Modules)。docs/cpp/naming.md:C++ 命名规范(Google 基线)。docs/cpp/toolchain.md:C++ 工具链与验证命令模板。docs/cpp/dependencies_conan.md:C++ Conan 依赖管理建议。docs/cpp/clangd.md:clangd 补全配置建议(.clangd)。docs/python/style_guide.md:Python 代码风格(Google 基线)。docs/python/tooling.md:Python 工具链(black/isort/flake8/pylint/mypy/pytest/pre-commit)。docs/python/configuration.md:Python 配置清单(落地时从templates/python/复制到项目根目录)。docs/markdown/index.md:Markdown 代码块与行内代码格式(仅代码格式化)。templates/cpp/:C++ 落地模板(.clang-format、conanfile.txt、CMakeUserPresets.json、CMakeLists.txt)。templates/python/:Python 落地模板(pyproject.toml工具配置、.flake8、.pylintrc、.pre-commit-config.yaml、.editorconfig、.vscode/settings.json)。templates/ci/:目标项目 CI 示例模板(如 Gitea Actions),用于自动化校验部分规范。
rulesets/(规则集模板库 - 三层架构)
重要说明:playbook 仓库中的
rulesets/是规则集模板库,不是 playbook 项目自身的代理规则。Playbook 本身不包含源代码,因此不需要 AI 代理遵循规则。
rulesets/存在的目的是:
- 作为模板源,供其他项目复制
- 通过
sync_standards.sh部署到目标项目的.agents/- 目标项目的 AI 代理读取项目根目录的
.agents/(从模板生成)
rulesets/ 是 AI 代理规则集模板(三层架构设计):
三层架构设计
Layer 1: rulesets/ (≤50 行/语言,模板源)
├─ 核心约束与安全红线
└─ 指向 Skills 和 docs
Layer 2: codex/skills/ (按需加载,$skill-name 触发)
├─ tsl-guide: TSL 渐进式语法教学(962 行)
├─ performance-optimization: 跨语言性能优化
└─ testing-workflow: 跨语言测试策略
Layer 3: docs/ (权威静态文档)
└─ 完整语法手册/代码风格/工具链配置
目录结构:
rulesets/index.md:规则集索引(跨语言)rulesets/tsl/index.md:TSL 核心约定(47 行)rulesets/cpp/index.md:C++ 核心约定(50 行)rulesets/python/index.md:Python 核心约定(48 行)rulesets/markdown/index.md:Markdown 核心约定(23 行,仅代码格式化)
详见:AGENTS.md
SKILLS(Codex CLI)
本仓库内置一组 Codex CLI skills(见 codex/skills/),用于按需加载的工作流与知识库。
核心 Skills:
$tsl-guide:TSL/TSF 语法完整指南(基础/高级/函数库/最佳实践)$performance-optimization:跨语言性能优化工作流$testing-workflow:跨语言测试策略
通用 Skills:
$code-review-workflow:代码审查流程$commit-message:提交信息规范$systematic-debugging:系统化调试- 更多见
SKILLS.md
安装与使用:详见 SKILLS.md
在其他项目中使用本 Playbook
由于本仓库需要内部权限访问,其他项目不能仅用外链引用;推荐把 Playbook 规范 vendoring 到项目内。
快速决策:我应该用哪种方式?
| 你的情况 | 推荐方式 | 优势 |
|---|---|---|
| 新项目,需要持续同步更新 | 方式一:git subtree(推荐) | 可随时拉取最新标准,版本可追溯 |
| 只需要一次性引入,不常更新 | 方式二:手动复制快照 | 简单直接,无需 git subtree 知识 |
| 只需要部分语言(如只要 TSL+C++) | 方式三:脚本裁剪复制 | 自动裁剪,只包含所需语言 |
| 不确定? | 方式一:git subtree(推荐) | 最灵活,后续可随时同步更新 |
大部分情况推荐使用方式一(git subtree)。
TL;DR - 30 秒快速开始
大部分项目只需运行以下命令即可完成落地(以 TSL 为例):
# 1. 引入标准快照
git subtree add --prefix docs/standards/playbook \
https://git.mytsl.cn/csh/playbook.git main --squash
# 2. 同步规则到项目根目录
sh docs/standards/playbook/scripts/sync_standards.sh tsl
# 3. 提交
git add .
git commit -m ":package: deps(playbook): add tsl standards"
完成! 后续同步更新只需重复步骤 1(把 add 改为 pull)和步骤 2。
详细说明和其他方式见下文 ↓
方式一:git subtree 同步(推荐)
-
在目标项目中首次引入:
git subtree add \ --prefix docs/standards/playbook \ https://git.mytsl.cn/csh/playbook.git \ main --squash -
后续同步更新:
git subtree pull \ --prefix docs/standards/playbook \ https://git.mytsl.cn/csh/playbook.git \ main --squash
快速落地(最小 4 步)
在目标项目中按以下顺序执行即可完成落地(推荐固定使用
--prefix docs/standards/playbook):
-
引入标准快照(见上文
git subtree add) -
同步到项目根目录(生成/更新
.agents/<lang>/、更新.gitattributes):sh docs/standards/playbook/scripts/sync_standards.sh同步 C++ 规则集(同一份快照,不同规则集):
sh docs/standards/playbook/scripts/sync_standards.sh cpp一次同步多个规则集(推荐,减少重复备份
.gitattributes):sh docs/standards/playbook/scripts/sync_standards.sh tsl cpp说明:若项目根目录没有
AGENTS.md,sync_standards.*会自动生成最小版;已存在则不会覆盖。 -
验收(任意满足其一即可):
- 目录存在:
.agents/tsl/ - 规则入口可读:
.agents/tsl/index.md - (可选)C++ 规则入口可读:
.agents/cpp/index.md - 标准文档可读:
docs/standards/playbook/docs/index.md .gitattributes包含追加块头:# Added from playbook .gitattributes
- 目录存在:
-
将同步产物纳入版本控制(目标项目建议提交):
docs/standards/playbook/(标准快照).agents/tsl/(落地规则集).gitattributes(追加缺失规则)AGENTS.md(若本次自动生成)
新项目 / 旧项目(命令示例)
新项目(无 .agents/ 与 AGENTS.md):
git subtree add --prefix docs/standards/playbook https://git.mytsl.cn/csh/playbook.git main --squash
sh docs/standards/playbook/scripts/sync_standards.sh tsl
旧项目(已有 AGENTS.md):
git subtree pull --prefix docs/standards/playbook https://git.mytsl.cn/csh/playbook.git main --squash
sh docs/standards/playbook/scripts/sync_standards.sh tsl
旧项目的 AGENTS.md 不会被覆盖;如需指向 .agents/,请手动对齐内容。
可选:项目包装脚本(多 playbook 串联)
多语言项目建议在目标项目创建一个包装脚本(便于一键同步多个规则集):
#!/usr/bin/env sh
set -eu
sh docs/standards/playbook/scripts/sync_standards.sh tsl cpp
# sh docs/standards/python/scripts/sync_standards.sh
也可以直接一次同步多个规则集:
sh docs/standards/playbook/scripts/sync_standards.sh tsl cpp
目录约定(建议)
目标项目推荐采用以下结构(Playbook 快照与项目文档分离):
.
├── .agents/
│ ├── index.md # 多语言代理规则集索引(缺省时由脚本创建)
│ ├── tsl/ # 从 Playbook 同步(仅覆盖该子目录)
│ └── cpp/ # 从 Playbook 同步(仅覆盖该子目录,按需)
├── .gitattributes # 从 Playbook 同步
├── docs/
│ ├── standards/
│ │ └── tsl/ # git subtree 快照(只读)
│ │ ├── docs/ # common/ + tsl/ + cpp/
│ │ ├── .agents/ # 标准代理规则快照
│ │ ├── .gitattributes
│ │ └── SOURCE.md # 记录来源版本/commit(项目自行维护)
│ └── project/ # 目标项目自己的文档(非语言标准:架构/运行/ADR/使用说明/业务约定等)
└── README.md # 说明遵循 standards
根目录的 .agents/<lang>/ 与 .gitattributes 通过同步脚本获得:
- 说明:在 本 playbook 仓库内脚本位于
scripts/;在 目标项目里通过git subtree引入到docs/standards/playbook/后,脚本路径变为docs/standards/playbook/scripts/。 - 在目标项目里直接运行 Playbook 提供的脚本(子树快照里自带):
docs/standards/playbook/scripts/sync_standards.sh(推荐,支持多语言参数)docs/standards/playbook/scripts/sync_standards.ps1(推荐,支持多语言参数)docs/standards/playbook/scripts/sync_standards.bat(推荐,支持多语言参数)
- 脚本会从快照目录同步到项目根目录,并先备份旧文件(
.bak.*)
建议固定使用 --prefix docs/standards/playbook,因为同步后的 .agents/*/
会引用该路径下的标准快照文档(docs/standards/playbook/docs/...)。无参数时若已存在
.agents/<lang>/,将按现有语言同步;否则默认 .agents/tsl/。如需同步 C++ 规则集,
推荐直接运行:sh docs/standards/playbook/scripts/sync_standards.sh tsl cpp。
这样 clone 任意项目时都能直接读取规范文件,不依赖外部访问权限。
同步脚本行为(目标项目内的最终落地内容):
- 覆盖/更新:
.agents/<AGENTS_NS>/(默认.agents/tsl/) - 自动识别:未传语言参数且已存在
.agents/<lang>/时,按现有语言同步 - 更新
.gitattributes:默认追加缺失规则(可用SYNC_GITATTR_MODE=append|block|overwrite|skip控制) - 缺省创建:
.agents/index.md - 覆盖前备份:写入同目录的
*.bak.*(或 Windows 下随机后缀) - 不修改:
.gitignore(项目自行维护)
高级选项:环境变量配置(点击展开)
环境变量(可选)
同步脚本支持以下可选环境变量(默认值可满足大多数项目):
| 变量名 | 默认值 | 说明 |
|---|---|---|
AGENTS_NS |
tsl |
同步的规则集名/落地目录名:.agents/<AGENTS_NS>/(例如 tsl、cpp) |
SYNC_GITATTR_MODE |
append |
.gitattributes 同步模式:append 仅追加缺失规则(忽略注释/空行,比对后按块追加);block 仅维护 managed 区块;overwrite 全量覆盖;skip 不更新 |
方式二:手动复制快照
如果不使用
git subtree,也可以由有权限的人手动复制 Playbook 到目标项目中(适合规范不频繁更新或项目数量较少的情况)。
步骤:
- 在目标项目创建目录:
docs/standards/playbook/。 - 从本仓库复制以下内容到目标项目:
docs/→docs/standards/playbook/docs/(包含docs/common/、docs/tsl/、docs/cpp/、docs/python/).agents/→docs/standards/playbook/.agents/.gitattributes→docs/standards/playbook/.gitattributesscripts/→docs/standards/playbook/scripts/
- 在目标项目根目录运行同步脚本,把
.agents/tsl/与.gitattributes落到根目录(见上文脚本路径)。 - 在
docs/standards/playbook/SOURCE.md记录本次复制的来源版本/日期(建议写 Playbook 的 commit hash)。
该方式没有自动同步能力,后续更新需重复上述复制流程。
方式三:脚本裁剪复制(按语言,离线)
当你希望“只 vendoring 需要的语言规范”(例如只需要 tsl +
cpp)时,可直接运行本仓库提供的裁剪脚本:
-
macOS/Linux:
sh <PLAYBOOK_ROOT>/scripts/vendor_playbook.sh <target-project-root> tsl cpp -
PowerShell:
powershell -File <PLAYBOOK_ROOT>\\scripts\\vendor_playbook.ps1 -DestRoot <target-project-root> -Langs tsl,cpp -
Windows bat:
<PLAYBOOK_ROOT>\\scripts\\vendor_playbook.bat <target-project-root> --langs tsl,cpp
脚本会:
- 生成裁剪快照到
docs/standards/playbook/(包含docs/common/+ 选定语言目录 + 对应.agents/<lang>/+scripts/+.gitattributes+ 通用templates/ci/+ 相关templates/<lang>/) - 自动执行
docs/standards/playbook/scripts/sync_standards.*,把.agents/<lang>/与.gitattributes落地到目标项目根目录 - 生成
docs/standards/playbook/SOURCE.md记录来源与版本信息
多语言项目落地(TSL + C++/其他语言)
多语言项目建议把规范拆成两类:
- 仓库级(跨语言)共识:对所有语言都成立的规则与流程。
- 提交信息:
docs/common/commit_message.md - 行尾与文本规范:
.gitattributes - 代理最低要求:
.agents/*(工作原则、质量底线、安全边界)
- 提交信息:
- 语言级(Language-specific)规范:只对某个语言成立的风格与工具。
- 例如 TSL 的命名/文件顶层声明限制、C++ 的
.clang-format/.clang-tidy、Python 的ruff等。
- 例如 TSL 的命名/文件顶层声明限制、C++ 的
建议:仓库级规则尽量少且稳定;语言级规则各自独立,避免互相"污染"。
本仓库提供多套代理规则集(同步后位于目标项目的 .agents/tsl/ / .agents/cpp/ / .agents/python/ / .agents/markdown/):
- 三者都包含核心约定与安全红线
- 并在
index.md中叠加语言级"硬约束"(TSL/TSF 语法限制、C++23/Modules、Python 风格、Markdown 代码格式化等)
多语言项目推荐结构(示例:TSL + C++ + Python + Markdown):
.
├── .agents/
│ ├── index.md # 多语言索引(缺省时由脚本创建)
│ ├── tsl/ # 由本 Playbook 同步(适用于 .tsl/.tsf)
│ ├── cpp/ # 由本 Playbook 同步(适用于 C++23/Modules)
│ ├── python/ # Python 规则集(同上)
│ └── markdown/ # Markdown 规则集(仅代码格式化)
├── .gitattributes # 行尾/文本规范(可由某个 playbook 同步)
├── docs/
│ ├── standards/
│ │ ├── tsl/ # 本 Playbook 快照(git subtree/vendoring;包含 common/tsl/cpp)
│ │ └── python/ # Python playbook 快照(可选)
│ └── project/ # 项目自有文档(架构、ADR、运行方式等)
├── scripts/
│ └── sync_standards.sh # 项目包装脚本:依次调用各 playbook 的 sync
└── src/ # 源码目录(按项目实际情况)
规则优先级建议:
- 同一项目内多个规则集并行放在
.agents/<lang>/,不要互相覆盖 - 若某个子目录需要更具体规则(模块/子系统差异),在更靠近代码的目录放置更具体规则(例如
src/foo/.agents/),并以"离代码更近者优先"为准
高级选项:`.agents` 覆盖/合并策略(点击展开)
.agents 的覆盖/合并策略(可执行流程)
同步脚本会同步到项目根目录的 .agents/tsl/(并不会覆盖 .agents/
下的其他语言目录)。若项目需要追加 C++ 等语言/模块专属规则,建议二选一:
- 推荐:子目录规则覆盖(无需改同步脚本)
- 让本 Playbook 的规则集固定落在
.agents/tsl/,由同步脚本维护。 - 在其他语言/模块目录下新增更具体规则,例如
.agents/cpp/、cpp/.agents/、src/.agents/。
- 让本 Playbook 的规则集固定落在
- Overlay 合并:项目维护叠加层并在同步后覆盖回去
- 约定项目自定义规则放在
docs/project/agents_overlay/(不叫.agents,避免被同步覆盖)。 - 每次运行
sync_standards.*后,再把 overlay 覆盖回.agents/tsl/(建议封装成项目脚本)。
- 约定项目自定义规则放在
macOS/Linux 示例(目标项目的 scripts/sync_standards.sh):
#!/usr/bin/env sh
set -eu
sh docs/standards/playbook/scripts/sync_standards.sh tsl cpp
OVERLAY="docs/project/agents_overlay"
if [ -d "$OVERLAY" ]; then
cp -R "$OVERLAY"/. ".agents/tsl/"
echo "Applied agents overlay."
fi
PowerShell 示例(目标项目的 scripts/sync_standards.ps1):
& "docs/standards/playbook/scripts/sync_standards.ps1" -Langs tsl,cpp
$overlay = "docs/project/agents_overlay"
if (Test-Path $overlay) {
Copy-Item "$overlay\\*" ".agents\\tsl" -Recurse -Force
Write-Host "Applied agents overlay."
}
扩展新语言(模板)
当目标项目需要新增一门语言(例如 C++),建议按以下模板扩展:
- 文档:
- 若使用本 Playbook 自带的 C++ 规范:无需额外 subtree,直接使用
docs/standards/playbook/docs/cpp/,并在项目README.md/docs/index.md链接入口。 - 若新增"本 Playbook 未覆盖的语言":再引入对应语言的标准仓库(subtree/vendoring 到
docs/standards/<lang>/)
- 若使用本 Playbook 自带的 C++ 规范:无需额外 subtree,直接使用
- 代理规则:
- C++:运行
sh docs/standards/playbook/scripts/sync_standards.sh cpp(或& "docs/standards/playbook/scripts/sync_standards.ps1" -Langs cpp),落地到.agents/cpp/(与.agents/tsl/并行)。 - 其他语言:在目标项目增加
.agents/<lang>/(与.agents/tsl/并行),只写该语言专属要求与工具链约束
- C++:运行
- 同步策略:每个规则集只同步到对应子目录(例如
.agents/cpp/),避免覆盖整个.agents/ - CI/工具:按文件类型分别执行格式化、lint、测试(不要让 TSL 规则去约束 C++ 代码,反之亦然)
- C++ 补全:建议在项目根目录提供
.clangd并指向正确的CompilationDatabase(模板见templates/cpp/.clangd)
- C++ 补全:建议在项目根目录提供