mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-12 12:16:04 +08:00
5f5dfff63f
The lambda function used to sort the enumerator list does not work properly. This list consists of tuples, (enum label, enum value). The key function returns x.enumval. enumval not being defined for a tuple, we see this exception in the test log: Python Exception <class 'AttributeError'> 'tuple' object has no attribute 'enumval' The function should return the second item of the tuple, which is the enumval. The pretty-printer still worked mostly correctly, except that the enumeration values were not sorted. The test still passed because the enumeration values are already sorted where they are defined. The test also passed despite the exception being printed, because the right output was printed after the exception: print (enum flag_enum) (FLAG_1) Python Exception <type 'exceptions.AttributeError'> 'tuple' objecthas no attribute 'enumval':M $7 = 0x1 [FLAG_1] (gdb) PASS: gdb.python/py-pp-maint.exp: print FLAG_1 New in v2: - Improved test case, I stole Pedro's example directly. It verifies that the sorting of enumerators by value works, by checking that printing FOO_MASK appears as FOO_1 | FOO_2 | FOO_3. I noticed that I could change the regexps to almost anything and the tests would still pass. I think it was because of the | in there. I made them more robust by using string_to_regexp. I used curly braces { } instead of quoting marks " " for strings, so that I could use square brackets [ ] in them without having to escape them all. I also removed the "message" part of the tests, since they are redundant with the command, and it's just more maintenance to have to update them. Tested with Python 2.7 and 3.5. gdb/ChangeLog: * python/lib/gdb/printing.py (FlagEnumerationPrinter.__call__): Fix enumerators sort key function. gdb/testsuite/ChangeLog: * gdb.python/py-pp-maint.exp: Change/add enum flag tests. * gdb.python/py-pp-maint.c (enum flag_enum): Use more complex enum flag values.
142 lines
4.5 KiB
Plaintext
142 lines
4.5 KiB
Plaintext
# Copyright (C) 2010-2016 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 Python-based
|
|
# pretty-printing for the CLI.
|
|
|
|
if [is_remote host] {
|
|
untested "py-pp-maint.exp can only be run locally"
|
|
return -1
|
|
}
|
|
|
|
load_lib gdb-python.exp
|
|
|
|
standard_testfile
|
|
|
|
if {[prepare_for_testing $testfile.exp $testfile $srcfile debug]} {
|
|
return -1
|
|
}
|
|
|
|
# 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 -1
|
|
}
|
|
|
|
gdb_test "b [gdb_get_line_number {break to inspect} ${testfile}.c ]" \
|
|
".*Breakpoint.*"
|
|
gdb_test "continue" ".*Breakpoint.*"
|
|
|
|
set python_file ${srcdir}/${subdir}/${testfile}.py
|
|
|
|
gdb_test_no_output "python exec (open ('${python_file}').read ())" ""
|
|
|
|
gdb_test "info pretty-printer" \
|
|
{.*function_lookup_test.*pp-test.*struct ss.*}
|
|
|
|
gdb_test "info pretty-printer global .*function" \
|
|
{.*function_lookup_test.*}
|
|
|
|
gdb_test "info pretty-printer .* pp-test" \
|
|
{.*pp-test.*struct ss.*}
|
|
|
|
gdb_test "print flt" " = x=<42> y=<43>" \
|
|
"print flt enabled #1"
|
|
|
|
gdb_test "print ss" " = a=<a=<1> b=<$hex>> b=<a=<2> b=<$hex>>" \
|
|
"print ss enabled #1"
|
|
|
|
set num_pp 7
|
|
|
|
gdb_test "disable pretty-printer" \
|
|
"$num_pp printers disabled.*0 of $num_pp printers enabled"
|
|
|
|
gdb_test "enable pretty-printer" \
|
|
"$num_pp printers enabled.*$num_pp of $num_pp printers enabled"
|
|
|
|
gdb_test "disable pretty-printer global" \
|
|
"$num_pp printers disabled.*0 of $num_pp printers enabled"
|
|
|
|
gdb_test "enable pretty-printer" \
|
|
"$num_pp printers enabled.*$num_pp of $num_pp printers enabled"
|
|
|
|
gdb_test "disable pretty-printer global lookup_function_lookup_test" \
|
|
"1 printer disabled.*[expr $num_pp - 1] of $num_pp printers enabled"
|
|
|
|
gdb_test "disable pretty-printer global pp-test;.*" \
|
|
"[expr $num_pp - 2] printers disabled.*1 of $num_pp printers enabled"
|
|
|
|
gdb_test "info pretty-printer global .*function" \
|
|
{.*function_lookup_test \[disabled\].*}
|
|
|
|
gdb_test "info pretty-printer .* pp-test" \
|
|
{.*pp-test.*struct ss \[disabled\].*}
|
|
|
|
gdb_test "print flt" " = {x = 42, y = 43}" \
|
|
"print flt disabled"
|
|
|
|
gdb_test "print ss" " = {a = {a = 1, b = $hex}, b = {a = 2, b = $hex}}" \
|
|
"print ss disabled"
|
|
|
|
gdb_test "enable pretty-printer global lookup_function_lookup_test" \
|
|
"1 printer enabled.*2 of $num_pp printers enabled"
|
|
|
|
# This doesn't enable any printers because each subprinter in the collection
|
|
# is still individually disabled. But this is still needed, to enable the
|
|
# collection itself.
|
|
gdb_test "enable pretty-printer global pp-test" \
|
|
"0 printers enabled.*2 of $num_pp printers enabled"
|
|
|
|
gdb_test "enable pretty-printer global pp-test;.*ss.*" \
|
|
"2 printers enabled.*[expr $num_pp - 3] of $num_pp printers enabled"
|
|
|
|
gdb_test "enable pretty-printer global pp-test;.*s.*" \
|
|
"2 printers enabled.*[expr $num_pp - 1] of $num_pp printers enabled"
|
|
|
|
gdb_test "enable pretty-printer global pp-test;.*" \
|
|
"1 printer enabled.*$num_pp of $num_pp printers enabled"
|
|
|
|
gdb_test "info pretty-printer" \
|
|
{.*function_lookup_test.*pp-test.*struct ss.*}
|
|
|
|
gdb_test "print flt" " = x=<42> y=<43>" \
|
|
"print flt re-enabled"
|
|
|
|
gdb_test "print ss" " = a=<a=<1> b=<$hex>> b=<a=<2> b=<$hex>>" \
|
|
"print ss re-enabled"
|
|
|
|
gdb_test_exact "print (enum flag_enum) (FOO_1)" \
|
|
{ = 0x1 [FOO_1]}
|
|
|
|
gdb_test_exact "print (enum flag_enum) (BAR_3)" \
|
|
{ = 0x40 [BAR_3]}
|
|
|
|
gdb_test_exact "print (enum flag_enum) (BAR_2 | FOO_2)" \
|
|
{ = 0x22 [FOO_2 | BAR_2]}
|
|
|
|
gdb_test_exact "print (enum flag_enum) (FOO_1 | FOO_2 | FOO_3)" \
|
|
{ = 0x7 [FOO_1 | FOO_2 | FOO_3]}
|
|
|
|
gdb_test_exact "print (enum flag_enum) (FOO_MASK)" \
|
|
{ = 0x7 [FOO_1 | FOO_2 | FOO_3]}
|
|
|
|
gdb_test_exact "print (enum flag_enum) (FOO_MASK | (BAR_MASK & ~BAR_2))" \
|
|
{ = 0x57 [FOO_1 | FOO_2 | FOO_3 | BAR_1 | BAR_3]}
|
|
|
|
gdb_test_exact "print (enum flag_enum) (0x4 + 0x8)" \
|
|
{ = 0xc [FOO_3 | <unknown: 0x8>]}
|