mirror of
https://github.com/bminor/binutils-gdb.git
synced 2025-12-26 17:18:55 +00:00
Fix latent bug with custom word point completers
Completion routines that use a custom word point, and that then recurse into complete_line (e.g., if we make "thread apply" a custom word point completer, and complete on the command passed as argument), we stumble on this latent bug: (gdb) thread apply all pri[TAB] (gdb) thread apply all priprint The problem is that there's a spot in complete_line_internal_1 that rewinds the completion word but does not reflect that change in the custom word point in the tracker. This patch fixes it. gdb/ChangeLog: 2019-06-13 Pedro Alves <palves@redhat.com> * completer.c (complete_line_internal_1): Rewind completion word point. (completion_tracker::advance_custom_word_point_by): Change parameter type to int. * completer.h (completion_tracker::advance_custom_word_point_by): Likewise.
This commit is contained in:
@@ -1,3 +1,12 @@
|
||||
2019-06-13 Pedro Alves <palves@redhat.com>
|
||||
|
||||
* completer.c (complete_line_internal_1): Rewind completion word
|
||||
point.
|
||||
(completion_tracker::advance_custom_word_point_by): Change
|
||||
parameter type to int.
|
||||
* completer.h (completion_tracker::advance_custom_word_point_by):
|
||||
Likewise.
|
||||
|
||||
2019-06-13 Pedro Alves <palves@redhat.com>
|
||||
|
||||
* completer.c (advance_to_completion_word): Handle delimiters.
|
||||
|
||||
@@ -1403,6 +1403,9 @@ complete_line_internal_1 (completion_tracker &tracker,
|
||||
break;
|
||||
}
|
||||
|
||||
/* Move the custom word point back too. */
|
||||
tracker.advance_custom_word_point_by (q - p);
|
||||
|
||||
if (reason != handle_brkchars)
|
||||
complete_on_cmdlist (result_list, tracker, q, word,
|
||||
ignore_help_classes);
|
||||
@@ -1972,7 +1975,7 @@ completion_tracker::recompute_lowest_common_denominator
|
||||
/* See completer.h. */
|
||||
|
||||
void
|
||||
completion_tracker::advance_custom_word_point_by (size_t len)
|
||||
completion_tracker::advance_custom_word_point_by (int len)
|
||||
{
|
||||
m_custom_word_point += len;
|
||||
}
|
||||
|
||||
@@ -357,7 +357,7 @@ public:
|
||||
{ m_custom_word_point = point; }
|
||||
|
||||
/* Advance the custom word point by LEN. */
|
||||
void advance_custom_word_point_by (size_t len);
|
||||
void advance_custom_word_point_by (int len);
|
||||
|
||||
/* Whether to tell readline to skip appending a whitespace after the
|
||||
completion. See m_suppress_append_ws. */
|
||||
|
||||
Reference in New Issue
Block a user