Added quota-tools completion

This commit is contained in:
David Paleino 2009-02-05 10:53:04 +01:00
parent fe04d9dedf
commit 06a8249326
3 changed files with 311 additions and 212 deletions

309
contrib/quota-tools Normal file
View File

@ -0,0 +1,309 @@
# -*- mode: shell-script; sh-basic-offset: 8; indent-tabs-mode: t -*-
# ex: ts=8 sw=8 noet filetype=sh
#
# bash completion for quota-tools
have quota && {
_user_or_group()
{
local i
# complete on groups if -g was given
for (( i=1; i < COMP_CWORD; i++ )); do
if [[ "${COMP_WORDS[i]}" == -g ]]; then
COMPREPLY=( $( compgen -g -- $cur ) )
return 0
fi
done
# otherwise complete on users
COMPREPLY=( $( compgen -u -- $cur ) )
}
_quota_formats()
{
COMPREPLY=( $( compgen -W 'vfsold vfsv0 rpc xfs' -- $cur ) )
}
_filesystems()
{
# Only list filesystems starting with "/", otherwise we also get
#+ "binfmt_misc", "proc", "tmpfs", ...
COMPREPLY=( $( compgen -W "$(awk '/^\// {print $1}' /etc/mtab)" \
-- $cur ) )
}
_quota()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
esac
if [[ "$cur" == *=* ]]; then
prev=${cur/=*/}
cur=${cur/*=/}
case $prev in
--format)
_quota_formats
return 0
;;
esac
fi
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-F --format= -g --group -u --user -v --verbose \
-s --human-readable -p --raw-grace -i --no-autofs -l --local-only \
-A --all-nfs -m --no-mixed-pathnames -q --quiet -Q --quiet-refuse \
-w --no-wrap' -- $cur ) )
else
_user_or_group
fi
}
complete -F _quota $default quota
_setquota()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
esac
if [[ "$cur" == *=* ]]; then
prev=${cur/=*/}
cur=${cur/*=/}
case $prev in
--format)
_quota_formats
return 0
;;
esac
fi
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-r --remote -m --no-mixed-pathnames \
-F --format= -g --group -u --user -p --prototype= -b --batch \
-c --continue-batch -t --edit-period -T --edit-times -a --all' -- $cur ) )
else
_count_args
case $args in
1)
_user_or_group
;;
2)
_filesystems
;;
esac
fi
}
complete -F _setquota $default setquota
_edquota()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
-@(f|-filesystem))
_filesystems
return 0
;;
esac
if [[ "$cur" == *=* ]]; then
prev=${cur/=*/}
cur=${cur/*=/}
case $prev in
--format)
_quota_formats
return 0
;;
esac
fi
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-r --remote -m --no-mixed-pathnames \
-g --group -u --user -p --prototype= -F --format= -f --filesystem \
-t --edit-period -T --edit-times' -- $cur ) )
else
_user_or_group
fi
}
complete -F _edquota $default edquota
_quotacheck()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
esac
if [[ "$cur" == *=* ]]; then
prev=${cur/=*/}
cur=${cur/*=/}
case $prev in
--format)
_quota_formats
return 0
;;
esac
fi
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-b --backup -v --verbose -d --debug \
-g --group -u --user -c --create-files -f --force -i \
--interactive -n --use-first-dquot -M --try-remount -m \
--no-remount -R --exclude-root -F --format= -a --all' \
-- $cur ) )
else
_filesystems
fi
}
complete -F _quotacheck $default quotacheck
_repquota()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
esac
if [[ "$cur" == *=* ]]; then
prev=${cur/=*/}
cur=${cur/*=/}
case $prev in
--format)
_quota_formats
return 0
;;
esac
fi
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-a --all -v --verbose -s --human-readable \
-c --batch-translation -C --no-batch-translation -t \
--truncate-names -n --no-names -p --raw-grace -i --no-autofs \
-u --user -g --group -F --format=' -- $cur ) )
else
_filesystems
fi
}
complete -F _repquota $default repquota
_quotaon()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
echo --$cmd--
case $prev in
-F)
_quota_formats
return 0
;;
esac
if [[ "$cur" == *=* ]]; then
prev=${cur/=*/}
cur=${cur/*=/}
case $prev in
--format)
_quota_formats
return 0
;;
esac
fi
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-a --all -v --verbose -u --user \
-g --group -f --off -p --print-state -F --format=' -- $cur ) )
else
_filesystems
fi
}
complete -F _quotaon $default quotaon
_quotaoff()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
-@(x|-xfs-command))
COMPREPLY=( $( compgen -W 'delete enforce' -- $cur ) )
return 0
;;
esac
if [[ "$cur" == *=* ]]; then
prev=${cur/=*/}
cur=${cur/*=/}
case $prev in
--format)
_quota_formats
return 0
;;
esac
fi
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-a --all -v --verbose -u --user \
-g --group -p --print-state -x --xfs-command -F --format=' \
-- $cur ) )
else
_filesystems
fi
}
complete -F _quotaoff $default quotaoff
}

3
debian/changelog vendored
View File

@ -9,6 +9,7 @@ bash-completion (200902xx) UNRELEASED; urgency=low
* Added qemu completion
* Added net-tools (mii-tool and mii-diag) completions
* Added minicom completion
* Added quota-tools completion
[ David Paleino ]
* Added .kar to Timidity completion.
@ -128,7 +129,7 @@ bash-completion (200902xx) UNRELEASED; urgency=low
* Prevent completion dir from being sourced twice if
BASH_COMPLETION_DIR and BASH_COMPLETION_COMPAT_DIR are equal (Alioth#311433)
-- David Paleino <d.paleino@gmail.com> Thu, 05 Feb 2009 10:04:16 +0100
-- David Paleino <d.paleino@gmail.com> Thu, 05 Feb 2009 10:52:42 +0100
bash-completion (20080705) unstable; urgency=low

View File

@ -1,211 +0,0 @@
# -*- mode: shell-script; sh-basic-offset: 8; indent-tabs-mode: t -*-
# ex: ts=8 sw=8 noet filetype=sh
#
# bash completion for quota-tools
have quota && {
_user_or_group()
{
local i
# complete on groups if -g was given
for (( i=1; i < COMP_CWORD; i++ )); do
if [[ "${COMP_WORDS[i]}" == -g ]]; then
COMPREPLY=( $( compgen -g -- $cur ) )
return 0
fi
done
# otherwise complete on users
COMPREPLY=( $( compgen -u -- $cur ) )
}
_quota_formats()
{
COMPREPLY=( $( compgen -W 'vfsold vfsv0 rpc xfs' -- $cur ) )
}
_filesystems()
{
COMPREPLY=( $( compgen -W '$(awk '!/^none/ {print $1}' /etc/mtab)' \
-- $cur ) )
}
_quota()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
esac
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-F -g -u -v -s -i -l -q -Q' -- $cur ) )
else
_user_or_group
fi
}
complete -F _quota quota
_setquota()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
esac
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-r -F -g -u -p -b -t -T -a' -- $cur ) )
else
_count_args
case $args in
1)
_user_or_group
;;
2)
_filesystems
;;
esac
fi
}
complete -F _setquota setquota
_edquota()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
-f)
_filesystems
return 0
;;
esac
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-r -g -u -p -F -f -t -T' -- $cur ) )
else
_user_or_group
fi
}
complete -F _edquota edquota
_quotacheck()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
esac
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-g -u -b -c -f -i -n -v -d -M -m -R \
-F -a' -- $cur ) )
else
_filesystems
fi
}
complete -F _quotacheck quotacheck
_repquota()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
esac
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-v -s -i -u -g -c -C -t -n -F' -- \
$cur ) )
else
_filesystems
fi
}
complete -F _repquota repquota
_quotaon()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
esac
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-a -v -u -g -f -p -F' -- $cur ) )
else
_filesystems
fi
}
complete -F _quotaon quotaon
_quotaoff()
{
local cur prev
COMPREPLY=()
cur=`_get_cword`
prev=${COMP_WORDS[COMP_CWORD-1]}
case $prev in
-F)
_quota_formats
return 0
;;
esac
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '-a -v -u -g -p -x' -- $cur ) )
else
_filesystems
fi
}
complete -F _quotaoff quotaoff
}