gdb: handle DW_AT_entry_pc pointing at an empty sub-range
[binutils-gdb.git] / gdb / cli / cli-cmds.h
blob8f26ca3e17a7e785df3d455b486f10c72ae81816
1 /* Header file for GDB CLI command implementation library.
2 Copyright (C) 2000-2024 Free Software Foundation, Inc.
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 3 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program. If not, see <http://www.gnu.org/licenses/>. */
17 #ifndef CLI_CLI_CMDS_H
18 #define CLI_CLI_CMDS_H
20 #include "gdbsupport/filestuff.h"
21 #include <optional>
22 #include "completer.h"
24 /* Chain containing all defined commands. */
26 extern struct cmd_list_element *cmdlist;
28 /* Chain containing all defined info subcommands. */
30 extern struct cmd_list_element *infolist;
32 /* Chain containing all defined enable subcommands. */
34 extern struct cmd_list_element *enablelist;
36 /* Chain containing all defined disable subcommands. */
38 extern struct cmd_list_element *disablelist;
40 /* Chain containing all defined delete subcommands. */
42 extern struct cmd_list_element *deletelist;
44 /* Chain containing all defined detach subcommands. */
46 extern struct cmd_list_element *detachlist;
48 /* Chain containing all defined kill subcommands. */
50 extern struct cmd_list_element *killlist;
52 /* Chain containing all defined stop subcommands. */
54 extern struct cmd_list_element *stoplist;
56 /* Chain containing all defined set subcommands */
58 extern struct cmd_list_element *setlist;
60 /* Chain containing all defined unset subcommands */
62 extern struct cmd_list_element *unsetlist;
64 /* Chain containing all defined show subcommands. */
66 extern struct cmd_list_element *showlist;
68 /* Chain containing all defined \"set history\". */
70 extern struct cmd_list_element *sethistlist;
72 /* Chain containing all defined \"show history\". */
74 extern struct cmd_list_element *showhistlist;
76 /* Chain containing all defined \"unset history\". */
78 extern struct cmd_list_element *unsethistlist;
80 /* Chain containing all defined maintenance subcommands. */
82 extern struct cmd_list_element *maintenancelist;
84 /* Chain containing all defined "maintenance info" subcommands. */
86 extern struct cmd_list_element *maintenanceinfolist;
88 /* Chain containing all defined "maintenance print" subcommands. */
90 extern struct cmd_list_element *maintenanceprintlist;
92 /* Chain containing all defined "maintenance flush" subcommands. */
94 extern struct cmd_list_element *maintenanceflushlist;
96 /* Chain containing all defined "maintenance check" subcommands. */
98 extern struct cmd_list_element *maintenancechecklist;
100 /* Chain containing all defined "maintenance set" subcommands. */
102 extern struct cmd_list_element *maintenance_set_cmdlist;
104 /* Chain containing all defined "maintenance show" subcommands. */
106 extern struct cmd_list_element *maintenance_show_cmdlist;
108 extern struct cmd_list_element *setprintlist;
110 extern struct cmd_list_element *showprintlist;
112 /* Chain containing all defined "set print raw" subcommands. */
114 extern struct cmd_list_element *setprintrawlist;
116 /* Chain containing all defined "show print raw" subcommands. */
118 extern struct cmd_list_element *showprintrawlist;
120 /* Chain containing all defined "set print type" subcommands. */
122 extern struct cmd_list_element *setprinttypelist;
124 /* Chain containing all defined "show print type" subcommands. */
126 extern struct cmd_list_element *showprinttypelist;
128 extern struct cmd_list_element *setdebuglist;
130 extern struct cmd_list_element *showdebuglist;
132 extern struct cmd_list_element *setchecklist;
134 extern struct cmd_list_element *showchecklist;
136 /* Chain containing all defined "save" subcommands. */
138 extern struct cmd_list_element *save_cmdlist;
140 /* Chain containing all defined "set source" subcommands. */
142 extern struct cmd_list_element *setsourcelist;
144 /* Chain containing all defined "show source" subcommands. */
146 extern struct cmd_list_element *showsourcelist;
148 /* Limit the call depth of user-defined commands */
150 extern unsigned int max_user_call_depth;
152 /* Exported to gdb/top.c */
154 int is_complete_command (struct cmd_list_element *cmd);
156 /* Exported to gdb/main.c */
158 extern void cd_command (const char *, int);
160 /* Exported to gdb/top.c and gdb/main.c */
162 extern void quit_command (const char *, int);
164 extern void source_script (const char *, int);
166 /* Exported to objfiles.c. */
168 /* The script that was opened. */
169 struct open_script
171 gdb_file_up stream;
172 gdb::unique_xmalloc_ptr<char> full_path;
174 open_script (gdb_file_up &&stream_,
175 gdb::unique_xmalloc_ptr<char> &&full_path_)
176 : stream (std::move (stream_)),
177 full_path (std::move (full_path_))
182 extern std::optional<open_script>
183 find_and_open_script (const char *file, int search_path);
185 /* Command tracing state. */
187 extern int source_verbose;
188 extern bool trace_commands;
190 /* Common code for the "with" and "maintenance with" commands.
191 SET_CMD_PREFIX is the spelling of the corresponding "set" command
192 prefix: i.e., "set " or "maintenance set ". SETLIST is the command
193 element for the same "set" command prefix. */
194 extern void with_command_1 (const char *set_cmd_prefix,
195 cmd_list_element *setlist,
196 const char *args, int from_tty);
198 /* Common code for the completers of the "with" and "maintenance with"
199 commands. SET_CMD_PREFIX is the spelling of the corresponding
200 "set" command prefix: i.e., "set " or "maintenance set ". */
201 extern void with_command_completer_1 (const char *set_cmd_prefix,
202 completion_tracker &tracker,
203 const char *text);
205 #endif /* CLI_CLI_CMDS_H */