[sbopkg-users] bash completion
Sergey V.
sftp.mtuci at gmail.com
Thu Feb 3 15:30:54 UTC 2011
On Sunday 09 of January 2011 05:46:42 slakmagik wrote:
> On 2011-01-09 (Sun) 03:22:05 [+0300], Sergey V. wrote:
> > On Saturday 08 of January 2011 06:05:40 slakmagik wrote:
> >
> > > Thanks for this contribution, but you need to either import have() from
> > > the main script or drop it and similarly with _get_comp_words_by_ref()
> > > and _filedir (and the functions those functions call, etc.). I'd prefer
> > > junking as much as possible from the main script to keep the part broken
> > > out for sbopkg as small and simple as possible. For instance, _filedir
> > > seems to try to rewrite a simple 'compgen -f' just for filenames with
> > > spaces. But whatever makes it work. That's all I see right off, as I
> > > haven't looked at it very closely yet.
> >
> > Sorry, forgot to say, sbopkg completion script written for
> > bash-completion-1.2 or above (slackbuild attached).
> >
> > have(), _get_comp_words_by_ref() and _filedir is builtin functions
> > of bash-completion-1.2.
>
> I know. So it looks like we had some miscommunication in #sbopkg. I
> don't see the point of this. If someone wants to install
> bash_completion, then they do so and they get sbopkg completions. And
> that's that package; not sbopkg. What I thought you were offering was a
> simple, independent, self-contained file such as the git or mercurial
> completion files. Something like that would be nice to include in
> sbopkg. But I don't want a file in sbopkg that doesn't work unless you
> install something else.
Sorry for long reply.
New version of completion script (attached) independent from bash-completion
package (uses only bash-builtin functions).
TODO: completion not work for syntax like this
sbopkg -i|-b "pkg1 pkg2"
(now I do not see any other issues)
Please review or/and test it.
-------------- next part --------------
# bash completion for sbopkg tool
_sbopkg()
{
COMPREPLY=()
local cur="${COMP_WORDS[COMP_CWORD]}"
local prev="${COMP_WORDS[COMP_CWORD-1]}"
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-b -c -d -e -f -g -h -i -k -l \
-o -P -p -q -R -r -s -u -V -v' -- "$cur" ) )
return 0
fi
case $prev in
-e)
COMPREPLY=( $( compgen -W 'ask continue stop' -- "$cur" ) )
return 0
;;
-f)
COMPREPLY=( $( compgen -f -- "$cur" ) )
return 0
;;
-d)
COMPREPLY=( $( compgen -d -- "$cur" ) )
return 0
;;
-V)
COMPREPLY=( $( compgen -W "? \
$(sbopkg -V ? 2>&1 | cut -s -f1)" -- "$cur" ) )
return 0
;;
-i|-b)
;;
*)
return 0
;;
esac
local config="/etc/sbopkg/sbopkg.conf"
for (( i=${#COMP_WORDS[@]}-1; i>0; i-- )); do
if [[ "${COMP_WORDS[i]}" == -f ]]; then
config="${COMP_WORDS[i+1]}"
break
fi
done
if [ ! -r "$config" ]; then
return 0
fi
. $config
for (( i=1; i<${#COMP_WORDS[@]}; i++ )); do
case "${COMP_WORDS[i]}" in
-V)
REPO_NAME="${COMP_WORDS[i+1]%%/*}"
REPO_BRANCH="${COMP_WORDS[i+1]#*/}"
;;
-d)
REPO_ROOT="${COMP_WORDS[i+1]}"
;;
esac
done
if [ ! -r "$REPO_ROOT/$REPO_NAME/$REPO_BRANCH/SLACKBUILDS.TXT" ]; then
return 0
fi
COMPREPLY=( $( sed -ne "/^SLACKBUILD NAME: $cur/{s/^SLACKBUILD NAME: //;p}"\
$REPO_ROOT/$REPO_NAME/$REPO_BRANCH/SLACKBUILDS.TXT )
$( cd $QUEUEDIR; compgen -f -X "!*.sqf" -- "$cur" ) )
} && complete -o filenames -F _sbopkg sbopkg
More information about the sbopkg-users
mailing list