Use cmd_list_element::doc_allocated for Python commands
[deliverable/binutils-gdb.git] / gdb / gdb-demangle.c
CommitLineData
c906108c 1/* Basic C++ demangling support for GDB.
1bac305b 2
42a4f53d 3 Copyright (C) 1991-2019 Free Software Foundation, Inc.
1bac305b 4
c906108c
SS
5 Written by Fred Fish at Cygnus Support.
6
7 This file is part of GDB.
8
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
a9762ec7 11 the Free Software Foundation; either version 3 of the License, or
c906108c
SS
12 (at your option) any later version.
13
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
18
19 You should have received a copy of the GNU General Public License
a9762ec7 20 along with this program. If not, see <http://www.gnu.org/licenses/>. */
c906108c
SS
21
22
23/* This file contains support code for C++ demangling that is common
0963b4bd 24 to a styles of demangling, and GDB specific. */
c906108c
SS
25
26#include "defs.h"
4de283e4 27#include "cli/cli-utils.h" /* for skip_to_space */
c906108c 28#include "command.h"
4de283e4 29#include "gdbcmd.h"
c906108c 30#include "demangle.h"
50f182aa 31#include "gdb-demangle.h"
439250fb
DE
32#include "language.h"
33
c906108c
SS
34/* Select the default C++ demangling style to use. The default is "auto",
35 which allows gdb to attempt to pick an appropriate demangling style for
36 the executable it has loaded. It can be set to a specific style ("gnu",
37 "lucid", "arm", "hp", etc.) in which case gdb will never attempt to do auto
38 selection of the style unless you do an explicit "set demangle auto".
39 To select one of these as the default, set DEFAULT_DEMANGLING_STYLE in
0963b4bd 40 the appropriate target configuration file. */
c906108c
SS
41
42#ifndef DEFAULT_DEMANGLING_STYLE
43#define DEFAULT_DEMANGLING_STYLE AUTO_DEMANGLING_STYLE_STRING
44#endif
45
50f182aa 46/* See documentation in gdb-demangle.h. */
491144b5 47bool demangle = true;
50f182aa
DE
48
49static void
50show_demangle (struct ui_file *file, int from_tty,
51 struct cmd_list_element *c, const char *value)
52{
53 fprintf_filtered (file,
54 _("Demangling of encoded C++/ObjC names "
55 "when displaying symbols is %s.\n"),
56 value);
57}
58
59/* See documentation in gdb-demangle.h. */
491144b5 60bool asm_demangle = false;
50f182aa
DE
61
62static void
63show_asm_demangle (struct ui_file *file, int from_tty,
64 struct cmd_list_element *c, const char *value)
65{
66 fprintf_filtered (file,
67 _("Demangling of C++/ObjC names in "
68 "disassembly listings is %s.\n"),
69 value);
70}
392a587b 71
c906108c
SS
72/* String name for the current demangling style. Set by the
73 "set demangle-style" command, printed as part of the output by the
0963b4bd 74 "show demangle-style" command. */
c906108c 75
10217050 76static const char *current_demangling_style_string;
c906108c 77
30baf67b 78/* The array of names of the known demangling styles. Generated by
fa58ee11
EZ
79 _initialize_demangler from libiberty_demanglers[] array. */
80
81static const char **demangling_style_names;
920d2a44
AC
82static void
83show_demangling_style_names(struct ui_file *file, int from_tty,
84 struct cmd_list_element *c, const char *value)
85{
86 fprintf_filtered (file, _("The current C++ demangling style is \"%s\".\n"),
87 value);
88}
89
c906108c
SS
90/* Set current demangling style. Called by the "set demangle-style"
91 command after it has updated the current_demangling_style_string to
92 match what the user has entered.
93
94 If the user has entered a string that matches a known demangling style
95 name in the demanglers[] array then just leave the string alone and update
96 the current_demangling_style enum value to match.
97
98 If the user has entered a string that doesn't match, including an empty
99 string, then print a list of the currently known styles and restore
100 the current_demangling_style_string to match the current_demangling_style
101 enum value.
102
103 Note: Assumes that current_demangling_style_string always points to
0963b4bd 104 a malloc'd string, even if it is a null-string. */
c906108c
SS
105
106static void
eb4c3f4a
TT
107set_demangling_command (const char *ignore,
108 int from_tty, struct cmd_list_element *c)
c906108c 109{
770de199 110 const struct demangler_engine *dem;
10217050 111 int i;
c906108c
SS
112
113 /* First just try to match whatever style name the user supplied with
114 one of the known ones. Don't bother special casing for an empty
115 name, we just treat it as any other style name that doesn't match.
0963b4bd 116 If we match, update the current demangling style enum. */
c906108c 117
10217050 118 for (dem = libiberty_demanglers, i = 0;
770de199
DB
119 dem->demangling_style != unknown_demangling;
120 dem++)
c906108c 121 {
bde58177
AC
122 if (strcmp (current_demangling_style_string,
123 dem->demangling_style_name) == 0)
c906108c
SS
124 {
125 current_demangling_style = dem->demangling_style;
10217050 126 current_demangling_style_string = demangling_style_names[i];
c906108c
SS
127 break;
128 }
10217050 129 i++;
c906108c
SS
130 }
131
10217050
PA
132 /* We should have found a match, given we only add known styles to
133 the enumeration list. */
134 gdb_assert (dem->demangling_style != unknown_demangling);
c906108c
SS
135}
136
8343f86c
DJ
137/* G++ uses a special character to indicate certain internal names. Which
138 character it is depends on the platform:
139 - Usually '$' on systems where the assembler will accept that
140 - Usually '.' otherwise (this includes most sysv4-like systems and most
141 ELF targets)
142 - Occasionally '_' if neither of the above is usable
143
144 We check '$' first because it is the safest, and '.' often has another
145 meaning. We don't currently try to handle '_' because the precise forms
146 of the names are different on those targets. */
147
148static char cplus_markers[] = {'$', '.', '\0'};
c906108c 149
50f182aa
DE
150/* See documentation in gdb-demangle.h. */
151
f10ffa41 152bool
fba45db2 153is_cplus_marker (int c)
c906108c
SS
154{
155 return c && strchr (cplus_markers, c) != NULL;
156}
157
439250fb
DE
158/* Demangle the given string in the current language. */
159
160static void
1f3f85eb 161demangle_command (const char *args, int from_tty)
439250fb 162{
45343786
TT
163 char *demangled;
164 const char *name;
165 const char *arg_start;
439250fb
DE
166 int processing_args = 1;
167 const struct language_defn *lang;
439250fb 168
45343786
TT
169 std::string arg_buf = args != NULL ? args : "";
170 arg_start = arg_buf.c_str ();
439250fb 171
cb791d59 172 std::string lang_name;
439250fb
DE
173 while (processing_args
174 && *arg_start == '-')
175 {
f1735a53 176 const char *p = skip_to_space (arg_start);
439250fb
DE
177
178 if (strncmp (arg_start, "-l", p - arg_start) == 0)
cb791d59 179 lang_name = extract_arg (&p);
439250fb
DE
180 else if (strncmp (arg_start, "--", p - arg_start) == 0)
181 processing_args = 0;
182 else
cd948f5b 183 report_unrecognized_option_error ("demangle", arg_start);
439250fb 184
f1735a53 185 arg_start = skip_spaces (p);
439250fb
DE
186 }
187
188 name = arg_start;
189
190 if (*name == '\0')
48c5e7e2 191 error (_("Usage: demangle [-l LANGUAGE] [--] NAME"));
439250fb 192
cb791d59 193 if (!lang_name.empty ())
439250fb
DE
194 {
195 enum language lang_enum;
196
cb791d59 197 lang_enum = language_enum (lang_name.c_str ());
439250fb 198 if (lang_enum == language_unknown)
cb791d59 199 error (_("Unknown language \"%s\""), lang_name.c_str ());
439250fb
DE
200 lang = language_def (lang_enum);
201 }
202 else
203 lang = current_language;
204
205 demangled = language_demangle (lang, name, DMGL_ANSI | DMGL_PARAMS);
206 if (demangled != NULL)
207 {
208 printf_filtered ("%s\n", demangled);
209 xfree (demangled);
210 }
211 else
212 error (_("Can't demangle \"%s\""), name);
439250fb
DE
213}
214
c906108c 215void
f10ffa41 216_initialize_gdb_demangle (void)
c906108c 217{
fa58ee11
EZ
218 int i, ndems;
219
10217050
PA
220 /* Fill the demangling_style_names[] array, and set the default
221 demangling style chosen at compilation time. */
fa58ee11
EZ
222 for (ndems = 0;
223 libiberty_demanglers[ndems].demangling_style != unknown_demangling;
224 ndems++)
225 ;
224c3ddb 226 demangling_style_names = XCNEWVEC (const char *, ndems + 1);
fa58ee11
EZ
227 for (i = 0;
228 libiberty_demanglers[i].demangling_style != unknown_demangling;
229 i++)
10217050
PA
230 {
231 demangling_style_names[i]
232 = xstrdup (libiberty_demanglers[i].demangling_style_name);
233
234 if (current_demangling_style_string == NULL
235 && strcmp (DEFAULT_DEMANGLING_STYLE, demangling_style_names[i]) == 0)
236 current_demangling_style_string = demangling_style_names[i];
237 }
fa58ee11 238
50f182aa
DE
239 add_setshow_boolean_cmd ("demangle", class_support, &demangle, _("\
240Set demangling of encoded C++/ObjC names when displaying symbols."), _("\
241Show demangling of encoded C++/ObjC names when displaying symbols."), NULL,
242 NULL,
243 show_demangle,
244 &setprintlist, &showprintlist);
245
246 add_setshow_boolean_cmd ("asm-demangle", class_support, &asm_demangle, _("\
247Set demangling of C++/ObjC names in disassembly listings."), _("\
248Show demangling of C++/ObjC names in disassembly listings."), NULL,
249 NULL,
250 show_asm_demangle,
251 &setprintlist, &showprintlist);
252
7ab04401
AC
253 add_setshow_enum_cmd ("demangle-style", class_support,
254 demangling_style_names,
10217050 255 &current_demangling_style_string, _("\
7ab04401
AC
256Set the current C++ demangling style."), _("\
257Show the current C++ demangling style."), _("\
258Use `set demangle-style' without arguments for a list of demangling styles."),
259 set_demangling_command,
920d2a44 260 show_demangling_style_names,
7ab04401 261 &setlist, &showlist);
439250fb
DE
262
263 add_cmd ("demangle", class_support, demangle_command, _("\
264Demangle a mangled name.\n\
48c5e7e2 265Usage: demangle [-l LANGUAGE] [--] NAME\n\
439250fb
DE
266If LANGUAGE is not specified, NAME is demangled in the current language."),
267 &cmdlist);
c906108c 268}
This page took 1.689325 seconds and 4 git commands to generate.