Skip to main content

No project description provided

Project description

Branchtree

branchtree is a command-line tool that displays a hierarchical representation of the branches in a Git repository. It visualizes the relationships between branches, showing which branches are based on others and how they are related through commits.

Alternatively it can also be imported and used as a Python module.

Features

  • Branch hierarchy: View a tree-like structure showing how branches are related to one another.
  • Filtering by regex: Filter branches by a regular expression to display only relevant branches.
  • Local and remote branches: Show either local or remote branches, or both.
  • Tag inclusion: Display whether a branch is merged into a given tag.
  • Branch-specific view: View a specific branch's hierarchy along with its children (if any).

Installation

To use the branchtree tool, ensure you have Python (>= 3.11) installed on your system.

You can install branchtree via pip:

$ pip install branchtree

Alternatively, you can install it by cloning this repository and installing via pip locally:

$ git clone https://github.com/nazsolti/branchtree.git
$ cd branchtree
$ pip install .

After installation the branchtree command will be available in your terminal.

Usage

usage: branchtree [-h] [--regex REGEX] [-l] [-r] [-b [BRANCH ...]] [-t TAG]

Options:

  • -h, --help: Show the help message and exit.
  • -V, --version: Show the version number and exit.
  • --regex REGEX: Only show branches matching the given regex.
  • -l, --local: Only show local branches.
  • -r, --remote: Only show remote branches from origin. For other remotes, use the --regex option.
  • -b [BRANCH ...], --branch [BRANCH ...]: Only show the specified branches and their children.
  • -t TAG, --tag TAG: Show whether each branch is included in the given tag (i.e., merged into the tag).

Examples

Displaying Remote Branches

$ branchtree -r

This command will display a tree of remote branches from origin.

🞄origin/feature-1234
  └── origin/bugfix-4567
🞄origin/bugfix-4567
🞄origin/feature-5678
🞄origin/release-2025-01
🞄origin/feature-6789
  └── origin/feature-1234
       └── origin/bugfix-4567
🞄origin/feature-7890
🞄origin/hotfix-3456

In this example, origin/feature-6789 is the parent branch of origin/feature-1234 and that is the parent of origin/bugfix-4567.

Filtering Branches with a Regex

$ branchtree -r --regex "feature"

This command will show only remote branches with names that match the regex pattern feature:

🞄origin/feature-1234
🞄origin/feature-5678
🞄origin/feature-6789
  └── origin/feature-1234
🞄origin/feature-7890

Show Only Local Branches

$ branchtree -l

This command will display the hierarchy of local branches in the repository.

🞄feature/login-setup
🞄feature/dashboard-UI
  └── feature/login-setup
🞄hotfix/ui-bug
🞄feature/profile-settings
  └── feature/dashboard-UI
       └── feature/login-setup

Show Only Specific Branches

$ branchtree -b feature/login-setup feature/dashboard-UI

This command will display the hierarchy for only the specified branches and their children.

🞄feature/login-setup
🞄feature/dashboard-UI
  └── feature/login-setup

Show Branches Merged Into a Tag

$ branchtree -r -t v1.2

This command will display all remote branches and indicate whether they are merged into the v1.2 tag.

🞄origin/feature-1234
  └── origin/bugfix-4567 (in v1.2)
🞄origin/bugfix-4567
🞄origin/feature-5678
🞄origin/release-2025-01
🞄origin/feature-6789
  └── origin/feature-1234
       └── origin/bugfix-4567 (in v1.2)
🞄origin/feature-7890
🞄origin/hotfix-3456 (in v1.2)

In this particular example branches origin/bugfix-4567 and origin/hotfix-3456 are merged into the v1.2 tag.

This can be useful to check whether a branch has been released already.

Show Branches Containing a Branch

$ branchtree -c feature/login-setup

This command will only display the hierarchy for the branches that contain the specified branch.

🞄feature/dashboard-UI
  └── feature/login-setup

Similarly to the -b argument, multiple branches can be specified.

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

branchtree-0.1.1.tar.gz (6.6 kB view details)

Uploaded Source

Built Distribution

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

branchtree-0.1.1-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file branchtree-0.1.1.tar.gz.

File metadata

  • Download URL: branchtree-0.1.1.tar.gz
  • Upload date:
  • Size: 6.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.4

File hashes

Hashes for branchtree-0.1.1.tar.gz
Algorithm Hash digest
SHA256 fd0cd14b7f3592fb6656bc9c38ca20ee60e8c0fe2aefd90caa97b79009614e1d
MD5 9c98ccb57306aa96ef4ecd23fe3d3fb6
BLAKE2b-256 33a107fea673858232b013282db72ead215c8047b40c35e2c354fb4957f84716

See more details on using hashes here.

File details

Details for the file branchtree-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: branchtree-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 7.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.4

File hashes

Hashes for branchtree-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 de7049cbde7ff26fadf7f8c10b0a00469d32eaba46036b18347112cdd527757b
MD5 5280169cc211dd8f36fe9e56a124d910
BLAKE2b-256 27a3042b43b4e4e3a8893b6462f84cc4bfe4d24a27955c92c38150f0e2960780

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