summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--etc/completion/bash/guix23
1 files changed, 19 insertions, 4 deletions
diff --git a/etc/completion/bash/guix b/etc/completion/bash/guix
index e4d9a497b3..807a0b2e1f 100644
--- a/etc/completion/bash/guix
+++ b/etc/completion/bash/guix
@@ -18,15 +18,24 @@
# Bash completion for Guix commands.
+declare _guix_available_packages
+
_guix_complete_available_package ()
{
local prefix="$1"
- local packages="$(${COMP_WORDS[0]} package -A "^$prefix" | cut -f1)"
- COMPREPLY=($(compgen -W "$packages" -- "$prefix"))
+ if [ -z "$_guix_available_packages" ]
+ then
+ # Cache the complete list because it rarely changes and makes
+ # completion much faster.
+ _guix_available_packages="$(${COMP_WORDS[0]} package -A | cut -f1)"
+ fi
+ COMPREPLY=($(compgen -W "$_guix_available_packages" -- "$prefix"))
}
_guix_complete_installed_package ()
{
+ # Here we do not cache the list of installed packages because that
+ # may change over time and the list is relatively small anyway.
local prefix="$1"
local packages="$(${COMP_WORDS[0]} package -I "^$prefix" | cut -f1)"
COMPREPLY=($(compgen -W "$packages" -- "$prefix"))
@@ -88,6 +97,8 @@ _guix_complete_file ()
COMPREPLY=()
}
+declare _guix_subcommands
+
_guix_complete ()
{
local word_count=${#COMP_WORDS[*]}
@@ -105,8 +116,12 @@ _guix_complete ()
case $COMP_CWORD in
1)
- local subcommands="$(guix --help | grep '^ ' | cut -c 2-)"
- COMPREPLY=($(compgen -W "$subcommands" -- "$word_at_point"))
+ if [ -z "$_guix_subcommands" ]
+ then
+ # Cache the list of subcommands to speed things up.
+ _guix_subcommands="$(guix --help | grep '^ ' | cut -c 2-)"
+ fi
+ COMPREPLY=($(compgen -W "$_guix_subcommands" -- "$word_at_point"))
;;
*)
if _guix_is_command "package"