git-worktree-manager

Manage git worktrees to enable efficient multi-branch development while keeping the main working directory clean.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "git-worktree-manager" with this command: npx skills add d-o-hub/rust-self-learning-memory/d-o-hub-rust-self-learning-memory-git-worktree-manager

Git Worktree Manager

Manage git worktrees to enable efficient multi-branch development while keeping the main working directory clean.

Purpose

Enable parallel development on multiple branches without switching contexts, allowing isolation and organization of work across multiple features, bugfixes, and experiments.

When to Use

Use this skill when:

  • Creating Worktrees: Setting up worktrees for new feature branches

  • Organizing Worktrees: Structuring worktree directories for better management

  • Cleaning Up: Removing unused or orphaned worktrees

  • Multi-Branch Development: Working on multiple features simultaneously

  • Isolated Development: Keeping experimental changes separate from main work

  • CI/CD Workflows: Using worktrees for testing and deployment

  • Worktree Maintenance: Listing, switching, and managing multiple worktrees

Worktree Fundamentals

What is a Git Worktree?

A git worktree is a linked working tree attached to the same repository. Each worktree allows you to:

  • Check out different branches simultaneously

  • Work on multiple features in parallel

  • Keep main working directory clean

  • Test changes without switching branches

Directory Structure

Recommended organization:

project/ ├── main-repo/ # Main working directory (default) └── worktrees/ # All worktrees organized here ├── feature/feature-1/ ├── bugfix/bug-2/ ├── hotfix/critical-3/ └── experiment/new-architecture/

Naming Conventions

  • Branch-Based: Name worktrees after their branches

  • Type Prefix: Use prefixes for organization (feature/, bugfix/, hotfix/, experiment/)

  • Descriptive Names: Clear, meaningful names that indicate purpose

  • No Special Characters: Avoid spaces, special characters in names

Core Operations

  1. Create a Worktree

From Existing Branch

Navigate to main repository

cd /path/to/project

Create worktree from existing branch

git worktree add ../worktrees/feature-name feature-branch-name

Verify creation

cd ../worktrees/feature-name git status

Create New Branch

Create worktree with new branch

git worktree add -b feature/new-feature ../worktrees/new-feature

Switch to worktree

cd ../worktrees/new-feature

Detached HEAD Worktree

Create worktree at specific commit

git worktree add ../worktrees/temp-checkout HEAD~5

  1. List Worktrees

Basic Listing

List all worktrees

git worktree list

List with porcelain format (machine-readable)

git worktree list --porcelain

Detailed Status Check

Check status of all worktrees

for wt in $(git worktree list --porcelain | grep worktree | sed 's/worktree //'); do echo "=== $wt ===" cd "$wt" && git status --short && git log --oneline -1 done

  1. Navigate Between Worktrees

Quick Navigation

Function to navigate to worktree

goto-worktree() { local wt=$1 local project_root=$(git rev-parse --show-toplevel) local worktree_path="$project_root/../worktrees/$wt"

if [ -d "$worktree_path" ]; then
    cd "$worktree_path"
    echo "Switched to worktree: $wt"
else
    echo "Worktree not found: $wt"
fi

}

Use with Projects

In .bashrc or .zshrc

alias gwt='goto-worktree'

Then use:

gwt feature-name

  1. Manage Worktree Status

Lock and Unlock

Lock a worktree (prevent operations)

git worktree lock ../worktrees/feature-name

Unlock a worktree

git worktree unlock ../worktrees/feature-name

Check locked status

git worktree list

Prune Worktrees

Clean up worktree administrative data

git worktree prune

Prune with verbose output

git worktree prune -v

Worktree Cleanup

Identify Unused Worktrees

Check for Orphaned Worktrees

Find worktrees with deleted branches

git worktree list | while read path commit branch; do if ! git show-ref --verify --quiet "refs/heads/${branch#*/}"; then echo "Orphaned: $path ($branch)" fi done

Check for Uncommitted Changes

List worktrees with uncommitted changes

for wt in $(git worktree list --porcelain | grep worktree | sed 's/worktree //'); do if [ -n "$(cd "$wt" && git status --porcelain)" ]; then echo "Uncommitted changes: $wt" fi done

Safe Removal

Remove a Worktree

Safe removal (if clean)

git worktree remove ../worktrees/feature-name

Force removal (ignores uncommitted changes)

git worktree remove --force ../worktrees/feature-name

Remove Multiple Worktrees

Remove all worktrees matching pattern

for wt in ../worktrees/feature-*; do git worktree remove "$wt" done

Workflow Integration

Feature Development Workflow

  1. Create worktree for new feature
    git worktree add -b feature/new-ui ../worktrees/feature/new-ui
    
    

Develop feature in isolation

cd ../worktrees/feature/new-ui

... develop feature ...

Test changes locally

cargo test

Commit and push to branch

git add . git commit -m "Implement new UI" git push

Merge back to main

cd /path/to/main-repo git checkout main git merge feature/new-ui

Clean up worktree

git worktree remove ../worktrees/feature/new-ui

Parallel Testing Workflow

# Test multiple branches simultaneously
for branch in feature/a feature/b feature/c; do
    git worktree add ../worktrees/$branch $branch
    cd ../worktrees/$branch
    cargo test &
done

# Wait for all tests to complete
wait

Bugfix Workflow

# Create worktree for urgent bugfix
git worktree add -b hotfix/critical-issue ../worktrees/hotfix/critical-issue

# Fix and test in isolation
cd ../worktrees/hotfix/critical-issue
# ... fix bug ...

# Test thoroughly
cargo test

# Merge to release branch
git checkout release/v1.2
git merge hotfix/critical-issue

# Clean up
git worktree remove ../worktrees/hotfix/critical-issue

CI/CD Integration

# GitHub Actions workflow example
- name: Test with Worktrees
  run: |
    # Create worktree for testing
    git worktree add /tmp/ci-test $GITHUB_SHA
    
    # Run tests in worktree
    cd /tmp/ci-test
    cargo test --all
    
    # Clean up
    rm -rf /tmp/ci-test

Code Review Workflow

# Create worktree for PR review
git worktree add ../worktrees/review/pr-123 origin/pr-123

# Review changes in isolation
cd ../worktrees/review/pr-123
# ... review code ...

# Run tests
cargo test

# Clean up after review
git worktree remove ../worktrees/review/pr-123

Git Configuration

Worktree-Specific Configuration

# Configure behavior in specific worktree
cd ../worktrees/feature-name

# Set up local Git config
git config user.name "Developer Name"
git config user.email "developer@example.com"

# Configure branch-specific settings
git config branch.feature-name.mergeoptions "no-ff"

Aliases for Common Operations

# Add to ~/.gitconfig
[alias]
    wt-list = worktree list
    wt-add = "!f() { git worktree add ../worktrees/$1 ${2:--b $2}; }; f"
    wt-remove = "!f() { git worktree remove ../worktrees/$1; }; f"
    wt-prune = worktree prune

Best Practices

DO:

✓ Organize worktrees in dedicated directory (../worktrees/)
✓ Use descriptive branch names and worktree paths
✓ Clean up worktrees after merging or abandoning work
✓ Test in worktree before merging to main branch
✓ Use worktrees for isolated, parallel development
✓ Prune worktrees regularly to remove orphaned data
✓ Lock worktrees during automated operations
✓ Verify worktree status before major operations

DON'T:

✗ Create worktrees in random locations
✗ Use worktrees as long-term storage (use branches instead)
✗ Leave worktrees with uncommitted changes indefinitely
✗ Forget to prune worktree administrative data
✗ Create worktrees with conflicting branches
✗ Mix worktree and non-worktree workflows without clear separation
✗ Remove worktrees without checking for uncommitted changes
✗ Use worktrees for unrelated changes (keep them focused)

Advanced Patterns

Main Branch Protection

# Keep main branch clean
# Never commit directly to main from worktree
# Always create feature branches from main
# Merge feature branches into main from main checkout

