tools: Pass opaque data in vshCompleter and introduce autoCompleteOpaque

This patch changes the signature of vshCompleters, allowing to pass along
some data that we might want to along with the completers; for example,
we might want to pass the autocomplete vshControl along with the
completer, in case the completer requires a connection to libvirtd.

Signed-off-by: Nishith Shah <nishithshah.2211@gmail.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
Nishith Shah 2016-09-06 12:04:37 +00:00 committed by Michal Privoznik
parent f8435a434a
commit cbbaa17faf
2 changed files with 11 additions and 2 deletions

View File

@ -64,6 +64,11 @@
# define SA_SIGINFO 0 # define SA_SIGINFO 0
#endif #endif
#ifdef WITH_READLINE
/* For autocompletion */
void *autoCompleteOpaque;
#endif
/* NOTE: It would be much nicer to have these two as part of vshControl /* NOTE: It would be much nicer to have these two as part of vshControl
* structure, unfortunately readline doesn't support passing opaque data * structure, unfortunately readline doesn't support passing opaque data
* and only relies on static data accessible from the user-side callback * and only relies on static data accessible from the user-side callback
@ -2808,7 +2813,8 @@ vshReadlineParse(const char *text, int state)
res = vshReadlineOptionsGenerator(sanitized_text, state, cmd); res = vshReadlineOptionsGenerator(sanitized_text, state, cmd);
} else if (non_bool_opt_exists && data_complete && opt->completer) { } else if (non_bool_opt_exists && data_complete && opt->completer) {
if (!completed_list) if (!completed_list)
completed_list = opt->completer(opt->completer_flags); completed_list = opt->completer(autoCompleteOpaque,
opt->completer_flags);
if (completed_list) { if (completed_list) {
while ((completed_name = completed_list[completed_list_index])) { while ((completed_name = completed_list[completed_list_index])) {
completed_list_index++; completed_list_index++;
@ -2858,6 +2864,9 @@ vshReadlineInit(vshControl *ctl)
char *histsize_env = NULL; char *histsize_env = NULL;
const char *histsize_str = NULL; const char *histsize_str = NULL;
/* Opaque data for autocomplete callbacks. */
autoCompleteOpaque = ctl;
/* Allow conditional parsing of the ~/.inputrc file. /* Allow conditional parsing of the ~/.inputrc file.
* Work around ancient readline 4.1 (hello Mac OS X), * Work around ancient readline 4.1 (hello Mac OS X),
* which declared it as 'char *' instead of 'const char *'. * which declared it as 'char *' instead of 'const char *'.

View File

@ -123,7 +123,7 @@ typedef struct _vshCmdOpt vshCmdOpt;
typedef struct _vshCmdOptDef vshCmdOptDef; typedef struct _vshCmdOptDef vshCmdOptDef;
typedef struct _vshControl vshControl; typedef struct _vshControl vshControl;
typedef char **(*vshCompleter)(unsigned int flags); typedef char **(*vshCompleter)(void *opaque, unsigned int flags);
/* /*
* vshCmdInfo -- name/value pair for information about command * vshCmdInfo -- name/value pair for information about command