mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-09 19:48:48 +00:00
428 lines
34 KiB
Fish
428 lines
34 KiB
Fish
# Completions for btrfs-progs
|
|
|
|
# Todo:
|
|
# - (Done) Detailed options per command
|
|
# - Simplified duplicate options completion with `for`
|
|
# - Simplified descriptions
|
|
|
|
# Filter the completions per primary command
|
|
function __btrfs_commands
|
|
if not set -q argv[1]
|
|
return 1
|
|
end
|
|
set -l cmd (commandline -cp)
|
|
if string match -qr -- "btrfs\s+$argv[1]\s+\S*" $cmd
|
|
return 0
|
|
end
|
|
return 1
|
|
end
|
|
|
|
# Filter the completions per command group
|
|
function __btrfs_command_groups
|
|
if not set -q argv[1]
|
|
return 1
|
|
end
|
|
set -l cmd (commandline -cp)
|
|
if set -q argv[2]
|
|
if string match -qr -- "btrfs\s+$argv[1]\s+$argv[2]\s+\S*" $cmd
|
|
return 0
|
|
end
|
|
return 1
|
|
end
|
|
if string match -qr -- "btrfs\s+$argv[1]\s+\S*\$" $cmd
|
|
return 0
|
|
end
|
|
return 1
|
|
end
|
|
|
|
set -l check '__btrfs_commands check'
|
|
set -l restore '__btrfs_commands restore'
|
|
set -l send '__btrfs_commands send'
|
|
set -l receive '__btrfs_commands receive'
|
|
set -l help '__btrfs_commands help'
|
|
|
|
set -l subvolume '__btrfs_command_groups subvolume'
|
|
set -l filesystem '__btrfs_command_groups filesystem'
|
|
set -l balance '__btrfs_command_groups balance'
|
|
set -l device '__btrfs_command_groups device'
|
|
set -l scrub '__btrfs_command_groups scrub'
|
|
set -l rescue '__btrfs_command_groups rescue'
|
|
set -l inspect_internal '__btrfs_command_groups inspect-internal'
|
|
set -l property '__btrfs_command_groups property'
|
|
set -l quota '__btrfs_command_groups quota'
|
|
set -l qgroup '__btrfs_command_groups qgroup'
|
|
set -l replace '__btrfs_command_groups replace'
|
|
|
|
# Global command
|
|
complete -f -c btrfs -l help -d 'Display help information'
|
|
|
|
# Primary command
|
|
complete -f -c btrfs -n __fish_is_first_arg -a check -d 'Check structural integrity of a filesystem (unmounted).'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a restore -d 'Try to restore files from a damaged filesystem (unmounted)'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a send -d 'Send the subvolume(s) to stdout.'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a receive -d 'Receive subvolumes from a stream'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a help -d 'Display help information'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a version -d 'Display btrfs-progs version'
|
|
|
|
# Primary command groups
|
|
complete -f -c btrfs -n __fish_is_first_arg -a subvolume -d 'manage subvolumes: create, delete, list, etc'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a filesystem -d 'overall filesystem tasks and information'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a balance -d 'balance data across devices, or change block groups using filters'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a device -d 'manage and query devices in the filesystem'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a scrub -d 'verify checksums of data and metadata'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a rescue -d 'toolbox for specific rescue operations'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a inspect-internal -d 'query various internal information'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a property -d 'modify properties of filesystem objects'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a quota -d 'manage filesystem quota settings'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a qgroup -d 'manage quota groups'
|
|
complete -f -c btrfs -n __fish_is_first_arg -a replace -d 'replace a device in the filesystem'
|
|
|
|
# btrfs check
|
|
complete -f -c btrfs -n $check -s s -l super -d 'Use this SUPERBLOCK copy'
|
|
complete -f -c btrfs -n $check -s b -l backup -d 'Use the first valid BACKUP root copy'
|
|
complete -f -c btrfs -n $check -s r -l tree-root -d 'Use the given bytenr for the TREE root'
|
|
complete -f -c btrfs -n $check -l chunk-root -d 'Use the given bytenr for the CHUNK-TREE root'
|
|
complete -f -c btrfs -n $check -l readonly -d 'Run in read-only mode'
|
|
complete -f -c btrfs -n $check -l repair -d 'Try to repair the filesystem'
|
|
complete -f -c btrfs -n $check -l force -d 'Skip mount checks, repair is not possible'
|
|
complete -f -c btrfs -n $check -l mode -d 'Allows choice of memory/IO trade-offs' -ra '{original,lowmem}'
|
|
complete -f -c btrfs -n $check -l init-csum-tree -d 'Create a new CRC tree (repair only)'
|
|
complete -f -c btrfs -n $check -l init-extent-tree -d 'Create a new extent tree (repair only)'
|
|
complete -f -c btrfs -n $check -l clear-space-cache -d 'clear space cache (repair only)' -ra '{v1,v2}'
|
|
complete -f -c btrfs -n $check -l check-data-csum -d 'Verify checksums of data blocks'
|
|
complete -f -c btrfs -n $check -s Q -l qgroup-report -d 'Print a report on qgroup consistency'
|
|
complete -f -c btrfs -n $check -s E -l subvol-extents -d 'Print subvolume extents and sharing state'
|
|
complete -f -c btrfs -n $check -s p -l progress -d 'Indicate progress'
|
|
|
|
# btrfs restore
|
|
complete -f -c btrfs -n $restore -s s -l snapshots -d 'Get snapshots'
|
|
complete -f -c btrfs -n $restore -s x -l xattr -d 'Restore extended attributes'
|
|
complete -f -c btrfs -n $restore -s m -l metadata -d 'Restore owner, mode and times'
|
|
complete -f -c btrfs -n $restore -s S -l symlink -d 'Restore symbolic links'
|
|
complete -f -c btrfs -n $restore -s v -l verbose -d Verbose
|
|
complete -f -c btrfs -n $restore -s i -l ignore-errors -d 'Ignore errors'
|
|
complete -f -c btrfs -n $restore -s o -l overwrite -d Overwrite
|
|
complete -f -c btrfs -n $restore -s t -d 'Tree location'
|
|
complete -f -c btrfs -n $restore -s f -d 'Filesystem location'
|
|
complete -f -c btrfs -n $restore -s u -l super -d 'Super mirror'
|
|
complete -f -c btrfs -n $restore -s r -l root -d 'Root objectid'
|
|
complete -f -c btrfs -n $restore -s d -d 'Find dir'
|
|
complete -f -c btrfs -n $restore -s l -l list-roots -d 'List tree roots'
|
|
complete -f -c btrfs -n $restore -s D -l dry-run -d 'Only list files that would be recovered'
|
|
complete -f -c btrfs -n $restore -l path-regex -d 'Restore only filenames matching regex'
|
|
complete -f -c btrfs -n $restore -s c -d 'Ignore case (--path-regex only)'
|
|
|
|
# btrfs send
|
|
complete -f -c btrfs -n $send -s e -d ''
|
|
complete -f -c btrfs -n $send -s p -d 'Send an incremental stream from <parent> to <subvol>'
|
|
complete -f -c btrfs -n $send -s c -d 'Use this snapshot as a clone source for an incremental send'
|
|
complete -f -c btrfs -n $send -s f -d 'Output is normally written to stdout'
|
|
complete -f -c btrfs -n $send -l no-data -d 'send in NO_FILE_DATA mode'
|
|
complete -f -c btrfs -n $send -s v -l verbose -d 'Enable verbose output to stderr'
|
|
complete -f -c btrfs -n $send -s q -l quiet -d 'Suppress all messages, except errors'
|
|
|
|
# btrfs receive
|
|
complete -f -c btrfs -n $receive -s v -d 'Increase verbosity about performed actions'
|
|
complete -f -c btrfs -n $receive -s q -l quiet -d 'Suppress all messages, except errors'
|
|
complete -f -c btrfs -n $receive -s f -d 'Read the stream from FILE instead of stdin'
|
|
complete -f -c btrfs -n $receive -s e -d 'Terminate after receiving an <end cmd> marker in the stream'
|
|
complete -f -c btrfs -n $receive -s C -l chroot -d 'Confine the process to <mount> using chroot'
|
|
complete -f -c btrfs -n $receive -s E -l max-errors -d 'Terminate when NUMBER errors occur'
|
|
complete -f -c btrfs -n $receive -s m -d 'The root mount point of the destination filesystem'
|
|
complete -f -c btrfs -n $receive -l dump -d 'Dump stream metadata'
|
|
|
|
# btrfs help
|
|
complete -f -c btrfs -n $help -l full -d 'Display detailed help on every command'
|
|
complete -f -c btrfs -n $help -l box -d 'Show list of built-in tools (busybox style)'
|
|
|
|
# btrfs subvolume
|
|
complete -f -c btrfs -n $subvolume -a create -d 'Create a subvolume'
|
|
complete -f -c btrfs -n $subvolume -a delete -d 'Delete subvolume(s)'
|
|
complete -f -c btrfs -n $subvolume -a list -d 'List subvolumes and snapshots in the filesystem.'
|
|
complete -f -c btrfs -n $subvolume -a snapshot -d 'Create a snapshot of the subvolume'
|
|
complete -f -c btrfs -n $subvolume -a get-default -d 'Get the default subvolume of a filesystem'
|
|
complete -f -c btrfs -n $subvolume -a set-default -d 'Set the default subvolume of the filesystem mounted as default.'
|
|
complete -f -c btrfs -n $subvolume -a find-new -d 'List the recently modified files in a filesystem'
|
|
complete -f -c btrfs -n $subvolume -a show -d 'Show more information about the subvolume'
|
|
complete -f -c btrfs -n $subvolume -a sync -d 'Wait until given subvolume(s) are completely removed from the filesystem.'
|
|
# btrfs subvolume create
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume create' -s i -d 'Add subvolume to a qgroup (can be given multiple times)'
|
|
# btrfs subvolume delete
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume delete' -s c -l commit-after -d 'Wait for transaction commit at the end of the operation'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume delete' -s C -l commit-each -d 'Wait for transaction commit after deleting each subvolume'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume delete' -s v -l verbose -d 'Verbose output of operations'
|
|
# btrfs subvolume list
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s o -d 'Print only subvolumes below specified path'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s a -d 'Print all the subvolumes and absolute and relative path'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s p -d 'Print parent ID'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s c -d 'Print the ogeneration of the subvolume'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s g -d 'Print the generation of the subvolume'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s u -d 'Print the uuid of subvolumes (and snapshots)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s q -d 'Print the parent uuid of the snapshots'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s R -d 'Print the uuid of the received snapshots'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s s -d 'List only snapshots'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s r -d 'List readonly subvolumes (including snapshots)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s d -d 'List deleted subvolumes that are not yet cleaned'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s t -d 'Print the result as a table'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s G -d 'Filter the subvolumes by generation'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -s C -d 'Filter the subvolumes by ogeneration'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume list' -l sort -d 'List the subvolume in order' -a '{gen,ogen,rootid,path}'
|
|
# btrfs subvolume snapshot
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume snapshot' -s r -d 'Create a readonly snapshot'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume snapshot' -s i -d 'Add snapshot to a qgroup (can be given multiple times)'
|
|
# btrfs subvolume show
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume show' -s r -l rootid -d 'Show rootid of the subvolume'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume show' -s u -l uuid -d 'Show uuid of the subvolume'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume show' -s b -l raw -d 'Show raw numbers in bytes'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume show' -s h -l human-readable -d 'Show human friendly numbers, base 1024'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume show' -s H -d 'Show human friendly numbers, base 1000'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume show' -l iec -d 'Use 1024 as a base (KiB, MiB, GiB, TiB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume show' -l si -d 'Use 1000 as a base (kB, MB, GB, TB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume show' -s k -l kbytes -d 'Show sizes in KiB, or kB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume show' -s m -l mbytes -d 'Show sizes in MiB, or MB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume show' -s g -l gbytes -d 'Show sizes in GiB, or GB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume show' -s t -l tbytes -d 'Show sizes in TiB, or TB with --si'
|
|
# btrfs subvolume sync
|
|
complete -f -c btrfs -n '__btrfs_command_groups subvolume sync' -s s -d 'Sleep NUMBER seconds between checks'
|
|
|
|
# btrfs filesystem
|
|
complete -f -c btrfs -n $filesystem -a df -d 'Show space usage information for a mount point'
|
|
complete -f -c btrfs -n $filesystem -a du -d 'Summarize disk usage of each file.'
|
|
complete -f -c btrfs -n $filesystem -a show -d 'Show the structure of a filesystem'
|
|
complete -f -c btrfs -n $filesystem -a sync -d 'Force a sync on a filesystem'
|
|
complete -f -c btrfs -n $filesystem -a defragment -d 'Defragment a file or a directory'
|
|
complete -f -c btrfs -n $filesystem -a resize -d 'Resize a filesystem'
|
|
complete -f -c btrfs -n $filesystem -a label -d 'Get or change the label of a filesystem'
|
|
complete -f -c btrfs -n $filesystem -a usage -d 'Show detailed information about internal filesystem usage.'
|
|
# btrfs filesystem df
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem df' -s b -l raw -d 'Show raw numbers in bytes'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem df' -s h -l human-readable -d 'Show human friendly numbers, base 1024'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem df' -s H -d 'Show human friendly numbers, base 1000'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem df' -l iec -d 'Use 1024 as a base (KiB, MiB, GiB, TiB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem df' -l si -d 'Use 1000 as a base (kB, MB, GB, TB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem df' -s k -l kbytes -d 'Show sizes in KiB, or kB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem df' -s m -l mbytes -d 'Show sizes in MiB, or MB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem df' -s g -l gbytes -d 'Show sizes in GiB, or GB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem df' -s t -l tbytes -d 'Show sizes in TiB, or TB with --si'
|
|
# btrfs filesystem du
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem du' -s s -l summarize -d 'Display only a total for each argument'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem du' -l raw -d 'Show raw numbers in bytes'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem du' -l human-readable -d 'Show human friendly numbers, base 1024'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem du' -l iec -d 'Use 1024 as a base (KiB, MiB, GiB, TiB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem du' -l si -d 'Use 1000 as a base (kB, MB, GB, TB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem du' -l kbytes -d 'Show sizes in KiB, or kB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem du' -l mbytes -d 'Show sizes in MiB, or MB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem du' -l gbytes -d 'Show sizes in GiB, or GB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem du' -l tbytes -d 'Show sizes in TiB, or TB with --si'
|
|
# btrfs filesystem show
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem show' -s d -l all-devices -d 'Show only disks under /dev containing btrfs filesystem'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem show' -s m -l mounted -d 'Show only mounted btrfs'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem show' -l raw -d 'Show raw numbers in bytes'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem show' -l human-readable -d 'Show human friendly numbers, base 1024'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem show' -l iec -d 'Use 1024 as a base (KiB, MiB, GiB, TiB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem show' -l si -d 'Use 1000 as a base (kB, MB, GB, TB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem show' -l kbytes -d 'Show sizes in KiB, or kB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem show' -l mbytes -d 'Show sizes in MiB, or MB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem show' -l gbytes -d 'Show sizes in GiB, or GB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem show' -l tbytes -d 'Show sizes in TiB, or TB with --si'
|
|
# btrfs filesystem defragment
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem defragment' -s v -d 'Be verbose'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem defragment' -s r -d 'Defragment files recursively'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem defragment' -s c -d 'Compress the file while defragmenting' -ra '{zlib,lzo,zstd}'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem defragment' -s f -d 'Flush data to disk immediately after defragmenting'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem defragment' -s s -d 'Defragment only from NUMBER byte onward'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem defragment' -s l -d 'Defragment only up to LEN bytes'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem defragment' -s t -d 'Target extent SIZE hint'
|
|
# btrfs filesystem usage
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem usage' -s b -l raw -d 'Show raw numbers in bytes'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem usage' -s h -l human-readable -d 'Show human friendly numbers, base 1024'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem usage' -s H -d 'Show human friendly numbers, base 1000'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem usage' -l iec -d 'Use 1024 as a base (KiB, MiB, GiB, TiB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem usage' -l si -d 'Use 1000 as a base (kB, MB, GB, TB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem usage' -s k -l kbytes -d 'Show sizes in KiB, or kB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem usage' -s m -l mbytes -d 'Show sizes in MiB, or MB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem usage' -s g -l gbytes -d 'Show sizes in GiB, or GB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem usage' -s t -l tbytes -d 'Show sizes in TiB, or TB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups filesystem usage' -s T -d 'Show data in tabular format'
|
|
|
|
# btrfs balance
|
|
complete -f -c btrfs -n $balance -a start -d 'Balance chunks across the devices'
|
|
complete -f -c btrfs -n $balance -a pause -d 'Pause running balance'
|
|
complete -f -c btrfs -n $balance -a cancel -d 'Cancel running or paused balance'
|
|
complete -f -c btrfs -n $balance -a resume -d 'Resume interrupted balance'
|
|
complete -f -c btrfs -n $balance -a status -d 'Show status of running or paused balance'
|
|
# btrfs balance start
|
|
complete -f -c btrfs -n '__btrfs_command_groups balance start' -s d -d 'Act on data chunks with FILTERS'
|
|
complete -f -c btrfs -n '__btrfs_command_groups balance start' -s m -d 'Act on metadata chunks with FILTERS'
|
|
complete -f -c btrfs -n '__btrfs_command_groups balance start' -s s -d 'Act on system chunks with FILTERS (only under -f)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups balance start' -s v -d 'Be verbose'
|
|
complete -f -c btrfs -n '__btrfs_command_groups balance start' -s f -d 'Force a reduction of metadata integrity'
|
|
complete -f -c btrfs -n '__btrfs_command_groups balance start' -l full-balance -d 'Do not print warning and do not delay start'
|
|
complete -f -c btrfs -n '__btrfs_command_groups balance start' -l background -l bg -d 'Run the balance as a background process'
|
|
# btrfs balance status
|
|
complete -f -c btrfs -n '__btrfs_command_groups balance status' -s v -d 'Be verbose'
|
|
|
|
# btrfs device
|
|
complete -f -c btrfs -n $device -a add -d 'Add one or more devices to a mounted filesystem.'
|
|
complete -f -c btrfs -n $device -a delete -d 'Remove a device from a filesystem'
|
|
complete -f -c btrfs -n $device -a remove -d 'Remove a device from a filesystem'
|
|
complete -f -c btrfs -n $device -a scan -d 'Scan or forget (unregister) devices of btrfs filesystems'
|
|
complete -f -c btrfs -n $device -a ready -d 'Check and wait until a group of devices of a filesystem is ready for mount'
|
|
complete -f -c btrfs -n $device -a stats -d 'Show device IO error statistics'
|
|
complete -f -c btrfs -n $device -a usage -d 'Show detailed information about internal allocations in devices.'
|
|
# btrfs device add
|
|
complete -f -c btrfs -n '__btrfs_command_groups device add' -s K -l nodiscard -d 'Do not perform TRIM on DEVICES'
|
|
complete -f -c btrfs -n '__btrfs_command_groups device add' -s f -l force -d 'Force overwrite existing filesystem on the disk'
|
|
# btrfs device scan
|
|
complete -f -c btrfs -n '__btrfs_command_groups device scan' -s d -l all-devices -d 'Enumerate and register all devices'
|
|
complete -f -c btrfs -n '__btrfs_command_groups device scan' -s u -l forget -d 'Unregister a given device or all stale devices'
|
|
# btrfs device stats
|
|
complete -f -c btrfs -n '__btrfs_command_groups device stats' -s c -l check -d 'Return non-zero if any stat counter is not zero'
|
|
complete -f -c btrfs -n '__btrfs_command_groups device stats' -s z -l reset -d 'Show current stats and reset values to zero'
|
|
# btrfs device usage
|
|
complete -f -c btrfs -n '__btrfs_command_groups device usage' -s b -l raw -d 'Show raw numbers in bytes'
|
|
complete -f -c btrfs -n '__btrfs_command_groups device usage' -s h -l human-readable -d 'Show human friendly numbers, base 1024'
|
|
complete -f -c btrfs -n '__btrfs_command_groups device usage' -s H -d 'Show human friendly numbers, base 1000'
|
|
complete -f -c btrfs -n '__btrfs_command_groups device usage' -l iec -d 'Use 1024 as a base (KiB, MiB, GiB, TiB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups device usage' -l si -d 'Use 1000 as a base (kB, MB, GB, TB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups device usage' -s k -l kbytes -d 'Show sizes in KiB, or kB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups device usage' -s m -l mbytes -d 'Show sizes in MiB, or MB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups device usage' -s g -l gbytes -d 'Show sizes in GiB, or GB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups device usage' -s t -l tbytes -d 'Show sizes in TiB, or TB with --si'
|
|
|
|
# btrfs scrub
|
|
complete -f -c btrfs -n $scrub -a start -d 'Start a new scrub. If a scrub is already running, the new one fails.'
|
|
complete -f -c btrfs -n $scrub -a cancel -d 'Cancel a running scrub'
|
|
complete -f -c btrfs -n $scrub -a resume -d 'Resume previously canceled or interrupted scrub'
|
|
complete -f -c btrfs -n $scrub -a status -d 'Show status of running or finished scrub'
|
|
# btrfs scrub start
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub start' -s B -d 'Do not background'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub start' -s d -d 'Stats per device (-B only)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub start' -s q -d 'Be quiet'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub start' -s r -d 'Read only mode'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub start' -s R -d 'Raw print mode, print full data instead of summary'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub start' -s c -d 'Set ioprio class (see ionice(1) manpage)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub start' -s n -d 'Set ioprio classdata (see ionice(1) manpage)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub start' -s f -d 'Force starting new scrub'
|
|
# btrfs scrub resume
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub resume' -s B -d 'Do not background'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub resume' -s d -d 'Stats per device (-B only)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub resume' -s q -d 'Be quiet'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub resume' -s r -d 'Read only mode'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub resume' -s R -d 'Raw print mode, print full data instead of summary'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub resume' -s c -d 'Set ioprio class (see ionice(1) manpage)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub resume' -s n -d 'Set ioprio classdata (see ionice(1) manpage)'
|
|
# btrfs scrub status
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub status' -s d -d 'Stats per DEVICE'
|
|
complete -f -c btrfs -n '__btrfs_command_groups scrub status' -s R -d 'Print raw stats'
|
|
|
|
# btrfs rescue
|
|
complete -f -c btrfs -n $rescue -a chunk-recover -d 'Recover the chunk tree by scanning the devices one by one.'
|
|
complete -f -c btrfs -n $rescue -a super-recover -d 'Recover bad superblocks from good copies'
|
|
complete -f -c btrfs -n $rescue -a zero-log -d 'Clear the tree log. Usable if it\'s corrupted and prevents mount.'
|
|
complete -f -c btrfs -n $rescue -a fix-device-size -d 'Re-align device and super block sizes. Usable if newer kernel refuse to mount it due to mismatch super size'
|
|
# btrfs rescue chunk-recover
|
|
complete -f -c btrfs -n '__btrfs_command_groups rescue chunk-recover' -s y -d 'Assume an answer of YES to all questions'
|
|
complete -f -c btrfs -n '__btrfs_command_groups rescue chunk-recover' -s v -d 'Verbose mode'
|
|
# btrfs rescue super-recover
|
|
complete -f -c btrfs -n '__btrfs_command_groups rescue super-recover' -s y -d 'Assume an answer of YES to all questions'
|
|
complete -f -c btrfs -n '__btrfs_command_groups rescue super-recover' -s v -d 'Verbose mode'
|
|
|
|
# btrfs inspect-internal
|
|
complete -f -c btrfs -n $inspect_internal -a inode-resolve -d 'Get file system paths for the given inode'
|
|
complete -f -c btrfs -n $inspect_internal -a logical-resolve -d 'Get file system paths for the given logical address'
|
|
complete -f -c btrfs -n $inspect_internal -a subvolid-resolve -d 'Get file system paths for the given subvolume ID.'
|
|
complete -f -c btrfs -n $inspect_internal -a rootid -d 'Get tree ID of the containing subvolume of path.'
|
|
complete -f -c btrfs -n $inspect_internal -a min-dev-size -d 'Get the minimum size the device can be shrunk to. (Default: 1)'
|
|
complete -f -c btrfs -n $inspect_internal -a dump-tree -d 'Dump tree structures from a given device'
|
|
complete -f -c btrfs -n $inspect_internal -a dump-super -d 'Dump superblock from a device in a textual form'
|
|
complete -f -c btrfs -n $inspect_internal -a tree-stats -d 'Print various stats for trees'
|
|
# btrfs inspect-internal inode-resolve
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal inode-resolve' -s v -d 'Verbose mode'
|
|
# btrfs inspect-internal logical-resolve
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal logical-resolve' -s P -d 'Skip the path resolving and print the inodes instead'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal logical-resolve' -s v -d 'Verbose mode'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal logical-resolve' -s s -d 'Set inode container\'s SIZE'
|
|
# btrfs inspect-internal min-dev-size
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal min-dev-size' -l id -d 'Specify the DEVICE-ID to query'
|
|
# btrfs inspect-internal dump-tree
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-tree' -s e -l extents -d 'Print only extent info: extent and device trees'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-tree' -s d -l device -d 'Print only device info: tree root, chunk and device trees'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-tree' -s r -l roots -d 'Print only short root node info'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-tree' -s R -l backups -d 'Print short root node info and backup root info'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-tree' -s u -l uuid -d 'Print only the uuid tree'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-tree' -s b -l block -d 'Print info from the specified BLOCK only'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-tree' -s t -l tree -d 'Print only tree with the given ID'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-tree' -l follow -d 'Use with -b, to show all children tree blocks of <block_num>'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-tree' -l noscan -d 'Do not scan the devices from the filesystem'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-tree' -l bfs -d 'Breadth-first traversal of the trees, print nodes, then leaves'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-tree' -l dfs -d 'Depth-first traversal of the trees'
|
|
# btrfs inspect-internal dump-super
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-super' -s f -l full -d 'Print full superblock information, backup roots etc.'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-super' -s a -l all -d 'Print information about all superblocks'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-super' -s s -l super -d 'Specify which SUPER-BLOCK copy to print out' -ra '{0,1,2}'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-super' -s F -l force -d 'Attempt to dump superblocks with bad magic'
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal dump-super' -l bytenr -d 'Specify alternate superblock OFFSET'
|
|
# btrfs inspect-internal tree-stats
|
|
complete -f -c btrfs -n '__btrfs_command_groups inspect-internal tree-stats' -s b -d 'Show raw numbers in bytes'
|
|
|
|
# btrfs property
|
|
complete -f -c btrfs -n $property -a get -d 'Get a property value of a btrfs object'
|
|
complete -f -c btrfs -n $property -a set -d 'Set a property on a btrfs object'
|
|
complete -f -c btrfs -n $property -a list -d 'Lists available properties with their descriptions for the given object'
|
|
# btrfs property get
|
|
complete -f -c btrfs -n '__btrfs_command_groups property get' -s t -d 'List properties for the given object type' -ra '{inode,subvol,filesystem,device}'
|
|
# btrfs property set
|
|
complete -f -c btrfs -n '__btrfs_command_groups property set' -s t -d 'List properties for the given object type' -ra '{inode,subvol,filesystem,device}'
|
|
# btrfs property list
|
|
complete -f -c btrfs -n '__btrfs_command_groups property list' -s t -d 'List properties for the given object type' -ra '{inode,subvol,filesystem,device}'
|
|
|
|
# btrfs quota
|
|
complete -f -c btrfs -n $quota -a enable -d 'Enable subvolume quota support for a filesystem.'
|
|
complete -f -c btrfs -n $quota -a disable -d 'Disable subvolume quota support for a filesystem.'
|
|
complete -f -c btrfs -n $quota -a rescan -d 'Trash all qgroup numbers and scan the metadata again with the current config.'
|
|
# btrfs quota rescan
|
|
complete -f -c btrfs -n '__btrfs_command_groups quota rescan' -s s -d 'Show status of a running rescan operation'
|
|
complete -f -c btrfs -n '__btrfs_command_groups quota rescan' -s w -d 'Wait for rescan operation to finish'
|
|
|
|
# btrfs qgroup
|
|
complete -f -c btrfs -n $qgroup -a assign -d 'Assign SRC as the child qgroup of DST'
|
|
complete -f -c btrfs -n $qgroup -a remove -d 'Remove a child qgroup SRC from DST.'
|
|
complete -f -c btrfs -n $qgroup -a create -d 'Create a subvolume quota group.'
|
|
complete -f -c btrfs -n $qgroup -a destroy -d 'Destroy a quota group.'
|
|
complete -f -c btrfs -n $qgroup -a show -d 'Show subvolume quota groups.'
|
|
complete -f -c btrfs -n $qgroup -a limit -d 'Set the limits a subvolume quota group.'
|
|
# btrfs qgroup assign
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup assign' -l rescan -d 'Schedule qutoa rescan if needed'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup assign' -l no-rescan -d 'Don\'t schedule quota rescan'
|
|
# btrfs qgroup show
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -s p -d 'Print parent qgroup id'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -s c -d 'Print child qgroup id'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -s r -d 'Print limit of referenced size of qgroup'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -s e -d 'Print limit of exclusive size of qgroup'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -s F -d 'List all qgroups including ancestral qgroups'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -s f -d 'List all qgroups excluding ancestral qgroups'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -l raw -d 'Show raw numbers in bytes'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -l human-readable -d 'Show human friendly numbers, base 1024'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -l iec -d 'Use 1024 as a base (KiB, MiB, GiB, TiB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -l si -d 'Use 1000 as a base (kB, MB, GB, TB)'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -l kbytes -d 'Show sizes in KiB, or kB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -l mbytes -d 'Show sizes in MiB, or MB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -l gbytes -d 'Show sizes in GiB, or GB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -l tbytes -d 'Show sizes in TiB, or TB with --si'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -l sort -d 'List qgroups sorted by specified items' -a '{qgroupid,rfer,excl,max_rfer,max_excl}'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup show' -l sync -d 'Force sync of the filesystem before getting info'
|
|
# btrfs qgroup limit
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup limit' -s c -d 'Limit amount of data after compression'
|
|
complete -f -c btrfs -n '__btrfs_command_groups qgroup limit' -s e -d 'Limit space exclusively assigned to this qgroup'
|
|
|
|
# btrfs replace
|
|
complete -f -c btrfs -n $replace -a start -d 'Replace device of a btrfs filesystem.'
|
|
complete -f -c btrfs -n $replace -a status -d 'Print status and progress information of a running device replace'
|
|
complete -f -c btrfs -n $replace -a cancel -d 'Cancel a running device replace operation.'
|
|
# btrfs replace start
|
|
complete -f -c btrfs -n '__btrfs_command_groups replace start' -s r -d 'Only read from <srcdev> if no other zero-defect mirror exists'
|
|
complete -f -c btrfs -n '__btrfs_command_groups replace start' -s f -d 'Force using and overwriting <targetdev>'
|
|
complete -f -c btrfs -n '__btrfs_command_groups replace start' -s B -d 'Do not background'
|
|
# btrfs replace status
|
|
complete -f -c btrfs -n '__btrfs_command_groups replace status' -s 1 -d 'Only print once until the replace operation finishes'
|