Skip to main content

A terminal TUI application for managing Git branches

Project description

gittwig

A terminal user interface (TUI) for viewing and switching git branches, built with Python and Textual.

I built this because I wanted a quick way to view git branches and switch between them. Vibe-coded with Claude Code.

This provides a fast, easy way to browse branches, see the commit history for a given branch, identify files changed in a branch, and view file diffs with syntax highlighting. As an open source developer who works with many branches across multiple projects, this is very helpful for figuring out where I left off and juggling multiple branches.

Screenshot

Features

  • Browse local and remote branches in a navigable list
  • View changed files compared to your default branch
  • View commit history unique to each branch
  • Syntax-highlighted diff viewer
  • Checkout branches with Enter
  • Create and delete branches
  • Fetch, push, and pull operations
  • Filter branches with / search
  • Vim-style keyboard navigation

Installation

Requires Python 3.12 or later.

Install uv and run:

uv tool install gittwig

To run with uv without installing:

uv tool run --from gittwig twig

Usage

Run twig in any git repository:

twig

Or specify a repository path:

twig /path/to/repo

Keyboard Shortcuts

Navigation

Key Action
j / k Move cursor down / up
h / l Focus left / right pane
g g Go to top of list
G Go to bottom of list
Ctrl+d / Ctrl+u Page down / up
Enter Select item / checkout branch

Branch Operations

Key Action
n Create new branch
d Delete branch (with confirmation)
r Refresh data
f Fetch from remotes
p Push current branch
P Pull current branch

Other

Key Action
/ Search/filter branches
? Show help
q Quit
Escape Close modal / cancel

Development

# Install development dependencies
uv sync --group dev

# Run tests
pytest

# Run linter
ruff check .

# Run type checker
mypy src

License

MIT License - see LICENSE for details.

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

gittwig-0.2.4.tar.gz (15.3 kB view details)

Uploaded Source

Built Distribution

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

gittwig-0.2.4-py3-none-any.whl (23.2 kB view details)

Uploaded Python 3

File details

Details for the file gittwig-0.2.4.tar.gz.

File metadata

  • Download URL: gittwig-0.2.4.tar.gz
  • Upload date:
  • Size: 15.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.2

File hashes

Hashes for gittwig-0.2.4.tar.gz
Algorithm Hash digest
SHA256 ec8f796ef4dfe1e4225facc8564bea39f1566d8708b652b512ee3f452c72c288
MD5 89df910f007fa425ccf96e72047c5e21
BLAKE2b-256 57cdb4b2461ab5d42c6ec61b6645afbd6e7114748845ac33c65402ab5f1dd450

See more details on using hashes here.

File details

Details for the file gittwig-0.2.4-py3-none-any.whl.

File metadata

  • Download URL: gittwig-0.2.4-py3-none-any.whl
  • Upload date:
  • Size: 23.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.2

File hashes

Hashes for gittwig-0.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 019fd89ddce208a82478139685de6877bc4d1f0466e6fd6d19ead2f64c1e2d8c
MD5 1ef6ceacb66ab815322beb81b9a81cf7
BLAKE2b-256 4a39c22935bc8f645d5d8820303bbfc5229c68335694210d12071afdd32d6644

See more details on using hashes here.

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