aboutsummaryrefslogtreecommitdiff
path: root/zsh-completion/_gitbmerge
diff options
context:
space:
mode:
Diffstat (limited to 'zsh-completion/_gitbmerge')
-rw-r--r--zsh-completion/_gitbmerge20
1 files changed, 7 insertions, 13 deletions
diff --git a/zsh-completion/_gitbmerge b/zsh-completion/_gitbmerge
index 733dbfb..0b598a0 100644
--- a/zsh-completion/_gitbmerge
+++ b/zsh-completion/_gitbmerge
@@ -2,20 +2,14 @@
#autoload
_gitbmerge() {
- (( CURRENT > 2)) && return # Complete only single dependency
- local GDIR="$(pwd)"
- while [ ! -d "$GDIR/.git" ]; do
- [ -z "$GDIR" ] && return
- GDIR="${GDIR%/*}"
- done
- GDIR="$GDIR/.git"
- [ -f "$GDIR" ] && GDIR="$(cat "$GDIR")" # This just points to some other directory
- [ -d "$GDIR/refs/heads" ] || return # No completion if there is no local branch
+ ((CURRENT > 2)) && return # Complete only single branch
+ local gdir branch
+ gdir="$(git rev-parse --git-common-dir 2>/dev/null)" || return
local branches=()
- for B in "$GDIR"/refs/heads/*; do
- # TODO skip branch on HEAD
- branches+=("${B#$GDIR/refs/heads/}")
- done
+ # TODO ignore current HEAD (merging HEAD to HEAD does not makes sense)
+ while read -r branch; do
+ branches+=("$branch")
+ done < <(find "$gdir/refs/heads" -mindepth 1 -printf '%P\n')
_describe -t branches 'gitbmerge' branches
}