-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathgit-delete-merged-on-remote
executable file
·78 lines (68 loc) · 2.14 KB
/
git-delete-merged-on-remote
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#!/usr/bin/env bash
set -e
#
# This script takes the name of a remote, and of a local branch or ref
# (defaulting to "master"). It then iterates over all branches available on
# the remote, and checks whether that remote branch has been merged or rebased
# into the given local branch.
#
while test $# -ne 0
do
case "$1" in
-n|--dry-run)
# -n, --dry-run
# Don't actually remove anything, just show what would be done.
dry_run=1
;;
--)
shift
break;;
*)
break;;
esac
shift
done
if test $# -eq 1 ; then
remote=$1
base_branch=$(git get-mainbranch $remote)
elif test $# -eq 2 ; then
remote=$1
base_branch=$2
else
echo "Error, usage: $(basename $0) [-n | --dry-run] <REMOTE> [<LOCAL-BRANCH>]"
exit 1
fi
# ensure the given remote name is valid
remote_url=$(git remote get-url $remote)
# ensure the given base branch is a valid ref
base_rev=$(git rev-list -n1 $base_branch)
# make sure we have an up-to-date list of branches on that remote
#echo "Fetching remote $remote"
git fetch --prune --quiet $remote
# iterate over the remote branches
#echo "Iterating over branches of remote $remote..."
to_delete=""
for branch in $(git for-each-ref --format='%(refname:short)' refs/remotes/$remote); do
remote_branch=${branch#$remote/} # remove prefix
case $remote_branch in
$base_branch | HEAD | stable* | bisect* | master | trunk | gh-pages ) continue ;;
esac
echo -n "." # progress bar
diff=$(git rev-list -n1 --cherry-pick --right-only --no-merges "$base_branch"..."$branch")
if [ -z "$diff" ]; then
#echo $branch
to_delete="$to_delete $remote_branch"
# TODO: actually delete? or perhaps leave that to the user...
# git push --delete $remote $remote_branch
fi
done
printf "\r\033[0K" # clear progress bar
if [[ -z $to_delete ]] ; then
echo "No merged or rebased remote branches found"
else
# echo "To delete merged branches on remote $remote, enter this command:"
echo "git push --delete $remote$to_delete"
if test -z "$dry_run" ; then
git push ${dry_run} --delete $remote$to_delete
fi
fi