skills/using-git-worktrees/SKILL.md
Use when starting feature work that needs isolation from current workspace or before executing implementation plans - ensures an isolated workspace exists via native tools or git worktree fallback
npx skillsauth add sartoris-digital/pi-superpowers using-git-worktreesInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Ensure work happens in an isolated workspace. Prefer the platform's native worktree tools when present. Fall back to manual git worktrees only when no native tool is available.
Core principle: Detect existing isolation first. Then use native tools. Then fall back to git. Never fight the harness.
Announce at start: "I'm using the using-git-worktrees skill to set up an isolated workspace."
Before creating anything, check whether the agent is already inside an isolated workspace.
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 guard: GIT_DIR != GIT_COMMON is also true inside git submodules. Before concluding "already in a worktree," verify the agent is not in a submodule:
# If this returns a path, the agent is in a submodule, not a worktree — treat as normal repo
git rev-parse --show-superproject-working-tree 2>/dev/null
If GIT_DIR != GIT_COMMON (and not a submodule): The agent is already in a linked worktree. Skip to Step 3 (Project Setup). Do NOT create another worktree.
Report with branch state:
<path> on branch <name>."<path> (detached HEAD, externally managed). Branch creation needed at finish time."If GIT_DIR == GIT_COMMON (or in a submodule): The agent is in a normal repo checkout.
Has the user already indicated a worktree preference in the session instructions? If not, ask for consent before creating a worktree:
"Would you like me to set up an isolated worktree? It protects your current branch from changes."
Honor any existing declared preference without asking. If the user declines consent, work in place and skip to Step 3.
Why consent matters: Earlier versions of the skill (and orchestration skills that called it) created worktrees implicitly. Surprise worktrees confuse users and pollute repositories. Always ask, or honor a declared preference.
Two mechanisms. Try them in this order.
The user has consented to an isolated workspace (Step 0). Does the harness expose a native worktree tool — something like EnterWorktree, WorktreeCreate, a /worktree command, or a --worktree flag? If so, use it and skip to Step 3.
Native tools handle directory placement, branch creation, and cleanup automatically. Using git worktree add when a native tool exists creates phantom state the harness cannot see or manage.
Only proceed to Step 1b if no native worktree tool is available.
Only use this if Step 1a does not apply — there is no native worktree tool. Create a worktree manually using git worktree via bash.
Follow this priority order. Explicit user preference always beats observed filesystem state.
Check session instructions for a declared worktree directory preference. If the user has already specified one, use it without asking.
Check for an existing project-local worktree directory:
ls -d .worktrees 2>/dev/null # Preferred (hidden)
ls -d worktrees 2>/dev/null # Alternative
If found, use it. If both exist, .worktrees wins.
Check for an existing global directory:
project=$(basename "$(git rev-parse --show-toplevel)")
ls -d ~/.config/superpowers/worktrees/$project 2>/dev/null
If found, use it (backward compatibility with legacy global path).
If there is no other guidance available, default to .worktrees/ at the project root.
MUST verify directory is ignored before creating worktree:
git check-ignore -q .worktrees 2>/dev/null || git check-ignore -q worktrees 2>/dev/null
If NOT ignored: Add to .gitignore, commit the change, then proceed.
Why critical: Prevents accidentally committing worktree contents to the repository.
Global directories (~/.config/superpowers/worktrees/) need no verification.
project=$(basename "$(git rev-parse --show-toplevel)")
# Determine path based on chosen location
# For project-local: path="$LOCATION/$BRANCH_NAME"
# For global: path="~/.config/superpowers/worktrees/$project/$BRANCH_NAME"
git worktree add "$path" -b "$BRANCH_NAME"
cd "$path"
Sandbox fallback: If git worktree add fails with a permission error (sandbox denial), tell the user the sandbox blocked worktree creation and the agent is working in the current directory instead. Then run setup and baseline tests in place.
Auto-detect and run appropriate setup:
# 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
Run tests to ensure the workspace starts clean:
# Use project-appropriate command
npm test / cargo test / pytest / go test ./...
If tests fail: Report failures, ask whether to proceed or investigate.
If tests pass: Report ready.
Worktree ready at <full-path>
Tests passing (<N> tests, 0 failures)
Ready to implement <feature-name>
| Situation | Action |
|-----------|--------|
| Already in linked worktree | Skip creation (Step 0) |
| In a submodule | Treat as normal repo (Step 0 guard) |
| Native worktree tool available | Use it (Step 1a) |
| No native tool | git worktree fallback via bash (Step 1b) |
| .worktrees/ exists | Use it (verify ignored) |
| worktrees/ exists | Use it (verify ignored) |
| Both exist | Use .worktrees/ |
| Neither exists | Check instruction file, then default .worktrees/ |
| Global path exists | Use it (backward compat) |
| Directory not ignored | Add to .gitignore + commit |
| Permission error on create | Sandbox fallback, work in place |
| Tests fail during baseline | Report failures + ask |
| No package.json/Cargo.toml | Skip dependency install |
git worktree add when the platform already provides isolationgit statusgit check-ignore before creating project-local worktreeAgent: I'm using the using-git-worktrees skill to set up an isolated workspace.
[Step 0: GIT_DIR == GIT_COMMON, not a submodule — normal repo]
[No declared preference — ask for consent]
[User: yes]
[Step 1a: no native worktree tool on Pi — fall through]
[Step 1b: .worktrees/ exists, git check-ignore confirms ignored]
[Create worktree: git worktree add .worktrees/auth -b feature/auth]
[Run npm install]
[Run npm test - 47 passing]
Worktree ready at /path/to/repo/.worktrees/auth
Tests passing (47 tests, 0 failures)
Ready to implement auth feature
Never:
git worktree add when a native worktree tool exists. This is the #1 mistake — if it exists, use it.Always:
Pi has no native worktree tool. The bundled @mariozechner/pi-coding-agent tool registry and the pi-superpowers extension surface (bootstrap, subagent, state-manager, persistence-engine, orchestrator) do not expose any worktree, EnterWorktree, or ExitWorktree primitive. Step 1a will therefore never match on Pi — the skill always falls through to Step 1b and uses git worktree via bash.
Concrete Pi flow:
bash (git rev-parse --git-dir, --git-common-dir).git worktree add through bash.finishing-a-development-branch, which removes the worktree with git worktree remove via bash (no rm -rf fallback — see that skill for the provenance rules).If a future Pi extension registers a worktree tool, Step 1a will pick it up automatically and Step 1b becomes unreachable — no skill change required.
All other guidance (consent, safety checks, baseline tests, directory selection) applies unchanged.
testing
Use when creating new skills, editing existing skills, or verifying skills work before deployment
development
Use when you have a spec or requirements for a multi-step task, before touching code
data-ai
Use when about to claim work is complete, fixed, or passing, before committing or creating PRs - requires running verification commands and confirming output before making any success claims; evidence before assertions always
tools
Use when starting any conversation - establishes how to find and use skills, requiring Skill tool invocation before ANY response including clarifying questions