1/* ***DEPRECATED***  The gdblib files must not be calling/using things in any
2   of the possible command languages.  If necessary, a hook (that may be
3   present or not) must be used and set to the appropriate routine by any
4   command language that cares about it.  If you are having to include this
5   file you are possibly doing things the old way.  This file will dissapear.
6   fnasser@redhat.com    */
7
8/* Header file for GDB-specific command-line stuff.
9   Copyright (C) 1986-2020 Free Software Foundation, Inc.
10
11   This program is free software; you can redistribute it and/or modify
12   it under the terms of the GNU General Public License as published by
13   the Free Software Foundation; either version 3 of the License, or
14   (at your option) any later version.
15
16   This program is distributed in the hope that it will be useful,
17   but WITHOUT ANY WARRANTY; without even the implied warranty of
18   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19   GNU General Public License for more details.
20
21   You should have received a copy of the GNU General Public License
22   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
23
24#if !defined (GDBCMD_H)
25#define GDBCMD_H 1
26
27#include "command.h"
28#include "ui-out.h"
29#include "cli/cli-script.h"
30
31/* Chain containing all defined commands.  */
32
33extern struct cmd_list_element *cmdlist;
34
35/* Chain containing all defined info subcommands.  */
36
37extern struct cmd_list_element *infolist;
38
39/* Chain containing all defined enable subcommands.  */
40
41extern struct cmd_list_element *enablelist;
42
43/* Chain containing all defined disable subcommands.  */
44
45extern struct cmd_list_element *disablelist;
46
47/* Chain containing all defined delete subcommands.  */
48
49extern struct cmd_list_element *deletelist;
50
51/* Chain containing all defined detach subcommands.  */
52
53extern struct cmd_list_element *detachlist;
54
55/* Chain containing all defined kill subcommands.  */
56
57extern struct cmd_list_element *killlist;
58
59/* Chain containing all defined stop subcommands.  */
60
61extern struct cmd_list_element *stoplist;
62
63/* Chain containing all defined set subcommands.  */
64
65extern struct cmd_list_element *setlist;
66
67/* Chain containing all defined unset subcommands.  */
68
69extern struct cmd_list_element *unsetlist;
70
71/* Chain containing all defined show subcommands.  */
72
73extern struct cmd_list_element *showlist;
74
75/* Chain containing all defined \"set history\".  */
76
77extern struct cmd_list_element *sethistlist;
78
79/* Chain containing all defined \"show history\".  */
80
81extern struct cmd_list_element *showhistlist;
82
83/* Chain containing all defined \"unset history\".  */
84
85extern struct cmd_list_element *unsethistlist;
86
87/* Chain containing all defined maintenance subcommands.  */
88
89extern struct cmd_list_element *maintenancelist;
90
91/* Chain containing all defined "maintenance info" subcommands.  */
92
93extern struct cmd_list_element *maintenanceinfolist;
94
95/* Chain containing all defined "maintenance print" subcommands.  */
96
97extern struct cmd_list_element *maintenanceprintlist;
98
99/* Chain containing all defined "maintenance check" subcommands.  */
100
101extern struct cmd_list_element *maintenancechecklist;
102
103/* Chain containing all defined "maintenance set" subcommands.  */
104
105extern struct cmd_list_element *maintenance_set_cmdlist;
106
107/* Chain containing all defined "maintenance show" subcommands.  */
108
109extern struct cmd_list_element *maintenance_show_cmdlist;
110
111extern struct cmd_list_element *setprintlist;
112
113extern struct cmd_list_element *showprintlist;
114
115extern struct cmd_list_element *setprintrawlist;
116
117extern struct cmd_list_element *showprintrawlist;
118
119extern struct cmd_list_element *setprinttypelist;
120
121extern struct cmd_list_element *showprinttypelist;
122
123extern struct cmd_list_element *setdebuglist;
124
125extern struct cmd_list_element *showdebuglist;
126
127extern struct cmd_list_element *setchecklist;
128
129extern struct cmd_list_element *showchecklist;
130
131/* Chain containing all defined "save" subcommands.  */
132
133extern struct cmd_list_element *save_cmdlist;
134
135extern void execute_command (const char *, int);
136
137/* Execute command P and returns its output.  If TERM_OUT,
138   the output is built using terminal output behaviour such
139   as cli_styling.  */
140extern std::string execute_command_to_string (const char *p, int from_tty,
141					      bool term_out);
142extern void execute_command_to_ui_file (struct ui_file *file,
143					const char *p, int from_tty);
144
145extern void print_command_line (struct command_line *, unsigned int,
146				struct ui_file *);
147extern void print_command_lines (struct ui_out *,
148				 struct command_line *, unsigned int);
149
150#endif /* !defined (GDBCMD_H) */
151