]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blob - gdb/python/lib/gdb/__init__.py
[gdb/testsuite] Make gdb_test message more informative in multi-term-settings.exp
[thirdparty/binutils-gdb.git] / gdb / python / lib / gdb / __init__.py
1 # Copyright (C) 2010-2019 Free Software Foundation, Inc.
2
3 # This program is free software; you can redistribute it and/or modify
4 # it under the terms of the GNU General Public License as published by
5 # the Free Software Foundation; either version 3 of the License, or
6 # (at your option) any later version.
7 #
8 # This program is distributed in the hope that it will be useful,
9 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # GNU General Public License for more details.
12 #
13 # You should have received a copy of the GNU General Public License
14 # along with this program. If not, see <http://www.gnu.org/licenses/>.
15
16 import traceback
17 import os
18 import sys
19 import _gdb
20
21 if sys.version_info[0] > 2:
22 # Python 3 moved "reload"
23 from imp import reload
24
25 from _gdb import *
26
27 class _GdbFile (object):
28 # These two are needed in Python 3
29 encoding = "UTF-8"
30 errors = "strict"
31
32 def close(self):
33 # Do nothing.
34 return None
35
36 def isatty(self):
37 return False
38
39 def writelines(self, iterable):
40 for line in iterable:
41 self.write(line)
42
43 def flush(self):
44 flush()
45
46 class _GdbOutputFile (_GdbFile):
47 def write(self, s):
48 write(s, stream=STDOUT)
49
50 sys.stdout = _GdbOutputFile()
51
52 class _GdbOutputErrorFile (_GdbFile):
53 def write(self, s):
54 write(s, stream=STDERR)
55
56 sys.stderr = _GdbOutputErrorFile()
57
58 # Default prompt hook does nothing.
59 prompt_hook = None
60
61 # Ensure that sys.argv is set to something.
62 # We do not use PySys_SetArgvEx because it did not appear until 2.6.6.
63 sys.argv = ['']
64
65 # Initial pretty printers.
66 pretty_printers = []
67
68 # Initial type printers.
69 type_printers = []
70 # Initial xmethod matchers.
71 xmethods = []
72 # Initial frame filters.
73 frame_filters = {}
74 # Initial frame unwinders.
75 frame_unwinders = []
76
77 def _execute_unwinders(pending_frame):
78 """Internal function called from GDB to execute all unwinders.
79
80 Runs each currently enabled unwinder until it finds the one that
81 can unwind given frame.
82
83 Arguments:
84 pending_frame: gdb.PendingFrame instance.
85 Returns:
86 gdb.UnwindInfo instance or None.
87 """
88 for objfile in objfiles():
89 for unwinder in objfile.frame_unwinders:
90 if unwinder.enabled:
91 unwind_info = unwinder(pending_frame)
92 if unwind_info is not None:
93 return unwind_info
94
95 for unwinder in current_progspace().frame_unwinders:
96 if unwinder.enabled:
97 unwind_info = unwinder(pending_frame)
98 if unwind_info is not None:
99 return unwind_info
100
101 for unwinder in frame_unwinders:
102 if unwinder.enabled:
103 unwind_info = unwinder(pending_frame)
104 if unwind_info is not None:
105 return unwind_info
106
107 return None
108
109
110 # Convenience variable to GDB's python directory
111 PYTHONDIR = os.path.dirname(os.path.dirname(__file__))
112
113 # Auto-load all functions/commands.
114
115 # Packages to auto-load.
116
117 packages = [
118 'function',
119 'command',
120 'printer'
121 ]
122
123 # pkgutil.iter_modules is not available prior to Python 2.6. Instead,
124 # manually iterate the list, collating the Python files in each module
125 # path. Construct the module name, and import.
126
127 def _auto_load_packages():
128 for package in packages:
129 location = os.path.join(os.path.dirname(__file__), package)
130 if os.path.exists(location):
131 py_files = filter(lambda x: x.endswith('.py')
132 and x != '__init__.py',
133 os.listdir(location))
134
135 for py_file in py_files:
136 # Construct from foo.py, gdb.module.foo
137 modname = "%s.%s.%s" % ( __name__, package, py_file[:-3] )
138 try:
139 if modname in sys.modules:
140 # reload modules with duplicate names
141 reload(__import__(modname))
142 else:
143 __import__(modname)
144 except:
145 sys.stderr.write (traceback.format_exc() + "\n")
146
147 _auto_load_packages()
148
149 def GdbSetPythonDirectory(dir):
150 """Update sys.path, reload gdb and auto-load packages."""
151 global PYTHONDIR
152
153 try:
154 sys.path.remove(PYTHONDIR)
155 except ValueError:
156 pass
157 sys.path.insert(0, dir)
158
159 PYTHONDIR = dir
160
161 # note that reload overwrites the gdb module without deleting existing
162 # attributes
163 reload(__import__(__name__))
164 _auto_load_packages()
165
166 def current_progspace():
167 "Return the current Progspace."
168 return selected_inferior().progspace
169
170 def objfiles():
171 "Return a sequence of the current program space's objfiles."
172 return current_progspace().objfiles()
173
174 def solib_name (addr):
175 """solib_name (Long) -> String.\n\
176 Return the name of the shared library holding a given address, or None."""
177 return current_progspace().solib_name(addr)
178
179 def block_for_pc(pc):
180 "Return the block containing the given pc value, or None."
181 return current_progspace().block_for_pc(pc)
182
183 def find_pc_line(pc):
184 """find_pc_line (pc) -> Symtab_and_line.
185 Return the gdb.Symtab_and_line object corresponding to the pc value."""
186 return current_progspace().find_pc_line(pc)