浏览代码

update bash completion script commands and options (#7273)

update bash completion script commands and options
Helmut Grohne 2 年之前
父节点
当前提交
f2f761212d
共有 1 个文件被更改,包括 45 次插入22 次删除
  1. 45 22
      scripts/shell_completions/bash/borg

+ 45 - 22
scripts/shell_completions/bash/borg

@@ -12,12 +12,12 @@ _borg()
     local cur="${COMP_WORDS[COMP_CWORD]}"
     local cur="${COMP_WORDS[COMP_CWORD]}"
     local prev="${COMP_WORDS[COMP_CWORD-1]}"
     local prev="${COMP_WORDS[COMP_CWORD-1]}"
     local prevprev="${COMP_WORDS[COMP_CWORD-2]}"
     local prevprev="${COMP_WORDS[COMP_CWORD-2]}"
-    local common_opts="-h --help --version --critical --error --warning --info -v --verbose --debug --debug-topic -p --progress --log-json --lock-wait --show-version --show-rc --umask --remote-path --remote-ratelimit --consider-part-files --debug-profile --rsh"
+    local common_opts="-h --help --critical --error --warning --info -v --verbose --debug --debug-topic -p --progress --iec --log-json --lock-wait --bypass-lock --show-version --show-rc --umask --remote-path --upload-ratelimit --upload-buffer --consider-part-files --debug-profile --rsh -r --repo"
     local opts="${common_opts}"
     local opts="${common_opts}"
 
 
     # Commands
     # Commands
     if [[ ${COMP_CWORD} == 1 ]] ; then
     if [[ ${COMP_CWORD} == 1 ]] ; then
-        local borg_commands="init create extract check rename list diff delete prune compact info mount umount key serve upgrade recreate export-tar with-lock break-lock config benchmark help"
+        local borg_commands="benchmark break-lock check compact config create delete diff export-tar extract help import-tar info key list mount prune rcompress rcreate rdelete recreate rename rinfo rlist serve transfer umount with-lock"
         COMPREPLY=( $(compgen -W "${borg_commands}" -- ${cur}) )
         COMPREPLY=( $(compgen -W "${borg_commands}" -- ${cur}) )
         compopt +o default
         compopt +o default
         return 0
         return 0
@@ -25,11 +25,11 @@ _borg()
 
 
     case "${prev}" in
     case "${prev}" in
         'key')
         'key')
-            COMPREPLY=( $(compgen -W "import export change-passphrase" -- ${cur}) )
+            COMPREPLY=( $(compgen -W "change-location change-passphrase export import" -- ${cur}) )
             return 0
             return 0
             ;;
             ;;
         'benchmark')
         'benchmark')
-            COMPREPLY=( $(compgen -W "crud" -- ${cur}) )
+            COMPREPLY=( $(compgen -W "cpu crud" -- ${cur}) )
             return 0
             return 0
             ;;
             ;;
         'help')
         'help')
@@ -37,7 +37,7 @@ _borg()
             return 0
             return 0
             ;;
             ;;
         '--encryption' | '-e')
         '--encryption' | '-e')
-            local encryption_modes="none keyfile keyfile-blake2 repokey repokey-blake2 authenticated authenticated-blake2"
+            local encryption_modes="authenticated authenticated-blake2 keyfile-aes-ocb keyfile-blake2-aes-ocb keyfile-blake2-chacha20-poly1305 keyfile-chacha20-poly1305 none repokey-aes-ocb repokey-blake2-aes-ocb repokey-blake2-chacha20-poly1305 repokey-chacha20-poly1305"
             COMPREPLY=( $(compgen -W "${encryption_modes}" -- ${cur}) )
             COMPREPLY=( $(compgen -W "${encryption_modes}" -- ${cur}) )
             return 0
             return 0
             ;;
             ;;
@@ -67,63 +67,86 @@ _borg()
             COMPREPLY=( $(compgen -W "${recompress_when}" -- ${cur}) )
             COMPREPLY=( $(compgen -W "${recompress_when}" -- ${cur}) )
             return 0
             return 0
             ;;
             ;;
