git-trim
automatically trims your git remote tracking branches that are merged or gone.
Instruction | Configurations | FAQ
Download binary from Releases, and put it under your PATH
directories.
You can also install with cargo install git-trim
if you have cargo
.
It uses git2
under the hood which depends conditionally on openssl-sys
on *nix platform.
You might need to install libssl-dev
and pkg-config
packages if you build from the source. See: https://docs.rs/openssl/0.10.28/openssl/#automatic
git push -u <remote> <branch>
will set an upstream for you on push.git trim
if you need to trim branches especially after PR reviews. It'll automatically recognize merged or gone branches, and delete it.git trim --delete all
git trim --dry-run
when you don't trust me.There are so many lines of commands to type and many statuses of branches that corresponding to PRs that you've sent. Were they merged or rejected? Did I forget to delete the remote branch after it is merged?
After some working with the repository, you'll execute git fetch --prune
or git remote update --prune
occasionally. However, you'll likely see the mess of local branches that are already merged and removed on the remote. Because git fetch --prune
only deletes refs/remotes/<remote>/<branch>
but not corresponding refs/heads/<branch>
for you. It is worse if remote branches that are merged but the maintainer forgot to delete them, the refs/remotes/<remote>/<branch>
would not be removed and so on even if you know that it is merged into the master.
They are tedious to remove manually. git branch --merged
'll likely to betray you it is rebase merged or squash merged
After the PR is merged or rejected, you're likely to delete them manually if you don't have git-trim
but it is tedious to type and error-prone.
You repeat these same commands as much as PRs that you've sent.
You have to remember what branch is for the PR that just have been closed and it is easy to make a mistake.
I feel nervous whenever I put --force
flag. Rebase merge forces to me to use --force
(no pun is intended).
git reflog
is a fun command to play with, isn't it? Also git remote update
and git push
is not instantaneous.
I hate to wait for the prompt even it is a fraction of a second when I have multiple commands to type.
git-trim
works!It is enough to type just git trim
and hit the y
key once.
Voila!
That's why I've made git-trim
.
It knows whether a branch is merged into the default base branch, or whether it is rejected.
It can even push --delete
when you forgot to delete the remote branch if needed.
git config trim.bases
Comma seperated multiple names of branches. All the other branches are compared with those branch's remote reference. Base branches are never be deleted.
The default value is develop,master
.
You can override it with CLI option --base develop --base master
or --bases develop,master
git config trim.protected
Comma seperated multiple glob patterns (e.g. release-*
, feature/*
) of branches or local/remote references that should never be deleted.
You don't have to put bases to the trim.protected
since they are never be deleted by default.
The default value is ``.
You can override it with CLI option with --protected release-*
git config trim.delete
Comma separated values of all
, merged
, gone
, local
, remote
, merged-local
, merged-remote
, gone-local
, gone-remote
.
all
is equivalent to merged-local,merged-remote,gone-local,gone-remote
.
merged
is equivalent to merged-local,merged-remote
.
gone
is equivalent to gone-local,gone-remote
.
local
is equivalent to merged-local,gone-local
.
remote
is equivalent to merged-remote,gone-remote
.
The default value is merged
.
You can override it with CLI flag with --delete local
git config trim.update
A boolean value. git-trim
will automatically call git remote update --prune
if it is true.
The default value is true
.
You can override it with CLI flag with --update
or --no-update
.
git config trim.update
A boolean value. git-trim
will automatically call git remote update --prune
if it is true.
The default value is true
.
You can override it with CLI flag with --update
or --no-update
.
git config trim.confirm
A boolean value. git-trim
will require you to put 'y/n' before destructive actions.
The default value is true
.
You can override it with CLI flag with --confirm
or --no-confirm
.
git config trim.detach
A boolean value. git-trim
will let the local repo in the detached HEAD state when it is true and the current branch will be deleted.
The default value is true
.
You can override it with CLI flag with --detach
or --no-detach
.
git-trim
support?git merge --no-ff
git merge --ff-only
git merge --squash
(With this method: https://stackoverflow.com/a/56026209)merged
and gone
branch?A merged branch is a branch that you can safely remove them. It is already merged into the base branch, so you're not going to lose the changes.
However, your PRs are sometimes rejected and deleted from the remote.
Or you might forget the fact that the PR is merged.
So you might have been mistakenly amended or rebased the branch and the patch is now completely different from the patch that is merged.
Then it is gone
, which means that you might lose your changes. The term is borrowed from the git's remote tracking states.
Git and the Git logo are either registered trademarks or trademarks of Software Freedom Conservancy, Inc., corporate home of the Git Project, in the United States and/or other countries.
The logo is a derivative work of Git Logo. Git Logo by Jason Long is licensed under the Creative Commons Attribution 3.0 Unported License. The logo uses Bitstream Charter.
Images of a man with heartburn are generated with https://gvsc.rajephon.dev