Skip to main content

A Terminal UI for managing Git worktrees

Project description

forestui

A terminal UI for managing Git worktrees, inspired by forest for macOS by @ricwo.

forestui brings the power of Git worktree management to the terminal with a beautiful TUI interface built on Textual, featuring deep integration with Claude Code.

forestui screenshot

Features

  • Repository Management: Add and track multiple Git repositories
  • Worktree Operations: Create, rename, archive, and delete worktrees
  • TUI Editor Integration: Opens TUI editors (vim, nvim, helix, etc.) in tmux windows
  • Claude Code Integration: Track and resume Claude Code sessions per worktree
  • Multi-Forest Support: Manage multiple forest directories via CLI argument
  • tmux Native: Runs inside tmux for a cohesive terminal experience

Requirements

  • Python 3.14+
  • tmux
  • uv (for installation)
  • gh (optional, for GitHub integration)

Installing

Quick Install (recommended)

Installs uv automatically if not present. No Python installation required.

curl -fsSL https://raw.githubusercontent.com/flipbit03/forestui/main/install.sh | bash

Install via uv

If you already have uv installed:

uv tool install forestui

Updating

forestui auto-updates on startup. To manually update:

uv tool upgrade forestui

Usage

# Start with default forest directory (~/forest)
forestui

# Start with a custom forest directory
forestui ~/my-projects

# Show help
forestui --help

Keyboard Shortcuts

Key Action
a Add repository
w Add worktree
e Open in editor
t Open in terminal
o Open in file manager
n Start Claude session
y Start Claude session (YOLO mode)
h Toggle archive
d Delete
s Settings
r Refresh
? Show help
q Quit

TUI Editor Integration

When your default editor is a TUI editor (vim, nvim, helix, nano, etc.), forestui opens it in a new tmux window named edit:<worktree>. This keeps your editing session organized alongside forestui and any Claude sessions.

Supported TUI editors: vim, nvim, vi, emacs, nano, helix, hx, micro, kakoune, kak

Multi-Forest Support

forestui stores its state (.forestui-config.json) in the forest directory itself, allowing you to manage multiple independent forests:

forestui ~/work      # Uses ~/work/.forestui-config.json
forestui ~/personal  # Uses ~/personal/.forestui-config.json

User preferences (editor, theme, branch prefix) are stored globally in ~/.config/forestui/settings.json.

Configuration

Settings are stored in ~/.config/forestui/settings.json:

{
  "default_editor": "nvim",
  "branch_prefix": "feat/",
  "theme": "system"
}

Press s in the app to open the settings modal.

Development

# Clone and enter the repo
git clone https://github.com/flipbit03/forestui.git
cd forestui

# Install dev dependencies
make dev

# Run checks
make check

# Format code
make format

# Run the app
make run

See CLAUDE.md for AI-assisted development guidelines.

Compatibility with forest (macOS)

forestui is designed to coexist with forest for macOS:

  • Both apps can share the same ~/forest directory for worktrees
  • Each app maintains its own state file:
    • forest: .forest-config.json (stored in ~/.config/forest/)
    • forestui: .forestui-config.json (stored in the forest folder itself)
  • Worktrees created by either app work seamlessly with both

Key difference: forestui stores its state inside the forest folder (~/forest/.forestui-config.json) rather than in a global config directory. This design enables multi-forest support - you can run forestui ~/work and forestui ~/personal with completely independent state for each.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

forestui-1.0.0.tar.gz (139.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

forestui-1.0.0-py3-none-any.whl (45.8 kB view details)

Uploaded Python 3

File details

Details for the file forestui-1.0.0.tar.gz.

File metadata

  • Download URL: forestui-1.0.0.tar.gz
  • Upload date:
  • Size: 139.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for forestui-1.0.0.tar.gz
Algorithm Hash digest
SHA256 a5664a24281dd5832aa3c056f0906d23f7080bb57aa28997e2aa1c332f3efd91
MD5 7ca04e78827c826055941daa92cd2146
BLAKE2b-256 993f9cede3105f83b06ee6df4ff24287bf26d8eef158c3da0e8f2060283064e7

See more details on using hashes here.

Provenance

The following attestation bundles were made for forestui-1.0.0.tar.gz:

Publisher: publish.yml on flipbit03/forestui

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file forestui-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: forestui-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 45.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for forestui-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7c7486c95ca16fe0bc82f8d54ed67fedcf351002bb631625eb78c19f697e7c83
MD5 eb66fa84710835ce8f08f21f5f77fffe
BLAKE2b-256 aa74e25b6273d8fb4fb7b46ce9fcd688b93a1bc83ae5d172f8b6a47273f459cd

See more details on using hashes here.

Provenance

The following attestation bundles were made for forestui-1.0.0-py3-none-any.whl:

Publisher: publish.yml on flipbit03/forestui

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page