]>
Commit | Line | Data |
---|---|---|
d57a3c85 TJB |
1 | /* Gdb/Python header for private use by Python module. |
2 | ||
d01e8234 | 3 | Copyright (C) 2008-2025 Free Software Foundation, Inc. |
d57a3c85 TJB |
4 | |
5 | This file is part of GDB. | |
6 | ||
7 | This program is free software; you can redistribute it and/or modify | |
8 | it under the terms of the GNU General Public License as published by | |
9 | the Free Software Foundation; either version 3 of the License, or | |
10 | (at your option) any later version. | |
11 | ||
12 | This program is distributed in the hope that it will be useful, | |
13 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
15 | GNU General Public License for more details. | |
16 | ||
17 | You should have received a copy of the GNU General Public License | |
18 | along with this program. If not, see <http://www.gnu.org/licenses/>. */ | |
19 | ||
cc709640 TT |
20 | #ifndef GDB_PYTHON_PYTHON_INTERNAL_H |
21 | #define GDB_PYTHON_PYTHON_INTERNAL_H | |
d57a3c85 | 22 | |
6dddc817 | 23 | #include "extension.h" |
e992c591 | 24 | #include "extension-priv.h" |
a6918531 | 25 | #include "registry.h" |
6dddc817 | 26 | |
62eec1a5 TT |
27 | /* These WITH_* macros are defined by the CPython API checker that |
28 | comes with the Python plugin for GCC. See: | |
29 | https://gcc-python-plugin.readthedocs.org/en/latest/cpychecker.html | |
30 | The checker defines a WITH_ macro for each attribute it | |
94c8b725 TT |
31 | exposes. Note that we intentionally do not use |
32 | 'cpychecker_returns_borrowed_ref' -- that idiom is forbidden in | |
33 | gdb. */ | |
634c58be | 34 | |
62eec1a5 TT |
35 | #ifdef WITH_CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF_ATTRIBUTE |
36 | #define CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF(ARG) \ | |
37 | __attribute__ ((cpychecker_type_object_for_typedef (ARG))) | |
38 | #else | |
39 | #define CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF(ARG) | |
40 | #endif | |
41 | ||
56cc411c TT |
42 | #ifdef WITH_CPYCHECKER_SETS_EXCEPTION_ATTRIBUTE |
43 | #define CPYCHECKER_SETS_EXCEPTION __attribute__ ((cpychecker_sets_exception)) | |
44 | #else | |
45 | #define CPYCHECKER_SETS_EXCEPTION | |
46 | #endif | |
47 | ||
5d153bd1 TT |
48 | #ifdef WITH_CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION_ATTRIBUTE |
49 | #define CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION \ | |
50 | __attribute__ ((cpychecker_negative_result_sets_exception)) | |
51 | #else | |
52 | #define CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION | |
53 | #endif | |
54 | ||
d57a3c85 TJB |
55 | /* /usr/include/features.h on linux systems will define _POSIX_C_SOURCE |
56 | if it sees _GNU_SOURCE (which config.h will define). | |
57 | pyconfig.h defines _POSIX_C_SOURCE to a different value than | |
58 | /usr/include/features.h does causing compilation to fail. | |
aac63f0f JB |
59 | To work around this, undef _POSIX_C_SOURCE before we include Python.h. |
60 | ||
61 | Same problem with _XOPEN_SOURCE. */ | |
d57a3c85 | 62 | #undef _POSIX_C_SOURCE |
aac63f0f | 63 | #undef _XOPEN_SOURCE |
d57a3c85 | 64 | |
aed1781d JB |
65 | /* On sparc-solaris, /usr/include/sys/feature_tests.h defines |
66 | _FILE_OFFSET_BITS, which pyconfig.h also defines. Same work | |
284a3db3 | 67 | around technique as above. */ |
aed1781d JB |
68 | #undef _FILE_OFFSET_BITS |
69 | ||
1cdd3232 EZ |
70 | /* A kludge to avoid redefinition of snprintf on Windows by pyerrors.h. */ |
71 | #if defined(_WIN32) && defined(HAVE_DECL_SNPRINTF) | |
72 | #define HAVE_SNPRINTF 1 | |
73 | #endif | |
74 | ||
b2a426e2 EZ |
75 | /* Another kludge to avoid compilation errors because MinGW defines |
76 | 'hypot' to '_hypot', but the C++ headers says "using ::hypot". */ | |
77 | #ifdef __MINGW32__ | |
78 | # define _hypot hypot | |
79 | #endif | |
80 | ||
1c033f8c TT |
81 | /* Request clean size types from Python. */ |
82 | #define PY_SSIZE_T_CLEAN | |
83 | ||
ac534cba JB |
84 | /* Include the Python header files using angle brackets rather than |
85 | double quotes. On case-insensitive filesystems, this prevents us | |
86 | from including our python/python.h header file. */ | |
87 | #include <Python.h> | |
88 | #include <frameobject.h> | |
a5c5eda7 | 89 | #include "py-ref.h" |
9a27f2c6 | 90 | |
d61186d8 TT |
91 | static_assert (PY_VERSION_HEX >= 0x03040000); |
92 | ||
9a27f2c6 PK |
93 | #define Py_TPFLAGS_CHECKTYPES 0 |
94 | ||
ca30a762 TT |
95 | /* If Python.h does not define WITH_THREAD, then the various |
96 | GIL-related functions will not be defined. However, | |
97 | PyGILState_STATE will be. */ | |
98 | #ifndef WITH_THREAD | |
99 | #define PyGILState_Ensure() ((PyGILState_STATE) 0) | |
548a926a | 100 | #define PyGILState_Release(ARG) ((void)(ARG)) |
aed1781d | 101 | #define PyEval_InitThreads() |
548a926a | 102 | #define PyThreadState_Swap(ARG) ((void)(ARG)) |
aed1781d | 103 | #define PyEval_ReleaseLock() |
ca30a762 TT |
104 | #endif |
105 | ||
74aedc46 TT |
106 | /* Python supplies HAVE_LONG_LONG and some `long long' support when it |
107 | is available. These defines let us handle the differences more | |
a8463c68 TV |
108 | cleanly. |
109 | ||
110 | Starting with python 3.6, support for platforms without long long support | |
111 | has been removed [1]. HAVE_LONG_LONG and PY_LONG_LONG are still defined, | |
112 | but only for compatibility, so we no longer rely on them. | |
113 | ||
114 | [1] https://github.com/python/cpython/issues/72148. */ | |
115 | #if PY_VERSION_HEX >= 0x03060000 || defined (HAVE_LONG_LONG) | |
74aedc46 TT |
116 | |
117 | #define GDB_PY_LL_ARG "L" | |
118 | #define GDB_PY_LLU_ARG "K" | |
a8463c68 TV |
119 | #if PY_VERSION_HEX >= 0x03060000 |
120 | typedef long long gdb_py_longest; | |
121 | typedef unsigned long long gdb_py_ulongest; | |
122 | #else | |
74aedc46 TT |
123 | typedef PY_LONG_LONG gdb_py_longest; |
124 | typedef unsigned PY_LONG_LONG gdb_py_ulongest; | |
a8463c68 | 125 | #endif |
74aedc46 | 126 | #define gdb_py_long_as_ulongest PyLong_AsUnsignedLongLong |
d5ad08d7 | 127 | #define gdb_py_long_as_long_and_overflow PyLong_AsLongLongAndOverflow |
74aedc46 TT |
128 | |
129 | #else /* HAVE_LONG_LONG */ | |
130 | ||
58a62853 TV |
131 | #define GDB_PY_LL_ARG "l" |
132 | #define GDB_PY_LLU_ARG "k" | |
74aedc46 TT |
133 | typedef long gdb_py_longest; |
134 | typedef unsigned long gdb_py_ulongest; | |
74aedc46 | 135 | #define gdb_py_long_as_ulongest PyLong_AsUnsignedLong |
d5ad08d7 | 136 | #define gdb_py_long_as_long_and_overflow PyLong_AsLongAndOverflow |
74aedc46 TT |
137 | |
138 | #endif /* HAVE_LONG_LONG */ | |
139 | ||
764af878 TT |
140 | /* A template variable holding the format character (as for |
141 | Py_BuildValue) for a given type. */ | |
142 | template<typename T> | |
ea4e03c0 | 143 | struct gdbpy_method_format {}; |
764af878 TT |
144 | |
145 | template<> | |
ea4e03c0 LS |
146 | struct gdbpy_method_format<gdb_py_longest> |
147 | { | |
148 | static constexpr char format = GDB_PY_LL_ARG[0]; | |
149 | }; | |
764af878 TT |
150 | |
151 | template<> | |
ea4e03c0 LS |
152 | struct gdbpy_method_format<gdb_py_ulongest> |
153 | { | |
154 | static constexpr char format = GDB_PY_LLU_ARG[0]; | |
155 | }; | |
764af878 TT |
156 | |
157 | template<> | |
ea4e03c0 LS |
158 | struct gdbpy_method_format<int> |
159 | { | |
160 | static constexpr char format = 'i'; | |
161 | }; | |
764af878 TT |
162 | |
163 | template<> | |
ea4e03c0 LS |
164 | struct gdbpy_method_format<unsigned> |
165 | { | |
166 | static constexpr char format = 'I'; | |
167 | }; | |
764af878 TT |
168 | |
169 | /* A helper function to compute the PyObject_CallMethod / | |
170 | Py_BuildValue format given the argument types. */ | |
4d759979 PA |
171 | |
172 | template<typename... Args> | |
764af878 TT |
173 | constexpr std::array<char, sizeof... (Args) + 1> |
174 | gdbpy_make_fmt () | |
175 | { | |
ea4e03c0 | 176 | return { gdbpy_method_format<Args>::format..., '\0' }; |
764af878 TT |
177 | } |
178 | ||
179 | /* Typesafe wrapper around PyObject_CallMethod. | |
180 | ||
181 | This variant accepts no arguments. */ | |
182 | ||
7c03e522 | 183 | static inline gdbpy_ref<> |
764af878 | 184 | gdbpy_call_method (PyObject *o, const char *method) |
4d759979 | 185 | { |
764af878 TT |
186 | /* PyObject_CallMethod's 'method' and 'format' parameters were missing the |
187 | 'const' qualifier before Python 3.4. */ | |
7c03e522 TT |
188 | return gdbpy_ref<> (PyObject_CallMethod (o, |
189 | const_cast<char *> (method), | |
190 | nullptr)); | |
4d759979 PA |
191 | } |
192 | ||
764af878 TT |
193 | /* Typesafe wrapper around PyObject_CallMethod. |
194 | ||
195 | This variant accepts any number of arguments and automatically | |
196 | computes the format string, ensuring that format/argument | |
197 | mismatches are impossible. */ | |
198 | ||
199 | template<typename Arg, typename... Args> | |
7c03e522 | 200 | static inline gdbpy_ref<> |
764af878 TT |
201 | gdbpy_call_method (PyObject *o, const char *method, |
202 | Arg arg, Args... args) | |
203 | { | |
204 | constexpr const auto fmt = gdbpy_make_fmt<Arg, Args...> (); | |
205 | ||
206 | /* PyObject_CallMethod's 'method' and 'format' parameters were missing the | |
207 | 'const' qualifier before Python 3.4. */ | |
7c03e522 TT |
208 | return gdbpy_ref<> (PyObject_CallMethod (o, |
209 | const_cast<char *> (method), | |
210 | const_cast<char *> (fmt.data ()), | |
211 | arg, args...)); | |
764af878 TT |
212 | } |
213 | ||
c2d091ff TT |
214 | /* An overload that takes a gdbpy_ref<> rather than a raw 'PyObject *'. */ |
215 | ||
216 | template<typename... Args> | |
217 | static inline gdbpy_ref<> | |
218 | gdbpy_call_method (const gdbpy_ref<> &o, const char *method, Args... args) | |
219 | { | |
220 | return gdbpy_call_method (o.get (), method, args...); | |
221 | } | |
222 | ||
764af878 TT |
223 | /* Poison PyObject_CallMethod. The typesafe wrapper gdbpy_call_method should be |
224 | used instead. */ | |
4d759979 | 225 | #undef PyObject_CallMethod |
b820cd55 TV |
226 | #ifdef __GNUC__ |
227 | # pragma GCC poison PyObject_CallMethod | |
228 | #else | |
229 | # define PyObject_CallMethod POISONED_PyObject_CallMethod | |
230 | #endif | |
4d759979 PA |
231 | |
232 | /* The 'name' parameter of PyErr_NewException was missing the 'const' | |
233 | qualifier in Python <= 3.4. Hence, we wrap it in a function to | |
234 | avoid errors when compiled with -Werror. */ | |
235 | ||
236 | static inline PyObject* | |
237 | gdb_PyErr_NewException (const char *name, PyObject *base, PyObject *dict) | |
238 | { | |
239 | return PyErr_NewException (const_cast<char *> (name), base, dict); | |
240 | } | |
241 | ||
242 | #define PyErr_NewException gdb_PyErr_NewException | |
243 | ||
244 | /* PySys_GetObject's 'name' parameter was missing the 'const' | |
245 | qualifier before Python 3.4. Hence, we wrap it in a function to | |
246 | avoid errors when compiled with -Werror. */ | |
247 | ||
248 | static inline PyObject * | |
249 | gdb_PySys_GetObject (const char *name) | |
250 | { | |
251 | return PySys_GetObject (const_cast<char *> (name)); | |
252 | } | |
253 | ||
254 | #define PySys_GetObject gdb_PySys_GetObject | |
255 | ||
fe587fc9 KB |
256 | /* PySys_SetPath was deprecated in Python 3.11. Disable the deprecated |
257 | code for Python 3.10 and newer. */ | |
258 | #if PY_VERSION_HEX < 0x030a0000 | |
259 | ||
4d759979 PA |
260 | /* PySys_SetPath's 'path' parameter was missing the 'const' qualifier |
261 | before Python 3.6. Hence, we wrap it in a function to avoid errors | |
262 | when compiled with -Werror. */ | |
263 | ||
4d759979 | 264 | # define GDB_PYSYS_SETPATH_CHAR wchar_t |
4d759979 PA |
265 | |
266 | static inline void | |
267 | gdb_PySys_SetPath (const GDB_PYSYS_SETPATH_CHAR *path) | |
268 | { | |
269 | PySys_SetPath (const_cast<GDB_PYSYS_SETPATH_CHAR *> (path)); | |
270 | } | |
271 | ||
272 | #define PySys_SetPath gdb_PySys_SetPath | |
fe587fc9 | 273 | #endif |
4d759979 | 274 | |
0d1f4ceb PA |
275 | /* Wrap PyGetSetDef to allow convenient construction with string |
276 | literals. Unfortunately, PyGetSetDef's 'name' and 'doc' members | |
277 | are 'char *' instead of 'const char *', meaning that in order to | |
278 | list-initialize PyGetSetDef arrays with string literals (and | |
279 | without the wrapping below) would require writing explicit 'char *' | |
280 | casts. Instead, we extend PyGetSetDef and add constexpr | |
281 | constructors that accept const 'name' and 'doc', hiding the ugly | |
282 | casts here in a single place. */ | |
283 | ||
284 | struct gdb_PyGetSetDef : PyGetSetDef | |
285 | { | |
286 | constexpr gdb_PyGetSetDef (const char *name_, getter get_, setter set_, | |
287 | const char *doc_, void *closure_) | |
288 | : PyGetSetDef {const_cast<char *> (name_), get_, set_, | |
289 | const_cast<char *> (doc_), closure_} | |
290 | {} | |
291 | ||
292 | /* Alternative constructor that allows omitting the closure in list | |
293 | initialization. */ | |
294 | constexpr gdb_PyGetSetDef (const char *name_, getter get_, setter set_, | |
295 | const char *doc_) | |
296 | : gdb_PyGetSetDef {name_, get_, set_, doc_, NULL} | |
297 | {} | |
298 | ||
299 | /* Constructor for the sentinel entries. */ | |
300 | constexpr gdb_PyGetSetDef (std::nullptr_t) | |
301 | : gdb_PyGetSetDef {NULL, NULL, NULL, NULL, NULL} | |
302 | {} | |
303 | }; | |
304 | ||
2adadf51 PA |
305 | /* The 'keywords' parameter of PyArg_ParseTupleAndKeywords has type |
306 | 'char **'. However, string literals are const in C++, and so to | |
307 | avoid casting at every keyword array definition, we'll need to make | |
308 | the keywords array an array of 'const char *'. To avoid having all | |
309 | callers add a 'const_cast<char **>' themselves when passing such an | |
310 | array through 'char **', we define our own version of | |
311 | PyArg_ParseTupleAndKeywords here with a corresponding 'keywords' | |
312 | parameter type that does the cast in a single place. (This is not | |
313 | an overload of PyArg_ParseTupleAndKeywords in order to make it | |
314 | clearer that we're calling our own function instead of a function | |
315 | that exists in some newer Python version.) */ | |
316 | ||
317 | static inline int | |
318 | gdb_PyArg_ParseTupleAndKeywords (PyObject *args, PyObject *kw, | |
319 | const char *format, const char **keywords, ...) | |
320 | { | |
321 | va_list ap; | |
322 | int res; | |
323 | ||
324 | va_start (ap, keywords); | |
325 | res = PyArg_VaParseTupleAndKeywords (args, kw, format, | |
326 | const_cast<char **> (keywords), | |
327 | ap); | |
328 | va_end (ap); | |
329 | ||
330 | return res; | |
331 | } | |
332 | ||
256458bc | 333 | /* In order to be able to parse symtab_and_line_to_sal_object function |
9cb74f47 PM |
334 | a real symtab_and_line structure is needed. */ |
335 | #include "symtab.h" | |
336 | ||
d7b32ed3 PM |
337 | /* Also needed to parse enum var_types. */ |
338 | #include "command.h" | |
505500db | 339 | #include "breakpoint.h" |
d7b32ed3 | 340 | |
a73bb892 PK |
341 | enum gdbpy_iter_kind { iter_keys, iter_values, iter_items }; |
342 | ||
f3e9a817 | 343 | struct block; |
a08702d6 | 344 | struct value; |
d452c4bc | 345 | struct language_defn; |
fa33c3cd | 346 | struct program_space; |
313f3b21 | 347 | struct bpstat; |
619cebe8 | 348 | struct inferior; |
d57a3c85 | 349 | |
0646da15 TT |
350 | extern int gdb_python_initialized; |
351 | ||
d57a3c85 | 352 | extern PyObject *gdb_module; |
b9516fa1 | 353 | extern PyObject *gdb_python_module; |
62eec1a5 TT |
354 | extern PyTypeObject value_object_type |
355 | CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("value_object"); | |
356 | extern PyTypeObject block_object_type | |
357 | CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF("block_object"); | |
358 | extern PyTypeObject symbol_object_type | |
359 | CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("symbol_object"); | |
360 | extern PyTypeObject event_object_type | |
361 | CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("event_object"); | |
62eec1a5 TT |
362 | extern PyTypeObject breakpoint_object_type |
363 | CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("breakpoint_object"); | |
364 | extern PyTypeObject frame_object_type | |
365 | CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("frame_object"); | |
fbbe5337 KB |
366 | extern PyTypeObject thread_object_type |
367 | CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("thread_object"); | |
cc72b2a2 | 368 | |
8a3b1706 AB |
369 | /* Ensure that breakpoint_object_type is initialized and return true. If |
370 | breakpoint_object_type can't be initialized then set a suitable Python | |
371 | error and return false. | |
372 | ||
373 | This function needs to be called from any gdbpy_initialize_* function | |
374 | that wants to reference breakpoint_object_type. After all the | |
375 | gdbpy_initialize_* functions have been called then breakpoint_object_type | |
376 | is guaranteed to have been initialized, and this function does not need | |
377 | calling before referencing breakpoint_object_type. */ | |
378 | ||
379 | extern bool gdbpy_breakpoint_init_breakpoint_type (); | |
380 | ||
f99b5177 | 381 | struct gdbpy_breakpoint_object |
cc72b2a2 KP |
382 | { |
383 | PyObject_HEAD | |
384 | ||
385 | /* The breakpoint number according to gdb. */ | |
386 | int number; | |
387 | ||
388 | /* The gdb breakpoint object, or NULL if the breakpoint has been | |
389 | deleted. */ | |
390 | struct breakpoint *bp; | |
391 | ||
392 | /* 1 is this is a FinishBreakpoint object, 0 otherwise. */ | |
393 | int is_finish_bp; | |
f99b5177 | 394 | }; |
cc72b2a2 KP |
395 | |
396 | /* Require that BREAKPOINT be a valid breakpoint ID; throw a Python | |
397 | exception if it is invalid. */ | |
398 | #define BPPY_REQUIRE_VALID(Breakpoint) \ | |
399 | do { \ | |
400 | if ((Breakpoint)->bp == NULL) \ | |
dda83cd7 SM |
401 | return PyErr_Format (PyExc_RuntimeError, \ |
402 | _("Breakpoint %d is invalid."), \ | |
403 | (Breakpoint)->number); \ | |
cc72b2a2 KP |
404 | } while (0) |
405 | ||
406 | /* Require that BREAKPOINT be a valid breakpoint ID; throw a Python | |
407 | exception if it is invalid. This macro is for use in setter functions. */ | |
408 | #define BPPY_SET_REQUIRE_VALID(Breakpoint) \ | |
409 | do { \ | |
410 | if ((Breakpoint)->bp == NULL) \ | |
dda83cd7 SM |
411 | { \ |
412 | PyErr_Format (PyExc_RuntimeError, _("Breakpoint %d is invalid."), \ | |
413 | (Breakpoint)->number); \ | |
414 | return -1; \ | |
415 | } \ | |
cc72b2a2 KP |
416 | } while (0) |
417 | ||
418 | ||
419 | /* Variables used to pass information between the Breakpoint | |
420 | constructor and the breakpoint-created hook function. */ | |
4cb0213d | 421 | extern gdbpy_breakpoint_object *bppy_pending_object; |
505500db | 422 | |
a08702d6 | 423 | |
f99b5177 | 424 | struct thread_object |
595939de PM |
425 | { |
426 | PyObject_HEAD | |
427 | ||
428 | /* The thread we represent. */ | |
429 | struct thread_info *thread; | |
430 | ||
431 | /* The Inferior object to which this thread belongs. */ | |
432 | PyObject *inf_obj; | |
1d586eda AB |
433 | |
434 | /* Dictionary holding user-added attributes. This is the __dict__ | |
435 | attribute of the object. */ | |
436 | PyObject *dict; | |
f99b5177 | 437 | }; |
595939de | 438 | |
00431a78 PA |
439 | struct inferior_object; |
440 | ||
8a1ea21f DE |
441 | extern struct cmd_list_element *set_python_list; |
442 | extern struct cmd_list_element *show_python_list; | |
6dddc817 DE |
443 | \f |
444 | /* extension_language_script_ops "methods". */ | |
445 | ||
db972fce SM |
446 | /* Return true if auto-loading Python scripts is enabled. |
447 | This is the extension_language_script_ops.auto_load_enabled "method". */ | |
448 | ||
449 | extern bool gdbpy_auto_load_enabled (const struct extension_language_defn *); | |
6dddc817 DE |
450 | |
451 | /* extension_language_ops "methods". */ | |
452 | ||
453 | extern enum ext_lang_rc gdbpy_apply_val_pretty_printer | |
454 | (const struct extension_language_defn *, | |
42331a1e | 455 | struct value *value, |
6dddc817 | 456 | struct ui_file *stream, int recurse, |
6dddc817 DE |
457 | const struct value_print_options *options, |
458 | const struct language_defn *language); | |
6be9971c FW |
459 | extern void gdbpy_load_ptwrite_filter |
460 | (const struct extension_language_defn *extlang, | |
461 | struct btrace_thread_info *btinfo); | |
6dddc817 DE |
462 | extern enum ext_lang_bt_status gdbpy_apply_frame_filter |
463 | (const struct extension_language_defn *, | |
8480a37e | 464 | const frame_info_ptr &frame, frame_filter_flags flags, |
d4dd3282 | 465 | enum ext_lang_frame_args args_type, |
6dddc817 DE |
466 | struct ui_out *out, int frame_low, int frame_high); |
467 | extern void gdbpy_preserve_values (const struct extension_language_defn *, | |
468 | struct objfile *objfile, | |
112f6d85 | 469 | copied_types_hash_t &copied_types); |
6dddc817 DE |
470 | extern enum ext_lang_bp_stop gdbpy_breakpoint_cond_says_stop |
471 | (const struct extension_language_defn *, struct breakpoint *); | |
472 | extern int gdbpy_breakpoint_has_cond (const struct extension_language_defn *, | |
473 | struct breakpoint *b); | |
883964a7 | 474 | |
883964a7 SC |
475 | extern enum ext_lang_rc gdbpy_get_matching_xmethod_workers |
476 | (const struct extension_language_defn *extlang, | |
477 | struct type *obj_type, const char *method_name, | |
ba18742c SM |
478 | std::vector<xmethod_worker_up> *dm_vec); |
479 | ||
6dddc817 | 480 | \f |
08c637de | 481 | PyObject *gdbpy_history (PyObject *self, PyObject *args); |
540bf37b | 482 | PyObject *gdbpy_add_history (PyObject *self, PyObject *args); |
30a87e90 | 483 | extern PyObject *gdbpy_history_count (PyObject *self, PyObject *args); |
7729052b TT |
484 | PyObject *gdbpy_convenience_variable (PyObject *self, PyObject *args); |
485 | PyObject *gdbpy_set_convenience_variable (PyObject *self, PyObject *args); | |
adc36818 | 486 | PyObject *gdbpy_breakpoints (PyObject *, PyObject *); |
f8f6f20b | 487 | PyObject *gdbpy_frame_stop_reason_string (PyObject *, PyObject *); |
f3e9a817 | 488 | PyObject *gdbpy_lookup_symbol (PyObject *self, PyObject *args, PyObject *kw); |
6e6fbe60 DE |
489 | PyObject *gdbpy_lookup_global_symbol (PyObject *self, PyObject *args, |
490 | PyObject *kw); | |
2906593f CB |
491 | PyObject *gdbpy_lookup_static_symbol (PyObject *self, PyObject *args, |
492 | PyObject *kw); | |
086baaf1 AB |
493 | PyObject *gdbpy_lookup_static_symbols (PyObject *self, PyObject *args, |
494 | PyObject *kw); | |
4726b2d8 TW |
495 | PyObject *gdbpy_start_recording (PyObject *self, PyObject *args); |
496 | PyObject *gdbpy_current_recording (PyObject *self, PyObject *args); | |
497 | PyObject *gdbpy_stop_recording (PyObject *self, PyObject *args); | |
d8e22779 | 498 | PyObject *gdbpy_newest_frame (PyObject *self, PyObject *args); |
f8f6f20b | 499 | PyObject *gdbpy_selected_frame (PyObject *self, PyObject *args); |
2c74e833 | 500 | PyObject *gdbpy_lookup_type (PyObject *self, PyObject *args, PyObject *kw); |
a16b0e22 | 501 | int gdbpy_is_field (PyObject *obj); |
be759fcf | 502 | PyObject *gdbpy_create_lazy_string_object (CORE_ADDR address, long length, |
9a2b4c1b MS |
503 | const char *encoding, |
504 | struct type *type); | |
595939de | 505 | PyObject *gdbpy_inferiors (PyObject *unused, PyObject *unused2); |
162078c8 | 506 | PyObject *gdbpy_create_ptid_object (ptid_t ptid); |
595939de | 507 | PyObject *gdbpy_selected_thread (PyObject *self, PyObject *args); |
2aa48337 | 508 | PyObject *gdbpy_selected_inferior (PyObject *self, PyObject *args); |
07ca107c | 509 | PyObject *gdbpy_string_to_argv (PyObject *self, PyObject *args); |
1d7fe7f0 | 510 | PyObject *gdbpy_parameter_value (const setting &var); |
4b8cb9dd SM |
511 | gdb::unique_xmalloc_ptr<char> gdbpy_parse_command_name |
512 | (const char *name, struct cmd_list_element ***base_list, | |
f84a4db9 AB |
513 | struct cmd_list_element **start_list, |
514 | struct cmd_list_element **prefix_cmd = nullptr); | |
01b1af32 TT |
515 | PyObject *gdbpy_register_tui_window (PyObject *self, PyObject *args, |
516 | PyObject *kw); | |
a08702d6 | 517 | |
f3e9a817 PM |
518 | PyObject *symtab_and_line_to_sal_object (struct symtab_and_line sal); |
519 | PyObject *symtab_to_symtab_object (struct symtab *symtab); | |
520 | PyObject *symbol_to_symbol_object (struct symbol *sym); | |
9df2fbc4 PM |
521 | PyObject *block_to_block_object (const struct block *block, |
522 | struct objfile *objfile); | |
a08702d6 | 523 | PyObject *value_to_value_object (struct value *v); |
2c74e833 | 524 | PyObject *type_to_type_object (struct type *); |
8480a37e | 525 | PyObject *frame_info_to_frame_object (const frame_info_ptr &frame); |
bc79de95 | 526 | PyObject *symtab_to_linetable_object (PyObject *symtab); |
3c7aa307 | 527 | gdbpy_ref<> pspace_to_pspace_object (struct program_space *); |
fa33c3cd | 528 | PyObject *pspy_get_printers (PyObject *, void *); |
1e611234 | 529 | PyObject *pspy_get_frame_filters (PyObject *, void *); |
d11916aa | 530 | PyObject *pspy_get_frame_unwinders (PyObject *, void *); |
883964a7 | 531 | PyObject *pspy_get_xmethods (PyObject *, void *); |
fa33c3cd | 532 | |
0a9db5ad | 533 | gdbpy_ref<> objfile_to_objfile_object (struct objfile *); |
89c73ade | 534 | PyObject *objfpy_get_printers (PyObject *, void *); |
1e611234 | 535 | PyObject *objfpy_get_frame_filters (PyObject *, void *); |
d11916aa | 536 | PyObject *objfpy_get_frame_unwinders (PyObject *, void *); |
883964a7 | 537 | PyObject *objfpy_get_xmethods (PyObject *, void *); |
6dddd6a5 | 538 | PyObject *gdbpy_lookup_objfile (PyObject *self, PyObject *args, PyObject *kw); |
a08702d6 | 539 | |
bea883fd | 540 | PyObject *gdbarch_to_arch_object (struct gdbarch *gdbarch); |
8b87fbe6 | 541 | PyObject *gdbpy_all_architecture_names (PyObject *self, PyObject *args); |
bea883fd | 542 | |
0f767f94 AB |
543 | PyObject *gdbpy_new_register_descriptor_iterator (struct gdbarch *gdbarch, |
544 | const char *group_name); | |
64cb3757 | 545 | PyObject *gdbpy_new_reggroup_iterator (struct gdbarch *gdbarch); |
0f767f94 | 546 | |
05b08ac1 | 547 | gdbpy_ref<thread_object> create_thread_object (struct thread_info *tp); |
db1337cc | 548 | gdbpy_ref<> thread_to_thread_object (thread_info *thr);; |
61fd3e73 | 549 | gdbpy_ref<inferior_object> inferior_to_inferior_object (inferior *inf); |
595939de | 550 | |
625f7b1c AB |
551 | PyObject *gdbpy_buffer_to_membuf (gdb::unique_xmalloc_ptr<gdb_byte> buffer, |
552 | CORE_ADDR address, ULONGEST length); | |
553 | ||
0e3b7c25 AB |
554 | struct process_stratum_target; |
555 | gdbpy_ref<> target_to_connection_object (process_stratum_target *target); | |
556 | PyObject *gdbpy_connections (PyObject *self, PyObject *args); | |
557 | ||
9df2fbc4 | 558 | const struct block *block_object_to_block (PyObject *obj); |
f3e9a817 | 559 | struct symbol *symbol_object_to_symbol (PyObject *obj); |
a6bac58e | 560 | struct value *value_object_to_value (PyObject *self); |
a08702d6 | 561 | struct value *convert_value_from_python (PyObject *obj); |
2c74e833 | 562 | struct type *type_object_to_type (PyObject *obj); |
f3e9a817 PM |
563 | struct symtab *symtab_object_to_symtab (PyObject *obj); |
564 | struct symtab_and_line *sal_object_to_symtab_and_line (PyObject *obj); | |
bd2b40ac | 565 | frame_info_ptr frame_object_to_frame_info (PyObject *frame_obj); |
bea883fd | 566 | struct gdbarch *arch_object_to_gdbarch (PyObject *obj); |
a08702d6 | 567 | |
c97d123d TT |
568 | extern PyObject *gdbpy_execute_mi_command (PyObject *self, PyObject *args, |
569 | PyObject *kw); | |
570 | ||
80a3485f JV |
571 | /* Serialize RESULTS and print it in MI format to the current_uiout. |
572 | ||
573 | This function handles the top-level results passed as a dictionary. | |
574 | The caller is responsible for ensuring that. The values within this | |
575 | dictionary can be a wider range of types. Handling the values of the top-level | |
576 | dictionary is done by serialize_mi_result_1, see that function for more | |
577 | details. | |
578 | ||
579 | If anything goes wrong while parsing and printing the MI output then an | |
580 | error is thrown. */ | |
581 | ||
582 | extern void serialize_mi_results (PyObject *results); | |
583 | ||
4825fd2d JV |
584 | /* Implementation of the gdb.notify_mi function. */ |
585 | ||
586 | extern PyObject *gdbpy_notify_mi (PyObject *self, PyObject *args, | |
587 | PyObject *kw); | |
588 | ||
25209e2c AB |
589 | /* Convert Python object OBJ to a program_space pointer. OBJ must be a |
590 | gdb.Progspace reference. Return nullptr if the gdb.Progspace is not | |
591 | valid (see gdb.Progspace.is_valid), otherwise return the program_space | |
592 | pointer. */ | |
593 | ||
594 | extern struct program_space *progspace_object_to_program_space (PyObject *obj); | |
595 | ||
3965bff5 AB |
596 | /* A class for managing the initialization, and finalization functions |
597 | from all Python files (e.g. gdb/python/py-*.c). | |
598 | ||
599 | Within any Python file, create an instance of this class, passing in | |
600 | the initialization function, and, optionally, the finalization | |
601 | function. | |
602 | ||
603 | These functions are added to a single global list of functions, which | |
604 | can then be called from do_start_initialization and finalize_python | |
605 | (see python.c) to initialize all the Python files within GDB. */ | |
606 | ||
607 | class gdbpy_initialize_file | |
608 | { | |
609 | /* The type of a function that can be called just after GDB has setup the | |
610 | Python interpreter. This function will setup any additional Python | |
611 | state required by a particular subsystem. Return 0 if the setup was | |
612 | successful, or return -1 if setup failed, in which case a Python | |
613 | exception should have been raised. */ | |
614 | ||
615 | using gdbpy_initialize_file_ftype = int (*) (void); | |
616 | ||
617 | /* The type of a function that can be called just before GDB shuts down | |
618 | the Python interpreter. This function can cleanup an Python state | |
619 | that is cached within GDB, for example, if GDB is holding any | |
620 | references to Python objects, these should be released before the | |
621 | Python interpreter is shut down. | |
622 | ||
623 | There is no error return in this case. This function is only called | |
624 | when GDB is already shutting down. The function should make a best | |
625 | effort to clean up, and then return. */ | |
626 | ||
627 | using gdbpy_finalize_file_ftype = void (*) (void); | |
628 | ||
629 | /* The type for an initialization and finalization function pair. */ | |
630 | ||
631 | using callback_pair_t = std::pair<gdbpy_initialize_file_ftype, | |
632 | gdbpy_finalize_file_ftype>; | |
633 | ||
634 | /* Return the vector of callbacks. The vector is defined as a static | |
635 | variable within this function so that it will be initialized the first | |
636 | time this function is called. This is important, as this function is | |
637 | called as part of the global object initialization process; if the | |
638 | vector was a static variable within this class then we could not | |
639 | guarantee that it had been initialized before it was used. */ | |
640 | ||
641 | static std::vector<callback_pair_t> & | |
642 | callbacks () | |
643 | { | |
644 | static std::vector<callback_pair_t> list; | |
645 | return list; | |
646 | } | |
647 | ||
648 | public: | |
649 | ||
650 | /* Register the initialization (INIT) and finalization (FINI) functions | |
651 | for a Python file. See the comments on the function types above for | |
652 | when these functions will be called. | |
653 | ||
654 | Either of these functions can be nullptr, in which case no function | |
655 | will be called. | |
656 | ||
657 | The FINI argument is optional, and defaults to nullptr (no function to | |
658 | call). */ | |
659 | ||
660 | gdbpy_initialize_file (gdbpy_initialize_file_ftype init, | |
661 | gdbpy_finalize_file_ftype fini = nullptr) | |
662 | { | |
663 | callbacks ().emplace_back (init, fini); | |
664 | } | |
665 | ||
666 | /* Run all the Python file initialize functions and return true. If any | |
667 | of the initialize functions fails then this function returns false. | |
668 | In the case of failure it is undefined how many of the initialize | |
669 | functions will have been called. */ | |
670 | ||
671 | static bool | |
672 | initialize_all () | |
673 | { | |
674 | /* The initialize_all function should only be called once. The | |
675 | following check reverses the global list, which will effect this | |
676 | initialize_all call, as well as the later finalize_all call. | |
677 | ||
678 | The environment variable checked here is the same as the one checked | |
679 | in the generated init.c file. */ | |
680 | if (getenv ("GDB_REVERSE_INIT_FUNCTIONS") != nullptr) | |
681 | std::reverse (callbacks ().begin (), callbacks ().end ()); | |
682 | ||
683 | for (const auto &p : gdbpy_initialize_file::callbacks ()) | |
684 | { | |
685 | if (p.first != nullptr && p.first () < 0) | |
686 | return false; | |
687 | } | |
688 | return true; | |
689 | } | |
690 | ||
691 | /* Run all the Python file finalize functions. */ | |
692 | ||
693 | static void | |
694 | finalize_all () | |
695 | { | |
696 | for (const auto &p : gdbpy_initialize_file::callbacks ()) | |
697 | { | |
698 | if (p.second != nullptr) | |
699 | p.second (); | |
700 | } | |
701 | } | |
702 | }; | |
703 | ||
704 | /* Macro to simplify registering the initialization and finalization | |
705 | functions for a Python file. */ | |
706 | ||
707 | #define GDBPY_INITIALIZE_FILE(INIT, ...) \ | |
708 | static gdbpy_initialize_file \ | |
709 | CONCAT(gdbpy_initialize_file_obj_, __LINE__) (INIT, ##__VA_ARGS__) | |
d57a3c85 | 710 | |
3acd9a69 TT |
711 | PyMODINIT_FUNC gdbpy_events_mod_func (); |
712 | ||
5c329e6a TT |
713 | /* A wrapper for PyErr_Fetch that handles reference counting for the |
714 | caller. */ | |
715 | class gdbpy_err_fetch | |
716 | { | |
717 | public: | |
718 | ||
719 | gdbpy_err_fetch () | |
720 | { | |
2cf3c79c | 721 | #if PY_VERSION_HEX < 0x030c0000 |
8a0b6047 | 722 | PyObject *error_type, *error_value, *error_traceback; |
5c329e6a | 723 | |
8a0b6047 AB |
724 | PyErr_Fetch (&error_type, &error_value, &error_traceback); |
725 | m_error_type.reset (error_type); | |
726 | m_error_value.reset (error_value); | |
727 | m_error_traceback.reset (error_traceback); | |
2cf3c79c TV |
728 | #else |
729 | /* PyErr_Fetch is deprecated in python 3.12, use PyErr_GetRaisedException | |
730 | instead. */ | |
731 | m_exc.reset (PyErr_GetRaisedException ()); | |
732 | #endif | |
5c329e6a TT |
733 | } |
734 | ||
735 | /* Call PyErr_Restore using the values stashed in this object. | |
736 | After this call, this object is invalid and neither the to_string | |
737 | nor restore methods may be used again. */ | |
738 | ||
739 | void restore () | |
740 | { | |
2cf3c79c | 741 | #if PY_VERSION_HEX < 0x030c0000 |
8a0b6047 AB |
742 | PyErr_Restore (m_error_type.release (), |
743 | m_error_value.release (), | |
744 | m_error_traceback.release ()); | |
2cf3c79c TV |
745 | #else |
746 | /* PyErr_Restore is deprecated in python 3.12, use PyErr_SetRaisedException | |
747 | instead. */ | |
748 | PyErr_SetRaisedException (m_exc.release ()); | |
749 | #endif | |
5c329e6a TT |
750 | } |
751 | ||
752 | /* Return the string representation of the exception represented by | |
753 | this object. If the result is NULL a python error occurred, the | |
754 | caller must clear it. */ | |
755 | ||
756 | gdb::unique_xmalloc_ptr<char> to_string () const; | |
757 | ||
758 | /* Return the string representation of the type of the exception | |
759 | represented by this object. If the result is NULL a python error | |
760 | occurred, the caller must clear it. */ | |
761 | ||
762 | gdb::unique_xmalloc_ptr<char> type_to_string () const; | |
763 | ||
764 | /* Return true if the stored type matches TYPE, false otherwise. */ | |
765 | ||
766 | bool type_matches (PyObject *type) const | |
767 | { | |
b1abf8b1 TV |
768 | gdbpy_ref<> err_type = this->type (); |
769 | return PyErr_GivenExceptionMatches (err_type.get (), type); | |
5c329e6a TT |
770 | } |
771 | ||
15e15b2d AB |
772 | /* Return a new reference to the exception value object. */ |
773 | ||
b1abf8b1 | 774 | gdbpy_ref<> value () const |
15e15b2d | 775 | { |
2cf3c79c | 776 | #if PY_VERSION_HEX < 0x030c0000 |
50ede768 TV |
777 | if (!m_normalized) |
778 | { | |
779 | PyObject *error_type, *error_value, *error_traceback; | |
780 | error_type = m_error_type.release (); | |
781 | error_value = m_error_value.release (); | |
782 | error_traceback = m_error_traceback.release (); | |
783 | PyErr_NormalizeException (&error_type, &error_value, &error_traceback); | |
784 | m_error_type.reset (error_type); | |
785 | m_error_value.reset (error_value); | |
786 | m_error_traceback.reset (error_traceback); | |
787 | m_normalized = true; | |
788 | } | |
15e15b2d | 789 | return m_error_value; |
2cf3c79c TV |
790 | #else |
791 | return m_exc; | |
792 | #endif | |
15e15b2d AB |
793 | } |
794 | ||
b1abf8b1 TV |
795 | /* Return a new reference to the exception type object. */ |
796 | ||
797 | gdbpy_ref<> type () const | |
798 | { | |
2cf3c79c | 799 | #if PY_VERSION_HEX < 0x030c0000 |
b1abf8b1 | 800 | return m_error_type; |
2cf3c79c TV |
801 | #else |
802 | if (m_exc.get() == nullptr) | |
803 | return nullptr; | |
804 | return gdbpy_ref<>::new_reference ((PyObject *)Py_TYPE (m_exc.get ())); | |
805 | #endif | |
b1abf8b1 TV |
806 | } |
807 | ||
5c329e6a TT |
808 | private: |
809 | ||
2cf3c79c | 810 | #if PY_VERSION_HEX < 0x030c0000 |
50ede768 TV |
811 | mutable gdbpy_ref<> m_error_type, m_error_value, m_error_traceback; |
812 | mutable bool m_normalized = false; | |
2cf3c79c TV |
813 | #else |
814 | gdbpy_ref<> m_exc; | |
815 | #endif | |
5c329e6a TT |
816 | }; |
817 | ||
4ecee2c4 TT |
818 | /* Called before entering the Python interpreter to install the |
819 | current language and architecture to be used for Python values. | |
820 | Also set the active extension language for GDB so that SIGINT's | |
821 | are directed our way, and if necessary install the right SIGINT | |
822 | handler. */ | |
823 | class gdbpy_enter | |
824 | { | |
825 | public: | |
826 | ||
1da5d0e6 TT |
827 | /* Set the ambient Python architecture to GDBARCH and the language |
828 | to LANGUAGE. If GDBARCH is nullptr, then the architecture will | |
829 | be computed, when needed, using get_current_arch; see the | |
830 | get_gdbarch method. If LANGUAGE is not nullptr, then the current | |
831 | language at time of construction will be saved (to be restored on | |
832 | destruction), and the current language will be set to | |
833 | LANGUAGE. */ | |
834 | explicit gdbpy_enter (struct gdbarch *gdbarch = nullptr, | |
835 | const struct language_defn *language = nullptr); | |
4ecee2c4 TT |
836 | |
837 | ~gdbpy_enter (); | |
838 | ||
d6541620 | 839 | DISABLE_COPY_AND_ASSIGN (gdbpy_enter); |
4ecee2c4 | 840 | |
1da5d0e6 TT |
841 | /* Return the current gdbarch, as known to the Python layer. This |
842 | is either python_gdbarch (which comes from the most recent call | |
843 | to the gdbpy_enter constructor), or, if that is nullptr, the | |
844 | result of get_current_arch. */ | |
845 | static struct gdbarch *get_gdbarch (); | |
846 | ||
847 | /* Called only during gdb shutdown. This sets python_gdbarch to an | |
848 | acceptable value. */ | |
849 | static void finalize (); | |
850 | ||
4ecee2c4 TT |
851 | private: |
852 | ||
1da5d0e6 TT |
853 | /* The current gdbarch, according to Python. This can be |
854 | nullptr. */ | |
855 | static struct gdbarch *python_gdbarch; | |
856 | ||
4ecee2c4 TT |
857 | struct active_ext_lang_state *m_previous_active; |
858 | PyGILState_STATE m_state; | |
859 | struct gdbarch *m_gdbarch; | |
860 | const struct language_defn *m_language; | |
5c329e6a TT |
861 | |
862 | /* An optional is used here because we don't want to call | |
863 | PyErr_Fetch too early. */ | |
6b09f134 | 864 | std::optional<gdbpy_err_fetch> m_error; |
4ecee2c4 TT |
865 | }; |
866 | ||
6cd67bea TT |
867 | /* Like gdbpy_enter, but takes a varobj. This is a subclass just to |
868 | make constructor delegation a little nicer. */ | |
869 | class gdbpy_enter_varobj : public gdbpy_enter | |
870 | { | |
871 | public: | |
872 | ||
873 | /* This is defined in varobj.c, where it can access varobj | |
874 | internals. */ | |
875 | gdbpy_enter_varobj (const struct varobj *var); | |
876 | ||
877 | }; | |
878 | ||
b5eba2d8 TT |
879 | /* The opposite of gdb_enter: this releases the GIL around a region, |
880 | allowing other Python threads to run. No Python APIs may be used | |
881 | while this is active. */ | |
882 | class gdbpy_allow_threads | |
883 | { | |
884 | public: | |
885 | ||
886 | gdbpy_allow_threads () | |
887 | : m_save (PyEval_SaveThread ()) | |
888 | { | |
889 | gdb_assert (m_save != nullptr); | |
890 | } | |
891 | ||
892 | ~gdbpy_allow_threads () | |
893 | { | |
894 | PyEval_RestoreThread (m_save); | |
895 | } | |
896 | ||
897 | DISABLE_COPY_AND_ASSIGN (gdbpy_allow_threads); | |
898 | ||
899 | private: | |
900 | ||
901 | PyThreadState *m_save; | |
902 | }; | |
903 | ||
7ae9ecfd AH |
904 | /* A helper class to save and restore the GIL, but without touching |
905 | the other globals that are handled by gdbpy_enter. */ | |
906 | ||
907 | class gdbpy_gil | |
908 | { | |
909 | public: | |
910 | ||
911 | gdbpy_gil () | |
912 | : m_state (PyGILState_Ensure ()) | |
913 | { | |
914 | } | |
915 | ||
916 | ~gdbpy_gil () | |
917 | { | |
918 | PyGILState_Release (m_state); | |
919 | } | |
920 | ||
921 | DISABLE_COPY_AND_ASSIGN (gdbpy_gil); | |
922 | ||
923 | private: | |
924 | ||
925 | PyGILState_STATE m_state; | |
926 | }; | |
927 | ||
69b4374a | 928 | int gdbpy_print_python_errors_p (void); |
d57a3c85 | 929 | void gdbpy_print_stack (void); |
6ef2312a | 930 | void gdbpy_print_stack_or_quit (); |
d9deb60b | 931 | [[noreturn]] void gdbpy_handle_exception (); |
d57a3c85 | 932 | |
740b42ce AB |
933 | /* A wrapper around calling 'error'. Prefixes the error message with an |
934 | 'Error occurred in Python' string. Use this in C++ code if we spot | |
935 | something wrong with an object returned from Python code. The prefix | |
936 | string gives the user a hint that the mistake is within Python code, | |
937 | rather than some other part of GDB. | |
938 | ||
939 | This always calls error, and never returns. */ | |
940 | ||
d9deb60b | 941 | [[noreturn]] void gdbpy_error (const char *fmt, ...) ATTRIBUTE_PRINTF (1, 2); |
740b42ce | 942 | |
833d985d | 943 | gdbpy_ref<> python_string_to_unicode (PyObject *obj); |
9b972014 TT |
944 | gdb::unique_xmalloc_ptr<char> unicode_to_target_string (PyObject *unicode_str); |
945 | gdb::unique_xmalloc_ptr<char> python_string_to_target_string (PyObject *obj); | |
833d985d | 946 | gdbpy_ref<> python_string_to_target_python_string (PyObject *obj); |
9b972014 | 947 | gdb::unique_xmalloc_ptr<char> python_string_to_host_string (PyObject *obj); |
833d985d | 948 | gdbpy_ref<> host_string_to_python_string (const char *str); |
08c637de | 949 | int gdbpy_is_string (PyObject *obj); |
9b972014 | 950 | gdb::unique_xmalloc_ptr<char> gdbpy_obj_to_string (PyObject *obj); |
07ca107c | 951 | |
be759fcf | 952 | int gdbpy_is_lazy_string (PyObject *result); |
09ca9e2e | 953 | void gdbpy_extract_lazy_string (PyObject *string, CORE_ADDR *addr, |
256458bc | 954 | struct type **str_type, |
1eba6383 TT |
955 | long *length, |
956 | gdb::unique_xmalloc_ptr<char> *encoding); | |
d57a3c85 | 957 | |
595939de PM |
958 | int gdbpy_is_value_object (PyObject *obj); |
959 | ||
b6313243 TT |
960 | /* Note that these are declared here, and not in python.h with the |
961 | other pretty-printer functions, because they refer to PyObject. */ | |
a5c5eda7 SM |
962 | gdbpy_ref<> apply_varobj_pretty_printer (PyObject *print_obj, |
963 | struct value **replacement, | |
c4a3dbaf TT |
964 | struct ui_file *stream, |
965 | const value_print_options *opts); | |
a31abe80 | 966 | gdbpy_ref<> gdbpy_get_varobj_pretty_printer (struct value *value); |
9b972014 | 967 | gdb::unique_xmalloc_ptr<char> gdbpy_get_display_hint (PyObject *printer); |
b6313243 TT |
968 | PyObject *gdbpy_default_visualizer (PyObject *self, PyObject *args); |
969 | ||
c4a3dbaf TT |
970 | PyObject *gdbpy_print_options (PyObject *self, PyObject *args); |
971 | void gdbpy_get_print_options (value_print_options *opts); | |
972 | extern const struct value_print_options *gdbpy_current_print_options; | |
973 | ||
4cb0213d DE |
974 | void bpfinishpy_pre_stop_hook (struct gdbpy_breakpoint_object *bp_obj); |
975 | void bpfinishpy_post_stop_hook (struct gdbpy_breakpoint_object *bp_obj); | |
2968b79f | 976 | void bpfinishpy_pre_delete_hook (struct gdbpy_breakpoint_object *bp_obj); |
cc72b2a2 | 977 | |
d8906c6f | 978 | extern PyObject *gdbpy_doc_cst; |
a6bac58e TT |
979 | extern PyObject *gdbpy_children_cst; |
980 | extern PyObject *gdbpy_to_string_cst; | |
981 | extern PyObject *gdbpy_display_hint_cst; | |
967cf477 | 982 | extern PyObject *gdbpy_enabled_cst; |
fb6a3ed3 | 983 | extern PyObject *gdbpy_value_cst; |
d8906c6f | 984 | |
621c8364 TT |
985 | /* Exception types. */ |
986 | extern PyObject *gdbpy_gdb_error; | |
987 | extern PyObject *gdbpy_gdb_memory_error; | |
07ca107c DE |
988 | extern PyObject *gdbpy_gdberror_exc; |
989 | ||
94aeb44b | 990 | extern void gdbpy_convert_exception (const struct gdb_exception &) |
56cc411c | 991 | CPYCHECKER_SETS_EXCEPTION; |
621c8364 | 992 | |
912bc231 TV |
993 | /* Use this in a 'catch' block to convert the exception E to a Python |
994 | exception and return value VAL to signal that an exception occurred. | |
995 | Typically at the use site, that value will be returned immediately. */ | |
996 | ||
997 | template<typename T> | |
998 | [[nodiscard]] T | |
999 | gdbpy_handle_gdb_exception (T val, const gdb_exception &e) | |
1000 | { | |
1001 | gdbpy_convert_exception (e); | |
1002 | return val; | |
1003 | } | |
1004 | ||
b86af38a TT |
1005 | int get_addr_from_python (PyObject *obj, CORE_ADDR *addr) |
1006 | CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION; | |
595939de | 1007 | |
12dfa12a TT |
1008 | gdbpy_ref<> gdb_py_object_from_longest (LONGEST l); |
1009 | gdbpy_ref<> gdb_py_object_from_ulongest (ULONGEST l); | |
74aedc46 TT |
1010 | int gdb_py_int_as_long (PyObject *, long *); |
1011 | ||
2e8265fd TT |
1012 | PyObject *gdb_py_generic_dict (PyObject *self, void *closure); |
1013 | ||
aa36459a TT |
1014 | int gdb_pymodule_addobject (PyObject *module, const char *name, |
1015 | PyObject *object) | |
1016 | CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION; | |
1017 | ||
aef117b7 AB |
1018 | |
1019 | /* Return a Python string (str) object that represents SELF. SELF can be | |
1020 | any object type, but should be in an "invalid" state. What "invalid" | |
1021 | means is up to the caller. The returned string will take the form | |
1022 | "<TYPENAME (invalid)>", without the quotes, and with TYPENAME replaced | |
1023 | with the type of SELF. */ | |
1024 | ||
1025 | PyObject *gdb_py_invalid_object_repr (PyObject *self); | |
1026 | ||
e5250216 YQ |
1027 | struct varobj_iter; |
1028 | struct varobj; | |
c4a3dbaf TT |
1029 | std::unique_ptr<varobj_iter> py_varobj_get_iterator |
1030 | (struct varobj *var, | |
1031 | PyObject *printer, | |
1032 | const value_print_options *opts); | |
e5250216 | 1033 | |
26c89782 KB |
1034 | /* Deleter for Py_buffer unique_ptr specialization. */ |
1035 | ||
1036 | struct Py_buffer_deleter | |
1037 | { | |
1038 | void operator() (Py_buffer *b) const | |
1039 | { | |
1040 | PyBuffer_Release (b); | |
1041 | } | |
1042 | }; | |
1043 | ||
1044 | /* A unique_ptr specialization for Py_buffer. */ | |
1045 | typedef std::unique_ptr<Py_buffer, Py_buffer_deleter> Py_buffer_up; | |
1046 | ||
43d5901d AB |
1047 | /* Parse a register number from PYO_REG_ID and place the register number |
1048 | into *REG_NUM. The register is a register for GDBARCH. | |
1049 | ||
1050 | If a register is parsed successfully then *REG_NUM will have been | |
1051 | updated, and true is returned. Otherwise the contents of *REG_NUM are | |
bdc8cfc1 TT |
1052 | undefined, and false is returned. When false is returned, the |
1053 | Python error is set. | |
43d5901d AB |
1054 | |
1055 | The PYO_REG_ID object can be a string, the name of the register. This | |
1056 | is the slowest approach as GDB has to map the name to a number for each | |
1057 | call. Alternatively PYO_REG_ID can be an internal GDB register | |
1058 | number. This is quick but should not be encouraged as this means | |
1059 | Python scripts are now dependent on GDB's internal register numbering. | |
1060 | Final PYO_REG_ID can be a gdb.RegisterDescriptor object, these objects | |
1061 | can be looked up by name once, and then cache the register number so | |
1062 | should be as quick as using a register number. */ | |
1063 | ||
1064 | extern bool gdbpy_parse_register_id (struct gdbarch *gdbarch, | |
1065 | PyObject *pyo_reg_id, int *reg_num); | |
1066 | ||
25209e2c AB |
1067 | /* Return true if OBJ is a gdb.Architecture object, otherwise, return |
1068 | false. */ | |
1069 | ||
1070 | extern bool gdbpy_is_architecture (PyObject *obj); | |
1071 | ||
1072 | /* Return true if OBJ is a gdb.Progspace object, otherwise, return false. */ | |
1073 | ||
1074 | extern bool gdbpy_is_progspace (PyObject *obj); | |
1075 | ||
51e8dbe1 AB |
1076 | /* Take DOC, the documentation string for a GDB command defined in Python, |
1077 | and return an (possibly) modified version of that same string. | |
1078 | ||
1079 | When a command is defined in Python, the documentation string will | |
1080 | usually be indented based on the indentation of the surrounding Python | |
1081 | code. However, the documentation string is a literal string, all the | |
1082 | white-space added for indentation is included within the documentation | |
1083 | string. | |
1084 | ||
1085 | This indentation is then included in the help text that GDB displays, | |
1086 | which looks odd out of the context of the original Python source code. | |
1087 | ||
1088 | This function analyses DOC and tries to figure out what white-space | |
1089 | within DOC was added as part of the indentation, and then removes that | |
1090 | white-space from the copy that is returned. | |
1091 | ||
1092 | If the analysis of DOC fails then DOC will be returned unmodified. */ | |
1093 | ||
1094 | extern gdb::unique_xmalloc_ptr<char> gdbpy_fix_doc_string_indentation | |
1095 | (gdb::unique_xmalloc_ptr<char> doc); | |
1096 | ||
15e15b2d AB |
1097 | /* Implement the 'print_insn' hook for Python. Disassemble an instruction |
1098 | whose address is ADDRESS for architecture GDBARCH. The bytes of the | |
1099 | instruction should be read with INFO->read_memory_func as the | |
1100 | instruction being disassembled might actually be in a buffer. | |
1101 | ||
1102 | Used INFO->fprintf_func to print the results of the disassembly, and | |
1103 | return the length of the instruction in octets. | |
1104 | ||
1105 | If no instruction can be disassembled then return an empty value. */ | |
1106 | ||
6b09f134 | 1107 | extern std::optional<int> gdbpy_print_insn (struct gdbarch *gdbarch, |
15e15b2d AB |
1108 | CORE_ADDR address, |
1109 | disassemble_info *info); | |
1110 | ||
336bb2a1 TT |
1111 | /* A wrapper for PyType_Ready that also automatically registers the |
1112 | type in the appropriate module. Returns 0 on success, -1 on error. | |
1113 | If MOD is supplied, then the type is added to that module. If MOD | |
1114 | is not supplied, the type name (tp_name field) must be of the form | |
1115 | "gdb.Mumble", and the type will be added to the gdb module. */ | |
1116 | ||
1117 | static inline int | |
1118 | gdbpy_type_ready (PyTypeObject *type, PyObject *mod = nullptr) | |
1119 | { | |
1120 | if (PyType_Ready (type) < 0) | |
1121 | return -1; | |
1122 | if (mod == nullptr) | |
1123 | { | |
1124 | gdb_assert (startswith (type->tp_name, "gdb.")); | |
1125 | mod = gdb_module; | |
1126 | } | |
1127 | const char *dot = strrchr (type->tp_name, '.'); | |
1128 | gdb_assert (dot != nullptr); | |
1129 | return gdb_pymodule_addobject (mod, dot + 1, (PyObject *) type); | |
1130 | } | |
1131 | ||
1132 | /* Poison PyType_Ready. Only gdbpy_type_ready should be used, to | |
1133 | avoid forgetting to register the type. See PR python/32163. */ | |
1134 | #undef PyType_Ready | |
1135 | #ifdef __GNUC__ | |
1136 | # pragma GCC poison PyType_Ready | |
1137 | #else | |
1138 | # define PyType_Ready POISONED_PyType_Ready | |
1139 | #endif | |
1140 | ||
a6918531 JV |
1141 | /* A class to manage lifecycle of Python objects for objects that are "owned" |
1142 | by an objfile or a gdbarch. It keeps track of Python objects and when | |
1143 | the "owning" object (objfile or gdbarch) is about to be freed, ensures that | |
1144 | all Python objects "owned" by that object are properly invalidated. | |
1145 | ||
1146 | The actual tracking of "owned" Python objects is handled externally | |
1147 | by storage class. Storage object is created for each owning object | |
1148 | on demand and it is deleted when owning object is about to be freed. | |
1149 | ||
1150 | The storage class must provide two member types: | |
1151 | ||
1152 | * obj_type - the type of Python object whose lifecycle is managed. | |
1153 | * val_type - the type of GDB structure the Python objects are | |
1154 | representing. | |
1155 | ||
1156 | It must also provide following methods: | |
1157 | ||
1158 | void add (obj_type *obj); | |
1159 | void remove (obj_type *obj); | |
1160 | ||
1161 | Memoizing storage must in addition to method above provide: | |
1162 | ||
1163 | obj_type *lookup (val_type *val); | |
1164 | ||
1165 | Finally it must invalidate all registered Python objects upon deletion. */ | |
1166 | template <typename Storage> | |
1167 | class gdbpy_registry | |
1168 | { | |
1169 | public: | |
1170 | using obj_type = typename Storage::obj_type; | |
1171 | using val_type = typename Storage::val_type; | |
1172 | ||
1173 | /* Register Python object OBJ as being "owned" by OWNER. When OWNER is | |
1174 | about to be freed, OBJ will be invalidated. */ | |
1175 | template <typename O> | |
1176 | void add (O *owner, obj_type *obj) const | |
1177 | { | |
1178 | get_storage (owner)->add (obj); | |
1179 | } | |
1180 | ||
1181 | /* Unregister Python object OBJ. OBJ will no longer be invalidated when | |
1182 | OWNER is about to be be freed. */ | |
1183 | template <typename O> | |
1184 | void remove (O *owner, obj_type *obj) const | |
1185 | { | |
1186 | get_storage (owner)->remove (obj); | |
1187 | } | |
1188 | ||
1189 | /* Lookup pre-existing Python object for given VAL. Return such object | |
1190 | if found, otherwise return NULL. This method always returns new | |
1191 | reference. */ | |
1192 | template <typename O> | |
1193 | obj_type *lookup (O *owner, val_type *val) const | |
1194 | { | |
1195 | obj_type *obj = get_storage (owner)->lookup (val); | |
1196 | Py_XINCREF (obj); | |
1197 | return obj; | |
1198 | } | |
1199 | ||
1200 | private: | |
1201 | ||
1202 | template<typename O> | |
d3d4840e | 1203 | using StorageKey = typename registry<O>::template key<Storage>; |
a6918531 JV |
1204 | |
1205 | template<typename O> | |
1206 | Storage *get_storage (O *owner, const StorageKey<O> &key) const | |
1207 | { | |
1208 | Storage *r = key.get (owner); | |
1209 | if (r == nullptr) | |
1210 | { | |
1211 | r = new Storage(); | |
1212 | key.set (owner, r); | |
1213 | } | |
1214 | return r; | |
1215 | } | |
1216 | ||
1217 | Storage *get_storage (struct objfile* objf) const | |
1218 | { | |
1219 | return get_storage (objf, m_key_for_objf); | |
1220 | } | |
1221 | ||
1222 | Storage *get_storage (struct gdbarch* arch) const | |
1223 | { | |
1224 | return get_storage (arch, m_key_for_arch); | |
1225 | } | |
1226 | ||
1227 | const registry<objfile>::key<Storage> m_key_for_objf; | |
1228 | const registry<gdbarch>::key<Storage> m_key_for_arch; | |
1229 | }; | |
1230 | ||
1231 | /* Default invalidator for Python objects. */ | |
1232 | template <typename P, typename V, V* P::*val_slot> | |
1233 | struct gdbpy_default_invalidator | |
1234 | { | |
1235 | void operator() (P *obj) | |
1236 | { | |
1237 | obj->*val_slot = nullptr; | |
1238 | } | |
1239 | }; | |
1240 | ||
1241 | /* A "storage" implementation suitable for temporary (on-demand) objects. */ | |
1242 | template <typename P, | |
1243 | typename V, | |
1244 | V* P::*val_slot, | |
1245 | typename Invalidator = gdbpy_default_invalidator<P, V, val_slot>> | |
1246 | class gdbpy_tracking_registry_storage | |
1247 | { | |
1248 | public: | |
1249 | using obj_type = P; | |
1250 | using val_type = V; | |
1251 | ||
1252 | void add (obj_type *obj) | |
1253 | { | |
1254 | gdb_assert (obj != nullptr && obj->*val_slot != nullptr); | |
1255 | ||
1256 | m_objects.insert (obj); | |
1257 | } | |
1258 | ||
1259 | void remove (obj_type *obj) | |
1260 | { | |
1261 | gdb_assert (obj != nullptr && obj->*val_slot != nullptr); | |
1262 | gdb_assert (m_objects.contains (obj)); | |
1263 | ||
1264 | m_objects.erase (obj); | |
1265 | } | |
1266 | ||
1267 | ~gdbpy_tracking_registry_storage () | |
1268 | { | |
1269 | Invalidator invalidate; | |
1270 | gdbpy_enter enter_py; | |
1271 | ||
1272 | for (auto each : m_objects) | |
1273 | invalidate (each); | |
1274 | m_objects.clear (); | |
1275 | } | |
1276 | ||
1277 | protected: | |
1278 | gdb::unordered_set<obj_type *> m_objects; | |
1279 | }; | |
1280 | ||
1281 | /* A "storage" implementation suitable for memoized (interned) Python objects. | |
1282 | ||
1283 | Python objects are memoized (interned) temporarily, meaning that when user | |
1284 | drops all their references the Python object is deallocated and removed | |
1285 | from storage. | |
1286 | */ | |
1287 | template <typename P, | |
1288 | typename V, | |
1289 | V* P::*val_slot, | |
1290 | typename Invalidator = gdbpy_default_invalidator<P, V, val_slot>> | |
1291 | class gdbpy_memoizing_registry_storage | |
1292 | { | |
1293 | public: | |
1294 | using obj_type = P; | |
1295 | using val_type = V; | |
1296 | ||
1297 | void add (obj_type *obj) | |
1298 | { | |
1299 | gdb_assert (obj != nullptr && obj->*val_slot != nullptr); | |
1300 | ||
1301 | m_objects[obj->*val_slot] = obj; | |
1302 | } | |
1303 | ||
1304 | void remove (obj_type *obj) | |
1305 | { | |
1306 | gdb_assert (obj != nullptr && obj->*val_slot != nullptr); | |
1307 | gdb_assert (m_objects.contains (obj->*val_slot)); | |
1308 | ||
1309 | m_objects.erase (obj->*val_slot); | |
1310 | } | |
1311 | ||
1312 | obj_type *lookup (val_type *val) const | |
1313 | { | |
1314 | auto result = m_objects.find (val); | |
1315 | if (result != m_objects.end ()) | |
1316 | return result->second; | |
1317 | else | |
1318 | return nullptr; | |
1319 | } | |
1320 | ||
1321 | ~gdbpy_memoizing_registry_storage () | |
1322 | { | |
1323 | Invalidator invalidate; | |
1324 | gdbpy_enter enter_py; | |
1325 | ||
1326 | for (auto each : m_objects) | |
1327 | invalidate (each.second); | |
1328 | m_objects.clear (); | |
1329 | } | |
1330 | ||
1331 | protected: | |
1332 | gdb::unordered_map<val_type *, obj_type *> m_objects; | |
1333 | }; | |
1334 | ||
cc709640 | 1335 | #endif /* GDB_PYTHON_PYTHON_INTERNAL_H */ |