/etc/bash_completion.d/cryptsetup is in bash-completion 1:1.3-1ubuntu8.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 | # bash completion for cryptsetup
_cryptsetup_name()
{
COMPREPLY=( $( compgen -X control -W '$( command ls /dev/mapper )' \
-- "$cur" ) )
}
_cryptsetup_device()
{
cur=${cur:=/dev/}
_filedir
}
have cryptsetup &&
_cryptsetup()
{
local cur prev arg
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
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" ) )
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
_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
|