Commit | Line | Data |
---|---|---|
4389a95a AC |
1 | /* MI Command Set for GDB, the GNU debugger. |
2 | ||
6aba47ca | 3 | Copyright (C) 2000, 2003, 2004, 2005, 2007 Free Software Foundation, Inc. |
4389a95a | 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 | |
a9762ec7 | 11 | the Free Software Foundation; either version 3 of the License, or |
fb40c209 AC |
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 | |
a9762ec7 | 20 | along with this program. If not, see <http://www.gnu.org/licenses/>. */ |
fb40c209 AC |
21 | |
22 | #ifndef MI_CMDS_H | |
23 | #define MI_CMDS_H | |
24 | ||
25 | /* An MI command can return any of the following. */ | |
26 | ||
27 | enum mi_cmd_result | |
28 | { | |
29 | /* Report the command as ``done''. Display both the ``NNN^done'' | |
30 | message and the completion prompt. */ | |
31 | MI_CMD_DONE = 0, | |
32 | /* The command is still running in the forground. Main loop should | |
33 | display the completion prompt. */ | |
34 | MI_CMD_FORGROUND, | |
35 | /* An error condition was detected and an error message was | |
36 | asprintf'd into the mi_error_message buffer. The main loop will | |
37 | display the error message and the completion prompt. */ | |
38 | MI_CMD_ERROR, | |
fb40c209 AC |
39 | /* The MI command has already displayed its completion message. |
40 | Main loop will not display a completion message but will display | |
41 | the completion prompt. */ | |
42 | MI_CMD_QUIET | |
43 | }; | |
44 | ||
90e645cd NR |
45 | enum print_values { |
46 | PRINT_NO_VALUES, | |
47 | PRINT_ALL_VALUES, | |
48 | PRINT_SIMPLE_VALUES | |
49 | }; | |
50 | ||
1ecb4ee0 DJ |
51 | extern const char mi_no_values[]; |
52 | extern const char mi_simple_values[]; | |
53 | extern const char mi_all_values[]; | |
54 | ||
fb40c209 AC |
55 | typedef enum mi_cmd_result (mi_cmd_argv_ftype) (char *command, char **argv, int argc); |
56 | ||
57 | /* Older MI commands have this interface. Retained until all old | |
58 | commands are flushed. */ | |
59 | ||
60 | typedef enum mi_cmd_result (mi_cmd_args_ftype) ( /*ui */ char *args, int from_tty); | |
61 | ||
62 | /* Function implementing each command */ | |
63 | extern mi_cmd_argv_ftype mi_cmd_break_insert; | |
64 | extern mi_cmd_argv_ftype mi_cmd_break_watch; | |
65 | extern mi_cmd_argv_ftype mi_cmd_disassemble; | |
66 | extern mi_cmd_argv_ftype mi_cmd_data_evaluate_expression; | |
67 | extern mi_cmd_argv_ftype mi_cmd_data_list_register_names; | |
68 | extern mi_cmd_argv_ftype mi_cmd_data_list_register_values; | |
69 | extern mi_cmd_argv_ftype mi_cmd_data_list_changed_registers; | |
70 | extern mi_cmd_argv_ftype mi_cmd_data_read_memory; | |
71 | extern mi_cmd_argv_ftype mi_cmd_data_write_memory; | |
24e8cecf | 72 | extern mi_cmd_argv_ftype mi_cmd_data_write_register_values; |
d8c83789 | 73 | extern mi_cmd_argv_ftype mi_cmd_enable_timings; |
068890be JJ |
74 | extern mi_cmd_argv_ftype mi_cmd_env_cd; |
75 | extern mi_cmd_argv_ftype mi_cmd_env_dir; | |
76 | extern mi_cmd_argv_ftype mi_cmd_env_path; | |
77 | extern mi_cmd_argv_ftype mi_cmd_env_pwd; | |
fb40c209 AC |
78 | extern mi_cmd_args_ftype mi_cmd_exec_continue; |
79 | extern mi_cmd_args_ftype mi_cmd_exec_finish; | |
80 | extern mi_cmd_args_ftype mi_cmd_exec_next; | |
81 | extern mi_cmd_args_ftype mi_cmd_exec_next_instruction; | |
82 | extern mi_cmd_args_ftype mi_cmd_exec_return; | |
83 | extern mi_cmd_args_ftype mi_cmd_exec_run; | |
84 | extern mi_cmd_args_ftype mi_cmd_exec_step; | |
85 | extern mi_cmd_args_ftype mi_cmd_exec_step_instruction; | |
86 | extern mi_cmd_args_ftype mi_cmd_exec_until; | |
87 | extern mi_cmd_args_ftype mi_cmd_exec_interrupt; | |
1abaf70c | 88 | extern mi_cmd_argv_ftype mi_cmd_file_list_exec_source_file; |
57c22c6c | 89 | extern mi_cmd_argv_ftype mi_cmd_file_list_exec_source_files; |
fb40c209 | 90 | extern mi_cmd_argv_ftype mi_cmd_gdb_exit; |
3cb3b8df BR |
91 | extern mi_cmd_argv_ftype mi_cmd_inferior_tty_set; |
92 | extern mi_cmd_argv_ftype mi_cmd_inferior_tty_show; | |
4389a95a | 93 | extern mi_cmd_argv_ftype mi_cmd_interpreter_exec; |
084344da | 94 | extern mi_cmd_argv_ftype mi_cmd_list_features; |
fb40c209 | 95 | extern mi_cmd_argv_ftype mi_cmd_stack_info_depth; |
3ba51a77 | 96 | extern mi_cmd_argv_ftype mi_cmd_stack_info_frame; |
fb40c209 AC |
97 | extern mi_cmd_argv_ftype mi_cmd_stack_list_args; |
98 | extern mi_cmd_argv_ftype mi_cmd_stack_list_frames; | |
99 | extern mi_cmd_argv_ftype mi_cmd_stack_list_locals; | |
100 | extern mi_cmd_argv_ftype mi_cmd_stack_select_frame; | |
0d18235f | 101 | extern mi_cmd_argv_ftype mi_cmd_symbol_list_lines; |
fb40c209 | 102 | extern mi_cmd_args_ftype mi_cmd_target_download; |
a6b151f1 DJ |
103 | extern mi_cmd_argv_ftype mi_cmd_target_file_get; |
104 | extern mi_cmd_argv_ftype mi_cmd_target_file_put; | |
105 | extern mi_cmd_argv_ftype mi_cmd_target_file_delete; | |
fb40c209 AC |
106 | extern mi_cmd_args_ftype mi_cmd_target_select; |
107 | extern mi_cmd_argv_ftype mi_cmd_thread_list_ids; | |
108 | extern mi_cmd_argv_ftype mi_cmd_thread_select; | |
109 | extern mi_cmd_argv_ftype mi_cmd_var_assign; | |
110 | extern mi_cmd_argv_ftype mi_cmd_var_create; | |
111 | extern mi_cmd_argv_ftype mi_cmd_var_delete; | |
112 | extern mi_cmd_argv_ftype mi_cmd_var_evaluate_expression; | |
113 | extern mi_cmd_argv_ftype mi_cmd_var_info_expression; | |
02142340 | 114 | extern mi_cmd_argv_ftype mi_cmd_var_info_path_expression; |
fb40c209 AC |
115 | extern mi_cmd_argv_ftype mi_cmd_var_info_num_children; |
116 | extern mi_cmd_argv_ftype mi_cmd_var_info_type; | |
117 | extern mi_cmd_argv_ftype mi_cmd_var_list_children; | |
118 | extern mi_cmd_argv_ftype mi_cmd_var_set_format; | |
25d5ea92 | 119 | extern mi_cmd_argv_ftype mi_cmd_var_set_frozen; |
fb40c209 AC |
120 | extern mi_cmd_argv_ftype mi_cmd_var_show_attributes; |
121 | extern mi_cmd_argv_ftype mi_cmd_var_show_format; | |
122 | extern mi_cmd_argv_ftype mi_cmd_var_update; | |
123 | ||
124 | /* Description of a single command. */ | |
125 | ||
b2af646b AC |
126 | struct mi_cli |
127 | { | |
128 | /* Corresponding CLI command. If ARGS_P is non-zero, the MI | |
129 | command's argument list is appended to the CLI command. */ | |
130 | const char *cmd; | |
131 | int args_p; | |
132 | }; | |
133 | ||
fb40c209 | 134 | struct mi_cmd |
b2af646b AC |
135 | { |
136 | /* official name of the command. */ | |
137 | const char *name; | |
138 | /* The corresponding CLI command that can be used to implement this | |
139 | MI command (if cli.lhs is non NULL). */ | |
140 | struct mi_cli cli; | |
141 | /* If non-null, the function implementing the MI command. */ | |
142 | mi_cmd_args_ftype *args_func; | |
143 | /* If non-null, the function implementing the MI command. */ | |
144 | mi_cmd_argv_ftype *argv_func; | |
145 | }; | |
fb40c209 AC |
146 | |
147 | /* Lookup a command in the mi comand table */ | |
148 | ||
149 | extern struct mi_cmd *mi_lookup (const char *command); | |
150 | ||
151 | /* Debug flag */ | |
152 | extern int mi_debug_p; | |
153 | ||
154 | /* Raw console output - FIXME: should this be a parameter? */ | |
155 | extern struct ui_file *raw_stdout; | |
156 | ||
4389a95a | 157 | extern char *mi_error_message; |
4389a95a AC |
158 | extern void mi_execute_command (char *cmd, int from_tty); |
159 | ||
fb40c209 | 160 | #endif |