Git worktree manager for parallel coding agent development
Project description
Timberline
Git worktree manager for parallel coding agent development.
Features
- Auto-launch coding agents — spawn Claude, Codex, OpenCode, or Aider directly into a worktree (
tl new --agent) - Agent context injection — auto-injects worktree metadata (branch, base, sibling worktrees) into agent config files (CLAUDE.md, AGENTS.md)
- Auto-init dependencies — detects & installs via bun/npm/pnpm/yarn/uv/pip/cargo/go/composer/bundle on worktree creation
- Auto-copy .env files — glob-based discovery with include/exclude patterns, sync & diff commands
- Auto-init submodules — recursive submodule setup on worktree creation
- Shell integration —
tlcdto cd into worktrees,tl-promptfor PS1, auto-install for bash/zsh/fish - Creative naming schemes — minerals, cities, or compound names for auto-named worktrees
- Branch templates — configurable
{user}/{type}/{name}patterns for consistent naming - Land workflow — pre-land checks → push → PR creation in one command
- Multi-worktree status — git status, ahead/behind tracking across all worktrees
- Sync all worktrees — rebase or merge all worktrees on latest base branch
Install
# global CLI (recommended)
uv tool install timberline
# or with pip
pip install timberline
Upgrade
uv tool upgrade timberline
Setup
Setup shell aliases
tl install
Quick Start
cd your-repo
tl init # create .timberline.toml
tl new auth-refactor # create worktree + branch
tl new --type fix # auto-named fix worktree
tl ls # list all worktrees
cd $(tl cd auth-refactor) # jump into worktree
tlcd auth-refactor # jump into worktree (shell aliases installed)
tl land # commit, run checks and push pr
tl rm auth-refactor # clean up
Getting Started
Run tl init inside any git repo to create .timberline.toml. The wizard auto-detects:
- Branch prefix from your git user
- Base branch (main/master/develop)
- Package manager (bun, npm, pnpm, yarn, uv, pip, cargo, go, composer, bundle) for dependency install
- Pre-land checks (Makefile targets, npm scripts like
lint,test,check) - Default agent (claude, codex, opencode, aider) if installed
Use --defaults to skip prompts and accept detected values.
Create & Enter a Worktree
tl new auth-refactor # named worktree
tl new --type fix # auto-named (minerals, cities, or compound)
tl new --agent # create + launch coding agent
Enter a worktree:
cd $(tl cd auth-refactor) # subshell-friendly
Or with shell integration (tl install):
tlcd auth-refactor # cd directly
Each worktree gets its own branch (from branch_template), dependencies installed via auto_init, and .env files copied from the main repo.
Sync with Base Branch
tl sync # rebase current worktree onto base
tl sync auth-refactor # rebase specific worktree
tl sync --all # rebase all worktrees
tl sync --merge # merge instead of rebase
Fetches all remotes, then rebases (default) or merges onto origin/{base_branch}. Each worktree tracks its own base branch from creation — no hardcoded "main".
Land a PR
tl land auth-refactor # checks → push → PR
tl land --draft # create as draft PR
tl land --skip-checks # bypass pre-land checks
tl land runs your configured pre_land command (e.g. make check), pushes the branch, then creates a PR via gh. Configure it in .timberline.toml:
[timberline]
pre_land = "make check" # or "bun run lint && bun run test", etc.
Commands
| Command | Description |
|---|---|
tl init |
Interactive setup, write .timberline.toml |
tl new [name] |
Create worktree (aliases: create) |
tl ls |
List worktrees (aliases: list). --json, --paths |
tl rm <name> |
Remove worktree (aliases: remove). --force, --keep-branch, --all |
tl cd <name> |
Print worktree path. --shell for subshell |
tl status |
Git status across all worktrees |
tl sync [name] |
Rebase/merge on base branch. --all, --merge |
tl land [name] |
Run checks, push, and create PR. --draft, --skip-checks |
tl rename <branch> |
Rename worktree's git branch. -n <name> |
tl agent [name] |
Launch coding agent in worktree. --new |
tl run-init [name] |
Re-run dependency install |
tl pr [name] |
Create PR via gh CLI. --draft |
tl env sync [name] |
Re-copy .env files from main repo |
tl env ls |
List discovered .env files |
tl env diff [name] |
Show .env differences |
tl clean |
Prune stale worktrees. --dry-run |
tl install |
Install shell integration into rc file. --uninstall |
tl shell-init |
Output shell integration script |
tl config show |
Print resolved config |
tl config set <k> <v> |
Set config value |
tl config edit |
Open config in $EDITOR |
Config
.timberline.toml in repo root:
[timberline]
worktree_dir = ".tl"
branch_template = "{user}/{type}/{name}"
user = "nc9"
default_type = "feature"
base_branch = "main"
naming_scheme = "minerals" # minerals | cities | compound
default_agent = "claude" # claude | codex | opencode | aider
pre_land = "make check" # command to run before pushing
[timberline.init]
auto_init = true
# init_command = "bun run init"
# post_init = ["echo done"]
[timberline.env]
auto_copy = true
patterns = [".env", ".env.*", "!.env.example", "!.env.template"]
scan_depth = 3
[timberline.submodules]
auto_init = true
recursive = true
[timberline.agent]
auto_launch = false
inject_context = true
Shell Integration
# Automatic install:
tl install
# Or manually add to .zshrc / .bashrc:
eval "$(tl shell-init)"
# Then use:
tlcd obsidian # cd into worktree
tl-prompt # worktree name for PS1
Development
uv sync
make test # pytest
make lint # ruff + basedpyright
make fmt # ruff format
make check # all of the above
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file timberline-0.1.3.tar.gz.
File metadata
- Download URL: timberline-0.1.3.tar.gz
- Upload date:
- Size: 49.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.10 {"installer":{"name":"uv","version":"0.9.10"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
243239c9423f328423a07457d15cb6025a506a787201704e449cf0c4bd97c4dc
|
|
| MD5 |
3f61be89a7285ace894f732f804624e6
|
|
| BLAKE2b-256 |
70029b40d6a157bba487a5ffefcfbf67d3bdefe5308c17dde887f670da47fd9f
|
File details
Details for the file timberline-0.1.3-py3-none-any.whl.
File metadata
- Download URL: timberline-0.1.3-py3-none-any.whl
- Upload date:
- Size: 27.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.10 {"installer":{"name":"uv","version":"0.9.10"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2e8c4838a878f627f3a625b3a665319a7e21b69eb6fe74993b97f4bba2dd41ee
|
|
| MD5 |
7a26f9eb091dde7912013f17ce972535
|
|
| BLAKE2b-256 |
ab0a6d691451e124c869ecbc7b4045869903c2030e107c374a4d9c4c549473e5
|