| Index: gdb/mi/mi-cmd-catch.c
|
| diff --git a/gdb/mi/mi-cmd-catch.c b/gdb/mi/mi-cmd-catch.c
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..bcfc1bad2044291b8d5126e60380b225f30dc9eb
|
| --- /dev/null
|
| +++ b/gdb/mi/mi-cmd-catch.c
|
| @@ -0,0 +1,242 @@
|
| +/* MI Command Set - catch commands.
|
| + Copyright (C) 2012-2013 Free Software Foundation, Inc.
|
| +
|
| + Contributed by Intel Corporation.
|
| +
|
| + 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 "arch-utils.h"
|
| +#include "breakpoint.h"
|
| +#include "gdb.h"
|
| +#include "libiberty.h"
|
| +#include "ada-lang.h"
|
| +#include "mi-cmds.h"
|
| +#include "mi-getopt.h"
|
| +#include "mi-cmd-break.h"
|
| +
|
| +/* Handler for the -catch-assert command. */
|
| +
|
| +void
|
| +mi_cmd_catch_assert (char *cmd, char *argv[], int argc)
|
| +{
|
| + struct gdbarch *gdbarch = get_current_arch();
|
| + char *condition = NULL;
|
| + int enabled = 1;
|
| + int temp = 0;
|
| +
|
| + int oind = 0;
|
| + char *oarg;
|
| +
|
| + enum opt
|
| + {
|
| + OPT_CONDITION, OPT_DISABLED, OPT_TEMP,
|
| + };
|
| + static const struct mi_opt opts[] =
|
| + {
|
| + { "c", OPT_CONDITION, 1},
|
| + { "d", OPT_DISABLED, 0 },
|
| + { "t", OPT_TEMP, 0 },
|
| + { 0, 0, 0 }
|
| + };
|
| +
|
| + for (;;)
|
| + {
|
| + int opt = mi_getopt ("-catch-assert", argc, argv, opts,
|
| + &oind, &oarg);
|
| +
|
| + if (opt < 0)
|
| + break;
|
| +
|
| + switch ((enum opt) opt)
|
| + {
|
| + case OPT_CONDITION:
|
| + condition = oarg;
|
| + break;
|
| + case OPT_DISABLED:
|
| + enabled = 0;
|
| + break;
|
| + case OPT_TEMP:
|
| + temp = 1;
|
| + break;
|
| + }
|
| + }
|
| +
|
| + /* This command does not accept any argument. Make sure the user
|
| + did not provide any. */
|
| + if (oind != argc)
|
| + error (_("Invalid argument: %s"), argv[oind]);
|
| +
|
| + setup_breakpoint_reporting ();
|
| + /* create_ada_exception_catchpoint needs CONDITION to be xstrdup'ed,
|
| + and will assume control of its lifetime. */
|
| + if (condition != NULL)
|
| + condition = xstrdup (condition);
|
| + create_ada_exception_catchpoint (gdbarch, ada_catch_assert,
|
| + NULL, condition, temp, enabled, 0);
|
| +}
|
| +
|
| +/* Handler for the -catch-exception command. */
|
| +
|
| +void
|
| +mi_cmd_catch_exception (char *cmd, char *argv[], int argc)
|
| +{
|
| + struct gdbarch *gdbarch = get_current_arch();
|
| + char *condition = NULL;
|
| + int enabled = 1;
|
| + char *exception_name = NULL;
|
| + int temp = 0;
|
| + enum ada_exception_catchpoint_kind ex_kind = ada_catch_exception;
|
| +
|
| + int oind = 0;
|
| + char *oarg;
|
| +
|
| + enum opt
|
| + {
|
| + OPT_CONDITION, OPT_DISABLED, OPT_EXCEPTION_NAME, OPT_TEMP,
|
| + OPT_UNHANDLED,
|
| + };
|
| + static const struct mi_opt opts[] =
|
| + {
|
| + { "c", OPT_CONDITION, 1},
|
| + { "d", OPT_DISABLED, 0 },
|
| + { "e", OPT_EXCEPTION_NAME, 1 },
|
| + { "t", OPT_TEMP, 0 },
|
| + { "u", OPT_UNHANDLED, 0},
|
| + { 0, 0, 0 }
|
| + };
|
| +
|
| + for (;;)
|
| + {
|
| + int opt = mi_getopt ("-catch-exception", argc, argv, opts,
|
| + &oind, &oarg);
|
| +
|
| + if (opt < 0)
|
| + break;
|
| +
|
| + switch ((enum opt) opt)
|
| + {
|
| + case OPT_CONDITION:
|
| + condition = oarg;
|
| + break;
|
| + case OPT_DISABLED:
|
| + enabled = 0;
|
| + break;
|
| + case OPT_EXCEPTION_NAME:
|
| + exception_name = oarg;
|
| + break;
|
| + case OPT_TEMP:
|
| + temp = 1;
|
| + break;
|
| + case OPT_UNHANDLED:
|
| + ex_kind = ada_catch_exception_unhandled;
|
| + break;
|
| + }
|
| + }
|
| +
|
| + /* This command does not accept any argument. Make sure the user
|
| + did not provide any. */
|
| + if (oind != argc)
|
| + error (_("Invalid argument: %s"), argv[oind]);
|
| +
|
| + /* Specifying an exception name does not make sense when requesting
|
| + an unhandled exception breakpoint. */
|
| + if (ex_kind == ada_catch_exception_unhandled && exception_name != NULL)
|
| + error (_("\"-e\" and \"-u\" are mutually exclusive"));
|
| +
|
| + setup_breakpoint_reporting ();
|
| + /* create_ada_exception_catchpoint needs EXCEPTION_NAME and CONDITION
|
| + to be xstrdup'ed, and will assume control of their lifetime. */
|
| + if (exception_name != NULL)
|
| + exception_name = xstrdup (exception_name);
|
| + if (condition != NULL)
|
| + condition = xstrdup (condition);
|
| + create_ada_exception_catchpoint (gdbarch, ex_kind,
|
| + exception_name, condition,
|
| + temp, enabled, 0);
|
| +}
|
| +
|
| +/* Common path for the -catch-load and -catch-unload. */
|
| +
|
| +static void
|
| +mi_catch_load_unload (int load, char *argv[], int argc)
|
| +{
|
| + struct cleanup *back_to;
|
| + const char *actual_cmd = load ? "-catch-load" : "-catch-unload";
|
| + int temp = 0;
|
| + int enabled = 1;
|
| + int oind = 0;
|
| + char *oarg;
|
| + enum opt
|
| + {
|
| + OPT_TEMP,
|
| + OPT_DISABLED,
|
| + };
|
| + static const struct mi_opt opts[] =
|
| + {
|
| + { "t", OPT_TEMP, 0 },
|
| + { "d", OPT_DISABLED, 0 },
|
| + { 0, 0, 0 }
|
| + };
|
| +
|
| + for (;;)
|
| + {
|
| + int opt = mi_getopt (actual_cmd, argc, argv, opts,
|
| + &oind, &oarg);
|
| +
|
| + if (opt < 0)
|
| + break;
|
| +
|
| + switch ((enum opt) opt)
|
| + {
|
| + case OPT_TEMP:
|
| + temp = 1;
|
| + break;
|
| + case OPT_DISABLED:
|
| + enabled = 0;
|
| + break;
|
| + }
|
| + }
|
| +
|
| + if (oind >= argc)
|
| + error (_("-catch-load/unload: Missing <library name>"));
|
| + if (oind < argc -1)
|
| + error (_("-catch-load/unload: Garbage following the <library name>"));
|
| +
|
| + back_to = setup_breakpoint_reporting ();
|
| +
|
| + add_solib_catchpoint (argv[oind], load, temp, enabled);
|
| +
|
| + do_cleanups (back_to);
|
| +}
|
| +
|
| +/* Handler for the -catch-load. */
|
| +
|
| +void
|
| +mi_cmd_catch_load (char *cmd, char *argv[], int argc)
|
| +{
|
| + mi_catch_load_unload (1, argv, argc);
|
| +}
|
| +
|
| +
|
| +/* Handler for the -catch-unload. */
|
| +
|
| +void
|
| +mi_cmd_catch_unload (char *cmd, char *argv[], int argc)
|
| +{
|
| + mi_catch_load_unload (0, argv, argc);
|
| +}
|
| +
|
|
|