Your shipyard for parallel development workflows. AI-era ready.
A developerโs repo is their yard and their pride. Everyone keeps their yards manicured.
branchyard gives you the tools to maintain your digital yard โ keeping your branches clean, your workflow productive, and your development environment perfectly organized.
You get a tree! You get a tree! Everybody gets a tree! ๐ณ
Parallel development is powerful but messy with raw git worktree:
- Switching branches constantly breaks focus
- Running multiple features in parallel is error-prone
- Managing worktrees manually is tedious and risky
branchyard solves this by:
- Automating safe worktree creation/removal
- Managing multiple editors and sessions
- Adding safety checks, dry-run mode, and fun touches
- Keeping everything in one place โ no hidden docs, no guesswork
branchyard is built on three principles:
- 
Be Playful We believe tools should have personality. From ASCII Oprah to the yard pride story, branchyard reflects the people who build it. 
- 
Be Clear Every feature, every flag, every capability is documented here in the README. No hidden features, no buried docs โ everything you need is in one place. 
- 
Empower the User Whether branchyard is right for you or not, youโll know after reading this README. Our goal is to give you the best possible shot at making the right choice for your workflow. 
branchyard works on Windows, macOS, and Linux.
- Bun โ JavaScript runtime (v1.0+) If Bun is missing, branchyard will exit with a clear error.
- Git โ must be installed and available in your system PATHIf Git is missing, branchyard will exit with a clear error.
- Editor CLI command installed and available in PATH:- VS Code โ code
- Cursor โ cursor
- Windsurf โ windsurf
- Trae โ trae
- Zed โ zedIf the selected editor CLI is missing, branchyard will exit with a clear error.
 
- VS Code โ 
- On Windows, you can use branchyard from:
- PowerShell
- Command Prompt
- Git Bash
 
- On macOS/Linux, any modern terminal will work.
- ASCII art Easter eggs (like Oprah) require a UTF-8 capable terminal (most modern terminals support this by default).
- Create multiple worktrees from any base branch
- Remove worktrees safely (with dry-run mode)
- Bulk remove multiple worktrees at once
- List active worktrees with branch, path, last commit, and age
- Pre-flight checks:
- Git installed
- Inside a Git repo
- Show current directory, repo root, and branch
- Warn if not in repo root (with --allow-subdirfor monorepos)
 
- Dry-run mode (--dry-run) to preview changes
- Double-confirm force mode (--force) to prevent overwrites
- Triple checks before creating worktrees
- Guided prompts for creating, removing, listing, and restoring
- Branch auto-suggestions
- Multi-select worktree removal
- Editor selection (VS Code, Cursor, Windsurf, Trae, Zed)
- Auto-prompt to save setup as a named session
- Open worktrees in your preferred editor
- Save default editor in ~/.branchyardrc
- Easily extendable for future editors
- Save a setup with branchyard save-session <name>
- Restore with branchyard restore [name](auto-recreates missing worktrees)
- List sessions with branchyard sessions
- Delete sessions with branchyard delete-session <name>
- Generates .code-workspacewith all worktrees
- Merges with a custom template from ~/.branchyardrc
- Supports settings, extensions, and more
bun install -g branchyardgit clone https://github.com/YOUR_USERNAME/branchyard.git
cd branchyard
bun linkbranchyardGuided prompts for creating, removing, listing, and restoring worktrees. Pre-flight check runs first to show:
- Current directory
- Repo root
- Current branch
- Warn if not in repo root
branchyard agent-factory upgrades-marketplace --base develop --open- Creates agent-factoryandupgrades-marketplacefromdevelop
- Opens them in your default editor
branchyard remove agent-factory upgrades-marketplace
# Prompts: "Also delete the git branches? (y/N):"Auto-delete branches without prompting:
branchyard remove agent-factory --delete-branchWith dry-run:
branchyard remove agent-factory --dry-runbranchyard listShows all active worktrees with branch, commit, and age.
branchyard save-session sprint-42branchyard restore sprint-42If no name is given:
branchyard restoreRestores the last saved session.
branchyard sessionsbranchyard delete-session sprint-42| Flag | Description | 
|---|---|
| --base <branch> | Base branch to create worktrees from (default: main) | 
| --no-create | Skip creating worktrees, only regenerate workspace/tasks | 
| --open | Open in default editor after setup | 
| --cwd <path> | Path to main repo (default: current directory) | 
| --dry-run | Show what would happen without making changes | 
| --force | Overwrite existing folders (requires double confirmation) | 
| --delete-branch | Auto-delete git branches without prompting when removing worktrees | 
| --allow-subdir | Allow running from a subfolder in a monorepo without warning | 
| --fun | Trigger Easter egg output | 
| --sequential | Run operations sequentially instead of in parallel | 
| Task | Raw git worktree | branchyard | 
|---|---|---|
| Create 2 worktrees | git worktree add ../foo foo && git worktree add ../bar bar | branchyard foo bar | 
| Remove worktree | git worktree remove ../foo | branchyard remove foo | 
| List worktrees | git worktree list | branchyard list(with branch, commit, age) | 
| Restore session | (manual) | branchyard restore my-session | 
We take productivity seriouslyโฆ but we also believe your tools should make you smile.
- Easter Eggs: Create more than one worktree at a time andโฆ well, youโll see. ๐
- On-Demand Fun: Run branchyard --funto instantly trigger one of our Easter eggs.
- CLI Personality: branchyard isnโt just functional โ itโs got character.
- Shareable Moments: Some outputs are just begging to be screenshotted and shared.
๐ก Tip: Keep an eye out for special surprises when youโre working in parallel.
Error: Git not found
- Install Git: https://git-scm.com/
Error: Bun not found
- Install Bun: https://bun.sh/
Error: Editor CLI not found
- Enable your editor's CLI in PATH (e.g., VS Code โ codecommand)
- Worktree pruning (auto mode + dry-run) โ branchyard prune --autowith safe preview before deletion.
- Git hook integration โ Auto-prune orphaned worktrees on branch delete (see README for hook setup).
- Parallel operations โ Bulk create/remove with Promise.all()and progress indicators.
- Config validation โ Zod schema validation for config and sessions to prevent corruption.
- Workspace generation enhancements โ Merge custom workspaceTemplatefrom~/.branchyardrcinto.code-workspace.
- Interactive session restore โ Pick from list instead of typing name.
- Manual prune mode โ Interactive pruning with selection.
- Named session switching โ branchyard switch <name>to close current session and open another.
- Session metadata โ Store and optionally re-run last commands for a session.
- Editor profiles per session โ Different sessions can have different default editors.
- Remote sync for sessions โ Cloud/Gist backup.
- Dual distribution โ Standalone binaries for Windows/macOS/Linux.
- Enhanced progress bars โ Real-time progress visualization.
You can customize the generated .code-workspace by adding a workspaceTemplate to your ~/.branchyardrc:
{
  "workspaceTemplate": {
    "settings": {
      "editor.formatOnSave": true,
      "typescript.tsdk": "node_modules/typescript/lib"
    },
    "extensions": {
      "recommendations": ["dbaeumer.vscode-eslint"]
    }
  }
}This template will be merged with the generated folders array for your worktrees.
- Fork the repo
- Create a feature branch
- Commit your changes
- Open a PR
MIT License โ feel free to use, modify, and share.
A developerโs repo is their yard and their pride. branchyard helps you keep your digital yard manicured โ clean branches, productive workflows, AI-era ready.