+        '--upgrader')
+            local upgraders="From12To20 NoOp"
+            COMPREPLY=( $(compgren -W "${upgraders}" -- ${cur}) )
+            return 0
+            ;;
     esac
     esac
 
 
     if [[ ${cur} == -* ]] ; then
     if [[ ${cur} == -* ]] ; then
         case "${COMP_LINE}" in
         case "${COMP_LINE}" in
-            *' init '*)
-                local opts="-e --encryption --append-only --storage-quota --make-parent-dirs ${common_opts}"
+            *' rcreate '*)
+                local opts="--other-repo -e --encryption --append-only --storage-quota --make-parent-dirs --copy-crypt-key ${common_opts}"
+                ;;
+            *' rlist '*)
+                local opts="--consider-checkpoints --short --format --json ${common_opts} -a --match-archives --sort-by --first --last"
+                ;;
+            *' rinfo '*)
+                local opts="--json ${common_opts}"
+                ;;
+            *' rcompress '*)
+                local opts="-C --compression -s --stats -c --checkpoint-interval ${common_opts}"
+                ;;
+            *' rdelete '*)
+                local opts="-n --dry-run --list --force --cache-only --keep-security-info ${common_opts}"
                 ;;
                 ;;
             *' create '*)
             *' create '*)
-                local opts="-n --dry-run -s --stats --list --filter --json --no-cache-sync --stdin-name --content-from-command -e --exclude --exclude-from --pattern --patterns-from --exclude-caches --exclude-if-present --keep-exclude-tags --exclude-nodump -x --one-file-system --numeric-owner --noatime --noctime --nobirthtime --nobsdflags --noacls --noxattrs --noflags --files-cache --read-special --comment --timestamp -c --checkpoint-interval --chunker-params -C --compression ${common_opts}"
+                local opts="-n --dry-run -s --stats --list --filter --json --no-cache-sync --stdin-name --stdin-user --stdin-group --stdin-mode --content-from-command --paths-from-stdin --paths-from-command --paths-delimiter -e --exclude --exclude-from --pattern --patterns-from --exclude-caches --exclude-if-present --keep-exclude-tags --exclude-nodump -x --one-file-system --numeric-ids --atime --noctime --nobirthtime --noflags --noacls --noxattrs --sparse --files-cache --read-special --comment --timestamp -c --checkpoint-interval --chunker-params -C --compression ${common_opts}"
                 ;;
                 ;;
             *' extract '*)
             *' extract '*)
-                local opts="--list -n --dry-run --numeric-owner --nobsdflags --noacls --noxattrs --stdout --sparse -e --exclude --exclude-from --pattern --patterns-from --strip-components ${common_opts}"
+                local opts="--list -n --dry-run --numeric-ids --noflags --noacls --noxattrs --stdout --sparse -e --exclude --exclude-from --pattern --patterns-from --strip-components ${common_opts}"
                 ;;
                 ;;
             *' check '*)
             *' check '*)
-                local opts="--repository-only --archives-only --verify-data --repair --save-space --max-duration -P --prefix -a --glob-archives --sort-by --first --last ${common_opts}"
+                local opts="--repository-only --archives-only --verify-data --repair --max-duration -a --match-archives --sort-by --first --last ${common_opts}"
                 ;;
                 ;;
             # rename
             # rename
             #   no specific options
             #   no specific options
             *" list "*)
             *" list "*)
-                local opts="--short --format --json --json-lines -P --prefix -a --glob-archives --sort-by --first --last -e --exclude --exclude-from --pattern --patterns-from ${common_opts}"
+                local opts="--short --format --json-lines -e --exclude --exclude-from --pattern --patterns-from ${common_opts}"
                 ;;
                 ;;
             *' diff '*)
             *' diff '*)
-                local opts="--numeric-owner --same-chunker-params --sort --json-lines -e --exclude --exclude-from --pattern --patterns-from ${common_opts}"
+                local opts="--numeric-ids --same-chunker-params --sort --json-lines -e --exclude --exclude-from --pattern --patterns-from ${common_opts}"
                 ;;
                 ;;
             *' delete '*)
             *' delete '*)
