Merge remote-tracking branch 'garik/slackware'
This commit is contained in:
commit
ebb446d8cb
@ -135,17 +135,21 @@ bashcomp_DATA = abook \
|
|||||||
ri \
|
ri \
|
||||||
rpcdebug \
|
rpcdebug \
|
||||||
rpm \
|
rpm \
|
||||||
|
rpm2tgz \
|
||||||
rpmcheck \
|
rpmcheck \
|
||||||
rrdtool \
|
rrdtool \
|
||||||
rsync \
|
rsync \
|
||||||
rtcwake \
|
rtcwake \
|
||||||
samba \
|
samba \
|
||||||
sbcl \
|
sbcl \
|
||||||
|
sbopkg \
|
||||||
screen \
|
screen \
|
||||||
service \
|
service \
|
||||||
sh \
|
sh \
|
||||||
shadow \
|
shadow \
|
||||||
sitecopy \
|
sitecopy \
|
||||||
|
slackpkg \
|
||||||
|
slapt \
|
||||||
smartctl \
|
smartctl \
|
||||||
snownews \
|
snownews \
|
||||||
sqlite3 \
|
sqlite3 \
|
||||||
|
@ -1,21 +1,119 @@
|
|||||||
# bash completion for Slackware Linux pkgtools
|
# bash completion for Slackware Linux pkgtools
|
||||||
|
|
||||||
[ -f /etc/slackware-version ] && have removepkg || return
|
[ -f /etc/slackware-version ] || return
|
||||||
|
|
||||||
|
|
||||||
|
have pkgtool &&
|
||||||
|
_pkgtool()
|
||||||
|
{
|
||||||
|
local cur prev words cword
|
||||||
|
_init_completion || return
|
||||||
|
if [[ "$cur" == -* ]]; then
|
||||||
|
COMPREPLY=( $( compgen -W '--sets --ignore-tagfiles --tagfile \
|
||||||
|
--source-mounted --source_dir --target_dir --source_device' \
|
||||||
|
-- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$prev" in
|
||||||
|
--source_dir|--target_dir)
|
||||||
|
_filedir -d
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
--sets)
|
||||||
|
# argument required but no completions available
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
--source_device)
|
||||||
|
COMPREPLY=( $( compgen -f -d -- "${cur:-/dev/}" ) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
--tagfile)
|
||||||
|
_filedir
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
} &&
|
||||||
|
complete -F _pkgtool pkgtool
|
||||||
|
|
||||||
|
have removepkg &&
|
||||||
_removepkg()
|
_removepkg()
|
||||||
{
|
{
|
||||||
local cur prev words cword
|
local cur prev words cword
|
||||||
_init_completion || return
|
_init_completion || return
|
||||||
|
if [[ "$cur" == -* ]]; then
|
||||||
|
COMPREPLY=( $( compgen -W '-copy -keep -preserve -warn' \
|
||||||
|
-- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
COMPREPLY=( $( (cd /var/log/packages; compgen -f -- "$cur") ) )
|
COMPREPLY=( $( cd /var/log/packages; compgen -f -- "$cur" ) )
|
||||||
} &&
|
} &&
|
||||||
complete -F _removepkg -o filenames removepkg &&
|
complete -F _removepkg removepkg
|
||||||
complete -o dirnames -f -X '!*.t[bglx]z' installpkg upgradepkg explodepkg
|
|
||||||
|
|
||||||
# Local variables:
|
have upgradepkg &&
|
||||||
# mode: shell-script
|
_upgradepkg()
|
||||||
# sh-basic-offset: 4
|
{
|
||||||
# sh-indent-comment: t
|
local cur prev words cword
|
||||||
# indent-tabs-mode: nil
|
_init_completion || return
|
||||||
# End:
|
if [[ "$cur" == -* ]]; then
|
||||||
# ex: ts=4 sw=4 et filetype=sh
|
COMPREPLY=( $( compgen -W '--dry-run --install-new --reinstall \
|
||||||
|
--verbose' -- "$cur") )
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
_filedir "t[bglx]z"
|
||||||
|
} && complete -F _upgradepkg upgradepkg
|
||||||
|
|
||||||
|
have installpkg &&
|
||||||
|
_installpkg()
|
||||||
|
{
|
||||||
|
local cur prev words cword
|
||||||
|
_init_completion || return
|
||||||
|
if [[ "$cur" == -* ]]; then
|
||||||
|
COMPREPLY=( $( compgen -W '--warn --md5sum --root --infobox --terse \
|
||||||
|
--menu --ask --priority --tagfile' -- "$cur") )
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$prev" in
|
||||||
|
--root)
|
||||||
|
_filedir -d
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
--priority)
|
||||||
|
COMPREPLY=( $( compgen -W 'ADD REC OPT SKP' -- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
--tagfile)
|
||||||
|
_filedir
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
_filedir "t[bglx]z"
|
||||||
|
} && complete -F _installpkg installpkg
|
||||||
|
|
||||||
|
have makepkg &&
|
||||||
|
_makepkg()
|
||||||
|
{
|
||||||
|
local cur prev words cword
|
||||||
|
_init_completion || return
|
||||||
|
if [[ "$cur" == -* ]]; then
|
||||||
|
COMPREPLY=( $( compgen -W '-l --linkadd -p --prepend \
|
||||||
|
-c --chown' -- "$cur") )
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$prev" in
|
||||||
|
-l|--linkadd|-c|--chown)
|
||||||
|
COMPREPLY=( $( compgen -W 'y n' -- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
_filedir
|
||||||
|
} && complete -F _makepkg makepkg
|
||||||
|
|
||||||
|
have explodepkg &&
|
||||||
|
complete -o plusdirs -f -X '!*.t[bglx]z' explodepkg
|
||||||
|
16
completions/rpm2tgz
Normal file
16
completions/rpm2tgz
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
# Slackware rpm2tgz completion.
|
||||||
|
|
||||||
|
have rpm2tgz || return
|
||||||
|
|
||||||
|
_rpm2tgz()
|
||||||
|
{
|
||||||
|
local cur prev words cword
|
||||||
|
_init_completion || return
|
||||||
|
|
||||||
|
if [[ "$cur" == -* ]]; then
|
||||||
|
COMPREPLY=( $( compgen -W '-s -S -n -r -d -c' -- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
COMPREPLY=( $(compgen -f -X "!*.rpm" -- "$cur") )
|
||||||
|
} && complete -F _rpm2tgz -o plusdirs rpm2tgz rpm2txz rpm2targz
|
74
completions/sbopkg
Normal file
74
completions/sbopkg
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
# bash completion for sbopkg tool
|
||||||
|
|
||||||
|
have sbopkg || return
|
||||||
|
|
||||||
|
_sbopkg()
|
||||||
|
{
|
||||||
|
local cur prev words cword
|
||||||
|
_init_completion || return
|
||||||
|
|
||||||
|
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)
|
||||||
|
_filedir
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
-d)
|
||||||
|
_filedir -d
|
||||||
|
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=${#words[@]}-1; i>0; i-- )); do
|
||||||
|
if [[ "${words[i]}" == -f ]]; then
|
||||||
|
config="${words[i+1]}"
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ ! -r "$config" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
. $config
|
||||||
|
|
||||||
|
for (( i=1; i<${#words[@]}; i++ )); do
|
||||||
|
case "${words[i]}" in
|
||||||
|
-V)
|
||||||
|
REPO_NAME="${words[i+1]%%/*}"
|
||||||
|
REPO_BRANCH="${words[i+1]#*/}"
|
||||||
|
;;
|
||||||
|
-d)
|
||||||
|
REPO_ROOT="${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 -F _sbopkg sbopkg
|
108
completions/slackpkg
Normal file
108
completions/slackpkg
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
# bash completion for slackpkg tool
|
||||||
|
# options list is based on `grep '\-.*\=.*)' /usr/sbin/slackpkg | cut -f1 -d\)`
|
||||||
|
|
||||||
|
have slackpkg || return
|
||||||
|
|
||||||
|
_slackpkg()
|
||||||
|
{
|
||||||
|
local cur prev words cword
|
||||||
|
_init_completion -n = || return
|
||||||
|
|
||||||
|
local split=false
|
||||||
|
if [[ "$cur" == -?*=* ]]; then
|
||||||
|
prev="${cur%%?(\\)=*}"
|
||||||
|
cur="${cur#*=}"
|
||||||
|
split=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$prev" in
|
||||||
|
-delall|-checkmd5|-checkgpg|-checksize|-postinst|-onoff|-download_all|\
|
||||||
|
-dialog|-batch|-only_new_dotnew|-use_includes|-spinning)
|
||||||
|
COMPREPLY=( $( compgen -W 'on off' -- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
-default_answer)
|
||||||
|
COMPREPLY=( $( compgen -W 'yes no' -- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
-dialog_maxargs|-mirror)
|
||||||
|
# argument required but no completions available
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
$split && return 0
|
||||||
|
|
||||||
|
if [[ "$cur" == -* ]]; then
|
||||||
|
compopt -o nospace
|
||||||
|
COMPREPLY=( $( compgen -W '-delall= -checkmd5= -checkgpg= \
|
||||||
|
-checksize= -postinst= -onoff= -download_all= -dialog= \
|
||||||
|
-dialog_maxargs= -batch= -only_new_dotnew= -use_includes= \
|
||||||
|
-spinning= -default_answer= -mirror=' -- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
local confdir="/etc/slackpkg"
|
||||||
|
local config="$confdir/slackpkg.conf"
|
||||||
|
|
||||||
|
if [ ! -r "$config" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
. "$config"
|
||||||
|
|
||||||
|
local action
|
||||||
|
for (( i=1; i<${#words[@]}; i++ )); do
|
||||||
|
if [[ "${words[i]}" != -* ]]; then
|
||||||
|
action="${words[i]}"
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
case "$action" in
|
||||||
|
generate-template|search|file-search)
|
||||||
|
# argument required but no completions available
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
install-template|remove-template)
|
||||||
|
if [ -e "$confdir/templates" ]; then
|
||||||
|
COMPREPLY=( $( cd "$confdir/templates"; \
|
||||||
|
compgen -f -X "!*.template" -- "$cur" ) )
|
||||||
|
COMPREPLY=( ${COMPREPLY[@]%.template} )
|
||||||
|
fi
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
remove)
|
||||||
|
_filedir
|
||||||
|
COMPREPLY+=( $( compgen -W 'a ap d e f k kde kdei l n t tcl x \
|
||||||
|
xap y' -- "$cur" ) )
|
||||||
|
COMPREPLY+=( $( cd /var/log/packages; compgen -f -- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
install|reinstall|upgrade|blacklist|download)
|
||||||
|
_filedir
|
||||||
|
COMPREPLY+=( $( compgen -W 'a ap d e f k kde kdei l n t tcl x \
|
||||||
|
xap y' -- "$cur" ) )
|
||||||
|
COMPREPLY+=( $( cut -f 6 -d\ ${WORKDIR}/pkglist 2> /dev/null | \
|
||||||
|
grep "^$cur" ) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
info)
|
||||||
|
COMPREPLY+=( $( cut -f 6 -d\ ${WORKDIR}/pkglist 2> /dev/null | \
|
||||||
|
grep "^$cur" ) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
update)
|
||||||
|
# we should complete the same as the next `list` + "gpg"
|
||||||
|
COMPREPLY=( $( compgen -W 'gpg' -- "$cur" ) )
|
||||||
|
;&
|
||||||
|
*)
|
||||||
|
COMPREPLY+=( $( compgen -W 'install reinstall upgrade remove \
|
||||||
|
blacklist download update install-new upgrade-all \
|
||||||
|
clean-system new-config check-updates help generate-template \
|
||||||
|
install-template remove-template search file-search info' -- \
|
||||||
|
"$cur" ) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
} && complete -F _slackpkg slackpkg
|
129
completions/slapt
Normal file
129
completions/slapt
Normal file
@ -0,0 +1,129 @@
|
|||||||
|
# slapt-get and slapt-src completion
|
||||||
|
|
||||||
|
have slapt-get &&
|
||||||
|
_slapt_get()
|
||||||
|
{
|
||||||
|
local cur prev words cword
|
||||||
|
_init_completion || return
|
||||||
|
|
||||||
|
if [[ "$cur" == -* ]]; then
|
||||||
|
COMPREPLY=( $( compgen -W '--download-only -d --simulate -s \
|
||||||
|
--no-prompt -y --prompt -p --reinstall --ignore-excludes \
|
||||||
|
--no-md5 --ignore-dep --no-dep --print-uris --show-stats -S \
|
||||||
|
--config -c --remove-obsolete --retry --no-upgrade \
|
||||||
|
--update -u --upgrade --dist-upgrade --install -i --install-set \
|
||||||
|
--remove --show --filelist --search --list --available \
|
||||||
|
--installed --clean --autoclean --add-keys \
|
||||||
|
--version --help -h' -- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$prev" in
|
||||||
|
--config|-c)
|
||||||
|
_filedir
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
--retry|--search)
|
||||||
|
# argument required but no completions available
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
local t
|
||||||
|
# search for last action (--install|--install-set|--remove|--show|--filelist)
|
||||||
|
for (( i=${#words[@]}-1; i>0; i-- )); do
|
||||||
|
if [[ ${words[i]} == -@(i|-install|-show) ]]; then
|
||||||
|
t="all"
|
||||||
|
break
|
||||||
|
elif [[ ${words[i]} == --install-set ]]; then
|
||||||
|
t="set"
|
||||||
|
break
|
||||||
|
elif [[ ${words[i]} == --@(remove|filelist) ]]; then
|
||||||
|
t="ins"
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
case $t in
|
||||||
|
all) # --install|-i|--show
|
||||||
|
# slapt-get will fail to search for "^name-version"
|
||||||
|
# it can search for names only
|
||||||
|
local name=$( echo $cur | cut -f1 -d- )
|
||||||
|
COMPREPLY=( $( slapt-get --search "^$name" 2> /dev/null | \
|
||||||
|
sed -ne "/^$cur/{s/ .*$//;p}" ) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
ins) # --remove|--filelist
|
||||||
|
COMPREPLY=( $( cd /var/log/packages; compgen -f -- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
set) # --install-set
|
||||||
|
COMPREPLY=( $( compgen -W 'a ap d e f k kde kdei l n t tcl x \
|
||||||
|
xap y' -- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
} && complete -F _slapt_get slapt-get
|
||||||
|
|
||||||
|
have slapt-src &&
|
||||||
|
_slapt_src()
|
||||||
|
{
|
||||||
|
local cur prev words cword
|
||||||
|
_init_completion || return
|
||||||
|
|
||||||
|
if [[ "$cur" == -* ]]; then
|
||||||
|
COMPREPLY=( $( compgen -W '--update -u --list -l --clean -e \
|
||||||
|
--search -s --show -w --install -i --build -b --fetch -f \
|
||||||
|
--yes -y --config -c --no-dep -n --postprocess -p \
|
||||||
|
--version -v --help -h' -- "$cur" ) )
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$prev" in
|
||||||
|
--config|-c)
|
||||||
|
_filedir
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
--search|-s|--postprocess|-p)
|
||||||
|
# argument required but no completions available
|
||||||
|
return 0
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
local t
|
||||||
|
# search for last action (-i|-w|-b|-f)
|
||||||
|
for (( i=${#words[@]}-1; i>0; i-- )); do
|
||||||
|
if [[ ${words[i]} == -@(i|w|f|b|-install|-show|-build|-fetch) ]]; then
|
||||||
|
t="all"
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
if [ "$t" != "all" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
local config="/etc/slapt-get/slapt-srcrc" # default config location
|
||||||
|
# search for config
|
||||||
|
for (( i=${#words[@]}-1; i>0; i-- )); do
|
||||||
|
if [[ ${words[i]} == -@(c|-config) ]]; then
|
||||||
|
config="${words[i+1]}"
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
if [ ! -r "$config" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
local builddir=$( sed -ne "/^BUILDDIR=/{s/^BUILDDIR=//;p}" "$config" )
|
||||||
|
if [ ! -d "$builddir" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
local slck_data="${builddir}/slackbuilds_data"
|
||||||
|
if [ ! -r "$slck_data" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
COMPREPLY=( $( sed -ne \
|
||||||
|
"/^SLACKBUILD NAME: $cur/{s/^SLACKBUILD NAME: //;p}" "$slck_data" ) )
|
||||||
|
} && complete -F _slapt_src slapt-src
|
Loading…
x
Reference in New Issue
Block a user