From: Jonatan Schlag <jonatan.schlag@ipfire.org>
To: network@lists.ipfire.org
Subject: [PATCH 4/4] autocompletion: improve config part
Date: Mon, 24 Jul 2017 21:10:05 +0200 [thread overview]
Message-ID: <1500923405-17258-4-git-send-email-jonatan.schlag@ipfire.org> (raw)
In-Reply-To: <1500923405-17258-1-git-send-email-jonatan.schlag@ipfire.org>
[-- Attachment #1: Type: text/plain, Size: 2083 bytes --]
Signed-off-by: Jonatan Schlag <jonatan.schlag(a)ipfire.org>
---
src/bash-completion/network | 46 ++++++++++++++++++++++++++++++++++++++++++++-
1 file changed, 45 insertions(+), 1 deletion(-)
diff --git a/src/bash-completion/network b/src/bash-completion/network
index f7c58a9..820c2d4 100644
--- a/src/bash-completion/network
+++ b/src/bash-completion/network
@@ -421,20 +421,64 @@ _network_zone_subcommand_config() {
local words=( $@ )
- local commands="new destroy"
+ local commands="destroy list new $(network raw list-zone-config-ids ${zone})"
+
local cmd="$(_network_find_on_cmdline "${commands}")"
if [[ -z "${cmd}" ]]; then
COMPREPLY=( $(compgen -W "${commands}" -- "${cur}") )
return 0
fi
+ local args="${words[@]:1}"
case "${cmd}" in
new)
_network_complete_hooks "config"
;;
+ destroy)
+ _network_zone_subcommand_config_destroy ${zone} ${args}
+ ;;
+ # We use no better globbing like [:digit:] here because hids would not match the glob
+ # Also bash is silly here and does not unterstand things like ^[[:digit:]]+$ here.
+ *)
+ # Check if we get a valid id
+ # TODO: We should also accept a valid hid
+ if network raw zone-config-id-is-valid ${zone} ${cmd}; then
+ _network_zone_subcommand_config_subcommand ${zone} ${args}
+ fi
+ ;;
esac
}
+_network_zone_subcommand_config_subcommand() {
+ local zone="${1}"
+ shift
+
+ local words=( $@ )
+
+ local commands="edit"
+
+ local cmd="$(_network_find_on_cmdline "${commands}")"
+ if [[ -z "${cmd}" ]]; then
+ COMPREPLY=( $(compgen -W "${commands}" -- "${cur}") )
+ return 0
+ fi
+}
+
+_network_zone_subcommand_config_destroy() {
+ local zone="${1}"
+ shift
+
+ local words=( $@ )
+
+ local commands="$(network raw list-zone-config-ids ${zone})"
+
+ local cmd="$(_network_find_on_cmdline "${commands}")"
+ if [[ -z "${cmd}" ]]; then
+ COMPREPLY=( $(compgen -W "${commands}" -- "${cur}") )
+ return 0
+ fi
+}
+
_network_zone_subcommand_port() {
local zone="${1}"
shift
--
2.6.3
next prev parent reply other threads:[~2017-07-24 19:10 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-07-24 19:10 [PATCH 1/4] zone: add new function zone_config_list_ids Jonatan Schlag
2017-07-24 19:10 ` [PATCH 2/4] network: add new raw command list-zone-config-ids Jonatan Schlag
2017-07-24 19:10 ` [PATCH 3/4] network: add new raw command zone-config-id-is-valid Jonatan Schlag
2017-07-24 19:10 ` Jonatan Schlag [this message]
2017-07-25 16:23 ` [PATCH 1/4] zone: add new function zone_config_list_ids Michael Tremer
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1500923405-17258-4-git-send-email-jonatan.schlag@ipfire.org \
--to=jonatan.schlag@ipfire.org \
--cc=network@lists.ipfire.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox