Automatic Copyright Year update after running gdb/copyright.py
[deliverable/binutils-gdb.git] / gdb / python / python-internal.h
CommitLineData
d57a3c85
TJB
1/* Gdb/Python header for private use by Python module.
2
88b9d363 3 Copyright (C) 2008-2022 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
1a5c2598
TT
20#ifndef PYTHON_PYTHON_INTERNAL_H
21#define PYTHON_PYTHON_INTERNAL_H
d57a3c85 22
6dddc817 23#include "extension.h"
e992c591 24#include "extension-priv.h"
6dddc817 25
62eec1a5
TT
26/* These WITH_* macros are defined by the CPython API checker that
27 comes with the Python plugin for GCC. See:
28 https://gcc-python-plugin.readthedocs.org/en/latest/cpychecker.html
29 The checker defines a WITH_ macro for each attribute it
94c8b725
TT
30 exposes. Note that we intentionally do not use
31 'cpychecker_returns_borrowed_ref' -- that idiom is forbidden in
32 gdb. */
634c58be 33
62eec1a5
TT
34#ifdef WITH_CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF_ATTRIBUTE
35#define CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF(ARG) \
36 __attribute__ ((cpychecker_type_object_for_typedef (ARG)))
37#else
38#define CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF(ARG)
39#endif
40
56cc411c
TT
41#ifdef WITH_CPYCHECKER_SETS_EXCEPTION_ATTRIBUTE
42#define CPYCHECKER_SETS_EXCEPTION __attribute__ ((cpychecker_sets_exception))
43#else
44#define CPYCHECKER_SETS_EXCEPTION
45#endif
46
5d153bd1
TT
47#ifdef WITH_CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION_ATTRIBUTE
48#define CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION \
49 __attribute__ ((cpychecker_negative_result_sets_exception))
50#else
51#define CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION
52#endif
53
d57a3c85
TJB
54/* /usr/include/features.h on linux systems will define _POSIX_C_SOURCE
55 if it sees _GNU_SOURCE (which config.h will define).
56 pyconfig.h defines _POSIX_C_SOURCE to a different value than
57 /usr/include/features.h does causing compilation to fail.
aac63f0f
JB
58 To work around this, undef _POSIX_C_SOURCE before we include Python.h.
59
60 Same problem with _XOPEN_SOURCE. */
d57a3c85 61#undef _POSIX_C_SOURCE
aac63f0f 62#undef _XOPEN_SOURCE
d57a3c85 63
aed1781d
JB
64/* On sparc-solaris, /usr/include/sys/feature_tests.h defines
65 _FILE_OFFSET_BITS, which pyconfig.h also defines. Same work
284a3db3 66 around technique as above. */
aed1781d
JB
67#undef _FILE_OFFSET_BITS
68
1cdd3232
EZ
69/* A kludge to avoid redefinition of snprintf on Windows by pyerrors.h. */
70#if defined(_WIN32) && defined(HAVE_DECL_SNPRINTF)
71#define HAVE_SNPRINTF 1
72#endif
73
b2a426e2
EZ
74/* Another kludge to avoid compilation errors because MinGW defines
75 'hypot' to '_hypot', but the C++ headers says "using ::hypot". */
76#ifdef __MINGW32__
77# define _hypot hypot
78#endif
79
1c033f8c
TT
80/* Request clean size types from Python. */
81#define PY_SSIZE_T_CLEAN
82
ac534cba
JB
83/* Include the Python header files using angle brackets rather than
84 double quotes. On case-insensitive filesystems, this prevents us
85 from including our python/python.h header file. */
86#include <Python.h>
87#include <frameobject.h>
a5c5eda7 88#include "py-ref.h"
9a27f2c6
PK
89
90#if PY_MAJOR_VERSION >= 3
91#define IS_PY3K 1
92#endif
93
94#ifdef IS_PY3K
95#define Py_TPFLAGS_HAVE_ITER 0
96#define Py_TPFLAGS_CHECKTYPES 0
97
98#define PyInt_Check PyLong_Check
9a27f2c6 99#define PyInt_AsLong PyLong_AsLong
75c0bdf4 100#define PyInt_AsSsize_t PyLong_AsSsize_t
9a27f2c6
PK
101
102#define PyString_FromString PyUnicode_FromString
103#define PyString_Decode PyUnicode_Decode
104#define PyString_FromFormat PyUnicode_FromFormat
105#define PyString_Check PyUnicode_Check
106#endif
107
ca30a762
TT
108/* If Python.h does not define WITH_THREAD, then the various
109 GIL-related functions will not be defined. However,
110 PyGILState_STATE will be. */
111#ifndef WITH_THREAD
112#define PyGILState_Ensure() ((PyGILState_STATE) 0)
548a926a 113#define PyGILState_Release(ARG) ((void)(ARG))
aed1781d 114#define PyEval_InitThreads()
548a926a 115#define PyThreadState_Swap(ARG) ((void)(ARG))
aed1781d 116#define PyEval_ReleaseLock()
ca30a762
TT
117#endif
118
74aedc46
TT
119/* Python supplies HAVE_LONG_LONG and some `long long' support when it
120 is available. These defines let us handle the differences more
121 cleanly. */
122#ifdef HAVE_LONG_LONG
123
124#define GDB_PY_LL_ARG "L"
125#define GDB_PY_LLU_ARG "K"
126typedef PY_LONG_LONG gdb_py_longest;
127typedef unsigned PY_LONG_LONG gdb_py_ulongest;
74aedc46
TT
128#define gdb_py_long_as_ulongest PyLong_AsUnsignedLongLong
129
130#else /* HAVE_LONG_LONG */
131
132#define GDB_PY_LL_ARG "L"
133#define GDB_PY_LLU_ARG "K"
134typedef long gdb_py_longest;
135typedef unsigned long gdb_py_ulongest;
74aedc46
TT
136#define gdb_py_long_as_ulongest PyLong_AsUnsignedLong
137
138#endif /* HAVE_LONG_LONG */
139
881d5d5d
JK
140#if PY_VERSION_HEX < 0x03020000
141typedef long Py_hash_t;
142#endif
143
6f8b0407
SM
144/* PyMem_RawMalloc appeared in Python 3.4. For earlier versions, we can just
145 fall back to PyMem_Malloc. */
146
147#if PY_VERSION_HEX < 0x03040000
148#define PyMem_RawMalloc PyMem_Malloc
149#endif
150
1915daeb
PA
151/* Python 2.6 did not wrap Py_DECREF in 'do {...} while (0)', leading
152 to 'suggest explicit braces to avoid ambiguous ‘else’' gcc errors.
153 Wrap it ourselves, so that callers don't need to care. */
154
155static inline void
ac90359c 156gdb_Py_DECREF (void *op) /* ARI: editCase function */
1915daeb 157{
6c28e44a 158 Py_DECREF (op);
1915daeb
PA
159}
160
161#undef Py_DECREF
162#define Py_DECREF(op) gdb_Py_DECREF (op)
74aedc46 163
4d759979
PA
164/* PyObject_CallMethod's 'method' and 'format' parameters were missing
165 the 'const' qualifier before Python 3.4. Hence, we wrap the
166 function in our own version to avoid errors with string literals.
167 Note, this is a variadic template because PyObject_CallMethod is a
168 varargs function and Python doesn't have a "PyObject_VaCallMethod"
169 variant taking a va_list that we could defer to instead. */
170
171template<typename... Args>
172static inline PyObject *
173gdb_PyObject_CallMethod (PyObject *o, const char *method, const char *format,
174 Args... args) /* ARI: editCase function */
175{
176 return PyObject_CallMethod (o,
177 const_cast<char *> (method),
178 const_cast<char *> (format),
179 args...);
180}
181
182#undef PyObject_CallMethod
183#define PyObject_CallMethod gdb_PyObject_CallMethod
184
185/* The 'name' parameter of PyErr_NewException was missing the 'const'
186 qualifier in Python <= 3.4. Hence, we wrap it in a function to
187 avoid errors when compiled with -Werror. */
188
189static inline PyObject*
190gdb_PyErr_NewException (const char *name, PyObject *base, PyObject *dict)
191{
192 return PyErr_NewException (const_cast<char *> (name), base, dict);
193}
194
195#define PyErr_NewException gdb_PyErr_NewException
196
197/* PySys_GetObject's 'name' parameter was missing the 'const'
198 qualifier before Python 3.4. Hence, we wrap it in a function to
199 avoid errors when compiled with -Werror. */
200
201static inline PyObject *
202gdb_PySys_GetObject (const char *name)
203{
204 return PySys_GetObject (const_cast<char *> (name));
205}
206
207#define PySys_GetObject gdb_PySys_GetObject
208
209/* PySys_SetPath's 'path' parameter was missing the 'const' qualifier
210 before Python 3.6. Hence, we wrap it in a function to avoid errors
211 when compiled with -Werror. */
212
213#ifdef IS_PY3K
214# define GDB_PYSYS_SETPATH_CHAR wchar_t
215#else
216# define GDB_PYSYS_SETPATH_CHAR char
217#endif
218
219static inline void
220gdb_PySys_SetPath (const GDB_PYSYS_SETPATH_CHAR *path)
221{
222 PySys_SetPath (const_cast<GDB_PYSYS_SETPATH_CHAR *> (path));
223}
224
225#define PySys_SetPath gdb_PySys_SetPath
226
0d1f4ceb
PA
227/* Wrap PyGetSetDef to allow convenient construction with string
228 literals. Unfortunately, PyGetSetDef's 'name' and 'doc' members
229 are 'char *' instead of 'const char *', meaning that in order to
230 list-initialize PyGetSetDef arrays with string literals (and
231 without the wrapping below) would require writing explicit 'char *'
232 casts. Instead, we extend PyGetSetDef and add constexpr
233 constructors that accept const 'name' and 'doc', hiding the ugly
234 casts here in a single place. */
235
236struct gdb_PyGetSetDef : PyGetSetDef
237{
238 constexpr gdb_PyGetSetDef (const char *name_, getter get_, setter set_,
239 const char *doc_, void *closure_)
240 : PyGetSetDef {const_cast<char *> (name_), get_, set_,
241 const_cast<char *> (doc_), closure_}
242 {}
243
244 /* Alternative constructor that allows omitting the closure in list
245 initialization. */
246 constexpr gdb_PyGetSetDef (const char *name_, getter get_, setter set_,
247 const char *doc_)
248 : gdb_PyGetSetDef {name_, get_, set_, doc_, NULL}
249 {}
250
251 /* Constructor for the sentinel entries. */
252 constexpr gdb_PyGetSetDef (std::nullptr_t)
253 : gdb_PyGetSetDef {NULL, NULL, NULL, NULL, NULL}
254 {}
255};
256
2adadf51
PA
257/* The 'keywords' parameter of PyArg_ParseTupleAndKeywords has type
258 'char **'. However, string literals are const in C++, and so to
259 avoid casting at every keyword array definition, we'll need to make
260 the keywords array an array of 'const char *'. To avoid having all
261 callers add a 'const_cast<char **>' themselves when passing such an
262 array through 'char **', we define our own version of
263 PyArg_ParseTupleAndKeywords here with a corresponding 'keywords'
264 parameter type that does the cast in a single place. (This is not
265 an overload of PyArg_ParseTupleAndKeywords in order to make it
266 clearer that we're calling our own function instead of a function
267 that exists in some newer Python version.) */
268
269static inline int
270gdb_PyArg_ParseTupleAndKeywords (PyObject *args, PyObject *kw,
271 const char *format, const char **keywords, ...)
272{
273 va_list ap;
274 int res;
275
276 va_start (ap, keywords);
277 res = PyArg_VaParseTupleAndKeywords (args, kw, format,
278 const_cast<char **> (keywords),
279 ap);
280 va_end (ap);
281
282 return res;
283}
284
256458bc 285/* In order to be able to parse symtab_and_line_to_sal_object function
9cb74f47
PM
286 a real symtab_and_line structure is needed. */
287#include "symtab.h"
288
d7b32ed3
PM
289/* Also needed to parse enum var_types. */
290#include "command.h"
505500db 291#include "breakpoint.h"
d7b32ed3 292
a73bb892
PK
293enum gdbpy_iter_kind { iter_keys, iter_values, iter_items };
294
f3e9a817 295struct block;
a08702d6 296struct value;
d452c4bc 297struct language_defn;
fa33c3cd 298struct program_space;
505500db 299struct bpstats;
619cebe8 300struct inferior;
d57a3c85 301
0646da15
TT
302extern int gdb_python_initialized;
303
d57a3c85 304extern PyObject *gdb_module;
b9516fa1 305extern PyObject *gdb_python_module;
62eec1a5
TT
306extern PyTypeObject value_object_type
307 CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("value_object");
308extern PyTypeObject block_object_type
309 CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF("block_object");
310extern PyTypeObject symbol_object_type
311 CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("symbol_object");
312extern PyTypeObject event_object_type
313 CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("event_object");
62eec1a5
TT
314extern PyTypeObject breakpoint_object_type
315 CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("breakpoint_object");
316extern PyTypeObject frame_object_type
317 CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("frame_object");
fbbe5337
KB
318extern PyTypeObject thread_object_type
319 CPYCHECKER_TYPE_OBJECT_FOR_TYPEDEF ("thread_object");
cc72b2a2 320
f99b5177 321struct gdbpy_breakpoint_object
cc72b2a2
KP
322{
323 PyObject_HEAD
324
325 /* The breakpoint number according to gdb. */
326 int number;
327
328 /* The gdb breakpoint object, or NULL if the breakpoint has been
329 deleted. */
330 struct breakpoint *bp;
331
332 /* 1 is this is a FinishBreakpoint object, 0 otherwise. */
333 int is_finish_bp;
f99b5177 334};
cc72b2a2
KP
335
336/* Require that BREAKPOINT be a valid breakpoint ID; throw a Python
337 exception if it is invalid. */
338#define BPPY_REQUIRE_VALID(Breakpoint) \
339 do { \
340 if ((Breakpoint)->bp == NULL) \
dda83cd7
SM
341 return PyErr_Format (PyExc_RuntimeError, \
342 _("Breakpoint %d is invalid."), \
343 (Breakpoint)->number); \
cc72b2a2
KP
344 } while (0)
345
346/* Require that BREAKPOINT be a valid breakpoint ID; throw a Python
347 exception if it is invalid. This macro is for use in setter functions. */
348#define BPPY_SET_REQUIRE_VALID(Breakpoint) \
349 do { \
350 if ((Breakpoint)->bp == NULL) \
dda83cd7
SM
351 { \
352 PyErr_Format (PyExc_RuntimeError, _("Breakpoint %d is invalid."), \
353 (Breakpoint)->number); \
354 return -1; \
355 } \
cc72b2a2
KP
356 } while (0)
357
358
359/* Variables used to pass information between the Breakpoint
360 constructor and the breakpoint-created hook function. */
4cb0213d 361extern gdbpy_breakpoint_object *bppy_pending_object;
505500db 362
a08702d6 363
f99b5177 364struct thread_object
595939de
PM
365{
366 PyObject_HEAD
367
368 /* The thread we represent. */
369 struct thread_info *thread;
370
371 /* The Inferior object to which this thread belongs. */
372 PyObject *inf_obj;
f99b5177 373};
595939de 374
00431a78
PA
375struct inferior_object;
376
8a1ea21f
DE
377extern struct cmd_list_element *set_python_list;
378extern struct cmd_list_element *show_python_list;
6dddc817
DE
379\f
380/* extension_language_script_ops "methods". */
381
db972fce
SM
382/* Return true if auto-loading Python scripts is enabled.
383 This is the extension_language_script_ops.auto_load_enabled "method". */
384
385extern bool gdbpy_auto_load_enabled (const struct extension_language_defn *);
6dddc817
DE
386
387/* extension_language_ops "methods". */
388
389extern enum ext_lang_rc gdbpy_apply_val_pretty_printer
390 (const struct extension_language_defn *,
42331a1e 391 struct value *value,
6dddc817 392 struct ui_file *stream, int recurse,
6dddc817
DE
393 const struct value_print_options *options,
394 const struct language_defn *language);
395extern enum ext_lang_bt_status gdbpy_apply_frame_filter
396 (const struct extension_language_defn *,
d4dd3282
TT
397 struct frame_info *frame, frame_filter_flags flags,
398 enum ext_lang_frame_args args_type,
6dddc817
DE
399 struct ui_out *out, int frame_low, int frame_high);
400extern void gdbpy_preserve_values (const struct extension_language_defn *,
401 struct objfile *objfile,
402 htab_t copied_types);
403extern enum ext_lang_bp_stop gdbpy_breakpoint_cond_says_stop
404 (const struct extension_language_defn *, struct breakpoint *);
405extern int gdbpy_breakpoint_has_cond (const struct extension_language_defn *,
406 struct breakpoint *b);
883964a7 407
883964a7
SC
408extern enum ext_lang_rc gdbpy_get_matching_xmethod_workers
409 (const struct extension_language_defn *extlang,
410 struct type *obj_type, const char *method_name,
ba18742c
SM
411 std::vector<xmethod_worker_up> *dm_vec);
412
6dddc817 413\f
08c637de 414PyObject *gdbpy_history (PyObject *self, PyObject *args);
7729052b
TT
415PyObject *gdbpy_convenience_variable (PyObject *self, PyObject *args);
416PyObject *gdbpy_set_convenience_variable (PyObject *self, PyObject *args);
adc36818 417PyObject *gdbpy_breakpoints (PyObject *, PyObject *);
f8f6f20b 418PyObject *gdbpy_frame_stop_reason_string (PyObject *, PyObject *);
f3e9a817 419PyObject *gdbpy_lookup_symbol (PyObject *self, PyObject *args, PyObject *kw);
6e6fbe60
DE
420PyObject *gdbpy_lookup_global_symbol (PyObject *self, PyObject *args,
421 PyObject *kw);
2906593f
CB
422PyObject *gdbpy_lookup_static_symbol (PyObject *self, PyObject *args,
423 PyObject *kw);
086baaf1
AB
424PyObject *gdbpy_lookup_static_symbols (PyObject *self, PyObject *args,
425 PyObject *kw);
4726b2d8
TW
426PyObject *gdbpy_start_recording (PyObject *self, PyObject *args);
427PyObject *gdbpy_current_recording (PyObject *self, PyObject *args);
428PyObject *gdbpy_stop_recording (PyObject *self, PyObject *args);
d8e22779 429PyObject *gdbpy_newest_frame (PyObject *self, PyObject *args);
f8f6f20b 430PyObject *gdbpy_selected_frame (PyObject *self, PyObject *args);
2c74e833 431PyObject *gdbpy_lookup_type (PyObject *self, PyObject *args, PyObject *kw);
a16b0e22 432int gdbpy_is_field (PyObject *obj);
be759fcf 433PyObject *gdbpy_create_lazy_string_object (CORE_ADDR address, long length,
9a2b4c1b
MS
434 const char *encoding,
435 struct type *type);
595939de 436PyObject *gdbpy_inferiors (PyObject *unused, PyObject *unused2);
162078c8 437PyObject *gdbpy_create_ptid_object (ptid_t ptid);
595939de 438PyObject *gdbpy_selected_thread (PyObject *self, PyObject *args);
2aa48337 439PyObject *gdbpy_selected_inferior (PyObject *self, PyObject *args);
07ca107c 440PyObject *gdbpy_string_to_argv (PyObject *self, PyObject *args);
d7b32ed3 441PyObject *gdbpy_parameter_value (enum var_types type, void *var);
4b8cb9dd
SM
442gdb::unique_xmalloc_ptr<char> gdbpy_parse_command_name
443 (const char *name, struct cmd_list_element ***base_list,
444 struct cmd_list_element **start_list);
01b1af32
TT
445PyObject *gdbpy_register_tui_window (PyObject *self, PyObject *args,
446 PyObject *kw);
a08702d6 447
f3e9a817
PM
448PyObject *symtab_and_line_to_sal_object (struct symtab_and_line sal);
449PyObject *symtab_to_symtab_object (struct symtab *symtab);
450PyObject *symbol_to_symbol_object (struct symbol *sym);
9df2fbc4
PM
451PyObject *block_to_block_object (const struct block *block,
452 struct objfile *objfile);
a08702d6 453PyObject *value_to_value_object (struct value *v);
42331a1e 454PyObject *value_to_value_object_no_release (struct value *v);
2c74e833 455PyObject *type_to_type_object (struct type *);
595939de 456PyObject *frame_info_to_frame_object (struct frame_info *frame);
bc79de95 457PyObject *symtab_to_linetable_object (PyObject *symtab);
3c7aa307 458gdbpy_ref<> pspace_to_pspace_object (struct program_space *);
fa33c3cd 459PyObject *pspy_get_printers (PyObject *, void *);
1e611234 460PyObject *pspy_get_frame_filters (PyObject *, void *);
d11916aa 461PyObject *pspy_get_frame_unwinders (PyObject *, void *);
883964a7 462PyObject *pspy_get_xmethods (PyObject *, void *);
fa33c3cd 463
0a9db5ad 464gdbpy_ref<> objfile_to_objfile_object (struct objfile *);
89c73ade 465PyObject *objfpy_get_printers (PyObject *, void *);
1e611234 466PyObject *objfpy_get_frame_filters (PyObject *, void *);
d11916aa 467PyObject *objfpy_get_frame_unwinders (PyObject *, void *);
883964a7 468PyObject *objfpy_get_xmethods (PyObject *, void *);
6dddd6a5 469PyObject *gdbpy_lookup_objfile (PyObject *self, PyObject *args, PyObject *kw);
a08702d6 470
bea883fd
SCR
471PyObject *gdbarch_to_arch_object (struct gdbarch *gdbarch);
472
0f767f94
AB
473PyObject *gdbpy_new_register_descriptor_iterator (struct gdbarch *gdbarch,
474 const char *group_name);
64cb3757 475PyObject *gdbpy_new_reggroup_iterator (struct gdbarch *gdbarch);
0f767f94 476
05b08ac1 477gdbpy_ref<thread_object> create_thread_object (struct thread_info *tp);
db1337cc 478gdbpy_ref<> thread_to_thread_object (thread_info *thr);;
61fd3e73 479gdbpy_ref<inferior_object> inferior_to_inferior_object (inferior *inf);
595939de 480
9df2fbc4 481const struct block *block_object_to_block (PyObject *obj);
f3e9a817 482struct symbol *symbol_object_to_symbol (PyObject *obj);
a6bac58e 483struct value *value_object_to_value (PyObject *self);
a08702d6 484struct value *convert_value_from_python (PyObject *obj);
2c74e833 485struct type *type_object_to_type (PyObject *obj);
f3e9a817
PM
486struct symtab *symtab_object_to_symtab (PyObject *obj);
487struct symtab_and_line *sal_object_to_symtab_and_line (PyObject *obj);
cc72b2a2 488struct frame_info *frame_object_to_frame_info (PyObject *frame_obj);
bea883fd 489struct gdbarch *arch_object_to_gdbarch (PyObject *obj);
a08702d6 490
037bbc8e 491void gdbpy_initialize_gdb_readline (void);
999633ed
TT
492int gdbpy_initialize_auto_load (void)
493 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
494int gdbpy_initialize_values (void)
495 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
496int gdbpy_initialize_frames (void)
497 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
d050f7d7
TW
498int gdbpy_initialize_instruction (void)
499 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
75c0bdf4
TW
500int gdbpy_initialize_btrace (void)
501 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
4726b2d8
TW
502int gdbpy_initialize_record (void)
503 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
999633ed
TT
504int gdbpy_initialize_symtabs (void)
505 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
506int gdbpy_initialize_commands (void)
507 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
508int gdbpy_initialize_symbols (void)
509 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
510int gdbpy_initialize_symtabs (void)
511 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
512int gdbpy_initialize_blocks (void)
513 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
514int gdbpy_initialize_types (void)
515 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
516int gdbpy_initialize_functions (void)
517 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
518int gdbpy_initialize_pspace (void)
519 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
520int gdbpy_initialize_objfile (void)
521 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
522int gdbpy_initialize_breakpoints (void)
523 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
524int gdbpy_initialize_finishbreakpoints (void)
525 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
526int gdbpy_initialize_lazy_string (void)
527 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
bc79de95
PM
528int gdbpy_initialize_linetable (void)
529 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
999633ed
TT
530int gdbpy_initialize_parameters (void)
531 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
532int gdbpy_initialize_thread (void)
533 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
534int gdbpy_initialize_inferior (void)
535 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
536int gdbpy_initialize_eventregistry (void)
537 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
538int gdbpy_initialize_event (void)
539 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
540int gdbpy_initialize_py_events (void)
541 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
999633ed
TT
542int gdbpy_initialize_arch (void)
543 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
0f767f94
AB
544int gdbpy_initialize_registers ()
545 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
883964a7
SC
546int gdbpy_initialize_xmethods (void)
547 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
d11916aa
SS
548int gdbpy_initialize_unwind (void)
549 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
01b1af32
TT
550int gdbpy_initialize_tui ()
551 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
d57a3c85 552
5c329e6a
TT
553/* A wrapper for PyErr_Fetch that handles reference counting for the
554 caller. */
555class gdbpy_err_fetch
556{
557public:
558
559 gdbpy_err_fetch ()
560 {
561 PyErr_Fetch (&m_error_type, &m_error_value, &m_error_traceback);
562 }
563
564 ~gdbpy_err_fetch ()
565 {
566 Py_XDECREF (m_error_type);
567 Py_XDECREF (m_error_value);
568 Py_XDECREF (m_error_traceback);
569 }
570
571 /* Call PyErr_Restore using the values stashed in this object.
572 After this call, this object is invalid and neither the to_string
573 nor restore methods may be used again. */
574
575 void restore ()
576 {
577 PyErr_Restore (m_error_type, m_error_value, m_error_traceback);
578 m_error_type = nullptr;
579 m_error_value = nullptr;
580 m_error_traceback = nullptr;
581 }
582
583 /* Return the string representation of the exception represented by
584 this object. If the result is NULL a python error occurred, the
585 caller must clear it. */
586
587 gdb::unique_xmalloc_ptr<char> to_string () const;
588
589 /* Return the string representation of the type of the exception
590 represented by this object. If the result is NULL a python error
591 occurred, the caller must clear it. */
592
593 gdb::unique_xmalloc_ptr<char> type_to_string () const;
594
595 /* Return true if the stored type matches TYPE, false otherwise. */
596
597 bool type_matches (PyObject *type) const
598 {
599 return PyErr_GivenExceptionMatches (m_error_type, type);
600 }
601
602private:
603
604 PyObject *m_error_type, *m_error_value, *m_error_traceback;
605};
606
4ecee2c4
TT
607/* Called before entering the Python interpreter to install the
608 current language and architecture to be used for Python values.
609 Also set the active extension language for GDB so that SIGINT's
610 are directed our way, and if necessary install the right SIGINT
611 handler. */
612class gdbpy_enter
613{
614 public:
615
616 gdbpy_enter (struct gdbarch *gdbarch, const struct language_defn *language);
617
618 ~gdbpy_enter ();
619
d6541620 620 DISABLE_COPY_AND_ASSIGN (gdbpy_enter);
4ecee2c4
TT
621
622 private:
623
624 struct active_ext_lang_state *m_previous_active;
625 PyGILState_STATE m_state;
626 struct gdbarch *m_gdbarch;
627 const struct language_defn *m_language;
5c329e6a
TT
628
629 /* An optional is used here because we don't want to call
630 PyErr_Fetch too early. */
631 gdb::optional<gdbpy_err_fetch> m_error;
4ecee2c4
TT
632};
633
6cd67bea
TT
634/* Like gdbpy_enter, but takes a varobj. This is a subclass just to
635 make constructor delegation a little nicer. */
636class gdbpy_enter_varobj : public gdbpy_enter
637{
638 public:
639
640 /* This is defined in varobj.c, where it can access varobj
641 internals. */
642 gdbpy_enter_varobj (const struct varobj *var);
643
644};
645
b5eba2d8
TT
646/* The opposite of gdb_enter: this releases the GIL around a region,
647 allowing other Python threads to run. No Python APIs may be used
648 while this is active. */
649class gdbpy_allow_threads
650{
651public:
652
653 gdbpy_allow_threads ()
654 : m_save (PyEval_SaveThread ())
655 {
656 gdb_assert (m_save != nullptr);
657 }
658
659 ~gdbpy_allow_threads ()
660 {
661 PyEval_RestoreThread (m_save);
662 }
663
664 DISABLE_COPY_AND_ASSIGN (gdbpy_allow_threads);
665
666private:
667
668 PyThreadState *m_save;
669};
670
d452c4bc
UW
671extern struct gdbarch *python_gdbarch;
672extern const struct language_defn *python_language;
d57a3c85
TJB
673
674/* Use this after a TRY_EXCEPT to throw the appropriate Python
675 exception. */
56cc411c
TT
676#define GDB_PY_HANDLE_EXCEPTION(Exception) \
677 do { \
678 if (Exception.reason < 0) \
679 { \
680 gdbpy_convert_exception (Exception); \
dda83cd7 681 return NULL; \
56cc411c
TT
682 } \
683 } while (0)
d57a3c85 684
adc36818
PM
685/* Use this after a TRY_EXCEPT to throw the appropriate Python
686 exception. This macro is for use inside setter functions. */
687#define GDB_PY_SET_HANDLE_EXCEPTION(Exception) \
688 do { \
689 if (Exception.reason < 0) \
dda83cd7 690 { \
621c8364 691 gdbpy_convert_exception (Exception); \
adc36818
PM
692 return -1; \
693 } \
694 } while (0)
d57a3c85 695
69b4374a 696int gdbpy_print_python_errors_p (void);
d57a3c85 697void gdbpy_print_stack (void);
6ef2312a 698void gdbpy_print_stack_or_quit ();
2b4ad2fe 699void gdbpy_handle_exception () ATTRIBUTE_NORETURN;
d57a3c85 700
833d985d 701gdbpy_ref<> python_string_to_unicode (PyObject *obj);
9b972014
TT
702gdb::unique_xmalloc_ptr<char> unicode_to_target_string (PyObject *unicode_str);
703gdb::unique_xmalloc_ptr<char> python_string_to_target_string (PyObject *obj);
833d985d 704gdbpy_ref<> python_string_to_target_python_string (PyObject *obj);
9b972014 705gdb::unique_xmalloc_ptr<char> python_string_to_host_string (PyObject *obj);
833d985d 706gdbpy_ref<> host_string_to_python_string (const char *str);
08c637de 707int gdbpy_is_string (PyObject *obj);
9b972014 708gdb::unique_xmalloc_ptr<char> gdbpy_obj_to_string (PyObject *obj);
07ca107c 709
be759fcf 710int gdbpy_is_lazy_string (PyObject *result);
09ca9e2e 711void gdbpy_extract_lazy_string (PyObject *string, CORE_ADDR *addr,
256458bc 712 struct type **str_type,
1eba6383
TT
713 long *length,
714 gdb::unique_xmalloc_ptr<char> *encoding);
d57a3c85 715
595939de
PM
716int gdbpy_is_value_object (PyObject *obj);
717
b6313243
TT
718/* Note that these are declared here, and not in python.h with the
719 other pretty-printer functions, because they refer to PyObject. */
a5c5eda7
SM
720gdbpy_ref<> apply_varobj_pretty_printer (PyObject *print_obj,
721 struct value **replacement,
722 struct ui_file *stream);
a31abe80 723gdbpy_ref<> gdbpy_get_varobj_pretty_printer (struct value *value);
9b972014 724gdb::unique_xmalloc_ptr<char> gdbpy_get_display_hint (PyObject *printer);
b6313243
TT
725PyObject *gdbpy_default_visualizer (PyObject *self, PyObject *args);
726
4cb0213d
DE
727void bpfinishpy_pre_stop_hook (struct gdbpy_breakpoint_object *bp_obj);
728void bpfinishpy_post_stop_hook (struct gdbpy_breakpoint_object *bp_obj);
cc72b2a2 729
d8906c6f 730extern PyObject *gdbpy_doc_cst;
a6bac58e
TT
731extern PyObject *gdbpy_children_cst;
732extern PyObject *gdbpy_to_string_cst;
733extern PyObject *gdbpy_display_hint_cst;
967cf477 734extern PyObject *gdbpy_enabled_cst;
fb6a3ed3 735extern PyObject *gdbpy_value_cst;
d8906c6f 736
621c8364
TT
737/* Exception types. */
738extern PyObject *gdbpy_gdb_error;
739extern PyObject *gdbpy_gdb_memory_error;
07ca107c
DE
740extern PyObject *gdbpy_gdberror_exc;
741
94aeb44b 742extern void gdbpy_convert_exception (const struct gdb_exception &)
56cc411c 743 CPYCHECKER_SETS_EXCEPTION;
621c8364 744
b86af38a
TT
745int get_addr_from_python (PyObject *obj, CORE_ADDR *addr)
746 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
595939de 747
12dfa12a
TT
748gdbpy_ref<> gdb_py_object_from_longest (LONGEST l);
749gdbpy_ref<> gdb_py_object_from_ulongest (ULONGEST l);
74aedc46
TT
750int gdb_py_int_as_long (PyObject *, long *);
751
2e8265fd
TT
752PyObject *gdb_py_generic_dict (PyObject *self, void *closure);
753
aa36459a
TT
754int gdb_pymodule_addobject (PyObject *module, const char *name,
755 PyObject *object)
756 CPYCHECKER_NEGATIVE_RESULT_SETS_EXCEPTION;
757
e5250216
YQ
758struct varobj_iter;
759struct varobj;
24fd95b4
TT
760std::unique_ptr<varobj_iter> py_varobj_get_iterator (struct varobj *var,
761 PyObject *printer);
e5250216 762
26c89782
KB
763/* Deleter for Py_buffer unique_ptr specialization. */
764
765struct Py_buffer_deleter
766{
767 void operator() (Py_buffer *b) const
768 {
769 PyBuffer_Release (b);
770 }
771};
772
773/* A unique_ptr specialization for Py_buffer. */
774typedef std::unique_ptr<Py_buffer, Py_buffer_deleter> Py_buffer_up;
775
43d5901d
AB
776/* Parse a register number from PYO_REG_ID and place the register number
777 into *REG_NUM. The register is a register for GDBARCH.
778
779 If a register is parsed successfully then *REG_NUM will have been
780 updated, and true is returned. Otherwise the contents of *REG_NUM are
781 undefined, and false is returned.
782
783 The PYO_REG_ID object can be a string, the name of the register. This
784 is the slowest approach as GDB has to map the name to a number for each
785 call. Alternatively PYO_REG_ID can be an internal GDB register
786 number. This is quick but should not be encouraged as this means
787 Python scripts are now dependent on GDB's internal register numbering.
788 Final PYO_REG_ID can be a gdb.RegisterDescriptor object, these objects
789 can be looked up by name once, and then cache the register number so
790 should be as quick as using a register number. */
791
792extern bool gdbpy_parse_register_id (struct gdbarch *gdbarch,
793 PyObject *pyo_reg_id, int *reg_num);
794
1a5c2598 795#endif /* PYTHON_PYTHON_INTERNAL_H */
This page took 1.471521 seconds and 4 git commands to generate.