2016-12-25 07:30:44 +00:00
|
|
|
#compdef udisksctl
|
|
|
|
#
|
|
|
|
# ------------------------------------------------------------------------------
|
2016-12-27 06:33:33 +00:00
|
|
|
# The MIT License
|
2016-12-25 07:30:44 +00:00
|
|
|
#
|
2016-12-27 06:33:33 +00:00
|
|
|
# Copyright 2014 Damir Jelić
|
|
|
|
#
|
|
|
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
# of this software and associated documentation files (the "Software"), to deal
|
|
|
|
# in the Software without restriction, including without limitation the rights
|
|
|
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
# copies of the Software, and to permit persons to whom the Software is
|
|
|
|
# furnished to do so, subject to the following conditions:
|
|
|
|
#
|
|
|
|
# The above copyright notice and this permission notice shall be included in all
|
|
|
|
# copies or substantial portions of the Software.
|
|
|
|
#
|
|
|
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
# SOFTWARE.
|
2016-12-25 07:30:44 +00:00
|
|
|
#
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
# Description
|
|
|
|
# -----------
|
|
|
|
#
|
|
|
|
# Completion script for udisksctl
|
|
|
|
# (https://cgit.freedesktop.org/udisks/tree/tools)
|
|
|
|
#
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
# Authors
|
|
|
|
# -------
|
|
|
|
#
|
|
|
|
# * Damir Jelić <poljarinho at gmail.com> [1]
|
2016-12-27 06:25:40 +00:00
|
|
|
# * Ole Jørgen Brønner <olejorgenb at yahoo.no> (minor additions)
|
2016-12-25 07:30:44 +00:00
|
|
|
#
|
|
|
|
# [1] https://lists.freedesktop.org/archives/devkit-devel/2014-February/001554.html
|
|
|
|
#
|
2016-12-27 06:46:49 +00:00
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
# Notes
|
|
|
|
# -----
|
|
|
|
#
|
|
|
|
# udisksctl actually provide built-in support for completion: It accepts an
|
|
|
|
# special command 'complete' that returns completeions. That is what drives the
|
|
|
|
# upstream bash completion. In the future one might condsider rewriting using
|
|
|
|
# that. (but not sure how straight forward it would be to provide descriptions?)
|
|
|
|
#
|
2016-12-25 07:30:44 +00:00
|
|
|
|
|
|
|
_paths() {
|
|
|
|
local -a _path_list
|
|
|
|
|
|
|
|
for _path in $(_call_program paths "udisksctl complete \"udisksctl $words\" $CURSOR"); do
|
|
|
|
_path_list+=$_path
|
|
|
|
done
|
|
|
|
|
|
|
|
_describe 'paths' _path_list
|
|
|
|
}
|
|
|
|
|
|
|
|
_filesystems() {
|
|
|
|
_fs_types=(
|
|
|
|
'adfs' 'affs' 'autofs' 'cifs' 'coda' 'coherent' 'cramfs' 'debugfs' 'devpts'
|
|
|
|
'efs' 'ext' 'ext2' 'ext3' 'ext4' 'hfs' 'hfsplus' 'hpfs' 'iso9660' 'jfs' 'minix'
|
|
|
|
'msdos' 'ncpfs' 'nfs' 'nfs4' 'ntfs' 'proc' 'qnx4' 'ramfs' 'reiserfs' 'romfs'
|
|
|
|
'squashfs' 'smbfs' 'sysv' 'tmpfs' 'ubifs' 'udf' 'ufs' 'umsdos' 'usbfs' 'vfat'
|
|
|
|
'xenix' 'xfs' 'xiafs'
|
|
|
|
)
|
|
|
|
|
|
|
|
_describe 'file system types' _fs_types
|
|
|
|
}
|
|
|
|
|
|
|
|
_udisksctl() {
|
|
|
|
typeset -A opt_args
|
|
|
|
local curcontext="$curcontext" state line
|
|
|
|
|
|
|
|
_arguments -C \
|
|
|
|
'1:udisksctl commands:->cmds' \
|
|
|
|
'*:: :->cmd_args' \
|
|
|
|
|
|
|
|
case $state in
|
|
|
|
cmds)
|
|
|
|
local commands; commands=(
|
|
|
|
'help: Show help'
|
|
|
|
'info: Show info about an object'
|
|
|
|
'dump: Show info about all object'
|
|
|
|
'status: Shows high-level status'
|
|
|
|
'monitor: Monitor changes to objects'
|
|
|
|
'mount: Mount a filesystem'
|
|
|
|
'unmount: Unmount a filesystem'
|
|
|
|
'unlock: Unlock an encrypted device'
|
|
|
|
'lock: Lock an encrypted device'
|
|
|
|
'loop-setup: Set-up a loop device'
|
|
|
|
'loop-delete: Delete a loop device'
|
2016-12-27 06:25:40 +00:00
|
|
|
'power-off: Safely power off a drive'
|
2016-12-25 07:30:44 +00:00
|
|
|
'smart-simulate: Set SMART data for a drive'
|
|
|
|
)
|
|
|
|
_describe -t commands 'udisksctl commands' commands
|
|
|
|
;;
|
|
|
|
|
|
|
|
cmd_args)
|
|
|
|
case $words[1] in
|
|
|
|
info)
|
|
|
|
_arguments \
|
|
|
|
{-p,--object-path}'[Object to get information about]:object path:_paths' \
|
|
|
|
{-b,--block-device}'[Block device to get information about]:block device:_paths' \
|
|
|
|
{-d,--drive}'[Drive to get information about]:drives:_paths' \
|
|
|
|
;;
|
|
|
|
mount)
|
|
|
|
_arguments \
|
|
|
|
{-p,--object-path}'[Object to mount]:object path:_paths' \
|
|
|
|
{-b,--block-device}'[Block device to mount]:block device:_paths' \
|
|
|
|
{-t,--filesystem-type}'[Filesystem type to use]:fs type:_filesystems' \
|
|
|
|
{-o,--options}'[Mount options]' \
|
|
|
|
'(--no-user-interaction)--no-user-interaction[Do not authenticate the user if needed]' \
|
|
|
|
;;
|
|
|
|
unmount)
|
|
|
|
_arguments \
|
|
|
|
{-p,--object-path}'[Object to unmount]:object path:_paths' \
|
|
|
|
{-b,--block-device}'[Block device to unmount]:block device:_paths' \
|
|
|
|
{-f,--force}'[Force/lazy unmount]' \
|
|
|
|
'(--no-user-interaction)--no-user-interaction[Do not authenticate the user if needed]' \
|
|
|
|
;;
|
|
|
|
unlock|lock)
|
|
|
|
_arguments \
|
|
|
|
{-p,--object-path}'[Object to lock/unlock]:object path:_paths' \
|
|
|
|
{-b,--block-device}'[Block device to lock/unlock]:block device:_paths' \
|
|
|
|
'(--no-user-interaction)--no-user-interaction[Do not authenticate the user if needed]' \
|
|
|
|
;;
|
|
|
|
loop-setup)
|
|
|
|
_arguments \
|
|
|
|
{-f,--file}'[File to set-up a loop device for]:files:_files' \
|
|
|
|
{-r,--read-only}'[Setup read-only device]' \
|
|
|
|
{-o,--offset}'[Start at <num> bytes into file]:offset in bytes:' \
|
|
|
|
{-s,--size}'[Limit size to <num> bytes]:limit in bytes:' \
|
|
|
|
'(--no-user-interaction)--no-user-interaction[Do not authenticate the user if needed]' \
|
|
|
|
;;
|
|
|
|
loop-delete)
|
|
|
|
_arguments \
|
|
|
|
{-p,--object-path}'[Object for loop device to delete]:object path:_paths' \
|
|
|
|
{-b,--block-device}'[Loop device to delete]:block device:_paths' \
|
|
|
|
'(--no-user-interaction)--no-user-interaction[Do not authenticate the user if needed]' \
|
|
|
|
;;
|
2016-12-27 06:25:40 +00:00
|
|
|
power-off)
|
|
|
|
_arguments \
|
|
|
|
{-p,--object-path}'[Object path for ATA device]:object path:_paths' \
|
|
|
|
{-b,--block-device}'[Device file for ATA devic]:block device:_paths' \
|
|
|
|
'(--no-user-interaction)--no-user-interaction[Do not authenticate the user if needed]' \
|
|
|
|
;;
|
2016-12-25 07:30:44 +00:00
|
|
|
smart-simulate)
|
|
|
|
_arguments \
|
|
|
|
{-f,--file}'[File with libatasmart blob]:files:_files' \
|
|
|
|
{-p,--object-path}'[Object to get information about]:object path:_paths' \
|
|
|
|
{-b,--block-device}'[Block device to get information about]:block device:_paths' \
|
|
|
|
'(--no-user-interaction)--no-user-interaction[Do not authenticate the user if needed]' \
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
}
|
|
|
|
|
|
|
|
_udisksctl "$@"
|