gdb/
* linespec.c (decode_line_1): Handle FILE:FUNCTION even if FUNCTION contains parentheses. Improve removal of a trailing single quote. gdb/testsuite/ * gdb.base/list.exp (test_list_filename_and_function): Add test with single quotes. * gdb.cp/overload.cc (intToChar): Rewrite onto one line for easy matching. * gdb.cp/overload.exp: Add tests with filename, function, and quotes. Add KFAIL'd tests for PR gdb/11289.
This commit is contained in:
parent
14d1346bd3
commit
791dfb6488
6 changed files with 67 additions and 15 deletions
|
@ -1,3 +1,9 @@
|
||||||
|
2010-02-16 Daniel Jacobowitz <dan@codesourcery.com>
|
||||||
|
|
||||||
|
* linespec.c (decode_line_1): Handle FILE:FUNCTION even if
|
||||||
|
FUNCTION contains parentheses. Improve removal of a trailing
|
||||||
|
single quote.
|
||||||
|
|
||||||
2010-02-16 Daniel Jacobowitz <dan@codesourcery.com>
|
2010-02-16 Daniel Jacobowitz <dan@codesourcery.com>
|
||||||
|
|
||||||
* gcore.c (do_bfd_delete_cleanup): New function.
|
* gcore.c (do_bfd_delete_cleanup): New function.
|
||||||
|
|
|
@ -698,6 +698,8 @@ decode_line_1 (char **argptr, int funfirstline, struct symtab *default_symtab,
|
||||||
int is_quote_enclosed;
|
int is_quote_enclosed;
|
||||||
int is_objc_method = 0;
|
int is_objc_method = 0;
|
||||||
char *saved_arg = *argptr;
|
char *saved_arg = *argptr;
|
||||||
|
/* If IS_QUOTED, the end of the quoted bit. */
|
||||||
|
char *end_quote = NULL;
|
||||||
|
|
||||||
if (not_found_ptr)
|
if (not_found_ptr)
|
||||||
*not_found_ptr = 0;
|
*not_found_ptr = 0;
|
||||||
|
@ -717,6 +719,8 @@ decode_line_1 (char **argptr, int funfirstline, struct symtab *default_symtab,
|
||||||
*/
|
*/
|
||||||
|
|
||||||
set_flags (*argptr, &is_quoted, &paren_pointer);
|
set_flags (*argptr, &is_quoted, &paren_pointer);
|
||||||
|
if (is_quoted)
|
||||||
|
end_quote = skip_quoted (*argptr);
|
||||||
|
|
||||||
/* Check to see if it's a multipart linespec (with colons or
|
/* Check to see if it's a multipart linespec (with colons or
|
||||||
periods). */
|
periods). */
|
||||||
|
@ -747,13 +751,13 @@ decode_line_1 (char **argptr, int funfirstline, struct symtab *default_symtab,
|
||||||
return values;
|
return values;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (is_quoted)
|
||||||
|
*argptr = *argptr + 1;
|
||||||
|
|
||||||
/* Does it look like there actually were two parts? */
|
/* Does it look like there actually were two parts? */
|
||||||
|
|
||||||
if ((p[0] == ':' || p[0] == '.') && paren_pointer == NULL)
|
if (p[0] == ':' || p[0] == '.')
|
||||||
{
|
{
|
||||||
if (is_quoted)
|
|
||||||
*argptr = *argptr + 1;
|
|
||||||
|
|
||||||
/* Is it a C++ or Java compound data structure?
|
/* Is it a C++ or Java compound data structure?
|
||||||
The check on p[1] == ':' is capturing the case of "::",
|
The check on p[1] == ':' is capturing the case of "::",
|
||||||
since p[0]==':' was checked above.
|
since p[0]==':' was checked above.
|
||||||
|
@ -762,14 +766,30 @@ decode_line_1 (char **argptr, int funfirstline, struct symtab *default_symtab,
|
||||||
can return now. */
|
can return now. */
|
||||||
|
|
||||||
if (p[0] == '.' || p[1] == ':')
|
if (p[0] == '.' || p[1] == ':')
|
||||||
return decode_compound (argptr, funfirstline, canonical,
|
{
|
||||||
saved_arg, p, not_found_ptr);
|
if (paren_pointer == NULL)
|
||||||
|
return decode_compound (argptr, funfirstline, canonical,
|
||||||
|
saved_arg, p, not_found_ptr);
|
||||||
|
/* Otherwise, fall through to decode_variable below. */
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* No, the first part is a filename; set file_symtab to be that file's
|
||||||
|
symtab. Also, move argptr past the filename. */
|
||||||
|
|
||||||
/* No, the first part is a filename; set file_symtab to be that file's
|
file_symtab = symtab_from_filename (argptr, p, is_quote_enclosed,
|
||||||
symtab. Also, move argptr past the filename. */
|
not_found_ptr);
|
||||||
|
|
||||||
file_symtab = symtab_from_filename (argptr, p, is_quote_enclosed,
|
/* Check for single quotes on the non-filename part. */
|
||||||
not_found_ptr);
|
if (!is_quoted)
|
||||||
|
{
|
||||||
|
is_quoted = (**argptr
|
||||||
|
&& strchr (get_gdb_completer_quote_characters (),
|
||||||
|
**argptr) != NULL);
|
||||||
|
if (is_quoted)
|
||||||
|
end_quote = skip_quoted (*argptr);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#if 0
|
#if 0
|
||||||
/* No one really seems to know why this was added. It certainly
|
/* No one really seems to know why this was added. It certainly
|
||||||
|
@ -829,7 +849,7 @@ decode_line_1 (char **argptr, int funfirstline, struct symtab *default_symtab,
|
||||||
p = skip_quoted (*argptr + (((*argptr)[1] == '$') ? 2 : 1));
|
p = skip_quoted (*argptr + (((*argptr)[1] == '$') ? 2 : 1));
|
||||||
else if (is_quoted)
|
else if (is_quoted)
|
||||||
{
|
{
|
||||||
p = skip_quoted (*argptr);
|
p = end_quote;
|
||||||
if (p[-1] != '\'')
|
if (p[-1] != '\'')
|
||||||
error (_("Unmatched single quote."));
|
error (_("Unmatched single quote."));
|
||||||
}
|
}
|
||||||
|
@ -862,6 +882,8 @@ decode_line_1 (char **argptr, int funfirstline, struct symtab *default_symtab,
|
||||||
copy[p - *argptr - 1] = '\0';
|
copy[p - *argptr - 1] = '\0';
|
||||||
copy++;
|
copy++;
|
||||||
}
|
}
|
||||||
|
else if (is_quoted)
|
||||||
|
copy[p - *argptr - 1] = '\0';
|
||||||
while (*p == ' ' || *p == '\t')
|
while (*p == ' ' || *p == '\t')
|
||||||
p++;
|
p++;
|
||||||
*argptr = p;
|
*argptr = p;
|
||||||
|
|
|
@ -1,3 +1,12 @@
|
||||||
|
2010-02-16 Daniel Jacobowitz <dan@codesourcery.com>
|
||||||
|
|
||||||
|
* gdb.base/list.exp (test_list_filename_and_function): Add test
|
||||||
|
with single quotes.
|
||||||
|
* gdb.cp/overload.cc (intToChar): Rewrite onto one line for easy
|
||||||
|
matching.
|
||||||
|
* gdb.cp/overload.exp: Add tests with filename, function, and quotes.
|
||||||
|
Add KFAIL'd tests for PR gdb/11289.
|
||||||
|
|
||||||
2010-02-16 Daniel Jacobowitz <dan@codesourcery.com>
|
2010-02-16 Daniel Jacobowitz <dan@codesourcery.com>
|
||||||
|
|
||||||
* gdb.cp/cpcompletion.exp: Specify source file name explicitly.
|
* gdb.cp/cpcompletion.exp: Specify source file name explicitly.
|
||||||
|
|
|
@ -473,6 +473,9 @@ proc test_list_filename_and_function {} {
|
||||||
|
|
||||||
pass "list filename:function ($testcnt tests)"
|
pass "list filename:function ($testcnt tests)"
|
||||||
|
|
||||||
|
# Test with quoting.
|
||||||
|
gdb_test "list 'list0.c:main'" "int main.*"
|
||||||
|
|
||||||
# Test some invalid specs
|
# Test some invalid specs
|
||||||
# The following test takes the FIXME result on most systems using
|
# The following test takes the FIXME result on most systems using
|
||||||
# DWARF. It fails to notice that main() is not in the file requested.
|
# DWARF. It fails to notice that main() is not in the file requested.
|
||||||
|
|
|
@ -56,10 +56,7 @@ namespace N {
|
||||||
int nsoverload (int x, int y) { return x + y; }
|
int nsoverload (int x, int y) { return x + y; }
|
||||||
};
|
};
|
||||||
|
|
||||||
int intToChar (char c)
|
int intToChar (char c) { return 297; }
|
||||||
{
|
|
||||||
return 297;
|
|
||||||
}
|
|
||||||
|
|
||||||
void marker1()
|
void marker1()
|
||||||
{}
|
{}
|
||||||
|
|
|
@ -293,6 +293,21 @@ gdb_test "list \"foo::overloadfnarg(int, int (*)(int))\"" \
|
||||||
"int foo::overloadfnarg.*\\(int arg, int \\(\\*foo\\) \\(int\\)\\).*" \
|
"int foo::overloadfnarg.*\\(int arg, int \\(\\*foo\\) \\(int\\)\\).*" \
|
||||||
"list overloaded function with function ptr args - quotes around argument"
|
"list overloaded function with function ptr args - quotes around argument"
|
||||||
|
|
||||||
|
# Test list with filename.
|
||||||
|
|
||||||
|
gdb_test "list ${srcfile}:intToChar" "int intToChar.*"
|
||||||
|
gdb_test "list ${srcfile}:intToChar(char)" "int intToChar.*"
|
||||||
|
gdb_test "list ${srcfile}:'intToChar(char)'" "int intToChar.*"
|
||||||
|
gdb_test "list '${srcfile}:intToChar(char)'" "int intToChar.*"
|
||||||
|
|
||||||
|
# And with filename and namespace... which does not work.
|
||||||
|
|
||||||
|
setup_kfail *-*-* gdb/11289
|
||||||
|
gdb_test "list ${srcfile}:foo::overloadfnarg(int)" "int foo::overloadfnarg"
|
||||||
|
|
||||||
|
setup_kfail *-*-* gdb/11289
|
||||||
|
gdb_test "list ${srcfile}:'foo::overloadfnarg(int)'" "int foo::overloadfnarg"
|
||||||
|
|
||||||
# Now some tests to see how overloading and namespaces interact.
|
# Now some tests to see how overloading and namespaces interact.
|
||||||
|
|
||||||
gdb_test "print overloadNamespace(1)" ".\[0-9\]* = 1"
|
gdb_test "print overloadNamespace(1)" ".\[0-9\]* = 1"
|
||||||
|
|
Loading…
Reference in a new issue