wtt - Work Tree Tool
Overview
CLI tool for managing git worktrees using bare clones.
Installation
From a repository checkout:
Paths
| Type | Default Location |
|---|---|
| Config | ~/.config/wtt.toml |
| Bare clones | ~/.local/share/wtt/bare/<repo>.git |
| Worktrees | ~/devel/<repo>/<branch>/ |
Branch names containing / become subdirectories (e.g., feature/login → ~/devel/myrepo/feature/login/).
Configuration
Configuration is loaded from ~/.config/wtt.toml by default. All fields are optional.
= "/path/to/bare/clones"
= "/path/to/worktrees"
CLI Flags
| Flag | Description |
|---|---|
--config-file <PATH> |
Load configuration from specified file |
--no-config-file |
Disable configuration file loading |
Commands
setup
Create bare clone and prepare worktree directory.
<REPO>- Local name for the repository<URL>- Git remote URL to clone- Clones bare repo to
~/.local/share/wtt/bare/<repo>.git - Creates empty
~/devel/<repo>/directory
add
Create a worktree.
<BRANCH>- Branch name for the new worktree--base <BASE>- Base ref for new branches (default: remote default branch)--repo <REPO>- Repository name (default: auto-detected from current directory)- Auto-detects existing vs new branch:
- If branch exists (local/remote): checkout
- If branch doesn't exist: create from base
list
List worktrees.
--repo <REPO>- Repository name (default: auto-detected, or list all if outside worktree)
remove
Remove a worktree.
<BRANCH>- Branch name of the worktree to remove--repo <REPO>- Repository name (default: auto-detected from current directory)- Deletes worktree directory only, does not delete the branch