# Example safe workflow:
# 1. In main: create-feature-branch
# 2. In worktree: develop and test
# 3. In main: merge-feature-branch
# 4. Remove worktree

Worktree Isolation

# Each worktree is isolated environment
# No shared state between worktrees
# Each worktree has its own .git/config
# Changes in worktree don't affect main until merged

Stashing in Worktrees

# Stash works independently in each worktree
cd ../worktrees/feature-a
git stash save "WIP feature A"

cd ../worktrees/feature-b
git stash save "WIP feature B"

Submodule Considerations

# Worktrees interact with submodules carefully
# Each worktree has its own submodule checkout
# Be aware of submodule init/update operations

Troubleshooting

Common Issues

Issue: Worktree Already Exists

# Error: fatal: 'worktrees/feature-name' already exists
# Solution: Remove existing worktree first
git worktree remove ../worktrees/feature-name
# Then recreate
git worktree add ../worktrees/feature-name feature-branch-name

Issue: Detached HEAD

# Worktree in detached HEAD state
# Solution: Check out appropriate branch
cd ../worktrees/feature-name
git checkout feature-branch-name

Issue: Merge Conflicts

# Conflicts when merging from worktree
# Solution: Resolve in worktree, then merge
cd ../worktrees/feature-name
git merge main
# Resolve conflicts
git commit
git checkout main
git merge feature-name

Issue: Large .git Directory

# Worktrees can bloat .git directory
# Solution: Use prune regularly
git worktree prune
# Consider using sparse checkout for large repos

Tools and Commands Reference

Quick Reference

# List all worktrees
git worktree list

# Create from branch
git worktree add ../worktrees/name branch-name

# Create with new branch
git worktree add -b new-branch ../worktrees/name

# Remove worktree
git worktree remove ../worktrees/name

# Force remove
git worktree remove --force ../worktrees/name

# Prune administrative data
git worktree prune

# Move a worktree
git worktree move ../worktrees/old-path ../worktrees/new-path

# Lock worktree
git worktree lock ../worktrees/name

# Unlock worktree
git worktree unlock ../worktrees/name

Status Checking

# Check all worktree statuses
git worktree list

# Get detailed information
git worktree list --porcelain

# Find worktree for a branch
git worktree list | grep feature-branch-name

Integration with Development Workflows

With IDE

# VS Code: Add multiple workspace roots
# Settings -> Workspace -> Add Folder...
# Add: /path/to/project, /path/to/worktrees/*

# JetBrains: Configure multiple project roots
# File -> Open -> Add Directory to Project

With Testing

# Parallel test execution
for branch in $(git branch -r | grep -v HEAD); do
    git worktree add /tmp/test-$branch $branch
    cd /tmp/test-$branch && cargo test
    rm -rf /tmp/test-$branch
done

With CI/CD

# GitHub Actions: Use worktrees for isolated testing
- name: Parallel Testing
  run: |
    for branch in test-1 test-2 test-3; do
      git worktree add /tmp/$branch origin/$branch
      cd /tmp/$branch && cargo test
      rm -rf /tmp/$branch
    done

Maintenance

Regular Cleanup Schedule

- Daily: Prune worktrees

- Weekly: Check for orphaned worktrees

- Monthly: Review and clean up old worktree directories

Monitoring

# Monitor worktree usage
git worktree list | wc -l  # Count active worktrees

# Monitor disk usage
du -sh ../worktrees/

# Check for large .git directories
du -sh .git

Backup Considerations

# Worktrees don't need separate backups
# All data is in shared git repository
# Main worktree is primary working directory
# Worktrees are temporary workspaces

Summary

Git worktrees enable:

- Parallel Development: Multiple branches simultaneously

- Isolation: Clean main working directory

- Flexibility: Easy to create and remove workspaces

- Organization: Structured worktree management

- Efficiency: Faster context switching between features

Use worktrees for efficient, isolated multi-branch development while maintaining a clean main working directory.

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

clean-code-developer

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

rust-code-quality

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

codebase-analyzer

No summary provided by upstream source.

Repository SourceNeeds Review