-                local opts="-n --dry-run -s --stats --cache-only --force --save-space -P --prefix -a --glob-archives --sort-by --first --last ${common_opts}"
+                local opts="-n --dry-run --list --consider-checkpoints -s --stats --cache-only --force -c --checkpoint-interval -a --match-archives --sort-by --first --last ${common_opts}"
                 ;;
                 ;;
             *' prune '*)
             *' prune '*)
-                local opts="-n --dry-run --force -s --stats --list --keep-within --keep-last --keep-secondly --keep-minutely -H --keep-hourly -d --keep-daily -w --keep-weekly -m --keep-monthly -y --keep-yearly --save-space -P --prefix -a --glob-archives ${common_opts}"
+                local opts="-n --dry-run --force -s --stats --list --keep-within --keep-last --keep-secondly --keep-minutely -H --keep-hourly -d --keep-daily -w --keep-weekly -m --keep-monthly -y --keep-yearly -c --checkpoint-interval -a --match-archives ${common_opts}"
                 ;;
                 ;;
             *' compact '*)
             *' compact '*)
-                local opts="--cleanup-commits ${common_opts}"
+                local opts="--threshold ${common_opts}"
                 ;;
                 ;;
             *' info '*)
             *' info '*)
-                local opts="--json -P --prefix -a --glob-archives --sort-by --first --last ${common_opts}"
+                local opts="--json -a --match-archives --sort-by --first --last ${common_opts}"
                 ;;
                 ;;
             *' mount '*)
             *' mount '*)
-                local opts="-f --foreground -o -P --prefix -a --glob-archives --sort-by --first --last -e --exclude --exclude-from --pattern --patterns-from --strip-components ${common_opts}"
+                local opts="--consider-checkpoints -f --foreground -o --numeric-ids -a --match-archives --sort-by --first --last -e --exclude --exclude-from --pattern --patterns-from --strip-components ${common_opts}"
                 ;;
                 ;;
             # umount
             # umount
             #   no specific options
             #   no specific options
             # key change-passphrase
             # key change-passphrase
             #   no specific options
             #   no specific options
+            *' change-location '*)
+                local opts="${common_opts} keyfile repokey --keep"
+                ;;
             *' export '*)
             *' export '*)
                 local opts="--paper --qr-html ${common_opts}"
                 local opts="--paper --qr-html ${common_opts}"
                 ;;
                 ;;
             *' import '*)
             *' import '*)
                 local opts="--paper ${common_opts}"
                 local opts="--paper ${common_opts}"
                 ;;
                 ;;
-            *' upgrade '*)
-                local opts="-n --dry-run --inplace --force --tam --disable-tam ${common_opts}"
-                ;;
             *' recreate '*)
             *' recreate '*)
-                local opts="--list --filter -n dry-run -s stats -e exclude --exclude-from --pattern --patterns-from --exclude-caches --exclude-if-present --keep-exclude-tags --target -c checkpoint-interval --comment --timestamp --timestamp -C compression --recompress --chunker-params ${common_opts}"
+                local opts="--list --filter -n dry-run -s stats -e exclude --exclude-from --pattern --patterns-from --exclude-caches --exclude-if-present --keep-exclude-tags -a --match-archives --sort-by --first --last --target -c --checkpoint-interval --comment --timestamp -C --compression --recompress --chunker-params ${common_opts}"
                 ;;
                 ;;
             *' export-tar '*)
             *' export-tar '*)
-                local opts="--tar-filter --list -e exclude --exclude-from --pattern --patterns-from --strip-components ${common_opts}"
+                local opts="--tar-filter --list --tar-format -e exclude --exclude-from --pattern --patterns-from --strip-components ${common_opts}"
+                ;;
+            *' import-tar '*)
+                local opts="--tar-filter -s --stats --list --filter --json ${common_opts} --comment --timestamp -c --checkpoint-interval --chunker-params -C --compression"
+                ;;
+            *' transfer '*)
+                local opts="-n --dry-run --other-repo --upgrader ${common_opts} -a --match-archives --sort-by --first --last"
                 ;;
                 ;;
             *' serve '*)
             *' serve '*)
                 local opts="--restrict-to-path --restrict-to-repository --append-only --storage-quota ${common_opts}"
                 local opts="--restrict-to-path --restrict-to-repository --append-only --storage-quota ${common_opts}"