aboutsummaryrefslogtreecommitdiff
path: root/gdb/completer.c
diff options
context:
space:
mode:
authorPedro Alves <palves@redhat.com>2017-11-25 00:20:31 +0000
committerPedro Alves <palves@redhat.com>2017-11-25 00:20:31 +0000
commita81aaca0578ee91ce1cee56c0a31e26c2a5ef581 (patch)
tree798c788bd50a995f352ed34b91e10cf7dbd1883d /gdb/completer.c
parent6a3c6ee41898743234d8fd9f9cab15f2ecdaba49 (diff)
downloadgdb-a81aaca0578ee91ce1cee56c0a31e26c2a5ef581.zip
gdb-a81aaca0578ee91ce1cee56c0a31e26c2a5ef581.tar.gz
gdb-a81aaca0578ee91ce1cee56c0a31e26c2a5ef581.tar.bz2
Fix completing an empty string
Earlier while working on the big completer rework series, I managed to break (gdb) [TAB] locally, and make GDB crash, but only notice a few weeks down the road, because we have no test for that... I also noticed that: (gdb) [TAB] didn't work (didn't show all commands as matches), even though entering a command with leading whitespace works: (gdb) help This commit fixes the latter and adds a testcase that covers both issues. The gdb.base/completion.exp change is necessary because the new test has a file name that also starts with "gdb.base/complet", making that particular test ambiguous. Adding another letter disambiguates. gdb/ChangeLog: 2017-11-25 Pedro Alves <palves@redhat.com> * completer.c (complete_line_internal_1): Skip spaces until the start of the command. gdb/testsuite/ChangeLog: 2017-11-25 Pedro Alves <palves@redhat.com> * gdb.base/complete-empty.exp: New file. * gdb.base/completion.exp: Adjust.
Diffstat (limited to 'gdb/completer.c')
-rw-r--r--gdb/completer.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/gdb/completer.c b/gdb/completer.c
index 68e9171..f9ece59 100644
--- a/gdb/completer.c
+++ b/gdb/completer.c
@@ -1270,10 +1270,13 @@ complete_line_internal_1 (completion_tracker &tracker,
word = tmp_command + point - strlen (text);
}
- if (point == 0)
+ /* Move P up to the start of the command. */
+ p = skip_spaces (p);
+
+ if (*p == '\0')
{
- /* An empty line we want to consider ambiguous; that is, it
- could be any command. */
+ /* An empty line is ambiguous; that is, it could be any
+ command. */
c = CMD_LIST_AMBIGUOUS;
result_list = 0;
}