cec808ecec
* gdb.cp/cplusfuncs.cc (dm_type_short): New function. (dm_type_long): New function. (dm_type_unsigned_short): New function. (dm_type_unsigned_long): New function. (myint): New typedef. * gdb.cp/cplusfuncs.exp (probe_demangler): Add tests for short, long, unsigned shor and long, operator char*, and typedef. (test_lookup_operator_functions): Add operator char* test. (test_paddr_operator_functions): Likewise. (test_paddr_overloaded_functions): Use probe values for short, long, and unsigned short and long. (test_paddr_hairy_functions): If the demangler probe detected gdb type printers, "expect" them. Otherwise "expect" the v2 or v3 demangler. * gdb.cp/expand-sals.exp: Backtrace may contain class names. * gdb.cp/member-ptr.exp: Refine expected result for "print pmf" and "print null_pmf". Add test "ptype a.*pmf". * gdb.cp/overload.exp: Allow optional "int" to appear with "short" and "long". * gdb.cp/ovldbreak.exp: Use append to construct super-duper long expect value for men_overload1arg. Allow "int" to appear with "short" and "long". When testing "info break", add argument for main (void). Also allow "int" to appear with "short" and "long". Ditto with "unsigned" and "long long". * gdb.java/jmain.exp: Do not enclose methods names in single quotes. * gdb.java/jmisc.exp: Likewise. * gdb.java/jprint.exp: Likewise. * gdb.python/py-symbol.exp: Update expected "linkage_name" value. From Jan Kratochvil <jan.kratochvil@redhat.com>: * gdb.cp/exception.exp (backtrace after first throw) (backtrace after second throw): Allow a namespace before __cxa_throw. (backtrace after first catch, backtrace after second catch): Allow a namespace before __cxa_begin_catch. * gdb.cp/cpexprs.exp: New file. * gdb.cp/cpexprs.cc: New file. From Daniel Jacobowitz <dan@codesourcery.com> * gdb.cp/cpexprs.exp (escape): Delete. Change all callers to use string_to_regexp. (ctor, dtor): New functions. Use them to match constructor and destructor function types. (Top level): Use runto_main.
132 lines
5.5 KiB
Text
132 lines
5.5 KiB
Text
# Copyright (C) 2010 Free Software Foundation, Inc.
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
# This file is part of the GDB testsuite. It tests the mechanism
|
|
# exposing values to Python.
|
|
|
|
if $tracelevel then {
|
|
strace $tracelevel
|
|
}
|
|
|
|
set testfile "py-symbol"
|
|
set srcfile ${testfile}.c
|
|
set binfile ${objdir}/${subdir}/${testfile}
|
|
if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug}] != "" } {
|
|
untested "Couldn't compile ${srcfile}"
|
|
return -1
|
|
}
|
|
|
|
# Run a command in GDB, and report a failure if a Python exception is thrown.
|
|
# If report_pass is true, report a pass if no exception is thrown.
|
|
proc gdb_py_test_silent_cmd {cmd name report_pass} {
|
|
global gdb_prompt
|
|
|
|
gdb_test_multiple $cmd $name {
|
|
-re "Traceback.*$gdb_prompt $" { fail $name }
|
|
-re "$gdb_prompt $" { if $report_pass { pass $name } }
|
|
}
|
|
}
|
|
|
|
# Start with a fresh gdb.
|
|
gdb_exit
|
|
gdb_start
|
|
gdb_reinitialize_dir $srcdir/$subdir
|
|
gdb_load ${binfile}
|
|
|
|
# Skip all tests if Python scripting is not enabled.
|
|
if { [skip_python_tests] } { continue }
|
|
|
|
if ![runto_main] then {
|
|
fail "Can't run to main"
|
|
return 0
|
|
}
|
|
|
|
global hex decimal
|
|
|
|
gdb_breakpoint [gdb_get_line_number "Block break here."]
|
|
gdb_continue_to_breakpoint "Block break here."
|
|
gdb_py_test_silent_cmd "python frame = gdb.selected_frame()" "Get Frame" 0
|
|
gdb_py_test_silent_cmd "python block = frame.block()" "Get block" 0
|
|
|
|
# Test is_argument attribute.
|
|
gdb_py_test_silent_cmd "python arg = gdb.lookup_symbol(\"arg\")" "Get variable a" 0
|
|
gdb_test "python print arg\[0\].is_variable" "False" "Test arg.is_variable"
|
|
gdb_test "python print arg\[0\].is_constant" "False" "Test arg.is_constant"
|
|
gdb_test "python print arg\[0\].is_argument" "True" "Test arg.is_argument"
|
|
gdb_test "python print arg\[0\].is_function" "False" "Test arg.is_function"
|
|
|
|
# Test is_function attribute.
|
|
gdb_py_test_silent_cmd "python func = frame.block().function" "Get block" 0
|
|
gdb_test "python print func.is_variable" "False" "Test func.is_variable"
|
|
gdb_test "python print func.is_constant" "False" "Test func.is_constant"
|
|
gdb_test "python print func.is_argument" "False" "Test func.is_argument"
|
|
gdb_test "python print func.is_function" "True" "Test func.is_function"
|
|
gdb_test "python print func.name" "func" "Test func.name"
|
|
gdb_test "python print func.print_name" "func" "Test func.print_name"
|
|
gdb_test "python print func.linkage_name" "func" "Test func.linkage_name"
|
|
gdb_test "python print func.addr_class == gdb.SYMBOL_LOC_BLOCK" "True" "Test func.addr_class"
|
|
|
|
gdb_breakpoint [gdb_get_line_number "Break at end."]
|
|
gdb_continue_to_breakpoint "Break at end."
|
|
gdb_py_test_silent_cmd "python frame = gdb.selected_frame()" "Get Frame" 0
|
|
|
|
# Test is_variable attribute.
|
|
gdb_py_test_silent_cmd "python a = gdb.lookup_symbol(\'a\')" "Get variable a" 0
|
|
gdb_test "python print a\[0\].is_variable" "True" "Test a.is_variable"
|
|
gdb_test "python print a\[0\].is_constant" "False" "Test a.is_constant"
|
|
gdb_test "python print a\[0\].is_argument" "False" "Test a.is_argument"
|
|
gdb_test "python print a\[0\].is_function" "False" "Test a.is_function"
|
|
gdb_test "python print a\[0\].addr_class == gdb.SYMBOL_LOC_COMPUTED" "True" "Test a.addr_class"
|
|
|
|
# Test is_constant attribute
|
|
gdb_py_test_silent_cmd "python t = gdb.lookup_symbol(\"one\")" "Get variable a" 0
|
|
gdb_test "python print t\[0\].is_variable" "False" "Test t.is_variable"
|
|
gdb_test "python print t\[0\].is_constant" "True" "Test t.is_constant"
|
|
gdb_test "python print t\[0\].is_argument" "False" "Test t.is_argument"
|
|
gdb_test "python print t\[0\].is_function" "False" "Test t.is_function"
|
|
gdb_test "python print t\[0\].addr_class == gdb.SYMBOL_LOC_CONST" "True" "Test t.addr_class"
|
|
gdb_test "python print t\[0\].symtab" "gdb.python/py-symbol.c.*" "Get symtab"
|
|
|
|
# C++ tests
|
|
# Recompile binary.
|
|
if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable "debug c++"] != "" } {
|
|
untested "Couldn't compile ${srcfile} in c++ mode"
|
|
return -1
|
|
}
|
|
|
|
# Start with a fresh gdb.
|
|
gdb_exit
|
|
gdb_start
|
|
gdb_reinitialize_dir $srcdir/$subdir
|
|
gdb_load ${binfile}
|
|
|
|
if ![runto_main] then {
|
|
fail "Can't run to main"
|
|
return 0
|
|
}
|
|
|
|
gdb_breakpoint [gdb_get_line_number "Break in class."]
|
|
gdb_continue_to_breakpoint "Break in class."
|
|
|
|
gdb_py_test_silent_cmd "python cplusframe = gdb.selected_frame()" "Get Frame" 0
|
|
gdb_py_test_silent_cmd "python cplusfunc = cplusframe.block().function" "Get block" 0
|
|
gdb_test "python print cplusfunc.is_variable" "False" "Test func.is_variable"
|
|
gdb_test "python print cplusfunc.is_constant" "False" "Test func.is_constant"
|
|
gdb_test "python print cplusfunc.is_argument" "False" "Test func.is_argument"
|
|
gdb_test "python print cplusfunc.is_function" "True" "Test func.is_function"
|
|
gdb_test "python print cplusfunc.name" "SimpleClass::valueofi().*" "Test func.name"
|
|
gdb_test "python print cplusfunc.print_name" "SimpleClass::valueofi().*" "Test func.print_name"
|
|
gdb_test "python print cplusfunc.linkage_name" "SimpleClass::valueofi().*" "Test func.linkage_name"
|
|
gdb_test "python print cplusfunc.addr_class == gdb.SYMBOL_LOC_BLOCK" "True" "Test func.addr_class"
|