gdb/mi/mi-cmd-break.c - gdb
Global variables defined
Data types defined
Functions defined
Source code
- #include "defs.h"
- #include "arch-utils.h"
- #include "mi-cmds.h"
- #include "ui-out.h"
- #include "mi-out.h"
- #include "breakpoint.h"
- #include "mi-getopt.h"
- #include "gdb.h"
- #include "observer.h"
- #include "mi-main.h"
- #include "mi-cmd-break.h"
- #include "gdb_obstack.h"
- #include <ctype.h>
- enum
- {
- FROM_TTY = 0
- };
- static int mi_breakpoint_observers_installed;
- static int mi_can_breakpoint_notify;
- static void
- breakpoint_notify (struct breakpoint *b)
- {
- if (mi_can_breakpoint_notify)
- gdb_breakpoint_query (current_uiout, b->number, NULL);
- }
- enum bp_type
- {
- REG_BP,
- HW_BP,
- REGEXP_BP
- };
- struct cleanup *
- setup_breakpoint_reporting (void)
- {
- struct cleanup *rev_flag;
- if (! mi_breakpoint_observers_installed)
- {
- observer_attach_breakpoint_created (breakpoint_notify);
- mi_breakpoint_observers_installed = 1;
- }
- rev_flag = make_cleanup_restore_integer (&mi_can_breakpoint_notify);
- mi_can_breakpoint_notify = 1;
- return rev_flag;
- }
- static char *
- mi_argv_to_format (char **argv, int argc)
- {
- int i;
- struct obstack obstack;
- char *ret;
- obstack_init (&obstack);
-
- obstack_1grow (&obstack, '\"');
- for (i = 0; i < strlen (argv[0]); i++)
- {
- switch (argv[0][i])
- {
- case '\\':
- obstack_grow (&obstack, "\\\\", 2);
- break;
- case '\a':
- obstack_grow (&obstack, "\\a", 2);
- break;
- case '\b':
- obstack_grow (&obstack, "\\b", 2);
- break;
- case '\f':
- obstack_grow (&obstack, "\\f", 2);
- break;
- case '\n':
- obstack_grow (&obstack, "\\n", 2);
- break;
- case '\r':
- obstack_grow (&obstack, "\\r", 2);
- break;
- case '\t':
- obstack_grow (&obstack, "\\t", 2);
- break;
- case '\v':
- obstack_grow (&obstack, "\\v", 2);
- break;
- case '"':
- obstack_grow (&obstack, "\\\"", 2);
- break;
- default:
- if (isprint (argv[0][i]))
- obstack_grow (&obstack, argv[0] + i, 1);
- else
- {
- char tmp[5];
- xsnprintf (tmp, sizeof (tmp), "\\%o",
- (unsigned char) argv[0][i]);
- obstack_grow (&obstack, tmp, strlen (tmp));
- }
- break;
- }
- }
- obstack_1grow (&obstack, '\"');
-
- for (i = 1; i < argc; i++)
- {
- obstack_1grow (&obstack, ',');
- obstack_grow (&obstack, argv[i], strlen (argv[i]));
- }
- obstack_1grow (&obstack, '\0');
- ret = xstrdup (obstack_finish (&obstack));
- obstack_free (&obstack, NULL);
- return ret;
- }
- static void
- mi_cmd_break_insert_1 (int dprintf, char *command, char **argv, int argc)
- {
- char *address = NULL;
- int hardware = 0;
- int temp_p = 0;
- int thread = -1;
- int ignore_count = 0;
- char *condition = NULL;
- int pending = 0;
- int enabled = 1;
- int tracepoint = 0;
- struct cleanup *back_to = make_cleanup (null_cleanup, NULL);
- enum bptype type_wanted;
- struct breakpoint_ops *ops;
- char *extra_string = NULL;
- enum opt
- {
- HARDWARE_OPT, TEMP_OPT, CONDITION_OPT,
- IGNORE_COUNT_OPT, THREAD_OPT, PENDING_OPT, DISABLE_OPT,
- TRACEPOINT_OPT,
- };
- static const struct mi_opt opts[] =
- {
- {"h", HARDWARE_OPT, 0},
- {"t", TEMP_OPT, 0},
- {"c", CONDITION_OPT, 1},
- {"i", IGNORE_COUNT_OPT, 1},
- {"p", THREAD_OPT, 1},
- {"f", PENDING_OPT, 0},
- {"d", DISABLE_OPT, 0},
- {"a", TRACEPOINT_OPT, 0},
- { 0, 0, 0 }
- };
-
- int oind = 0;
- char *oarg;
- while (1)
- {
- int opt = mi_getopt ("-break-insert", argc, argv,
- opts, &oind, &oarg);
- if (opt < 0)
- break;
- switch ((enum opt) opt)
- {
- case TEMP_OPT:
- temp_p = 1;
- break;
- case HARDWARE_OPT:
- hardware = 1;
- break;
- case CONDITION_OPT:
- condition = oarg;
- break;
- case IGNORE_COUNT_OPT:
- ignore_count = atol (oarg);
- break;
- case THREAD_OPT:
- thread = atol (oarg);
- break;
- case PENDING_OPT:
- pending = 1;
- break;
- case DISABLE_OPT:
- enabled = 0;
- break;
- case TRACEPOINT_OPT:
- tracepoint = 1;
- break;
- }
- }
- if (oind >= argc)
- error (_("-%s-insert: Missing <location>"),
- dprintf ? "dprintf" : "break");
- address = argv[oind];
- if (dprintf)
- {
- int format_num = oind + 1;
- if (hardware || tracepoint)
- error (_("-dprintf-insert: does not support -h or -a"));
- if (format_num >= argc)
- error (_("-dprintf-insert: Missing <format>"));
- extra_string = mi_argv_to_format (argv + format_num, argc - format_num);
- make_cleanup (xfree, extra_string);
- }
- else
- {
- if (oind < argc - 1)
- error (_("-break-insert: Garbage following <location>"));
- }
-
- setup_breakpoint_reporting ();
- if (tracepoint)
- {
-
- type_wanted = hardware ? bp_fast_tracepoint : bp_tracepoint;
- ops = &tracepoint_breakpoint_ops;
- }
- else if (dprintf)
- {
- type_wanted = bp_dprintf;
- ops = &dprintf_breakpoint_ops;
- }
- else
- {
- type_wanted = hardware ? bp_hardware_breakpoint : bp_breakpoint;
- ops = &bkpt_breakpoint_ops;
- }
- create_breakpoint (get_current_arch (), address, condition, thread,
- extra_string,
- 0 ,
- temp_p, type_wanted,
- ignore_count,
- pending ? AUTO_BOOLEAN_TRUE : AUTO_BOOLEAN_FALSE,
- ops, 0, enabled, 0, 0);
- do_cleanups (back_to);
- }
- void
- mi_cmd_break_insert (char *command, char **argv, int argc)
- {
- mi_cmd_break_insert_1 (0, command, argv, argc);
- }
- void
- mi_cmd_dprintf_insert (char *command, char **argv, int argc)
- {
- mi_cmd_break_insert_1 (1, command, argv, argc);
- }
- enum wp_type
- {
- REG_WP,
- READ_WP,
- ACCESS_WP
- };
- void
- mi_cmd_break_passcount (char *command, char **argv, int argc)
- {
- int n;
- int p;
- struct tracepoint *t;
- if (argc != 2)
- error (_("Usage: tracepoint-number passcount"));
- n = atoi (argv[0]);
- p = atoi (argv[1]);
- t = get_tracepoint (n);
- if (t)
- {
- t->pass_count = p;
- observer_notify_breakpoint_modified (&t->base);
- }
- else
- {
- error (_("Could not find tracepoint %d"), n);
- }
- }
- void
- mi_cmd_break_watch (char *command, char **argv, int argc)
- {
- char *expr = NULL;
- enum wp_type type = REG_WP;
- enum opt
- {
- READ_OPT, ACCESS_OPT
- };
- static const struct mi_opt opts[] =
- {
- {"r", READ_OPT, 0},
- {"a", ACCESS_OPT, 0},
- { 0, 0, 0 }
- };
-
- int oind = 0;
- char *oarg;
- while (1)
- {
- int opt = mi_getopt ("-break-watch", argc, argv,
- opts, &oind, &oarg);
- if (opt < 0)
- break;
- switch ((enum opt) opt)
- {
- case READ_OPT:
- type = READ_WP;
- break;
- case ACCESS_OPT:
- type = ACCESS_WP;
- break;
- }
- }
- if (oind >= argc)
- error (_("-break-watch: Missing <expression>"));
- if (oind < argc - 1)
- error (_("-break-watch: Garbage following <expression>"));
- expr = argv[oind];
-
- switch (type)
- {
- case REG_WP:
- watch_command_wrapper (expr, FROM_TTY, 0);
- break;
- case READ_WP:
- rwatch_command_wrapper (expr, FROM_TTY, 0);
- break;
- case ACCESS_WP:
- awatch_command_wrapper (expr, FROM_TTY, 0);
- break;
- default:
- error (_("-break-watch: Unknown watchpoint type."));
- }
- }
- static char **mi_command_line_array;
- static int mi_command_line_array_cnt;
- static int mi_command_line_array_ptr;
- static char *
- mi_read_next_line (void)
- {
- if (mi_command_line_array_ptr == mi_command_line_array_cnt)
- return NULL;
- else
- return mi_command_line_array[mi_command_line_array_ptr++];
- }
- void
- mi_cmd_break_commands (char *command, char **argv, int argc)
- {
- struct command_line *break_command;
- char *endptr;
- int bnum;
- struct breakpoint *b;
- if (argc < 1)
- error (_("USAGE: %s <BKPT> [<COMMAND> [<COMMAND>...]]"), command);
- bnum = strtol (argv[0], &endptr, 0);
- if (endptr == argv[0])
- error (_("breakpoint number argument \"%s\" is not a number."),
- argv[0]);
- else if (*endptr != '\0')
- error (_("junk at the end of breakpoint number argument \"%s\"."),
- argv[0]);
- b = get_breakpoint (bnum);
- if (b == NULL)
- error (_("breakpoint %d not found."), bnum);
- mi_command_line_array = argv;
- mi_command_line_array_ptr = 1;
- mi_command_line_array_cnt = argc;
- if (is_tracepoint (b))
- break_command = read_command_lines_1 (mi_read_next_line, 1,
- check_tracepoint_command, b);
- else
- break_command = read_command_lines_1 (mi_read_next_line, 1, 0, 0);
- breakpoint_set_commands (b, break_command);
- }