Files
binutils-gdb/gdb/testsuite/gdb.base/frame-view.py
Simon Marchi 0c830fc574 gdb/{testsuite,system-gdbinit}: import gdb module in Python scripts
Fix flake8 warnings like:

    gdb/system-gdbinit/wrs-linux.py:21:5: F821 undefined name 'gdb'

These scripts get executed in a context where the gdb module is already
loaded, so this is not strictly necessary.  However, adding these
imports removes a lot of red lines when editing these files in an IDE.
Without them, the code uses this `gdb` thing that appears to be
undefined.  Pylance is able to pull the module definition from typeshed
[1] and provide a good experience with typings.

[1] https://github.com/python/typeshed/tree/main/stubs/gdb/gdb

Change-Id: I09c6ae1866ef66f10d8270457771687343c84e32
Approved-By: Tom Tromey <tom@tromey.com>
2025-10-30 12:15:13 -04:00

43 lines
1.2 KiB
Python

# Copyright (C) 2022-2025 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/>.
import gdb
class Printer1:
def to_string(self):
n = gdb.parse_and_eval("called_from_pretty_printer ()")
assert n == 23
return "hahaha"
class Printer2:
def to_string(self):
n = gdb.parse_and_eval("called_from_pretty_printer ()")
assert n == 23
return "hohoho"
def lookup_function(val):
if str(val.type) == "struct type_1":
return Printer1()
if str(val.type) == "struct type_2":
return Printer2()
return None
gdb.pretty_printers.append(lookup_function)