[PATCH 7/57][Arm][GAS] Add support for MVE instructions: vstr/vldr
[binutils-gdb.git] / gdb / python / py-framefilter.c
blob017ea90f61909146112ca7a5497fd2bb7ff6db02
1 /* Python frame filters
3 Copyright (C) 2013-2019 Free Software Foundation, Inc.
5 This file is part of GDB.
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.
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.
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/>. */
20 #include "defs.h"
21 #include "objfiles.h"
22 #include "symtab.h"
23 #include "language.h"
24 #include "arch-utils.h"
25 #include "python.h"
26 #include "ui-out.h"
27 #include "valprint.h"
28 #include "annotate.h"
29 #include "hashtab.h"
30 #include "demangle.h"
31 #include "mi/mi-cmds.h"
32 #include "python-internal.h"
33 #include "common/gdb_optional.h"
35 enum mi_print_types
37 MI_PRINT_ARGS,
38 MI_PRINT_LOCALS
41 /* Helper function to extract a symbol, a name and a language
42 definition from a Python object that conforms to the "Symbol Value"
43 interface. OBJ is the Python object to extract the values from.
44 NAME is a pass-through argument where the name of the symbol will
45 be written. NAME is allocated in this function, but the caller is
46 responsible for clean up. SYM is a pass-through argument where the
47 symbol will be written and SYM_BLOCK is a pass-through argument to
48 write the block where the symbol lies in. In the case of the API
49 returning a string, this will be set to NULL. LANGUAGE is also a
50 pass-through argument denoting the language attributed to the
51 Symbol. In the case of SYM being NULL, this will be set to the
52 current language. Returns EXT_LANG_BT_ERROR on error with the
53 appropriate Python exception set, and EXT_LANG_BT_OK on success. */
55 static enum ext_lang_bt_status
56 extract_sym (PyObject *obj, gdb::unique_xmalloc_ptr<char> *name,
57 struct symbol **sym, const struct block **sym_block,
58 const struct language_defn **language)
60 gdbpy_ref<> result (PyObject_CallMethod (obj, "symbol", NULL));
62 if (result == NULL)
63 return EXT_LANG_BT_ERROR;
65 /* For 'symbol' callback, the function can return a symbol or a
66 string. */
67 if (gdbpy_is_string (result.get ()))
69 *name = python_string_to_host_string (result.get ());
71 if (*name == NULL)
72 return EXT_LANG_BT_ERROR;
73 /* If the API returns a string (and not a symbol), then there is
74 no symbol derived language available and the frame filter has
75 either overridden the symbol with a string, or supplied a
76 entirely synthetic symbol/value pairing. In that case, use
77 python_language. */
78 *language = python_language;
79 *sym = NULL;
80 *sym_block = NULL;
82 else
84 /* This type checks 'result' during the conversion so we
85 just call it unconditionally and check the return. */
86 *sym = symbol_object_to_symbol (result.get ());
87 /* TODO: currently, we have no way to recover the block in which SYMBOL
88 was found, so we have no block to return. Trying to evaluate SYMBOL
89 will yield an incorrect value when it's located in a FRAME and
90 evaluated from another frame (as permitted in nested functions). */
91 *sym_block = NULL;
93 if (*sym == NULL)
95 PyErr_SetString (PyExc_RuntimeError,
96 _("Unexpected value. Expecting a "
97 "gdb.Symbol or a Python string."));
98 return EXT_LANG_BT_ERROR;
101 /* Duplicate the symbol name, so the caller has consistency
102 in garbage collection. */
103 name->reset (xstrdup (SYMBOL_PRINT_NAME (*sym)));
105 /* If a symbol is specified attempt to determine the language
106 from the symbol. If mode is not "auto", then the language
107 has been explicitly set, use that. */
108 if (language_mode == language_mode_auto)
109 *language = language_def (SYMBOL_LANGUAGE (*sym));
110 else
111 *language = current_language;
114 return EXT_LANG_BT_OK;
117 /* Helper function to extract a value from an object that conforms to
118 the "Symbol Value" interface. OBJ is the Python object to extract
119 the value from. VALUE is a pass-through argument where the value
120 will be written. If the object does not have the value attribute,
121 or provides the Python None for a value, VALUE will be set to NULL
122 and this function will return as successful. Returns EXT_LANG_BT_ERROR
123 on error with the appropriate Python exception set, and EXT_LANG_BT_OK on
124 success. */
126 static enum ext_lang_bt_status
127 extract_value (PyObject *obj, struct value **value)
129 if (PyObject_HasAttrString (obj, "value"))
131 gdbpy_ref<> vresult (PyObject_CallMethod (obj, "value", NULL));
133 if (vresult == NULL)
134 return EXT_LANG_BT_ERROR;
136 /* The Python code has returned 'None' for a value, so we set
137 value to NULL. This flags that GDB should read the
138 value. */
139 if (vresult == Py_None)
141 *value = NULL;
142 return EXT_LANG_BT_OK;
144 else
146 *value = convert_value_from_python (vresult.get ());
148 if (*value == NULL)
149 return EXT_LANG_BT_ERROR;
151 return EXT_LANG_BT_OK;
154 else
155 *value = NULL;
157 return EXT_LANG_BT_OK;
160 /* MI prints only certain values according to the type of symbol and
161 also what the user has specified. SYM is the symbol to check, and
162 MI_PRINT_TYPES is an enum specifying what the user wants emitted
163 for the MI command in question. */
164 static int
165 mi_should_print (struct symbol *sym, enum mi_print_types type)
167 int print_me = 0;
169 switch (SYMBOL_CLASS (sym))
171 default:
172 case LOC_UNDEF: /* catches errors */
173 case LOC_CONST: /* constant */
174 case LOC_TYPEDEF: /* local typedef */
175 case LOC_LABEL: /* local label */
176 case LOC_BLOCK: /* local function */
177 case LOC_CONST_BYTES: /* loc. byte seq. */
178 case LOC_UNRESOLVED: /* unresolved static */
179 case LOC_OPTIMIZED_OUT: /* optimized out */
180 print_me = 0;
181 break;
183 case LOC_ARG: /* argument */
184 case LOC_REF_ARG: /* reference arg */
185 case LOC_REGPARM_ADDR: /* indirect register arg */
186 case LOC_LOCAL: /* stack local */
187 case LOC_STATIC: /* static */
188 case LOC_REGISTER: /* register */
189 case LOC_COMPUTED: /* computed location */
190 if (type == MI_PRINT_LOCALS)
191 print_me = ! SYMBOL_IS_ARGUMENT (sym);
192 else
193 print_me = SYMBOL_IS_ARGUMENT (sym);
195 return print_me;
198 /* Helper function which outputs a type name extracted from VAL to a
199 "type" field in the output stream OUT. OUT is the ui-out structure
200 the type name will be output too, and VAL is the value that the
201 type will be extracted from. */
203 static void
204 py_print_type (struct ui_out *out, struct value *val)
206 check_typedef (value_type (val));
208 string_file stb;
209 type_print (value_type (val), "", &stb, -1);
210 out->field_stream ("type", stb);
213 /* Helper function which outputs a value to an output field in a
214 stream. OUT is the ui-out structure the value will be output to,
215 VAL is the value that will be printed, OPTS contains the value
216 printing options, ARGS_TYPE is an enumerator describing the
217 argument format, and LANGUAGE is the language_defn that the value
218 will be printed with. */
220 static void
221 py_print_value (struct ui_out *out, struct value *val,
222 const struct value_print_options *opts,
223 int indent,
224 enum ext_lang_frame_args args_type,
225 const struct language_defn *language)
227 int should_print = 0;
229 /* MI does not print certain values, differentiated by type,
230 depending on what ARGS_TYPE indicates. Test type against option.
231 For CLI print all values. */
232 if (args_type == MI_PRINT_SIMPLE_VALUES
233 || args_type == MI_PRINT_ALL_VALUES)
235 struct type *type = check_typedef (value_type (val));
237 if (args_type == MI_PRINT_ALL_VALUES)
238 should_print = 1;
239 else if (args_type == MI_PRINT_SIMPLE_VALUES
240 && TYPE_CODE (type) != TYPE_CODE_ARRAY
241 && TYPE_CODE (type) != TYPE_CODE_STRUCT
242 && TYPE_CODE (type) != TYPE_CODE_UNION)
243 should_print = 1;
245 else if (args_type != NO_VALUES)
246 should_print = 1;
248 if (should_print)
250 string_file stb;
252 common_val_print (val, &stb, indent, opts, language);
253 out->field_stream ("value", stb);
257 /* Helper function to call a Python method and extract an iterator
258 from the result. If the function returns anything but an iterator
259 the exception is preserved and NULL is returned. FILTER is the
260 Python object to call, and FUNC is the name of the method. Returns
261 a PyObject, or NULL on error with the appropriate exception set.
262 This function can return an iterator, or NULL. */
264 static PyObject *
265 get_py_iter_from_func (PyObject *filter, const char *func)
267 if (PyObject_HasAttrString (filter, func))
269 gdbpy_ref<> result (PyObject_CallMethod (filter, func, NULL));
271 if (result != NULL)
273 if (result == Py_None)
275 return result.release ();
277 else
279 return PyObject_GetIter (result.get ());
283 else
284 Py_RETURN_NONE;
286 return NULL;
289 /* Helper function to output a single frame argument and value to an
290 output stream. This function will account for entry values if the
291 FV parameter is populated, the frame argument has entry values
292 associated with them, and the appropriate "set entry-value"
293 options are set. Will output in CLI or MI like format depending
294 on the type of output stream detected. OUT is the output stream,
295 SYM_NAME is the name of the symbol. If SYM_NAME is populated then
296 it must have an accompanying value in the parameter FV. FA is a
297 frame argument structure. If FA is populated, both SYM_NAME and
298 FV are ignored. OPTS contains the value printing options,
299 ARGS_TYPE is an enumerator describing the argument format,
300 PRINT_ARGS_FIELD is a flag which indicates if we output "ARGS=1"
301 in MI output in commands where both arguments and locals are
302 printed. */
304 static void
305 py_print_single_arg (struct ui_out *out,
306 const char *sym_name,
307 struct frame_arg *fa,
308 struct value *fv,
309 const struct value_print_options *opts,
310 enum ext_lang_frame_args args_type,
311 int print_args_field,
312 const struct language_defn *language)
314 struct value *val;
316 if (fa != NULL)
318 if (fa->val == NULL && fa->error == NULL)
319 return;
320 language = language_def (SYMBOL_LANGUAGE (fa->sym));
321 val = fa->val;
323 else
324 val = fv;
326 gdb::optional<ui_out_emit_tuple> maybe_tuple;
328 /* MI has varying rules for tuples, but generally if there is only
329 one element in each item in the list, do not start a tuple. The
330 exception is -stack-list-variables which emits an ARGS="1" field
331 if the value is a frame argument. This is denoted in this
332 function with PRINT_ARGS_FIELD which is flag from the caller to
333 emit the ARGS field. */
334 if (out->is_mi_like_p ())
336 if (print_args_field || args_type != NO_VALUES)
337 maybe_tuple.emplace (out, nullptr);
340 annotate_arg_begin ();
342 /* If frame argument is populated, check for entry-values and the
343 entry value options. */
344 if (fa != NULL)
346 string_file stb;
348 fprintf_symbol_filtered (&stb, SYMBOL_PRINT_NAME (fa->sym),
349 SYMBOL_LANGUAGE (fa->sym),
350 DMGL_PARAMS | DMGL_ANSI);
351 if (fa->entry_kind == print_entry_values_compact)
353 stb.puts ("=");
355 fprintf_symbol_filtered (&stb, SYMBOL_PRINT_NAME (fa->sym),
356 SYMBOL_LANGUAGE (fa->sym),
357 DMGL_PARAMS | DMGL_ANSI);
359 if (fa->entry_kind == print_entry_values_only
360 || fa->entry_kind == print_entry_values_compact)
361 stb.puts ("@entry");
362 out->field_stream ("name", stb);
364 else
365 /* Otherwise, just output the name. */
366 out->field_string ("name", sym_name);
368 annotate_arg_name_end ();
370 out->text ("=");
372 if (print_args_field)
373 out->field_int ("arg", 1);
375 /* For MI print the type, but only for simple values. This seems
376 weird, but this is how MI choose to format the various output
377 types. */
378 if (args_type == MI_PRINT_SIMPLE_VALUES && val != NULL)
379 py_print_type (out, val);
381 if (val != NULL)
382 annotate_arg_value (value_type (val));
384 /* If the output is to the CLI, and the user option "set print
385 frame-arguments" is set to none, just output "...". */
386 if (! out->is_mi_like_p () && args_type == NO_VALUES)
387 out->field_string ("value", "...");
388 else
390 /* Otherwise, print the value for both MI and the CLI, except
391 for the case of MI_PRINT_NO_VALUES. */
392 if (args_type != NO_VALUES)
394 if (val == NULL)
396 gdb_assert (fa != NULL && fa->error != NULL);
397 out->field_fmt ("value",
398 _("<error reading variable: %s>"),
399 fa->error);
401 else
402 py_print_value (out, val, opts, 0, args_type, language);
407 /* Helper function to loop over frame arguments provided by the
408 "frame_arguments" Python API. Elements in the iterator must
409 conform to the "Symbol Value" interface. ITER is the Python
410 iterable object, OUT is the output stream, ARGS_TYPE is an
411 enumerator describing the argument format, PRINT_ARGS_FIELD is a
412 flag which indicates if we output "ARGS=1" in MI output in commands
413 where both arguments and locals are printed, and FRAME is the
414 backing frame. Returns EXT_LANG_BT_ERROR on error, with any GDB
415 exceptions converted to a Python exception, or EXT_LANG_BT_OK on
416 success. */
418 static enum ext_lang_bt_status
419 enumerate_args (PyObject *iter,
420 struct ui_out *out,
421 enum ext_lang_frame_args args_type,
422 int print_args_field,
423 struct frame_info *frame)
425 struct value_print_options opts;
427 get_user_print_options (&opts);
429 if (args_type == CLI_SCALAR_VALUES)
431 /* True in "summary" mode, false otherwise. */
432 opts.summary = 1;
435 opts.deref_ref = 1;
437 annotate_frame_args ();
439 /* Collect the first argument outside of the loop, so output of
440 commas in the argument output is correct. At the end of the
441 loop block collect another item from the iterator, and, if it is
442 not null emit a comma. */
443 gdbpy_ref<> item (PyIter_Next (iter));
444 if (item == NULL && PyErr_Occurred ())
445 return EXT_LANG_BT_ERROR;
447 while (item != NULL)
449 const struct language_defn *language;
450 gdb::unique_xmalloc_ptr<char> sym_name;
451 struct symbol *sym;
452 const struct block *sym_block;
453 struct value *val;
454 enum ext_lang_bt_status success = EXT_LANG_BT_ERROR;
456 success = extract_sym (item.get (), &sym_name, &sym, &sym_block,
457 &language);
458 if (success == EXT_LANG_BT_ERROR)
459 return EXT_LANG_BT_ERROR;
461 success = extract_value (item.get (), &val);
462 if (success == EXT_LANG_BT_ERROR)
463 return EXT_LANG_BT_ERROR;
465 if (sym && out->is_mi_like_p ()
466 && ! mi_should_print (sym, MI_PRINT_ARGS))
467 continue;
469 /* If the object did not provide a value, read it using
470 read_frame_args and account for entry values, if any. */
471 if (val == NULL)
473 struct frame_arg arg, entryarg;
475 /* If there is no value, and also no symbol, set error and
476 exit. */
477 if (sym == NULL)
479 PyErr_SetString (PyExc_RuntimeError,
480 _("No symbol or value provided."));
481 return EXT_LANG_BT_ERROR;
484 read_frame_arg (sym, frame, &arg, &entryarg);
486 gdb::unique_xmalloc_ptr<char> arg_holder (arg.error);
487 gdb::unique_xmalloc_ptr<char> entry_holder (entryarg.error);
489 /* The object has not provided a value, so this is a frame
490 argument to be read by GDB. In this case we have to
491 account for entry-values. */
493 if (arg.entry_kind != print_entry_values_only)
495 py_print_single_arg (out, NULL, &arg,
496 NULL, &opts,
497 args_type,
498 print_args_field,
499 NULL);
502 if (entryarg.entry_kind != print_entry_values_no)
504 if (arg.entry_kind != print_entry_values_only)
506 out->text (", ");
507 out->wrap_hint (" ");
510 py_print_single_arg (out, NULL, &entryarg, NULL, &opts,
511 args_type, print_args_field, NULL);
514 else
516 /* If the object has provided a value, we just print that. */
517 if (val != NULL)
518 py_print_single_arg (out, sym_name.get (), NULL, val, &opts,
519 args_type, print_args_field,
520 language);
523 /* Collect the next item from the iterator. If
524 this is the last item, do not print the
525 comma. */
526 item.reset (PyIter_Next (iter));
527 if (item != NULL)
528 out->text (", ");
529 else if (PyErr_Occurred ())
530 return EXT_LANG_BT_ERROR;
532 annotate_arg_end ();
535 return EXT_LANG_BT_OK;
539 /* Helper function to loop over variables provided by the
540 "frame_locals" Python API. Elements in the iterable must conform
541 to the "Symbol Value" interface. ITER is the Python iterable
542 object, OUT is the output stream, INDENT is whether we should
543 indent the output (for CLI), ARGS_TYPE is an enumerator describing
544 the argument format, PRINT_ARGS_FIELD is flag which indicates
545 whether to output the ARGS field in the case of
546 -stack-list-variables and FRAME is the backing frame. Returns
547 EXT_LANG_BT_ERROR on error, with any GDB exceptions converted to a Python
548 exception, or EXT_LANG_BT_OK on success. */
550 static enum ext_lang_bt_status
551 enumerate_locals (PyObject *iter,
552 struct ui_out *out,
553 int indent,
554 enum ext_lang_frame_args args_type,
555 int print_args_field,
556 struct frame_info *frame)
558 struct value_print_options opts;
560 get_user_print_options (&opts);
561 opts.deref_ref = 1;
563 while (true)
565 const struct language_defn *language;
566 gdb::unique_xmalloc_ptr<char> sym_name;
567 struct value *val;
568 enum ext_lang_bt_status success = EXT_LANG_BT_ERROR;
569 struct symbol *sym;
570 const struct block *sym_block;
571 int local_indent = 8 + (8 * indent);
572 gdb::optional<ui_out_emit_tuple> tuple;
574 gdbpy_ref<> item (PyIter_Next (iter));
575 if (item == NULL)
576 break;
578 success = extract_sym (item.get (), &sym_name, &sym, &sym_block,
579 &language);
580 if (success == EXT_LANG_BT_ERROR)
581 return EXT_LANG_BT_ERROR;
583 success = extract_value (item.get (), &val);
584 if (success == EXT_LANG_BT_ERROR)
585 return EXT_LANG_BT_ERROR;
587 if (sym != NULL && out->is_mi_like_p ()
588 && ! mi_should_print (sym, MI_PRINT_LOCALS))
589 continue;
591 /* If the object did not provide a value, read it. */
592 if (val == NULL)
593 val = read_var_value (sym, sym_block, frame);
595 /* With PRINT_NO_VALUES, MI does not emit a tuple normally as
596 each output contains only one field. The exception is
597 -stack-list-variables, which always provides a tuple. */
598 if (out->is_mi_like_p ())
600 if (print_args_field || args_type != NO_VALUES)
601 tuple.emplace (out, nullptr);
604 /* If the output is not MI we indent locals. */
605 out->spaces (local_indent);
606 out->field_string ("name", sym_name.get ());
607 out->text (" = ");
609 if (args_type == MI_PRINT_SIMPLE_VALUES)
610 py_print_type (out, val);
612 /* CLI always prints values for locals. MI uses the
613 simple/no/all system. */
614 if (! out->is_mi_like_p ())
616 int val_indent = (indent + 1) * 4;
618 py_print_value (out, val, &opts, val_indent, args_type,
619 language);
621 else
623 if (args_type != NO_VALUES)
624 py_print_value (out, val, &opts, 0, args_type,
625 language);
628 out->text ("\n");
631 if (!PyErr_Occurred ())
632 return EXT_LANG_BT_OK;
634 return EXT_LANG_BT_ERROR;
637 /* Helper function for -stack-list-variables. Returns EXT_LANG_BT_ERROR on
638 error, or EXT_LANG_BT_OK on success. */
640 static enum ext_lang_bt_status
641 py_mi_print_variables (PyObject *filter, struct ui_out *out,
642 struct value_print_options *opts,
643 enum ext_lang_frame_args args_type,
644 struct frame_info *frame)
646 gdbpy_ref<> args_iter (get_py_iter_from_func (filter, "frame_args"));
647 if (args_iter == NULL)
648 return EXT_LANG_BT_ERROR;
650 gdbpy_ref<> locals_iter (get_py_iter_from_func (filter, "frame_locals"));
651 if (locals_iter == NULL)
652 return EXT_LANG_BT_ERROR;
654 ui_out_emit_list list_emitter (out, "variables");
656 if (args_iter != Py_None
657 && (enumerate_args (args_iter.get (), out, args_type, 1, frame)
658 == EXT_LANG_BT_ERROR))
659 return EXT_LANG_BT_ERROR;
661 if (locals_iter != Py_None
662 && (enumerate_locals (locals_iter.get (), out, 1, args_type, 1, frame)
663 == EXT_LANG_BT_ERROR))
664 return EXT_LANG_BT_ERROR;
666 return EXT_LANG_BT_OK;
669 /* Helper function for printing locals. This function largely just
670 creates the wrapping tuple, and calls enumerate_locals. Returns
671 EXT_LANG_BT_ERROR on error, or EXT_LANG_BT_OK on success. */
673 static enum ext_lang_bt_status
674 py_print_locals (PyObject *filter,
675 struct ui_out *out,
676 enum ext_lang_frame_args args_type,
677 int indent,
678 struct frame_info *frame)
680 gdbpy_ref<> locals_iter (get_py_iter_from_func (filter, "frame_locals"));
681 if (locals_iter == NULL)
682 return EXT_LANG_BT_ERROR;
684 ui_out_emit_list list_emitter (out, "locals");
686 if (locals_iter != Py_None
687 && (enumerate_locals (locals_iter.get (), out, indent, args_type,
688 0, frame) == EXT_LANG_BT_ERROR))
689 return EXT_LANG_BT_ERROR;
691 return EXT_LANG_BT_OK;
694 /* Helper function for printing frame arguments. This function
695 largely just creates the wrapping tuple, and calls enumerate_args.
696 Returns EXT_LANG_BT_ERROR on error, with any GDB exceptions converted to
697 a Python exception, or EXT_LANG_BT_OK on success. */
699 static enum ext_lang_bt_status
700 py_print_args (PyObject *filter,
701 struct ui_out *out,
702 enum ext_lang_frame_args args_type,
703 struct frame_info *frame)
705 gdbpy_ref<> args_iter (get_py_iter_from_func (filter, "frame_args"));
706 if (args_iter == NULL)
707 return EXT_LANG_BT_ERROR;
709 ui_out_emit_list list_emitter (out, "args");
711 out->wrap_hint (" ");
712 annotate_frame_args ();
713 out->text (" (");
715 if (args_iter != Py_None
716 && (enumerate_args (args_iter.get (), out, args_type, 0, frame)
717 == EXT_LANG_BT_ERROR))
718 return EXT_LANG_BT_ERROR;
720 out->text (")");
722 return EXT_LANG_BT_OK;
725 /* Print a single frame to the designated output stream, detecting
726 whether the output is MI or console, and formatting the output
727 according to the conventions of that protocol. FILTER is the
728 frame-filter associated with this frame. FLAGS is an integer
729 describing the various print options. The FLAGS variables is
730 described in "apply_frame_filter" function. ARGS_TYPE is an
731 enumerator describing the argument format. OUT is the output
732 stream to print, INDENT is the level of indention for this frame
733 (in the case of elided frames), and LEVELS_PRINTED is a hash-table
734 containing all the frames level that have already been printed.
735 If a frame level has been printed, do not print it again (in the
736 case of elided frames). Returns EXT_LANG_BT_ERROR on error, with any
737 GDB exceptions converted to a Python exception, or EXT_LANG_BT_OK
738 on success. It can also throw an exception RETURN_QUIT. */
740 static enum ext_lang_bt_status
741 py_print_frame (PyObject *filter, frame_filter_flags flags,
742 enum ext_lang_frame_args args_type,
743 struct ui_out *out, int indent, htab_t levels_printed)
745 int has_addr = 0;
746 CORE_ADDR address = 0;
747 struct gdbarch *gdbarch = NULL;
748 struct frame_info *frame = NULL;
749 struct value_print_options opts;
750 int print_level, print_frame_info, print_args, print_locals;
751 gdb::unique_xmalloc_ptr<char> function_to_free;
753 /* Extract print settings from FLAGS. */
754 print_level = (flags & PRINT_LEVEL) ? 1 : 0;
755 print_frame_info = (flags & PRINT_FRAME_INFO) ? 1 : 0;
756 print_args = (flags & PRINT_ARGS) ? 1 : 0;
757 print_locals = (flags & PRINT_LOCALS) ? 1 : 0;
759 get_user_print_options (&opts);
761 /* Get the underlying frame. This is needed to determine GDB
762 architecture, and also, in the cases of frame variables/arguments to
763 read them if they returned filter object requires us to do so. */
764 gdbpy_ref<> py_inf_frame (PyObject_CallMethod (filter, "inferior_frame",
765 NULL));
766 if (py_inf_frame == NULL)
767 return EXT_LANG_BT_ERROR;
769 frame = frame_object_to_frame_info (py_inf_frame.get ());
770 if (frame == NULL)
771 return EXT_LANG_BT_ERROR;
773 gdbarch = get_frame_arch (frame);
775 /* stack-list-variables. */
776 if (print_locals && print_args && ! print_frame_info)
778 if (py_mi_print_variables (filter, out, &opts,
779 args_type, frame) == EXT_LANG_BT_ERROR)
780 return EXT_LANG_BT_ERROR;
781 return EXT_LANG_BT_OK;
784 gdb::optional<ui_out_emit_tuple> tuple;
786 /* -stack-list-locals does not require a
787 wrapping frame attribute. */
788 if (print_frame_info || (print_args && ! print_locals))
789 tuple.emplace (out, "frame");
791 if (print_frame_info)
793 /* Elided frames are also printed with this function (recursively)
794 and are printed with indention. */
795 if (indent > 0)
796 out->spaces (indent * 4);
798 /* The address is required for frame annotations, and also for
799 address printing. */
800 if (PyObject_HasAttrString (filter, "address"))
802 gdbpy_ref<> paddr (PyObject_CallMethod (filter, "address", NULL));
804 if (paddr == NULL)
805 return EXT_LANG_BT_ERROR;
807 if (paddr != Py_None)
809 if (get_addr_from_python (paddr.get (), &address) < 0)
810 return EXT_LANG_BT_ERROR;
812 has_addr = 1;
817 /* Print frame level. MI does not require the level if
818 locals/variables only are being printed. */
819 if ((print_frame_info || print_args) && print_level)
821 struct frame_info **slot;
822 int level;
824 slot = (struct frame_info **) htab_find_slot (levels_printed,
825 frame, INSERT);
827 level = frame_relative_level (frame);
829 /* Check if this frame has already been printed (there are cases
830 where elided synthetic dummy-frames have to 'borrow' the frame
831 architecture from the eliding frame. If that is the case, do
832 not print 'level', but print spaces. */
833 if (*slot == frame)
834 out->field_skip ("level");
835 else
837 *slot = frame;
838 annotate_frame_begin (print_level ? level : 0,
839 gdbarch, address);
840 out->text ("#");
841 out->field_fmt_int (2, ui_left, "level",
842 level);
846 if (print_frame_info)
848 /* Print address to the address field. If an address is not provided,
849 print nothing. */
850 if (opts.addressprint && has_addr)
852 annotate_frame_address ();
853 out->field_core_addr ("addr", gdbarch, address);
854 annotate_frame_address_end ();
855 out->text (" in ");
858 /* Print frame function name. */
859 if (PyObject_HasAttrString (filter, "function"))
861 gdbpy_ref<> py_func (PyObject_CallMethod (filter, "function", NULL));
862 const char *function = NULL;
864 if (py_func == NULL)
865 return EXT_LANG_BT_ERROR;
867 if (gdbpy_is_string (py_func.get ()))
869 function_to_free = python_string_to_host_string (py_func.get ());
871 if (function_to_free == NULL)
872 return EXT_LANG_BT_ERROR;
874 function = function_to_free.get ();
876 else if (PyLong_Check (py_func.get ()))
878 CORE_ADDR addr;
879 struct bound_minimal_symbol msymbol;
881 if (get_addr_from_python (py_func.get (), &addr) < 0)
882 return EXT_LANG_BT_ERROR;
884 msymbol = lookup_minimal_symbol_by_pc (addr);
885 if (msymbol.minsym != NULL)
886 function = MSYMBOL_PRINT_NAME (msymbol.minsym);
888 else if (py_func != Py_None)
890 PyErr_SetString (PyExc_RuntimeError,
891 _("FrameDecorator.function: expecting a " \
892 "String, integer or None."));
893 return EXT_LANG_BT_ERROR;
896 annotate_frame_function_name ();
897 if (function == NULL)
898 out->field_skip ("func");
899 else
900 out->field_string ("func", function, ui_out_style_kind::FUNCTION);
905 /* Frame arguments. Check the result, and error if something went
906 wrong. */
907 if (print_args)
909 if (py_print_args (filter, out, args_type, frame) == EXT_LANG_BT_ERROR)
910 return EXT_LANG_BT_ERROR;
913 /* File name/source/line number information. */
914 if (print_frame_info)
916 annotate_frame_source_begin ();
918 if (PyObject_HasAttrString (filter, "filename"))
920 gdbpy_ref<> py_fn (PyObject_CallMethod (filter, "filename", NULL));
922 if (py_fn == NULL)
923 return EXT_LANG_BT_ERROR;
925 if (py_fn != Py_None)
927 gdb::unique_xmalloc_ptr<char>
928 filename (python_string_to_host_string (py_fn.get ()));
930 if (filename == NULL)
931 return EXT_LANG_BT_ERROR;
933 out->wrap_hint (" ");
934 out->text (" at ");
935 annotate_frame_source_file ();
936 out->field_string ("file", filename.get (),
937 ui_out_style_kind::FILE);
938 annotate_frame_source_file_end ();
942 if (PyObject_HasAttrString (filter, "line"))
944 gdbpy_ref<> py_line (PyObject_CallMethod (filter, "line", NULL));
945 int line;
947 if (py_line == NULL)
948 return EXT_LANG_BT_ERROR;
950 if (py_line != Py_None)
952 line = PyLong_AsLong (py_line.get ());
953 if (PyErr_Occurred ())
954 return EXT_LANG_BT_ERROR;
956 out->text (":");
957 annotate_frame_source_line ();
958 out->field_int ("line", line);
961 if (out->is_mi_like_p ())
962 out->field_string ("arch",
963 (gdbarch_bfd_arch_info (gdbarch))->printable_name);
966 /* For MI we need to deal with the "children" list population of
967 elided frames, so if MI output detected do not send newline. */
968 if (! out->is_mi_like_p ())
970 annotate_frame_end ();
971 out->text ("\n");
974 if (print_locals)
976 if (py_print_locals (filter, out, args_type, indent,
977 frame) == EXT_LANG_BT_ERROR)
978 return EXT_LANG_BT_ERROR;
981 if ((flags & PRINT_HIDE) == 0)
983 /* Finally recursively print elided frames, if any. */
984 gdbpy_ref<> elided (get_py_iter_from_func (filter, "elided"));
985 if (elided == NULL)
986 return EXT_LANG_BT_ERROR;
988 if (elided != Py_None)
990 PyObject *item;
992 ui_out_emit_list inner_list_emiter (out, "children");
994 indent++;
996 while ((item = PyIter_Next (elided.get ())))
998 gdbpy_ref<> item_ref (item);
1000 enum ext_lang_bt_status success
1001 = py_print_frame (item, flags, args_type, out, indent,
1002 levels_printed);
1004 if (success == EXT_LANG_BT_ERROR)
1005 return EXT_LANG_BT_ERROR;
1007 if (item == NULL && PyErr_Occurred ())
1008 return EXT_LANG_BT_ERROR;
1012 return EXT_LANG_BT_OK;
1015 /* Helper function to initiate frame filter invocation at starting
1016 frame FRAME. */
1018 static PyObject *
1019 bootstrap_python_frame_filters (struct frame_info *frame,
1020 int frame_low, int frame_high)
1022 gdbpy_ref<> frame_obj (frame_info_to_frame_object (frame));
1023 if (frame_obj == NULL)
1024 return NULL;
1026 gdbpy_ref<> module (PyImport_ImportModule ("gdb.frames"));
1027 if (module == NULL)
1028 return NULL;
1030 gdbpy_ref<> sort_func (PyObject_GetAttrString (module.get (),
1031 "execute_frame_filters"));
1032 if (sort_func == NULL)
1033 return NULL;
1035 gdbpy_ref<> py_frame_low (PyInt_FromLong (frame_low));
1036 if (py_frame_low == NULL)
1037 return NULL;
1039 gdbpy_ref<> py_frame_high (PyInt_FromLong (frame_high));
1040 if (py_frame_high == NULL)
1041 return NULL;
1043 gdbpy_ref<> iterable (PyObject_CallFunctionObjArgs (sort_func.get (),
1044 frame_obj.get (),
1045 py_frame_low.get (),
1046 py_frame_high.get (),
1047 NULL));
1048 if (iterable == NULL)
1049 return NULL;
1051 if (iterable != Py_None)
1052 return PyObject_GetIter (iterable.get ());
1053 else
1054 return iterable.release ();
1057 /* This is the only publicly exported function in this file. FRAME
1058 is the source frame to start frame-filter invocation. FLAGS is an
1059 integer holding the flags for printing. The following elements of
1060 the FRAME_FILTER_FLAGS enum denotes the make-up of FLAGS:
1061 PRINT_LEVEL is a flag indicating whether to print the frame's
1062 relative level in the output. PRINT_FRAME_INFO is a flag that
1063 indicates whether this function should print the frame
1064 information, PRINT_ARGS is a flag that indicates whether to print
1065 frame arguments, and PRINT_LOCALS, likewise, with frame local
1066 variables. ARGS_TYPE is an enumerator describing the argument
1067 format, OUT is the output stream to print. FRAME_LOW is the
1068 beginning of the slice of frames to print, and FRAME_HIGH is the
1069 upper limit of the frames to count. Returns EXT_LANG_BT_ERROR on error,
1070 or EXT_LANG_BT_OK on success. */
1072 enum ext_lang_bt_status
1073 gdbpy_apply_frame_filter (const struct extension_language_defn *extlang,
1074 struct frame_info *frame, frame_filter_flags flags,
1075 enum ext_lang_frame_args args_type,
1076 struct ui_out *out, int frame_low, int frame_high)
1078 struct gdbarch *gdbarch = NULL;
1079 enum ext_lang_bt_status success = EXT_LANG_BT_ERROR;
1081 if (!gdb_python_initialized)
1082 return EXT_LANG_BT_NO_FILTERS;
1086 gdbarch = get_frame_arch (frame);
1088 catch (const gdb_exception_error &except)
1090 /* Let gdb try to print the stack trace. */
1091 return EXT_LANG_BT_NO_FILTERS;
1094 gdbpy_enter enter_py (gdbarch, current_language);
1096 /* When we're limiting the number of frames, be careful to request
1097 one extra frame, so that we can print a message if there are more
1098 frames. */
1099 int frame_countdown = -1;
1100 if ((flags & PRINT_MORE_FRAMES) != 0 && frame_low >= 0 && frame_high >= 0)
1102 ++frame_high;
1103 /* This has an extra +1 because it is checked before a frame is
1104 printed. */
1105 frame_countdown = frame_high - frame_low + 1;
1108 gdbpy_ref<> iterable (bootstrap_python_frame_filters (frame, frame_low,
1109 frame_high));
1111 if (iterable == NULL)
1113 /* Normally if there is an error GDB prints the exception,
1114 abandons the backtrace and exits. The user can then call "bt
1115 no-filters", and get a default backtrace (it would be
1116 confusing to automatically start a standard backtrace halfway
1117 through a Python filtered backtrace). However in the case
1118 where GDB cannot initialize the frame filters (most likely
1119 due to incorrect auto-load paths), GDB has printed nothing.
1120 In this case it is OK to print the default backtrace after
1121 printing the error message. GDB returns EXT_LANG_BT_NO_FILTERS
1122 here to signify there are no filters after printing the
1123 initialization error. This return code will trigger a
1124 default backtrace. */
1126 gdbpy_print_stack_or_quit ();
1127 return EXT_LANG_BT_NO_FILTERS;
1130 /* If iterable is None, then there are no frame filters registered.
1131 If this is the case, defer to default GDB printing routines in MI
1132 and CLI. */
1133 if (iterable == Py_None)
1134 return EXT_LANG_BT_NO_FILTERS;
1136 htab_up levels_printed (htab_create (20,
1137 htab_hash_pointer,
1138 htab_eq_pointer,
1139 NULL));
1141 while (true)
1143 gdbpy_ref<> item (PyIter_Next (iterable.get ()));
1145 if (item == NULL)
1147 if (PyErr_Occurred ())
1149 gdbpy_print_stack_or_quit ();
1150 return EXT_LANG_BT_ERROR;
1152 break;
1155 if (frame_countdown != -1)
1157 gdb_assert ((flags & PRINT_MORE_FRAMES) != 0);
1158 --frame_countdown;
1159 if (frame_countdown == 0)
1161 /* We've printed all the frames we were asked to
1162 print, but more frames existed. */
1163 printf_filtered (_("(More stack frames follow...)\n"));
1164 break;
1170 success = py_print_frame (item.get (), flags, args_type, out, 0,
1171 levels_printed.get ());
1173 catch (const gdb_exception_error &except)
1175 gdbpy_convert_exception (except);
1176 success = EXT_LANG_BT_ERROR;
1179 /* Do not exit on error printing a single frame. Print the
1180 error and continue with other frames. */
1181 if (success == EXT_LANG_BT_ERROR)
1182 gdbpy_print_stack_or_quit ();
1185 return success;