Last active
July 12, 2022 12:17
-
-
Save ryanc414/f7686d2c97808b41ed8518a5840e2d78 to your computer and use it in GitHub Desktop.
Delete merged git branches locally and on remote
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#!/bin/bash | |
# Remove merged git branches locally and on remote(s) | |
set -e | |
# Script constants | |
BRANCH_WHITELIST="(\*|master|other-special-branches)" | |
REMOTES="origin" # Add more remotes here as space-separated list | |
echo "Deleting merged branches locally" | |
git branch --merged master \ | |
| egrep -v "$BRANCH_WHITELIST" \ | |
| xargs -r git branch -d | |
# Delete merged branches from each remote. | |
for remote in $REMOTES; do | |
echo "Deleting merged branches from $remote" | |
git fetch "$remote" --prune | |
for branch in $(git branch -r --merged master \ | |
| grep "$remote" \ | |
| egrep -v "$BRANCH_WHITELIST"); do | |
git push "$remote" --delete "${branch#*/}" | |
done | |
done |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
No particular harm no, the changes you make to a fork are completely independent of the changes to the upstream. Obviously if you delete an unmerged branch that you created in your fork and isn't mirrored in the upstream, you won't (easily) be able to get it back.
Sure you can pull a branch from upstream into your branch, you just need to pull it from upstream to your local repo first and then push it to your fork. Assuming you have the fork remote set up as "origin" and the upstream set up as "upstream" (
git remote add upstream <upstream URL>
if you don't have that):