Commit | Line | Data |
---|---|---|
fb40c209 | 1 | /* MI Command Set - MI Command Parser. |
618f726f | 2 | Copyright (C) 2000-2016 Free Software Foundation, Inc. |
ab91fdd5 | 3 | Contributed by Cygnus Solutions (a Red Hat company). |
fb40c209 AC |
4 | |
5 | This file is part of GDB. | |
6 | ||
7 | This program is free software; you can redistribute it and/or modify | |
8 | it under the terms of the GNU General Public License as published by | |
a9762ec7 | 9 | the Free Software Foundation; either version 3 of the License, or |
fb40c209 AC |
10 | (at your option) any later version. |
11 | ||
12 | This program is distributed in the hope that it will be useful, | |
13 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
15 | GNU General Public License for more details. | |
16 | ||
17 | You should have received a copy of the GNU General Public License | |
a9762ec7 | 18 | along with this program. If not, see <http://www.gnu.org/licenses/>. */ |
fb40c209 AC |
19 | |
20 | #ifndef MI_PARSE_H | |
21 | #define MI_PARSE_H | |
22 | ||
438e1e42 | 23 | #include "gdb_sys_time.h" |
6a089cf2 | 24 | |
fb40c209 AC |
25 | /* MI parser */ |
26 | ||
d8c83789 NR |
27 | /* Timestamps for current command and last asynchronous command. */ |
28 | struct mi_timestamp { | |
29 | struct timeval wallclock; | |
30 | struct timeval utime; | |
31 | struct timeval stime; | |
32 | }; | |
33 | ||
fb40c209 AC |
34 | enum mi_command_type |
35 | { | |
36 | MI_COMMAND, CLI_COMMAND | |
37 | }; | |
38 | ||
39 | struct mi_parse | |
40 | { | |
41 | enum mi_command_type op; | |
42 | char *command; | |
43 | char *token; | |
44 | const struct mi_cmd *cmd; | |
d8c83789 | 45 | struct mi_timestamp *cmd_start; |
fb40c209 AC |
46 | char *args; |
47 | char **argv; | |
48 | int argc; | |
a79b8f6e VP |
49 | int all; |
50 | int thread_group; /* At present, the same as inferior number. */ | |
1e92afda VP |
51 | int thread; |
52 | int frame; | |
403cb6b1 JB |
53 | |
54 | /* The language that should be used to evaluate the MI command. | |
55 | Ignored if set to language_unknown. */ | |
56 | enum language language; | |
fb40c209 AC |
57 | }; |
58 | ||
305aeedc TT |
59 | /* Attempts to parse CMD returning a ``struct mi_parse''. If CMD is |
60 | invalid, an exception is thrown. For an MI_COMMAND COMMAND, ARGS | |
61 | and OP are initialized. Un-initialized fields are zero. *TOKEN is | |
62 | set to the token, even if an exception is thrown. It is allocated | |
63 | with xmalloc; it must either be freed with xfree, or assigned to | |
64 | the TOKEN field of the resultant mi_parse object, to be freed by | |
65 | mi_parse_free. */ | |
fb40c209 | 66 | |
ee047554 | 67 | extern struct mi_parse *mi_parse (const char *cmd, char **token); |
fb40c209 | 68 | |
2b03b41d | 69 | /* Free a command returned by mi_parse_command. */ |
fb40c209 AC |
70 | |
71 | extern void mi_parse_free (struct mi_parse *cmd); | |
72 | ||
87967e27 YQ |
73 | /* Parse a string argument into a print_values value. */ |
74 | ||
75 | enum print_values mi_parse_print_values (const char *name); | |
76 | ||
fb40c209 | 77 | #endif |