当需要开始与当前工作区隔离的功能开发,或在执行实现计划之前使用——通过原生工具或 git worktree 回退机制确保隔离工作区存在
---
name: using-git-worktrees
description: 当需要开始与当前工作区隔离的功能开发,或在执行实现计划之前使用——通过原生工具或 git worktree 回退机制确保隔离工作区存在
version: "1.0.0"
license: MIT
metadata:
hermes:
tags: [git, workflow]
---
# 使用 Git 工作树
## 概述
确保工作发生在隔离的工作区中。优先使用你的平台的原生 worktree 工具。仅在没有原生工具可用时,再回退到手动 git worktree。
**核心原则:** 先检测现有隔离。然后用原生工具。再回退到 git。绝不与 harness 对抗。
**开始时宣布:** "我正在使用 using-git-worktrees 技能来建立一个隔离的工作区。"
## 步骤 0:检测现有隔离
**创建任何东西之前,先检查你是否已经在一个隔离的工作区里。**
```bash
GIT_DIR=$(cd "$(git rev-parse --git-dir)" 2>/dev/null && pwd -P)
GIT_COMMON=$(cd "$(git rev-parse --git-common-dir)" 2>/dev/null && pwd -P)
BRANCH=$(git branch --show-current)
```
**Submodule 守卫:** 在 git submodule 内 `GIT_DIR != GIT_COMMON` 也为真。在判定"已经在 worktree 内"之前,先确认你不在 submodule 里:
```bash
# 如果这条命令返回路径,说明你在 submodule 里,不是 worktree —— 按普通仓库处理
git rev-parse --show-superproject-working-tree 2>/dev/null
```
**如果 `GIT_DIR != GIT_COMMON`(且不是 submodule):** 你已经在一个 linked worktree 内。跳到步骤 2(项目设置)。**不要**再创建一个 worktree。
按分支状态报告:
- 在某个分支上:"已经在隔离工作区 `<path>`,分支 `<name>`。"
- 分离 HEAD:"已经在隔离工作区 `<path>`(分离 HEAD,由外部管理)。完成时需要创建分支。"
**如果 `GIT_DIR == GIT_COMMON`(或在 submodule 内):** 你在一个普通的仓库检出里。
用户是否已经在你的 instructions 里表明过 worktree 偏好?如果没有,创建 worktree 之前先征求同意:
> "你希望我搭一个隔离的 worktree 吗?它能保护你当前分支不被改动。"
如果用户已声明过偏好,直接遵循,不再询问。如果用户拒绝同意,原地工作并跳到步骤 2。
## 步骤 1:创建隔离工作区
**你有两种机制。按这个顺序尝试。**
### 1a. 原生 Worktree 工具(首选)
用户已经请求隔离工作区(步骤 0 已获同意)。你是否已经有创建 worktree 的方法?可能是名为 `EnterWorktree`、`WorktreeCreate` 的工具、`/worktree` 命令,或 `--worktree` 标志。如果有,用它,然后跳到步骤 2。
原生工具自动处理目录放置、分支创建和清理。在你已经有原生工具的情况下使用 `git worktree add`,会创建你的 harness 看不到也无法管理的"幻影状态"。
只有在没有原生 worktree 工具可用时,才进入步骤 1b。
### 1b. Git Worktree 回退
**只在步骤 1a 不适用时使用** —— 你没有可用的原生 worktree 工具。手动用 git 创建 worktree。
#### 目录选择
按以下优先级。明确的用户偏好始终优先于观察到的文件系统状态。
1. **检查你的 instructions 里是否声明过 worktree 目录偏好。** 如果用户已指定,不再询问直接用。
2. **检查是否存在项目本地的 worktree 目录:**
```bash
ls -d .worktrees 2>/dev/null # 首选(隐藏目录)
ls -d worktrees 2>/dev/null # 备选
```
找到就用。如果两者都存在,`.worktrees` 优先。
3. **如果没有其他可参考的信息**,默认用项目根目录下的 `.worktrees/`。
#### 安全验证(仅项目本地目录)
**创建 worktree 前必须验证目录已被忽略:**
```bash
git check-ignore -q .worktrees 2>/dev/null || git check-ignore -q worktrees 2>/dev/null
```
**如果未被忽略:** 添加到 .gitignore,提交该改动,然后继续。
**为什么关键:** 防止 worktree 内容被意外提交到仓库。
#### 创建工作树
```bash
# 根据选定位置确定路径
path="$LOCATION/$BRANCH_NAME"
git worktree add "$path" -b "$BRANCH_NAME"
cd "$path"
```
**沙盒回退:** 如果 `git worktree add` 因权限错误(沙盒拒绝)失败,告诉用户沙盒阻止了 worktree 创建,你将在当前目录原地工作。然后原地运行 setup 和基线测试。
## 步骤 2:项目设置
自动检测并运行相应的设置命令:
```bash
# Node.js
if [ -f package.json ]; then npm install; fi
# Rust
if [ -f Cargo.toml ]; then cargo build; fi
# Python
if [ -f requirements.txt ]; then pip install -r requirements.txt; fi
if [ -f pyproject.toml ]; then poetry install; fi
# Go
if [ -f go.mod ]; then go mod download; fi
```
## 步骤 3:验证基线干净
运行测试确保工作区初始状态干净:
```bash
# 使用项目对应的命令
npm test / cargo test / pytest / go test ./...
```
**如果测试失败:** 报告失败,询问是继续还是排查。
**如果测试通过:** 报告就绪。
### 报告
```
工作树已就绪:<full-path>
测试通过(<N> 个测试,0 个失败)
准备实现 <feature-name>
```
## 快速参考
| 情况 | 操作 |
|------|------|
| 已在 linked worktree 内 | 跳过创建(步骤 0) |
| 在 submodule 内 | 按普通仓库处理(步骤 0 守卫) |
| 有原生 worktree 工具 | 用它(步骤 1a) |
| 没有原生工具 | git worktree 回退(步骤 1b) |
| `.worktrees/` 存在 | 用它(验证已忽略) |
| `worktrees/` 存在 | 用它(验证已忽略) |
| 两者都存在 | 用 `.worktrees/` |
| 都不存在 | 检查 instructions 文件,再默认 `.worktrees/` |
| 目录未被忽略 | 添加到 .gitignore + 提交 |
| 创建时权限错误 | 沙盒回退,原地工作 |
| 基线测试失败 | 报告失败 + 询问 |
| 无 package.json/Cargo.toml | 跳过依赖安装 |
## 常见错误
### 与 harness 对抗
- **问题:** 平台已经提供隔离的情况下还在用 `git worktree add`
- **修复:** 步骤 0 检测现有隔离。步骤 1a 让位给原生工具。
### 跳过检测
- **问题:** 在已有的 worktree 内嵌套创建另一个 worktree
- **修复:** 创建任何东西之前都先跑步骤 0
### 跳过忽略验证
- **问题:** worktree 内容被跟踪,污染 git status
- **修复:** 创建项目本地 worktree 前始终使用 `git check-ignore`
### 假设目录位置
- **问题:** 造成不一致、违反项目约定
- **修复:** 遵循优先级:明确 instructions > 现有项目本地目录 > 默认
### 带着失败的测试继续
- **问题:** 无法区分新 bug 和已有问题
- **修复:** 报告失败,获得明确许可后再继续
## 红线
**绝不:**
- 步骤 0 已检测到现有隔离时还创建 worktree
- 在已有原生 worktree 工具(如 `EnterWorktree`)的情况下还用 `git worktree add`。这是 #1 错误——有就用。
- 跳过步骤 1a 直接跳到步骤 1b 的 git 命令
- 不验证已忽略就创建项目本地 worktree
- 跳过基线测试验证
- 不询问就带着失败的测试继续
**始终:**
- 先跑步骤 0 检测
- 优先原生工具,其次 git 回退
- 遵循目录优先级:明确 instructions > 现有项目本地目录 > 默认
- 项目本地目录验证已忽略
- 自动检测并运行项目设置
- 验证测试基线干净
## 集成
**被以下技能调用:**
- **brainstorming**(阶段 4)- 设计通过且需要实现时必需
- **subagent-driven-development** - 执行任何任务前必需
- **executing-plans** - 执行任何任务前必需
- 任何需要隔离工作区的技能
**配合使用:**
- **finishing-a-development-branch** - 工作完成后清理时必需
Creator's repository · 21307369/superpowers-zh