summaryrefslogtreecommitdiffstats
path: root/completion
diff options
context:
space:
mode:
authorJani Nikula <jani@nikula.org>2015-10-17 19:30:02 +0300
committerDavid Bremner <david@tethera.net>2015-10-21 21:29:20 -0300
commitcd4814ecb35c63152aced04fcb82e5facf1463ca (patch)
tree12867eceecffc3c4f9d8b8855c35b873a3a2e857 /completion
parent326824aee38c64ce80c50feac92c10dba4bb4879 (diff)
completion: complete shared options for each command
Add support for completing --help, --uuid=, and --version after the subcommand. Do not support shared options at the top level yet due to difficulties in handling options with arguments. --uuid necessitates adding 'compopt -o nospace' also to notmuch new completion, but that just brings it in line with the rest.
Diffstat (limited to 'completion')
-rw-r--r--completion/notmuch-completion.bash25
1 files changed, 14 insertions, 11 deletions
diff --git a/completion/notmuch-completion.bash b/completion/notmuch-completion.bash
index 1552c1e5..1356c4a4 100644
--- a/completion/notmuch-completion.bash
+++ b/completion/notmuch-completion.bash
@@ -27,6 +27,8 @@
# on completion.
#
+_notmuch_shared_options="--help --uuid= --version"
+
# $1: current input of the form prefix:partialinput, where prefix is
# to or from.
_notmuch_email()
@@ -109,7 +111,7 @@ _notmuch_compact()
! $split &&
case "${cur}" in
-*)
- local options="--backup= --quiet"
+ local options="--backup= --quiet ${_notmuch_shared_options}"
compopt -o nospace
COMPREPLY=( $(compgen -W "$options" -- ${cur}) )
;;
@@ -162,7 +164,7 @@ _notmuch_count()
! $split &&
case "${cur}" in
-*)
- local options="--output= --exclude= --batch --input= --lastmod"
+ local options="--output= --exclude= --batch --input= --lastmod ${_notmuch_shared_options}"
compopt -o nospace
COMPREPLY=( $(compgen -W "$options" -- ${cur}) )
;;
@@ -192,7 +194,7 @@ _notmuch_dump()
! $split &&
case "${cur}" in
-*)
- local options="--gzip --format= --output="
+ local options="--gzip --format= --output= ${_notmuch_shared_options}"
compopt -o nospace
COMPREPLY=( $(compgen -W "$options" -- ${cur}) )
;;
@@ -222,7 +224,7 @@ _notmuch_insert()
! $split &&
case "${cur}" in
--*)
- local options="--create-folder --folder= --keep --no-hooks"
+ local options="--create-folder --folder= --keep --no-hooks ${_notmuch_shared_options}"
compopt -o nospace
COMPREPLY=( $(compgen -W "$options" -- ${cur}) )
return
@@ -245,7 +247,8 @@ _notmuch_new()
case "${cur}" in
-*)
- local options="--no-hooks --quiet"
+ local options="--no-hooks --quiet ${_notmuch_shared_options}"
+ compopt -o nospace
COMPREPLY=( $(compgen -W "${options}" -- ${cur}) )
;;
esac
@@ -271,7 +274,7 @@ _notmuch_reply()
! $split &&
case "${cur}" in
-*)
- local options="--format= --format-version= --reply-to= --decrypt"
+ local options="--format= --format-version= --reply-to= --decrypt ${_notmuch_shared_options}"
compopt -o nospace
COMPREPLY=( $(compgen -W "$options" -- ${cur}) )
;;
@@ -301,7 +304,7 @@ _notmuch_restore()
! $split &&
case "${cur}" in
-*)
- local options="--format= --accumulate --input="
+ local options="--format= --accumulate --input= ${_notmuch_shared_options}"
compopt -o nospace
COMPREPLY=( $(compgen -W "$options" -- ${cur}) )
;;
@@ -336,7 +339,7 @@ _notmuch_search()
! $split &&
case "${cur}" in
-*)
- local options="--format= --output= --sort= --offset= --limit= --exclude= --duplicate="
+ local options="--format= --output= --sort= --offset= --limit= --exclude= --duplicate= ${_notmuch_shared_options}"
compopt -o nospace
COMPREPLY=( $(compgen -W "$options" -- ${cur}) )
;;
@@ -378,7 +381,7 @@ _notmuch_address()
! $split &&
case "${cur}" in
-*)
- local options="--format= --output= --sort= --exclude= --deduplicate="
+ local options="--format= --output= --sort= --exclude= --deduplicate= ${_notmuch_shared_options}"
compopt -o nospace
COMPREPLY=( $(compgen -W "$options" -- ${cur}) )
;;
@@ -412,7 +415,7 @@ _notmuch_show()
! $split &&
case "${cur}" in
-*)
- local options="--entire-thread= --format= --exclude= --body= --format-version= --part= --verify --decrypt --include-html"
+ local options="--entire-thread= --format= --exclude= --body= --format-version= --part= --verify --decrypt --include-html ${_notmuch_shared_options}"
compopt -o nospace
COMPREPLY=( $(compgen -W "$options" -- ${cur}) )
;;
@@ -439,7 +442,7 @@ _notmuch_tag()
! $split &&
case "${cur}" in
--*)
- local options="--batch --input= --remove-all"
+ local options="--batch --input= --remove-all ${_notmuch_shared_options}"
compopt -o nospace
COMPREPLY=( $(compgen -W "$options" -- ${cur}) )
return