diff options
Diffstat (limited to 'zsh-completion')
| -rw-r--r-- | zsh-completion/_gitbmerge | 23 | 
1 files changed, 23 insertions, 0 deletions
| diff --git a/zsh-completion/_gitbmerge b/zsh-completion/_gitbmerge new file mode 100644 index 0000000..733dbfb --- /dev/null +++ b/zsh-completion/_gitbmerge @@ -0,0 +1,23 @@ +#compdef gitbmerge +#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 +	local branches=() +	for B in "$GDIR"/refs/heads/*; do +		# TODO skip branch on HEAD +		branches+=("${B#$GDIR/refs/heads/}") +	done +	_describe -t branches 'gitbmerge' branches +} + +_gitbmerge +# vim: ft=zsh | 
