An open API service indexing awesome lists of open source software.

https://github.com/jlowin/claude-wt

๐ŸŒด Simple utility for managing parallel Claude Code instances
https://github.com/jlowin/claude-wt

agent claude claude-ai claude-code

Last synced: 2 months ago
JSON representation

๐ŸŒด Simple utility for managing parallel Claude Code instances

Awesome Lists containing this project

README

          

# ๐ŸŒด Claude-Worktree

Run multiple Claude Code instances in parallel without stepping on each other. This CLI creates isolated git worktrees for each Claude session, so you can work on different features simultaneously while keeping your main branch clean.

*Inspired by a script from [aaazzam](https://github.com/aaazzam).*

## ๐Ÿš€ Quick Start

Jump right in without installing anything:

```bash
uvx claude-wt new "implement user authentication"
```

**That's it.** You're now working in a clean branch where Claude can't mess up your pristine codebase.

### Installation Options

If you prefer global installation:

```bash
uv tool install claude-wt
```

Or from source:

```bash
git clone https://github.com/anthropics/claude-wt.git
cd claude-wt
uv install -e .
```

## ๐ŸŽฏ Commands

### โœจ Start Fresh: `new`

Spin up a new isolated Claude session:

```bash
uvx claude-wt new "implement user authentication"
```

Behind the scenes: creates a timestamp branch, sets up a worktree in `.claude-wt/worktrees/`, and launches Claude with your query.

Want a memorable branch name? Use `--name`:

```bash
uvx claude-wt new "fix the parser" --name parser-fix
```

Need to branch from a specific source? Use `--branch`:

```bash
uvx claude-wt new "hotfix for prod" --branch main --name hotfix-123
```

### ๐Ÿ”„ Pick Up Where You Left Off: `resume`

Claude sessions are like good TV showsโ€”you want to continue watching:

```bash
uvx claude-wt resume 20241201-143022
```

The session ID is shown when you create it.

### ๐Ÿ“‹ See What's Running: `list`

See all your active worktrees:

```bash
uvx claude-wt list
```

Shows each session with its health status.

### ๐Ÿงน Clean Up: `clean`

Remove a specific session when you're done:

```bash
uvx claude-wt clean 20241201-143022
```

Or clean everything:

```bash
uvx claude-wt clean --all # The Marie Kondo approach
```

## ๐Ÿ”ง How It Works

Think of it like having multiple parallel universes for your code:

1. **Branch Creation** โ†’ Each session gets its own branch (`claude-wt-{timestamp}` or your custom name)
2. **Worktree Setup** โ†’ Creates a separate directory in `.claude-wt/worktrees/` so files don't conflict
3. **Claude Launch** โ†’ Starts Claude in the isolated environment with full repo access
4. **Session Management** โ†’ Resume, list, and clean up sessions effortlessly

## ๐ŸŽ Why You'll Love This

- **Fear-Free Experimentation** โ†’ Claude can't break your main branch even if it tries
- **Mental Clarity** โ†’ No more "did I commit that test code?" anxiety
- **Context Switching** โ†’ Jump between different Claude conversations effortlessly
- **Easy Cleanup** โ†’ One command to remove all experimental branches
- **Clean History** โ†’ Your main branch stays pristine for serious work

## ๐Ÿ“‹ What You Need

- **Python 3.12+**
- **Git with worktree support** (any recent version)
- **Claude CLI** (installed and authenticated)

## ๐Ÿ› ๏ธ Development

Uses uv for dependency management:

```bash
uv sync
uv run claude-wt --help
```

Or test changes without installing:

```bash
uvx --from . claude-wt --help
```

---

*Built with the assumption that your Claude sessions shouldn't be a game of git-roulette with your main branch.*