PR 18303, Tolerate malformed input for lookup_symbol-called functions
authorDon Breazeal <donb@codesourcery.com>
Tue, 15 Mar 2016 22:18:28 +0000 (15:18 -0700)
committerDon Breazeal <donb@codesourcery.com>
Tue, 15 Mar 2016 22:25:15 +0000 (15:25 -0700)
commit1cafadb4e4eb329dea01355c6632b3077113d80c
tree2aa982ab01ff1f0649de210f67bdada496a42e0a
parent79427bd2f8edb59110f16a9c1652e3d6e41e08e7
PR 18303, Tolerate malformed input for lookup_symbol-called functions

lookup_symbol is often called with user input.  Consequently, any
function called from lookup_symbol{,_in_language} should attempt to
deal with malformed input gracefully.  After all, malformed user
input is not a programming/API error.

This patch does not attempt to find/correct all instances of this.  It
only fixes locations in the code that trigger test suite failures.

This patch fixes PR breakpoints/18303, "Assertion: -breakpoint-insert
with windows paths of file in non-current directory".

The patch includes three new tests related to this.  One is just
gdb.linespec/ls-errs.exp copied and converted to use C++ instead of C, and
to add a case using a file name containing a Windows-style logical drive
specifier.  The others include an MI test to provide a regression test for
the specific case reported in PR 18303, and a C++ test for proper error
handling of access to a program variable when using a file scope specifier
that refers to a non-existent file.

Tested on x86_64 native Linux.

gdb/ChangeLog
2016-01-28  Keith Seitz  <keiths@redhat.com>

PR breakpoints/18303
* cp-namespace.c (cp_lookup_bare_symbol): Change assertion to
look for "::" instead of simply ":".
(cp_search_static_and_baseclasses): Return null_block_symbol for
malformed input.
Remove assertions.
* cp-support.c (cp_find_first_component_aux): Do not return
a prefix length for ':' unless the next character is also ':'.

gdb/testsuite/ChangeLog
2016-01-28  Don Breazeal  <donb@codesourcery.com>

* gdb.cp/scope-err.cc: New test program.
* gdb.cp/scope-err.exp: New test script.
* gdb.linespec/ls-errs.c (myfunction): Expanded to have multiple
lines and "set breakpoint here" comment.
* gdb.linespec/ls-errs.exp: Added C++ testing and new test case.
Fixed some whitespace and format issues.
* gdb.mi/mi-linespec-err-cp.cc: New test program.
* gdb.mi/mi-linespec-err-cp.exp: New test script.
gdb/ChangeLog
gdb/cp-namespace.c
gdb/cp-support.c
gdb/testsuite/ChangeLog
gdb/testsuite/gdb.cp/scope-err.cc [new file with mode: 0644]
gdb/testsuite/gdb.cp/scope-err.exp [new file with mode: 0644]
gdb/testsuite/gdb.linespec/ls-errs.c
gdb/testsuite/gdb.linespec/ls-errs.exp
gdb/testsuite/gdb.mi/mi-linespec-err-cp.cc [new file with mode: 0644]
gdb/testsuite/gdb.mi/mi-linespec-err-cp.exp [new file with mode: 0644]