summaryrefslogtreecommitdiff
path: root/gdb/mi
diff options
context:
space:
mode:
authorqiyao <qiyao>2013-08-01 06:42:58 +0000
committerqiyao <qiyao>2013-08-01 06:42:58 +0000
commita1269d2a9a983622bbfcaa31206b78d165f18b18 (patch)
tree71fb3b20f8e975bfcaabfebbd4d06a1029803137 /gdb/mi
parent5339a63aa3d9196b38789e8094dca5697967d81e (diff)
downloadgdb-a1269d2a9a983622bbfcaa31206b78d165f18b18.tar.gz
gdb/
* mi/mi-cmd-stack.c (mi_cmd_stack_list_locals): Parse argv with mi_getopt. (mi_cmd_stack_list_variables): Likewise.
Diffstat (limited to 'gdb/mi')
-rw-r--r--gdb/mi/mi-cmd-stack.c79
1 files changed, 69 insertions, 10 deletions
diff --git a/gdb/mi/mi-cmd-stack.c b/gdb/mi/mi-cmd-stack.c
index 1f1068cd734..70ff0b601a6 100644
--- a/gdb/mi/mi-cmd-stack.c
+++ b/gdb/mi/mi-cmd-stack.c
@@ -212,16 +212,46 @@ mi_cmd_stack_list_locals (char *command, char **argv, int argc)
int raw_arg = 0;
enum py_bt_status result = PY_BT_ERROR;
int print_value;
+ int oind = 0;
- if (argc > 0)
- raw_arg = parse_no_frames_option (argv[0]);
+ if (argc > 1)
+ {
+ int i;
+ enum opt
+ {
+ NO_FRAME_FILTERS
+ };
+ static const struct mi_opt opts[] =
+ {
+ {"-no-frame-filters", NO_FRAME_FILTERS, 0},
+ { 0, 0, 0 }
+ };
+
+ while (1)
+ {
+ char *oarg;
+ /* Don't parse 'print-values' as an option. */
+ int opt = mi_getopt ("-stack-list-locals", argc - 1, argv,
+ opts, &oind, &oarg);
+
+ if (opt < 0)
+ break;
+ switch ((enum opt) opt)
+ {
+ case NO_FRAME_FILTERS:
+ raw_arg = oind;
+ break;
+ }
+ }
+ }
- if (argc < 1 || argc > 2 || (argc == 2 && ! raw_arg)
- || (argc == 1 && raw_arg))
+ /* After the last option is parsed, there should be only
+ 'print-values'. */
+ if (argc - oind != 1)
error (_("-stack-list-locals: Usage: [--no-frame-filters] PRINT_VALUES"));
frame = get_selected_frame (NULL);
- print_value = mi_parse_print_values (argv[raw_arg]);
+ print_value = mi_parse_print_values (argv[oind]);
if (! raw_arg && frame_filters)
{
@@ -341,17 +371,46 @@ mi_cmd_stack_list_variables (char *command, char **argv, int argc)
int raw_arg = 0;
enum py_bt_status result = PY_BT_ERROR;
int print_value;
+ int oind = 0;
- if (argc > 0)
- raw_arg = parse_no_frames_option (argv[0]);
+ if (argc > 1)
+ {
+ int i;
+ enum opt
+ {
+ NO_FRAME_FILTERS
+ };
+ static const struct mi_opt opts[] =
+ {
+ {"-no-frame-filters", NO_FRAME_FILTERS, 0},
+ { 0, 0, 0 }
+ };
+
+ while (1)
+ {
+ char *oarg;
+ /* Don't parse 'print-values' as an option. */
+ int opt = mi_getopt ("-stack-list-variables", argc - 1,
+ argv, opts, &oind, &oarg);
+ if (opt < 0)
+ break;
+ switch ((enum opt) opt)
+ {
+ case NO_FRAME_FILTERS:
+ raw_arg = oind;
+ break;
+ }
+ }
+ }
- if (argc < 1 || argc > 2 || (argc == 2 && ! raw_arg)
- || (argc == 1 && raw_arg))
+ /* After the last option is parsed, there should be only
+ 'print-values'. */
+ if (argc - oind != 1)
error (_("-stack-list-variables: Usage: " \
"[--no-frame-filters] PRINT_VALUES"));
frame = get_selected_frame (NULL);
- print_value = mi_parse_print_values (argv[raw_arg]);
+ print_value = mi_parse_print_values (argv[oind]);
if (! raw_arg && frame_filters)
{