diff options
author | Tom Tromey <tom@tromey.com> | 2019-02-07 06:23:40 -0700 |
---|---|---|
committer | Tom Tromey <tom@tromey.com> | 2019-02-17 08:35:14 -0700 |
commit | a008792038c2510800db466897c4bb6305d20042 (patch) | |
tree | a317ce9b81aa7874e144c6d08472a8344237b7d6 /gdb/ada-lang.c | |
parent | 75ba10dc558a450c7dbcdc24f816f6709f2b29f7 (diff) | |
download | binutils-a008792038c2510800db466897c4bb6305d20042.zip binutils-a008792038c2510800db466897c4bb6305d20042.tar.gz binutils-a008792038c2510800db466897c4bb6305d20042.tar.bz2 |
Fix pager bugs with style output
I believe this fixes all the pager output problems with styling that
Philippe pointed out, plus at least one more. The patch is somewhat
hard to reason about, so you may wish to give it a try. Even writing
the tests was hard.
This removes the style caching, because it was difficult to keep the
style cache correct in all cases. Since this would cause more style
escapes to be emitted, instead it changes fputs_styled to try to avoid
unnecessary changes.
Another bug was that the wrap buffer was not flushed in the case where
wrap_column==0. In the old (pre-patch series) code, characters were
directly emitted in this case; so flushing the wrap buffer here
restores this behavior.
On error the wrap buffer must be emptied. Otherwise, interrupting
output can leave characters in the buffer that will be emitted later.
As discussed on gdb-patches, this fixes the ada-lang.c problem where
filtered and unfiltered printing were mixed. Now user_select_syms
uses filtered printing, which is what its callees were already doing.
Finally, it was possible for source line highlighting to be garbled
(and invalid escape sequences emitted) if the pager was invoked at the
wrong spot. To fix this, the patch arranges for source line escapes
to always be emitted as a unit.
gdb/ChangeLog
2019-02-17 Tom Tromey <tom@tromey.com>
* ada-lang.c (user_select_syms): Use filtered printing.
* utils.c (wrap_style): New global.
(desired_style): Remove.
(emit_style_escape): Add stream parameter.
(set_output_style, reset_terminal_style, prompt_for_continue):
Update.
(flush_wrap_buffer): Only flush gdb_stdout.
(wrap_here): Set wrap_style.
(fputs_maybe_filtered): Clear the wrap buffer on exception. Don't
treat escape sequences as a character. Change when wrap buffer is
flushed.
(fputs_styled): Do not set the output style when the default is
requested.
* ui-style.h (struct ui_file_style) <is_default>: New method.
* source.c (print_source_lines_base): Emit escape sequences in one
piece.
gdb/testsuite/ChangeLog
2019-02-17 Tom Tromey <tom@tromey.com>
* gdb.base/style.exp: Add line-wrapping tests.
* gdb.base/page.exp: Add test for quitting during pagination.
Diffstat (limited to 'gdb/ada-lang.c')
-rw-r--r-- | gdb/ada-lang.c | 48 |
1 files changed, 24 insertions, 24 deletions
diff --git a/gdb/ada-lang.c b/gdb/ada-lang.c index 66df1d1..a6fadc8 100644 --- a/gdb/ada-lang.c +++ b/gdb/ada-lang.c @@ -3903,16 +3903,16 @@ user_select_syms (struct block_symbol *syms, int nsyms, int max_results) error (_("\ canceled because the command is ambiguous\n\ See set/show multiple-symbol.")); - + /* If select_mode is "all", then return all possible symbols. Only do that if more than one symbol can be selected, of course. Otherwise, display the menu as usual. */ if (select_mode == multiple_symbols_all && max_results > 1) return nsyms; - printf_unfiltered (_("[0] cancel\n")); + printf_filtered (_("[0] cancel\n")); if (max_results > 1) - printf_unfiltered (_("[1] all\n")); + printf_filtered (_("[1] all\n")); sort_choices (syms, nsyms); @@ -3926,16 +3926,16 @@ See set/show multiple-symbol.")); struct symtab_and_line sal = find_function_start_sal (syms[i].symbol, 1); - printf_unfiltered ("[%d] ", i + first_choice); + printf_filtered ("[%d] ", i + first_choice); ada_print_symbol_signature (gdb_stdout, syms[i].symbol, &type_print_raw_options); if (sal.symtab == NULL) - printf_unfiltered (_(" at <no source file available>:%d\n"), - sal.line); + printf_filtered (_(" at <no source file available>:%d\n"), + sal.line); else - printf_unfiltered (_(" at %s:%d\n"), - symtab_to_filename_for_display (sal.symtab), - sal.line); + printf_filtered (_(" at %s:%d\n"), + symtab_to_filename_for_display (sal.symtab), + sal.line); continue; } else @@ -3951,37 +3951,37 @@ See set/show multiple-symbol.")); if (SYMBOL_LINE (syms[i].symbol) != 0 && symtab != NULL) { - printf_unfiltered ("[%d] ", i + first_choice); + printf_filtered ("[%d] ", i + first_choice); ada_print_symbol_signature (gdb_stdout, syms[i].symbol, &type_print_raw_options); - printf_unfiltered (_(" at %s:%d\n"), - symtab_to_filename_for_display (symtab), - SYMBOL_LINE (syms[i].symbol)); + printf_filtered (_(" at %s:%d\n"), + symtab_to_filename_for_display (symtab), + SYMBOL_LINE (syms[i].symbol)); } else if (is_enumeral && TYPE_NAME (SYMBOL_TYPE (syms[i].symbol)) != NULL) { - printf_unfiltered (("[%d] "), i + first_choice); + printf_filtered (("[%d] "), i + first_choice); ada_print_type (SYMBOL_TYPE (syms[i].symbol), NULL, gdb_stdout, -1, 0, &type_print_raw_options); - printf_unfiltered (_("'(%s) (enumeral)\n"), - SYMBOL_PRINT_NAME (syms[i].symbol)); + printf_filtered (_("'(%s) (enumeral)\n"), + SYMBOL_PRINT_NAME (syms[i].symbol)); } else { - printf_unfiltered ("[%d] ", i + first_choice); + printf_filtered ("[%d] ", i + first_choice); ada_print_symbol_signature (gdb_stdout, syms[i].symbol, &type_print_raw_options); if (symtab != NULL) - printf_unfiltered (is_enumeral - ? _(" in %s (enumeral)\n") - : _(" at %s:?\n"), - symtab_to_filename_for_display (symtab)); + printf_filtered (is_enumeral + ? _(" in %s (enumeral)\n") + : _(" at %s:?\n"), + symtab_to_filename_for_display (symtab)); else - printf_unfiltered (is_enumeral - ? _(" (enumeral)\n") - : _(" at ?\n")); + printf_filtered (is_enumeral + ? _(" (enumeral)\n") + : _(" at ?\n")); } } } |