Commit | Line | Data |
---|---|---|
fb40c209 | 1 | /* MI Command Set - MI Command Parser. |
61baf725 | 2 | Copyright (C) 2000-2017 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 | ||
dcb07cfa PA |
23 | #include "run-time-clock.h" |
24 | #include <chrono> | |
6a089cf2 | 25 | |
fb40c209 AC |
26 | /* MI parser */ |
27 | ||
d8c83789 | 28 | /* Timestamps for current command and last asynchronous command. */ |
dcb07cfa PA |
29 | struct mi_timestamp |
30 | { | |
31 | std::chrono::steady_clock::time_point wallclock; | |
32 | user_cpu_time_clock::time_point utime; | |
33 | system_cpu_time_clock::time_point stime; | |
d8c83789 NR |
34 | }; |
35 | ||
fb40c209 AC |
36 | enum mi_command_type |
37 | { | |
38 | MI_COMMAND, CLI_COMMAND | |
39 | }; | |
40 | ||
41 | struct mi_parse | |
42 | { | |
43 | enum mi_command_type op; | |
44 | char *command; | |
45 | char *token; | |
46 | const struct mi_cmd *cmd; | |
d8c83789 | 47 | struct mi_timestamp *cmd_start; |
fb40c209 AC |
48 | char *args; |
49 | char **argv; | |
50 | int argc; | |
a79b8f6e VP |
51 | int all; |
52 | int thread_group; /* At present, the same as inferior number. */ | |
1e92afda VP |
53 | int thread; |
54 | int frame; | |
403cb6b1 JB |
55 | |
56 | /* The language that should be used to evaluate the MI command. | |
57 | Ignored if set to language_unknown. */ | |
58 | enum language language; | |
fb40c209 AC |
59 | }; |
60 | ||
305aeedc TT |
61 | /* Attempts to parse CMD returning a ``struct mi_parse''. If CMD is |
62 | invalid, an exception is thrown. For an MI_COMMAND COMMAND, ARGS | |
63 | and OP are initialized. Un-initialized fields are zero. *TOKEN is | |
64 | set to the token, even if an exception is thrown. It is allocated | |
65 | with xmalloc; it must either be freed with xfree, or assigned to | |
66 | the TOKEN field of the resultant mi_parse object, to be freed by | |
67 | mi_parse_free. */ | |
fb40c209 | 68 | |
ee047554 | 69 | extern struct mi_parse *mi_parse (const char *cmd, char **token); |
fb40c209 | 70 | |
2b03b41d | 71 | /* Free a command returned by mi_parse_command. */ |
fb40c209 AC |
72 | |
73 | extern void mi_parse_free (struct mi_parse *cmd); | |
74 | ||
87967e27 YQ |
75 | /* Parse a string argument into a print_values value. */ |
76 | ||
77 | enum print_values mi_parse_print_values (const char *name); | |
78 | ||
fb40c209 | 79 | #endif |