mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-18 12:24:38 +08:00
2e78302469
This patch changes various places to use ui_out_emit_tuple, eliminating a number of cleanups. This patch only tackles "easy" cases, which are ones where the cleanups in question were block-structured and did not involve any changes other than the obvious replacement. ChangeLog 2017-04-22 Tom Tromey <tom@tromey.com> * record-btrace.c (record_btrace_insn_history) (record_btrace_insn_history_range, record_btrace_call_history) (record_btrace_call_history_range): Use ui_out_emit_tuple. * thread.c (do_captured_list_thread_ids, print_thread_info_1): Use ui_out_emit_tuple. * stack.c (print_frame_info): Use ui_out_emit_tuple. * solib.c (info_sharedlibrary_command): Use ui_out_emit_tuple. * skip.c (skip_info): Use ui_out_emit_tuple. * remote.c (show_remote_cmd): Use ui_out_emit_tuple. * progspace.c (print_program_space): Use ui_out_emit_tuple. * probe.c (info_probes_for_ops): Use ui_out_emit_tuple. * osdata.c (info_osdata): Use ui_out_emit_tuple. * mi/mi-symbol-cmds.c (mi_cmd_symbol_list_lines): Use ui_out_emit_tuple. * mi/mi-main.c (print_one_inferior, list_available_thread_groups) (output_register, mi_cmd_data_read_memory) (mi_cmd_data_read_memory_bytes, mi_load_progress) (mi_cmd_trace_frame_collected): Use ui_out_emit_tuple. * mi/mi-cmd-var.c (mi_cmd_var_list_children, varobj_update_one): Use ui_out_emit_tuple. * mi/mi-cmd-stack.c (mi_cmd_stack_list_args): Use ui_out_emit_tuple. * mi/mi-cmd-info.c (mi_cmd_info_ada_exceptions) (mi_cmd_info_gdb_mi_command): Use ui_out_emit_tuple. * linux-thread-db.c (info_auto_load_libthread_db): Use ui_out_emit_tuple. * inferior.c (print_inferior): Use ui_out_emit_tuple. * gdb_bfd.c (print_one_bfd): Use ui_out_emit_tuple. * disasm.c (do_mixed_source_and_assembly_deprecated) (do_mixed_source_and_assembly): Use ui_out_emit_tuple. * cp-abi.c (list_cp_abis): Use ui_out_emit_tuple. * cli/cli-setshow.c (cmd_show_list): Use ui_out_emit_tuple. * breakpoint.c (print_one_breakpoint_location) (print_one_breakpoint): Use ui_out_emit_tuple. * auto-load.c (print_script, info_auto_load_cmd): Use ui_out_emit_tuple. * ada-tasks.c (print_ada_task_info): Use ui_out_emit_tuple.
113 lines
3.1 KiB
C
113 lines
3.1 KiB
C
/* MI Command Set - information commands.
|
|
Copyright (C) 2011-2017 Free Software Foundation, Inc.
|
|
|
|
This file is part of GDB.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
|
#include "defs.h"
|
|
#include "osdata.h"
|
|
#include "mi-cmds.h"
|
|
#include "ada-lang.h"
|
|
#include "arch-utils.h"
|
|
|
|
/* Implement the "-info-ada-exceptions" GDB/MI command. */
|
|
|
|
void
|
|
mi_cmd_info_ada_exceptions (const char *command, char **argv, int argc)
|
|
{
|
|
struct ui_out *uiout = current_uiout;
|
|
struct gdbarch *gdbarch = get_current_arch ();
|
|
char *regexp;
|
|
struct cleanup *old_chain;
|
|
VEC(ada_exc_info) *exceptions;
|
|
int ix;
|
|
struct ada_exc_info *info;
|
|
|
|
switch (argc)
|
|
{
|
|
case 0:
|
|
regexp = NULL;
|
|
break;
|
|
case 1:
|
|
regexp = argv[0];
|
|
break;
|
|
default:
|
|
error (_("Usage: -info-ada-exceptions [REGEXP]"));
|
|
break;
|
|
}
|
|
|
|
exceptions = ada_exceptions_list (regexp);
|
|
old_chain = make_cleanup (VEC_cleanup (ada_exc_info), &exceptions);
|
|
|
|
make_cleanup_ui_out_table_begin_end
|
|
(uiout, 2, VEC_length (ada_exc_info, exceptions), "ada-exceptions");
|
|
uiout->table_header (1, ui_left, "name", "Name");
|
|
uiout->table_header (1, ui_left, "address", "Address");
|
|
uiout->table_body ();
|
|
|
|
for (ix = 0; VEC_iterate(ada_exc_info, exceptions, ix, info); ix++)
|
|
{
|
|
ui_out_emit_tuple tuple_emitter (uiout, NULL);
|
|
uiout->field_string ("name", info->name);
|
|
uiout->field_core_addr ("address", gdbarch, info->addr);
|
|
}
|
|
|
|
do_cleanups (old_chain);
|
|
}
|
|
|
|
/* Implement the "-info-gdb-mi-command" GDB/MI command. */
|
|
|
|
void
|
|
mi_cmd_info_gdb_mi_command (const char *command, char **argv, int argc)
|
|
{
|
|
const char *cmd_name;
|
|
struct mi_cmd *cmd;
|
|
struct ui_out *uiout = current_uiout;
|
|
|
|
/* This command takes exactly one argument. */
|
|
if (argc != 1)
|
|
error (_("Usage: -info-gdb-mi-command MI_COMMAND_NAME"));
|
|
cmd_name = argv[0];
|
|
|
|
/* Normally, the command name (aka the "operation" in the GDB/MI
|
|
grammar), does not include the leading '-' (dash). But for
|
|
the user's convenience, allow the user to specify the command
|
|
name to be with or without that leading dash. */
|
|
if (cmd_name[0] == '-')
|
|
cmd_name++;
|
|
|
|
cmd = mi_lookup (cmd_name);
|
|
|
|
ui_out_emit_tuple tuple_emitter (uiout, "command");
|
|
uiout->field_string ("exists", cmd != NULL ? "true" : "false");
|
|
}
|
|
|
|
void
|
|
mi_cmd_info_os (const char *command, char **argv, int argc)
|
|
{
|
|
switch (argc)
|
|
{
|
|
case 0:
|
|
info_osdata (NULL);
|
|
break;
|
|
case 1:
|
|
info_osdata (argv[0]);
|
|
break;
|
|
default:
|
|
error (_("Usage: -info-os [INFOTYPE]"));
|
|
break;
|
|
}
|
|
}
|