xref: /openbsd-src/gnu/usr.bin/binutils/gdb/mi/mi-parse.h (revision b725ae7711052a2233e31a66fefb8a752c388d7a)
1*b725ae77Skettenis /* MI Command Set - MI Command Parser.
2*b725ae77Skettenis    Copyright 2000 Free Software Foundation, Inc.
3*b725ae77Skettenis    Contributed by Cygnus Solutions (a Red Hat company).
4*b725ae77Skettenis 
5*b725ae77Skettenis    This file is part of GDB.
6*b725ae77Skettenis 
7*b725ae77Skettenis    This program is free software; you can redistribute it and/or modify
8*b725ae77Skettenis    it under the terms of the GNU General Public License as published by
9*b725ae77Skettenis    the Free Software Foundation; either version 2 of the License, or
10*b725ae77Skettenis    (at your option) any later version.
11*b725ae77Skettenis 
12*b725ae77Skettenis    This program is distributed in the hope that it will be useful,
13*b725ae77Skettenis    but WITHOUT ANY WARRANTY; without even the implied warranty of
14*b725ae77Skettenis    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15*b725ae77Skettenis    GNU General Public License for more details.
16*b725ae77Skettenis 
17*b725ae77Skettenis    You should have received a copy of the GNU General Public License
18*b725ae77Skettenis    along with this program; if not, write to the Free Software
19*b725ae77Skettenis    Foundation, Inc., 59 Temple Place - Suite 330,
20*b725ae77Skettenis    Boston, MA 02111-1307, USA.  */
21*b725ae77Skettenis 
22*b725ae77Skettenis #ifndef MI_PARSE_H
23*b725ae77Skettenis #define MI_PARSE_H
24*b725ae77Skettenis 
25*b725ae77Skettenis /* MI parser */
26*b725ae77Skettenis 
27*b725ae77Skettenis enum mi_command_type
28*b725ae77Skettenis   {
29*b725ae77Skettenis     MI_COMMAND, CLI_COMMAND
30*b725ae77Skettenis   };
31*b725ae77Skettenis 
32*b725ae77Skettenis struct mi_parse
33*b725ae77Skettenis   {
34*b725ae77Skettenis     enum mi_command_type op;
35*b725ae77Skettenis     char *command;
36*b725ae77Skettenis     char *token;
37*b725ae77Skettenis     const struct mi_cmd *cmd;
38*b725ae77Skettenis     char *args;
39*b725ae77Skettenis     char **argv;
40*b725ae77Skettenis     int argc;
41*b725ae77Skettenis   };
42*b725ae77Skettenis 
43*b725ae77Skettenis /* Attempts to parse CMD returning a ``struct mi_command''.  If CMD is
44*b725ae77Skettenis    invalid, an error mesage is reported (MI format) and NULL is
45*b725ae77Skettenis    returned. For a CLI_COMMAND, COMMAND, TOKEN and OP are initialized.
46*b725ae77Skettenis    For an MI_COMMAND COMMAND, TOKEN, ARGS and OP are
47*b725ae77Skettenis    initialized. Un-initialized fields are zero. */
48*b725ae77Skettenis 
49*b725ae77Skettenis extern struct mi_parse *mi_parse (char *cmd);
50*b725ae77Skettenis 
51*b725ae77Skettenis /* Free a command returned by mi_parse_command. */
52*b725ae77Skettenis 
53*b725ae77Skettenis extern void mi_parse_free (struct mi_parse *cmd);
54*b725ae77Skettenis 
55*b725ae77Skettenis #endif
56