diff options
Diffstat (limited to '.local/bin/git-branch-cleaning')
-rwxr-xr-x | .local/bin/git-branch-cleaning | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/.local/bin/git-branch-cleaning b/.local/bin/git-branch-cleaning new file mode 100755 index 0000000..8c728be --- /dev/null +++ b/.local/bin/git-branch-cleaning @@ -0,0 +1,63 @@ +#! /usr/bin/env sh + +main() +{ + # Handle opts + opts "$@" + shift "$OPTS" + unset OPTS + + # Show help + [ "$OPT_HELP_ONLY" ] && usage && exit 0 + + # Get a list of branches + buffer=$(mktemp) + + git branch --merged \ + | awk '{ print $NF }' \ + | grep -Ev "^master$" \ + > "$buffer" + + printf "Going to remove the following %s branches:\n" "$(wc -l < "$buffer")" + cat -- "$buffer" + + printf "\n^C to cancel...\n" + read + + while read -r branch + do + git branch -D -- "$branch" + done < "$buffer" +} + +opts() +{ + OPTS=0 + + while getopts ":h" opt + do + case "$opt" in + h) OPT_HELP_ONLY=1 ;; + *) + printf "Invalid option passed: %s\n" "$OPTARG" >&2 + ;; + esac + done + + unset opt +} + +usage() +{ + cat <<EOF +Usage: + $(basename "$0") -h + +Clean up merged branches. + +Options: + -h Show this help text and exit. +EOF +} + +main "$@" |