New function cli-utils.c:extract_arg_const
[deliverable/binutils-gdb.git] / gdb / mi / mi-parse.h
CommitLineData
fb40c209 1/* MI Command Set - MI Command Parser.
28e7fd62 2 Copyright (C) 2000-2013 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
6a089cf2
DJ
23#include <sys/time.h>
24
fb40c209
AC
25/* MI parser */
26
d8c83789
NR
27/* Timestamps for current command and last asynchronous command. */
28struct mi_timestamp {
29 struct timeval wallclock;
30 struct timeval utime;
31 struct timeval stime;
32};
33
fb40c209
AC
34enum mi_command_type
35 {
36 MI_COMMAND, CLI_COMMAND
37 };
38
39struct 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;
fb40c209
AC
53 };
54
305aeedc
TT
55/* Attempts to parse CMD returning a ``struct mi_parse''. If CMD is
56 invalid, an exception is thrown. For an MI_COMMAND COMMAND, ARGS
57 and OP are initialized. Un-initialized fields are zero. *TOKEN is
58 set to the token, even if an exception is thrown. It is allocated
59 with xmalloc; it must either be freed with xfree, or assigned to
60 the TOKEN field of the resultant mi_parse object, to be freed by
61 mi_parse_free. */
fb40c209 62
ee047554 63extern struct mi_parse *mi_parse (const char *cmd, char **token);
fb40c209 64
2b03b41d 65/* Free a command returned by mi_parse_command. */
fb40c209
AC
66
67extern void mi_parse_free (struct mi_parse *cmd);
68
87967e27
YQ
69/* Parse a string argument into a print_values value. */
70
71enum print_values mi_parse_print_values (const char *name);
72
fb40c209 73#endif
This page took 1.156333 seconds and 4 git commands to generate.