Remove remote braches that are merged into master
git branch -r --merged master | grep -v 'master$' | sed -e 's/origin\///' | tee | xargs -I branch -p git push origin :branch
Finds branches that have been merged into master, excludes master, replaces 'origin/' prefix, then deletes them all.
Thanks to -p
option, console will always ask you for confirmation, so you do not delete branch by accident. Although it is still dangerous, so use this command with caution.
Based on @catchamonkey protip https://coderwall.com/p/oik3ta
Written by Anton Kalyaev
Related protips
2 Responses
data:image/s3,"s3://crabby-images/bea90/bea90bd7ef18287e9e97bd5333bb9a6a87a6081d" alt=""
It is bad practice when you have, for example, master and production branches, If you put your fixes to production branch and then merge it into master, then your script will delete production branch
over 1 year ago
·
data:image/s3,"s3://crabby-images/ac25f/ac25f711b721983050d62b5c969fbfe36ad9fbbb" alt=""
@kelion Thanks, I didn't think about it. I've added -p flag to xargs command for confirmation.
over 1 year ago
·
Have a fresh tip? Share with Coderwall community!
Post
Post a tip
Best
#Branch
Authors
data:image/s3,"s3://crabby-images/597f9/597f9df605bf0869b1ba694ffd868979f6c5c2cc" alt=""
niklongstone
42.01K
data:image/s3,"s3://crabby-images/e090f/e090f448e4aaaf61dd4e618743699ac86499ecad" alt=""
muzzlefork
11.98K
Sponsored by #native_company# — Learn More
#native_title#
#native_desc#