worktree
SKILL.md
/worktree — Git Worktree 生命週期管理
管理 worktree 的建立、狀態查詢、清理。統一存放位置為 ~/Documents/<repo>-<name>。
子指令解析
從 $ARGUMENTS 判斷子指令:
| 輸入 | 子指令 |
|---|---|
(空)或 status |
status |
create <name> |
create |
cleanup |
cleanup |
prune |
prune |
共用:偵測 Repo 資訊
所有子指令開始前,先取得 repo 資訊:
REPO_ROOT=$(git rev-parse --show-toplevel)
REPO_NAME=$(basename "$REPO_ROOT")
若不在 git repo 中,提示使用者切換到 git repo 目錄。
status(預設)
列出所有 worktree 及其狀態。
步驟:
git worktree list --porcelain取得所有 worktree- 排除 main worktree(即
REPO_ROOT本身) - 對每個 worktree:
- 取得路徑和分支名稱
gh pr list --head <branch> --state all --json number,state,mergedAt --limit 1查 PR 狀態du -sh <path>取得磁碟用量- 判斷路徑類型:
~/Documents/<repo>-*→ 標準路徑(無標記).claude/worktrees/→[legacy]/tmp/或/private/tmp/→[non-standard]- 其他 →
[non-standard]
輸出格式:
Repo: <repo-name> | Base: <current-branch> | N worktrees (+ main)
Path Branch PR State Disk
─────────────────────────────────────────────────────────────────────────────────────────────
~/Documents/<repo>-<name> worktree-<name> — no PR 196M
~/Documents/<repo>-<name2> feat/<name2> #1234 MERGED 1.8G
.claude/worktrees/<name3> worktree-<name3> #5678 OPEN 800M [legacy]
Tip: 有 MERGED/CLOSED 的 PR → `/worktree cleanup`
Tip 行只在有可清理 worktree 時顯示。
create
建立新 worktree。
步驟:
-
從
$ARGUMENTS解析 name(create後的部分) -
計算路徑:
~/Documents/<repo>-<name> -
計算分支名:
worktree-<name> -
檢查路徑是否已存在(
test -d)→ 已存在則提示並中止 -
檢查分支是否已存在(
git branch --list)→ 已存在則提示並中止 -
使用 AskUserQuestion 詢問 base branch:
從哪個分支建立 worktree?
- (目前分支)
- master
- 其他(請指定)
-
建立 worktree:
git worktree add -b worktree-<name> ~/Documents/<repo>-<name> <base-branch> -
輸出結果:
Worktree 已建立: - 路徑:~/Documents/<repo>-<name> - 分支:worktree-<name> - Base:<base-branch> 開新 Claude Code session 在該目錄開發: cd ~/Documents/<repo>-<name> && claude
cleanup
自動偵測並清理已 merge/closed PR 的 worktree。
步驟:
-
git worktree list --porcelain列出所有非 main worktree -
對每個 worktree 判斷是否符合清理條件:
- PR 狀態為 MERGED 或 CLOSED
- 或無 PR 且分支已 merged into base(
git branch --merged <base> | grep <branch>)
-
對符合條件的 worktree,檢查髒目錄:
git -C <path> status --porcelain若有輸出 → 標記[dirty]並警告
-
若無可清理的 worktree → 提示「沒有需要清理的 worktree」並結束
-
顯示清理清單,使用 AskUserQuestion 確認:
以下 worktree 符合清理條件:
Path Branch PR State Disk Note ~/Documents/- worktree- #1234 MERGED 800M .claude/worktrees/ worktree- — merged 200M [legacy] ~/Documents/- worktree- #5678 CLOSED 1.2G [dirty] ⚠️ 確認清理?(dirty worktree 將被跳過)
- 確認 — 清理上述 worktree(跳過 dirty)
- 全部清理 — 包含 dirty worktree(未 commit 變更將遺失)
- 取消
-
依使用者選擇執行:
git worktree remove <path> git branch -d <branch> # 若分支已 merged -
報告結果:
已清理 N 個 worktree,回收 X 磁碟空間。
prune
清理孤立 worktree metadata(worktree 目錄已被手動刪除但 git 紀錄仍在)。
步驟:
git worktree list --porcelain檢查每個 worktree 路徑是否存在- 若有孤立 metadata,顯示清單
- 執行
git worktree prune - 報告清理結果
設計原則
- Repo-agnostic:用
git rev-parse偵測 repo,不 hardcode - 命名慣例:路徑
~/Documents/<repo>-<name>,分支worktree-<name> - 確認閘門:cleanup/create 前都用 AskUserQuestion 等待確認
- 髒目錄保護:cleanup 預設跳過有未 commit 變更的 worktree
- Legacy 標記:status 輸出標記非標準路徑,鼓勵遷移至標準路徑
Weekly Installs
1
Repository
ashe-li/agent-skillsFirst Seen
3 days ago
Security Audits
Installed on
amp1
cline1
opencode1
cursor1
kimi-cli1
codex1