Switch the license of all .c files to GPLv3.
[deliverable/binutils-gdb.git] / gdb / mi / mi-cmds.h
CommitLineData
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
27enum 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
45enum print_values {
46 PRINT_NO_VALUES,
47 PRINT_ALL_VALUES,
48 PRINT_SIMPLE_VALUES
49};
50
1ecb4ee0
DJ
51extern const char mi_no_values[];
52extern const char mi_simple_values[];
53extern const char mi_all_values[];
54
fb40c209
AC
55typedef 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
60typedef enum mi_cmd_result (mi_cmd_args_ftype) ( /*ui */ char *args, int from_tty);
61
62/* Function implementing each command */
63extern mi_cmd_argv_ftype mi_cmd_break_insert;
64extern mi_cmd_argv_ftype mi_cmd_break_watch;
65extern mi_cmd_argv_ftype mi_cmd_disassemble;
66extern mi_cmd_argv_ftype mi_cmd_data_evaluate_expression;
67extern mi_cmd_argv_ftype mi_cmd_data_list_register_names;
68extern mi_cmd_argv_ftype mi_cmd_data_list_register_values;
69extern mi_cmd_argv_ftype mi_cmd_data_list_changed_registers;
70extern mi_cmd_argv_ftype mi_cmd_data_read_memory;
71extern mi_cmd_argv_ftype mi_cmd_data_write_memory;
24e8cecf 72extern mi_cmd_argv_ftype mi_cmd_data_write_register_values;
d8c83789 73extern mi_cmd_argv_ftype mi_cmd_enable_timings;
068890be
JJ
74extern mi_cmd_argv_ftype mi_cmd_env_cd;
75extern mi_cmd_argv_ftype mi_cmd_env_dir;
76extern mi_cmd_argv_ftype mi_cmd_env_path;
77extern mi_cmd_argv_ftype mi_cmd_env_pwd;
fb40c209
AC
78extern mi_cmd_args_ftype mi_cmd_exec_continue;
79extern mi_cmd_args_ftype mi_cmd_exec_finish;
80extern mi_cmd_args_ftype mi_cmd_exec_next;
81extern mi_cmd_args_ftype mi_cmd_exec_next_instruction;
82extern mi_cmd_args_ftype mi_cmd_exec_return;
83extern mi_cmd_args_ftype mi_cmd_exec_run;
84extern mi_cmd_args_ftype mi_cmd_exec_step;
85extern mi_cmd_args_ftype mi_cmd_exec_step_instruction;
86extern mi_cmd_args_ftype mi_cmd_exec_until;
87extern mi_cmd_args_ftype mi_cmd_exec_interrupt;
1abaf70c 88extern mi_cmd_argv_ftype mi_cmd_file_list_exec_source_file;
57c22c6c 89extern mi_cmd_argv_ftype mi_cmd_file_list_exec_source_files;
fb40c209 90extern mi_cmd_argv_ftype mi_cmd_gdb_exit;
3cb3b8df
BR
91extern mi_cmd_argv_ftype mi_cmd_inferior_tty_set;
92extern mi_cmd_argv_ftype mi_cmd_inferior_tty_show;
4389a95a 93extern mi_cmd_argv_ftype mi_cmd_interpreter_exec;
fb40c209 94extern mi_cmd_argv_ftype mi_cmd_stack_info_depth;
3ba51a77 95extern mi_cmd_argv_ftype mi_cmd_stack_info_frame;
fb40c209
AC
96extern mi_cmd_argv_ftype mi_cmd_stack_list_args;
97extern mi_cmd_argv_ftype mi_cmd_stack_list_frames;
98extern mi_cmd_argv_ftype mi_cmd_stack_list_locals;
99extern mi_cmd_argv_ftype mi_cmd_stack_select_frame;
0d18235f 100extern mi_cmd_argv_ftype mi_cmd_symbol_list_lines;
fb40c209
AC
101extern mi_cmd_args_ftype mi_cmd_target_download;
102extern mi_cmd_args_ftype mi_cmd_target_select;
103extern mi_cmd_argv_ftype mi_cmd_thread_list_ids;
104extern mi_cmd_argv_ftype mi_cmd_thread_select;
105extern mi_cmd_argv_ftype mi_cmd_var_assign;
106extern mi_cmd_argv_ftype mi_cmd_var_create;
107extern mi_cmd_argv_ftype mi_cmd_var_delete;
108extern mi_cmd_argv_ftype mi_cmd_var_evaluate_expression;
109extern mi_cmd_argv_ftype mi_cmd_var_info_expression;
110extern mi_cmd_argv_ftype mi_cmd_var_info_num_children;
111extern mi_cmd_argv_ftype mi_cmd_var_info_type;
112extern mi_cmd_argv_ftype mi_cmd_var_list_children;
113extern mi_cmd_argv_ftype mi_cmd_var_set_format;
25d5ea92 114extern mi_cmd_argv_ftype mi_cmd_var_set_frozen;
fb40c209
AC
115extern mi_cmd_argv_ftype mi_cmd_var_show_attributes;
116extern mi_cmd_argv_ftype mi_cmd_var_show_format;
117extern mi_cmd_argv_ftype mi_cmd_var_update;
118
119/* Description of a single command. */
120
b2af646b
AC
121struct mi_cli
122{
123 /* Corresponding CLI command. If ARGS_P is non-zero, the MI
124 command's argument list is appended to the CLI command. */
125 const char *cmd;
126 int args_p;
127};
128
fb40c209 129struct mi_cmd
b2af646b
AC
130{
131 /* official name of the command. */
132 const char *name;
133 /* The corresponding CLI command that can be used to implement this
134 MI command (if cli.lhs is non NULL). */
135 struct mi_cli cli;
136 /* If non-null, the function implementing the MI command. */
137 mi_cmd_args_ftype *args_func;
138 /* If non-null, the function implementing the MI command. */
139 mi_cmd_argv_ftype *argv_func;
140};
fb40c209
AC
141
142/* Lookup a command in the mi comand table */
143
144extern struct mi_cmd *mi_lookup (const char *command);
145
146/* Debug flag */
147extern int mi_debug_p;
148
149/* Raw console output - FIXME: should this be a parameter? */
150extern struct ui_file *raw_stdout;
151
4389a95a 152extern char *mi_error_message;
4389a95a
AC
153extern void mi_execute_command (char *cmd, int from_tty);
154
fb40c209 155#endif
This page took 0.59808 seconds and 4 git commands to generate.