diff options
| author | Hani Benhabiles | 2014-05-08 00:41:30 +0200 |
|---|---|---|
| committer | Luiz Capitulino | 2014-05-15 21:16:02 +0200 |
| commit | 40d19394b792fb80dba2f536fc13b5b604780a4d (patch) | |
| tree | 4b629b65764b2cb54b52656f00f26cd43da0c244 /monitor.c | |
| parent | monitor: Add chardev-add backend argument completion. (diff) | |
| download | qemu-40d19394b792fb80dba2f536fc13b5b604780a4d.tar.gz qemu-40d19394b792fb80dba2f536fc13b5b604780a4d.tar.xz qemu-40d19394b792fb80dba2f536fc13b5b604780a4d.zip | |
monitor: Add set_link arguments completion.
Make it possible to query all net clients without specifying an ID when calling
qemu_find_net_clients_except().
This also adds the add_completion_option() function which is to be used for
other commands completions as well.
Signed-off-by: Hani Benhabiles <hani@linux.com>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com>
Diffstat (limited to 'monitor.c')
| -rw-r--r-- | monitor.c | 34 |
1 files changed, 34 insertions, 0 deletions
@@ -4269,6 +4269,17 @@ static const char *next_arg_type(const char *typestr) return (p != NULL ? ++p : typestr); } +static void add_completion_option(ReadLineState *rs, const char *str, + const char *option) +{ + if (!str || !option) { + return; + } + if (!strncmp(option, str, strlen(str))) { + readline_add_completion(rs, option); + } +} + void chardev_add_completion(ReadLineState *rs, int nb_args, const char *str) { size_t len; @@ -4444,6 +4455,29 @@ void sendkey_completion(ReadLineState *rs, int nb_args, const char *str) } } +void set_link_completion(ReadLineState *rs, int nb_args, const char *str) +{ + size_t len; + + len = strlen(str); + readline_set_completion_index(rs, len); + if (nb_args == 2) { + NetClientState *ncs[255]; + int count, i; + count = qemu_find_net_clients_except(NULL, ncs, + NET_CLIENT_OPTIONS_KIND_NONE, 255); + for (i = 0; i < count; i++) { + const char *name = ncs[i]->name; + if (!strncmp(str, name, len)) { + readline_add_completion(rs, name); + } + } + } else if (nb_args == 3) { + add_completion_option(rs, str, "on"); + add_completion_option(rs, str, "off"); + } +} + static void monitor_find_completion_by_table(Monitor *mon, const mon_cmd_t *cmd_table, char **args, |
