gdb: Use C++11 std::chrono
[deliverable/binutils-gdb.git] / gdb / mi / mi-parse.h
1 /* MI Command Set - MI Command Parser.
2 Copyright (C) 2000-2016 Free Software Foundation, Inc.
3 Contributed by Cygnus Solutions (a Red Hat company).
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
9 the Free Software Foundation; either version 3 of the License, or
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
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
19
20 #ifndef MI_PARSE_H
21 #define MI_PARSE_H
22
23 #include "run-time-clock.h"
24 #include <chrono>
25
26 /* MI parser */
27
28 /* Timestamps for current command and last asynchronous command. */
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;
34 };
35
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;
47 struct mi_timestamp *cmd_start;
48 char *args;
49 char **argv;
50 int argc;
51 int all;
52 int thread_group; /* At present, the same as inferior number. */
53 int thread;
54 int frame;
55
56 /* The language that should be used to evaluate the MI command.
57 Ignored if set to language_unknown. */
58 enum language language;
59 };
60
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. */
68
69 extern struct mi_parse *mi_parse (const char *cmd, char **token);
70
71 /* Free a command returned by mi_parse_command. */
72
73 extern void mi_parse_free (struct mi_parse *cmd);
74
75 /* Parse a string argument into a print_values value. */
76
77 enum print_values mi_parse_print_values (const char *name);
78
79 #endif
This page took 0.041431 seconds and 4 git commands to generate.