2010-03-14 19:23:30 +01:00
|
|
|
# bash completion for cryptsetup
|
|
|
|
|
2011-04-05 00:35:51 +03:00
|
|
|
have cryptsetup || return
|
|
|
|
|
2010-03-14 19:23:30 +01:00
|
|
|
_cryptsetup_name()
|
|
|
|
{
|
2010-03-30 20:23:17 +03:00
|
|
|
COMPREPLY=( $( compgen -X control -W '$( command ls /dev/mapper )' \
|
2010-03-14 19:23:30 +01:00
|
|
|
-- "$cur" ) )
|
|
|
|
}
|
|
|
|
|
|
|
|
_cryptsetup_device()
|
|
|
|
{
|
|
|
|
cur=${cur:=/dev/}
|
|
|
|
_filedir
|
|
|
|
}
|
|
|
|
|
|
|
|
_cryptsetup()
|
|
|
|
{
|
2010-04-21 19:25:02 +03:00
|
|
|
local cur prev arg
|
2010-03-14 19:23:30 +01:00
|
|
|
COMPREPLY=()
|
|
|
|
cur=`_get_cword`
|
|
|
|
prev=`_get_pword`
|
|
|
|
|
|
|
|
case $prev in
|
|
|
|
--key-file|--master-key-file|--header-backup-file|-d)
|
|
|
|
_filedir
|
|
|
|
return 0;
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
_get_first_arg
|
|
|
|
if [ -z $arg ]; then
|
|
|
|
if [[ "$cur" == -* ]]; then
|
2010-03-30 20:26:28 +03:00
|
|
|
COMPREPLY=( $( compgen -W '--hash --cipher --verify-passphrase \
|
|
|
|
--key-file --master-key-file --key-slot --key-size --size \
|
|
|
|
--offset --skip --readonly --iter-time --batch-mode --timeout \
|
|
|
|
--tries --align-payload --version' -- "$cur" ) )
|
2010-03-14 19:23:30 +01:00
|
|
|
else
|
|
|
|
COMPREPLY=( $( compgen -W 'create remove status resize luksFormat \
|
|
|
|
luksOpen luksClose luksSuspend luksResume luksAddKey \
|
|
|
|
luksRemoveKey luksKillSlot luksDelKey luksUUID isLuks \
|
|
|
|
luksDump luksHeaderBackup luksHeaderRestore' -- "$cur" ) )
|
|
|
|
fi
|
|
|
|
else
|
2011-04-20 14:33:51 +03:00
|
|
|
local args
|
2010-03-14 19:23:30 +01:00
|
|
|
_count_args
|
|
|
|
case $arg in
|
|
|
|
create)
|
|
|
|
case $args in
|
|
|
|
2)
|
|
|
|
_cryptsetup_name
|
|
|
|
;;
|
|
|
|
3)
|
|
|
|
_cryptsetup_device
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
remove|status|resize|luksClose|luksSuspend|luksResume)
|
|
|
|
case $args in
|
|
|
|
2)
|
|
|
|
_cryptsetup_name
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
luksFormat|luksAddKey|luksRemoveKey)
|
|
|
|
case $args in
|
|
|
|
2)
|
|
|
|
_cryptsetup_device
|
|
|
|
;;
|
|
|
|
3)
|
|
|
|
_filedir
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
luksOpen)
|
|
|
|
case $args in
|
|
|
|
2)
|
|
|
|
_cryptsetup_device
|
|
|
|
;;
|
|
|
|
3)
|
|
|
|
_cryptsetup_name
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
luksKillSlot|luksDelKey|luksUUID|isLuks|luksDump)
|
|
|
|
case $args in
|
|
|
|
2)
|
|
|
|
_cryptsetup_device
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
luksHeaderBackup|luksHeaderRestore)
|
|
|
|
case $args in
|
|
|
|
2)
|
|
|
|
_cryptsetup_device
|
|
|
|
;;
|
|
|
|
3)
|
|
|
|
COMPREPLY=( '--header-backup-file' )
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
fi
|
|
|
|
|
|
|
|
return 0
|
|
|
|
} &&
|
|
|
|
complete -F _cryptsetup cryptsetup
|
|
|
|
|
|
|
|
# Local variables:
|
|
|
|
# mode: shell-script
|
|
|
|
# sh-basic-offset: 4
|
|
|
|
# sh-indent-comment: t
|
|
|
|
# indent-tabs-mode: nil
|
|
|
|
# End:
|
|
|
|
# ex: ts=4 sw=4 et filetype=sh
|