Clean up "completer_handle_brkchars" callback handling
This patch cleans up "completer_handle_brkchars" callback handling: - Renames the function typedef to better match its intent: completer_ftype_void -> completer_handle_brkchars_ftype - Factors out common code in complete_line_internal handling the "handle_brkchars" callback to a separate function. - Centralizes all the "completer method" to "handle_brkchars method" mapping in a single function. gdb/ChangeLog: 2017-07-17 Pedro Alves <palves@redhat.com> * cli/cli-decode.c (set_cmd_completer_handle_brkchars): Adjust to renames. * cli/cli-decode.h (struct cmd_list_element) <completer>: Move comments to completer_ftype's declaration. <completer_handle_brkchars>: Change type to completer_handle_brkchars_ftype. * command.h (completer_ftype): Add describing comment and give names to parameters. (completer_ftype_void): Rename to ... (completer_handle_brkchars_ftype) ... this. Add describing comment. (set_cmd_completer_handle_brkchars): Adjust. * completer.c (filename_completer_handle_brkchars): New function. (complete_line_internal_normal_command): New function, factored out from ... (complete_line_internal): ... here. (command_completer_handle_brkchars) (default_completer_handle_brkchars) (completer_handle_brkchars_func_for_completer): New functions. * completer.h (set_gdb_completion_word_break_characters): Delete declaration. (completer_handle_brkchars_func_for_completer): New declaration. * python/py-cmd.c (cmdpy_completer_handle_brkchars): Adjust to use completer_handle_brkchars_func_for_completer.
This commit is contained in:
parent
78b13106ed
commit
6e1dbf8cda
7 changed files with 154 additions and 69 deletions
|
@ -174,18 +174,28 @@ typedef void cmd_sfunc_ftype (char *args, int from_tty,
|
|||
extern void set_cmd_sfunc (struct cmd_list_element *cmd,
|
||||
cmd_sfunc_ftype *sfunc);
|
||||
|
||||
typedef VEC (char_ptr) *completer_ftype (struct cmd_list_element *,
|
||||
const char *, const char *);
|
||||
/* A completion routine. Return a list of possible completions.
|
||||
|
||||
typedef void completer_ftype_void (struct cmd_list_element *,
|
||||
const char *, const char *);
|
||||
TEXT is the text beyond what was matched for the command itself
|
||||
(leading whitespace is skipped). It stops where we are supposed to
|
||||
stop completing (rl_point) and is '\0' terminated. WORD points in
|
||||
the same buffer as TEXT, and completions should be returned
|
||||
relative to this position. For example, suppose TEXT is "foo" and
|
||||
we want to complete to "foobar". If WORD is "oo", return "oobar";
|
||||
if WORD is "baz/foo", return "baz/foobar". */
|
||||
typedef VEC (char_ptr) *completer_ftype (struct cmd_list_element *,
|
||||
const char *text, const char *word);
|
||||
|
||||
/* Same, but for set_cmd_completer_handle_brkchars. */
|
||||
typedef void completer_handle_brkchars_ftype (struct cmd_list_element *,
|
||||
const char *text, const char *word);
|
||||
|
||||
extern void set_cmd_completer (struct cmd_list_element *, completer_ftype *);
|
||||
|
||||
/* Set the completer_handle_brkchars callback. */
|
||||
|
||||
extern void set_cmd_completer_handle_brkchars (struct cmd_list_element *,
|
||||
completer_ftype_void *);
|
||||
completer_handle_brkchars_ftype *);
|
||||
|
||||
/* HACK: cagney/2002-02-23: Code, mostly in tracepoints.c, grubs
|
||||
around in cmd objects to test the value of the commands sfunc(). */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue