* breakpoint.c (bpstat_check_location)
[deliverable/binutils-gdb.git] / gdb / mi / mi-cmds.h
CommitLineData
4389a95a
AC
1/* MI Command Set for GDB, the GNU debugger.
2
9b254dd1
DJ
3 Copyright (C) 2000, 2003, 2004, 2005, 2007, 2008
4 Free Software Foundation, Inc.
4389a95a 5
ab91fdd5 6 Contributed by Cygnus Solutions (a Red Hat company).
fb40c209
AC
7
8 This file is part of GDB.
9
10 This program is free software; you can redistribute it and/or modify
11 it under the terms of the GNU General Public License as published by
a9762ec7 12 the Free Software Foundation; either version 3 of the License, or
fb40c209
AC
13 (at your option) any later version.
14
15 This program is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 GNU General Public License for more details.
19
20 You should have received a copy of the GNU General Public License
a9762ec7 21 along with this program. If not, see <http://www.gnu.org/licenses/>. */
fb40c209
AC
22
23#ifndef MI_CMDS_H
24#define MI_CMDS_H
25
26/* An MI command can return any of the following. */
27
28enum mi_cmd_result
29 {
30 /* Report the command as ``done''. Display both the ``NNN^done''
31 message and the completion prompt. */
32 MI_CMD_DONE = 0,
33 /* The command is still running in the forground. Main loop should
34 display the completion prompt. */
35 MI_CMD_FORGROUND,
fb40c209
AC
36 /* The MI command has already displayed its completion message.
37 Main loop will not display a completion message but will display
38 the completion prompt. */
39 MI_CMD_QUIET
40 };
41
90e645cd
NR
42enum print_values {
43 PRINT_NO_VALUES,
44 PRINT_ALL_VALUES,
45 PRINT_SIMPLE_VALUES
46};
47
1ecb4ee0
DJ
48extern const char mi_no_values[];
49extern const char mi_simple_values[];
50extern const char mi_all_values[];
51
fb40c209
AC
52typedef enum mi_cmd_result (mi_cmd_argv_ftype) (char *command, char **argv, int argc);
53
54/* Older MI commands have this interface. Retained until all old
55 commands are flushed. */
56
57typedef enum mi_cmd_result (mi_cmd_args_ftype) ( /*ui */ char *args, int from_tty);
58
59/* Function implementing each command */
60extern mi_cmd_argv_ftype mi_cmd_break_insert;
61extern mi_cmd_argv_ftype mi_cmd_break_watch;
62extern mi_cmd_argv_ftype mi_cmd_disassemble;
63extern mi_cmd_argv_ftype mi_cmd_data_evaluate_expression;
64extern mi_cmd_argv_ftype mi_cmd_data_list_register_names;
65extern mi_cmd_argv_ftype mi_cmd_data_list_register_values;
66extern mi_cmd_argv_ftype mi_cmd_data_list_changed_registers;
67extern mi_cmd_argv_ftype mi_cmd_data_read_memory;
68extern mi_cmd_argv_ftype mi_cmd_data_write_memory;
24e8cecf 69extern mi_cmd_argv_ftype mi_cmd_data_write_register_values;
d8c83789 70extern mi_cmd_argv_ftype mi_cmd_enable_timings;
068890be
JJ
71extern mi_cmd_argv_ftype mi_cmd_env_cd;
72extern mi_cmd_argv_ftype mi_cmd_env_dir;
73extern mi_cmd_argv_ftype mi_cmd_env_path;
74extern mi_cmd_argv_ftype mi_cmd_env_pwd;
fb40c209
AC
75extern mi_cmd_args_ftype mi_cmd_exec_continue;
76extern mi_cmd_args_ftype mi_cmd_exec_finish;
77extern mi_cmd_args_ftype mi_cmd_exec_next;
78extern mi_cmd_args_ftype mi_cmd_exec_next_instruction;
79extern mi_cmd_args_ftype mi_cmd_exec_return;
80extern mi_cmd_args_ftype mi_cmd_exec_run;
81extern mi_cmd_args_ftype mi_cmd_exec_step;
82extern mi_cmd_args_ftype mi_cmd_exec_step_instruction;
83extern mi_cmd_args_ftype mi_cmd_exec_until;
84extern mi_cmd_args_ftype mi_cmd_exec_interrupt;
1abaf70c 85extern mi_cmd_argv_ftype mi_cmd_file_list_exec_source_file;
57c22c6c 86extern mi_cmd_argv_ftype mi_cmd_file_list_exec_source_files;
fb40c209 87extern mi_cmd_argv_ftype mi_cmd_gdb_exit;
3cb3b8df
BR
88extern mi_cmd_argv_ftype mi_cmd_inferior_tty_set;
89extern mi_cmd_argv_ftype mi_cmd_inferior_tty_show;
4389a95a 90extern mi_cmd_argv_ftype mi_cmd_interpreter_exec;
084344da 91extern mi_cmd_argv_ftype mi_cmd_list_features;
fb40c209 92extern mi_cmd_argv_ftype mi_cmd_stack_info_depth;
3ba51a77 93extern mi_cmd_argv_ftype mi_cmd_stack_info_frame;
fb40c209
AC
94extern mi_cmd_argv_ftype mi_cmd_stack_list_args;
95extern mi_cmd_argv_ftype mi_cmd_stack_list_frames;
96extern mi_cmd_argv_ftype mi_cmd_stack_list_locals;
97extern mi_cmd_argv_ftype mi_cmd_stack_select_frame;
0d18235f 98extern mi_cmd_argv_ftype mi_cmd_symbol_list_lines;
fb40c209 99extern mi_cmd_args_ftype mi_cmd_target_download;
a6b151f1
DJ
100extern mi_cmd_argv_ftype mi_cmd_target_file_get;
101extern mi_cmd_argv_ftype mi_cmd_target_file_put;
102extern mi_cmd_argv_ftype mi_cmd_target_file_delete;
fb40c209 103extern mi_cmd_args_ftype mi_cmd_target_select;
8e8901c5 104extern mi_cmd_argv_ftype mi_cmd_thread_info;
fb40c209
AC
105extern mi_cmd_argv_ftype mi_cmd_thread_list_ids;
106extern mi_cmd_argv_ftype mi_cmd_thread_select;
107extern mi_cmd_argv_ftype mi_cmd_var_assign;
108extern mi_cmd_argv_ftype mi_cmd_var_create;
109extern mi_cmd_argv_ftype mi_cmd_var_delete;
110extern mi_cmd_argv_ftype mi_cmd_var_evaluate_expression;
111extern mi_cmd_argv_ftype mi_cmd_var_info_expression;
02142340 112extern mi_cmd_argv_ftype mi_cmd_var_info_path_expression;
fb40c209
AC
113extern mi_cmd_argv_ftype mi_cmd_var_info_num_children;
114extern mi_cmd_argv_ftype mi_cmd_var_info_type;
115extern mi_cmd_argv_ftype mi_cmd_var_list_children;
116extern mi_cmd_argv_ftype mi_cmd_var_set_format;
25d5ea92 117extern mi_cmd_argv_ftype mi_cmd_var_set_frozen;
fb40c209
AC
118extern mi_cmd_argv_ftype mi_cmd_var_show_attributes;
119extern mi_cmd_argv_ftype mi_cmd_var_show_format;
120extern mi_cmd_argv_ftype mi_cmd_var_update;
121
122/* Description of a single command. */
123
b2af646b
AC
124struct mi_cli
125{
126 /* Corresponding CLI command. If ARGS_P is non-zero, the MI
127 command's argument list is appended to the CLI command. */
128 const char *cmd;
129 int args_p;
130};
131
fb40c209 132struct mi_cmd
b2af646b
AC
133{
134 /* official name of the command. */
135 const char *name;
136 /* The corresponding CLI command that can be used to implement this
137 MI command (if cli.lhs is non NULL). */
138 struct mi_cli cli;
139 /* If non-null, the function implementing the MI command. */
140 mi_cmd_args_ftype *args_func;
141 /* If non-null, the function implementing the MI command. */
142 mi_cmd_argv_ftype *argv_func;
143};
fb40c209
AC
144
145/* Lookup a command in the mi comand table */
146
147extern struct mi_cmd *mi_lookup (const char *command);
148
149/* Debug flag */
150extern int mi_debug_p;
151
152/* Raw console output - FIXME: should this be a parameter? */
153extern struct ui_file *raw_stdout;
154
4389a95a
AC
155extern void mi_execute_command (char *cmd, int from_tty);
156
fb40c209 157#endif
This page took 0.64581 seconds and 4 git commands to generate.