Commit | Line | Data |
---|---|---|
4389a95a AC |
1 | /* MI Command Set for GDB, the GNU debugger. |
2 | ||
3 | Copyright 2000, 2003 Free Software Foundation, Inc. | |
4 | ||
ab91fdd5 | 5 | Contributed by Cygnus Solutions (a Red Hat company). |
fb40c209 AC |
6 | |
7 | This file is part of GDB. | |
8 | ||
9 | This program is free software; you can redistribute it and/or modify | |
10 | it under the terms of the GNU General Public License as published by | |
11 | the Free Software Foundation; either version 2 of the License, or | |
12 | (at your option) any later version. | |
13 | ||
14 | This program is distributed in the hope that it will be useful, | |
15 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
17 | GNU General Public License for more details. | |
18 | ||
19 | You should have received a copy of the GNU General Public License | |
20 | along with this program; if not, write to the Free Software | |
21 | Foundation, Inc., 59 Temple Place - Suite 330, | |
22 | Boston, MA 02111-1307, USA. */ | |
23 | ||
24 | #ifndef MI_CMDS_H | |
25 | #define MI_CMDS_H | |
26 | ||
27 | /* An MI command can return any of the following. */ | |
28 | ||
29 | enum mi_cmd_result | |
30 | { | |
31 | /* Report the command as ``done''. Display both the ``NNN^done'' | |
32 | message and the completion prompt. */ | |
33 | MI_CMD_DONE = 0, | |
34 | /* The command is still running in the forground. Main loop should | |
35 | display the completion prompt. */ | |
36 | MI_CMD_FORGROUND, | |
37 | /* An error condition was detected and an error message was | |
38 | asprintf'd into the mi_error_message buffer. The main loop will | |
39 | display the error message and the completion prompt. */ | |
40 | MI_CMD_ERROR, | |
41 | /* An error condition was detected and caught. The error message is | |
42 | in the global error message buffer. The main loop will display | |
43 | the error message and the completion prompt. */ | |
44 | MI_CMD_CAUGHT_ERROR, | |
45 | /* The MI command has already displayed its completion message. | |
46 | Main loop will not display a completion message but will display | |
47 | the completion prompt. */ | |
48 | MI_CMD_QUIET | |
49 | }; | |
50 | ||
51 | typedef enum mi_cmd_result (mi_cmd_argv_ftype) (char *command, char **argv, int argc); | |
52 | ||
53 | /* Older MI commands have this interface. Retained until all old | |
54 | commands are flushed. */ | |
55 | ||
56 | typedef enum mi_cmd_result (mi_cmd_args_ftype) ( /*ui */ char *args, int from_tty); | |
57 | ||
58 | /* Function implementing each command */ | |
59 | extern mi_cmd_argv_ftype mi_cmd_break_insert; | |
60 | extern mi_cmd_argv_ftype mi_cmd_break_watch; | |
61 | extern mi_cmd_argv_ftype mi_cmd_disassemble; | |
62 | extern mi_cmd_argv_ftype mi_cmd_data_evaluate_expression; | |
63 | extern mi_cmd_argv_ftype mi_cmd_data_list_register_names; | |
64 | extern mi_cmd_argv_ftype mi_cmd_data_list_register_values; | |
65 | extern mi_cmd_argv_ftype mi_cmd_data_list_changed_registers; | |
66 | extern mi_cmd_argv_ftype mi_cmd_data_read_memory; | |
67 | extern mi_cmd_argv_ftype mi_cmd_data_write_memory; | |
24e8cecf | 68 | extern mi_cmd_argv_ftype mi_cmd_data_write_register_values; |
068890be JJ |
69 | extern mi_cmd_argv_ftype mi_cmd_env_cd; |
70 | extern mi_cmd_argv_ftype mi_cmd_env_dir; | |
71 | extern mi_cmd_argv_ftype mi_cmd_env_path; | |
72 | extern mi_cmd_argv_ftype mi_cmd_env_pwd; | |
fb40c209 AC |
73 | extern mi_cmd_args_ftype mi_cmd_exec_continue; |
74 | extern mi_cmd_args_ftype mi_cmd_exec_finish; | |
75 | extern mi_cmd_args_ftype mi_cmd_exec_next; | |
76 | extern mi_cmd_args_ftype mi_cmd_exec_next_instruction; | |
77 | extern mi_cmd_args_ftype mi_cmd_exec_return; | |
78 | extern mi_cmd_args_ftype mi_cmd_exec_run; | |
79 | extern mi_cmd_args_ftype mi_cmd_exec_step; | |
80 | extern mi_cmd_args_ftype mi_cmd_exec_step_instruction; | |
81 | extern mi_cmd_args_ftype mi_cmd_exec_until; | |
82 | extern mi_cmd_args_ftype mi_cmd_exec_interrupt; | |
1abaf70c | 83 | extern mi_cmd_argv_ftype mi_cmd_file_list_exec_source_file; |
fb40c209 | 84 | extern mi_cmd_argv_ftype mi_cmd_gdb_exit; |
4389a95a | 85 | extern mi_cmd_argv_ftype mi_cmd_interpreter_exec; |
fb40c209 AC |
86 | extern mi_cmd_argv_ftype mi_cmd_stack_info_depth; |
87 | extern mi_cmd_argv_ftype mi_cmd_stack_list_args; | |
88 | extern mi_cmd_argv_ftype mi_cmd_stack_list_frames; | |
89 | extern mi_cmd_argv_ftype mi_cmd_stack_list_locals; | |
90 | extern mi_cmd_argv_ftype mi_cmd_stack_select_frame; | |
0d18235f | 91 | extern mi_cmd_argv_ftype mi_cmd_symbol_list_lines; |
fb40c209 AC |
92 | extern mi_cmd_args_ftype mi_cmd_target_download; |
93 | extern mi_cmd_args_ftype mi_cmd_target_select; | |
94 | extern mi_cmd_argv_ftype mi_cmd_thread_list_ids; | |
95 | extern mi_cmd_argv_ftype mi_cmd_thread_select; | |
96 | extern mi_cmd_argv_ftype mi_cmd_var_assign; | |
97 | extern mi_cmd_argv_ftype mi_cmd_var_create; | |
98 | extern mi_cmd_argv_ftype mi_cmd_var_delete; | |
99 | extern mi_cmd_argv_ftype mi_cmd_var_evaluate_expression; | |
100 | extern mi_cmd_argv_ftype mi_cmd_var_info_expression; | |
101 | extern mi_cmd_argv_ftype mi_cmd_var_info_num_children; | |
102 | extern mi_cmd_argv_ftype mi_cmd_var_info_type; | |
103 | extern mi_cmd_argv_ftype mi_cmd_var_list_children; | |
104 | extern mi_cmd_argv_ftype mi_cmd_var_set_format; | |
105 | extern mi_cmd_argv_ftype mi_cmd_var_show_attributes; | |
106 | extern mi_cmd_argv_ftype mi_cmd_var_show_format; | |
107 | extern mi_cmd_argv_ftype mi_cmd_var_update; | |
108 | ||
109 | /* Description of a single command. */ | |
110 | ||
111 | struct mi_cmd | |
112 | { | |
113 | /* official name of the command */ | |
114 | const char *name; | |
115 | /* If non-null, the corresponding CLI command that can be used to | |
116 | implement this MI command */ | |
117 | const char *cli; | |
118 | /* If non-null, the function implementing the MI command */ | |
119 | mi_cmd_args_ftype *args_func; | |
120 | /* If non-null, the function implementing the MI command */ | |
121 | mi_cmd_argv_ftype *argv_func; | |
122 | }; | |
123 | ||
124 | /* Lookup a command in the mi comand table */ | |
125 | ||
126 | extern struct mi_cmd *mi_lookup (const char *command); | |
127 | ||
128 | /* Debug flag */ | |
129 | extern int mi_debug_p; | |
130 | ||
131 | /* Raw console output - FIXME: should this be a parameter? */ | |
132 | extern struct ui_file *raw_stdout; | |
133 | ||
4389a95a AC |
134 | extern char *mi_error_message; |
135 | extern void mi_error_last_message (void); | |
136 | extern void mi_execute_command (char *cmd, int from_tty); | |
137 | ||
fb40c209 | 138 | #endif |