Skip to main content

Python Qt4 frontend for git filter-branch and git cherry-pick.

Project description

Formerly qGitFilterBranch.

” If there’s something strange / In your history / Who you gonna call ? / GitBuster! “

Frontend for git cherry-pick/git rebase:

  • use drag and drop to rebase a branch onto another (one or a set of commits)
  • graphical resolution of merge conflicts by displaying:
    • the original content of the file
    • the patch that was meant to be applied but failed
    • the unmerged content of the file for you to edit if necessary
    • a set of resolution choices (delete the file, add the file, add the file with custom content)
  • works with remote branches (directory on your filesystem or web)
  • rename a branch or create a new branch from any commit of your history
  • special conflicts mode that can be called right after a conflict when using ‘git rebase -i’

Frontend for git filter-branch:

  • use filters to display only the commits matching
    • committed before/after a date (e.g. commits before 01/01/11)
    • committed before/after a weekday (e.g. commits after friday)
    • committed before/after an hour (e.g. commits after 20:00)
    • the log message contains some string (e.g. matching “CHANGEME”)
    • the user/email contains some string (e.g. matching “”)
  • edit the displayed commits to change
    • the authored/committed date
    • the author/committer name and email
    • the log message
  • change multiple values at once
  • automatically re-order a given set of commits onto a given set of time ranges

Safe try

With the you can try gitbuster in a safe environment. The script will check that all dependencies are met and install GitPython in a virtualenv. That way it won’t interfere with your system packaging tools (like apt).

Installing From PyPI

Installing with pip:

$ pip install gitbuster

Note: here we’re talking about the Python package installer (

Manual Installation

Get the code:

$ git clone --recursive git://
$ cd gitbuster


$ make install

Building From Sources


  • pyuic4: on debian/ubuntu systems, look for a package named ‘pyqt4-dev-tools’.
  • gcc: on most systems, look for a package named ‘gcc’.
  • make: on most systems, look for a package named ‘make’.
  • gfbi_core: see
  • GitPython

To build gitbuster UI files:

$ cd gitbuster/
$ make

To launch gitbuster:

$ export PYTHONPATH=$PYTHONPATH:<path_to_>/gitbuster
$ cd gitbuster
$ ./gitbuster


There are bugs in gitbuster, especially in:

  • dealing with some unicode commit metadata
  • cherry-picking big commits (+10 modified files) may result in gitbuster being blocked

If you find any bug, don’t hesitate to report it and/or send patches:

Please mention the version you’re using, or the tip of the repository if you’re using the development version, and the steps to reproduce. Your help will be greatly appreciated.


As of v2.1, gitbuster now handles merge commits correctly instead of deleting them as “git rebase -i” would. You can modifiy metadata of an old commit without worrying that it would mess up your history tree. However, you should be careful when reordering commits in a non flat history, as gitbuster doesn’t display correctly the branched histories. The rule of thumb is that inserting a commit in a branch will take the commit below in the tableView as reference: the inserted commit inserted will take its place, and the reference commit will become the inserted commit’s parent. All commits that had the reference commit has parent will now have the inserted commit as parent.

Project details

Download files

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

Files for gitbuster, version 2.1b8
Filename, size File type Python version Upload date Hashes
Filename, size gitbuster-2.1b8.tar.gz (116.5 kB) File type Source Python version None Upload date Hashes View

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Huawei Huawei PSF Sponsor Microsoft Microsoft PSF Sponsor NVIDIA NVIDIA PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page