]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gdb/gdb-demangle.c
Automatic Copyright Year update after running gdb/copyright.py
[thirdparty/binutils-gdb.git] / gdb / gdb-demangle.c
CommitLineData
c906108c 1/* Basic C++ demangling support for GDB.
1bac305b 2
4a94e368 3 Copyright (C) 1991-2022 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 const char *name;
164 const char *arg_start;
439250fb
DE
165 int processing_args = 1;
166 const struct language_defn *lang;
439250fb 167
45343786
TT
168 std::string arg_buf = args != NULL ? args : "";
169 arg_start = arg_buf.c_str ();
439250fb 170
cb791d59 171 std::string lang_name;
439250fb
DE
172 while (processing_args
173 && *arg_start == '-')
174 {
f1735a53 175 const char *p = skip_to_space (arg_start);
439250fb
DE
176
177 if (strncmp (arg_start, "-l", p - arg_start) == 0)
cb791d59 178 lang_name = extract_arg (&p);
439250fb
DE
179 else if (strncmp (arg_start, "--", p - arg_start) == 0)
180 processing_args = 0;
181 else
cd948f5b 182 report_unrecognized_option_error ("demangle", arg_start);
439250fb 183
f1735a53 184 arg_start = skip_spaces (p);
439250fb
DE
185 }
186
187 name = arg_start;
188
189 if (*name == '\0')
48c5e7e2 190 error (_("Usage: demangle [-l LANGUAGE] [--] NAME"));
439250fb 191
cb791d59 192 if (!lang_name.empty ())
439250fb
DE
193 {
194 enum language lang_enum;
195
cb791d59 196 lang_enum = language_enum (lang_name.c_str ());
439250fb 197 if (lang_enum == language_unknown)
cb791d59 198 error (_("Unknown language \"%s\""), lang_name.c_str ());
439250fb
DE
199 lang = language_def (lang_enum);
200 }
201 else
202 lang = current_language;
203
3456e70c
TT
204 gdb::unique_xmalloc_ptr<char> demangled
205 = language_demangle (lang, name, DMGL_ANSI | DMGL_PARAMS);
439250fb 206 if (demangled != NULL)
3456e70c 207 printf_filtered ("%s\n", demangled.get ());
439250fb
DE
208 else
209 error (_("Can't demangle \"%s\""), name);
439250fb
DE
210}
211
6c265988 212void _initialize_gdb_demangle ();
c906108c 213void
6c265988 214_initialize_gdb_demangle ()
c906108c 215{
fa58ee11
EZ
216 int i, ndems;
217
10217050
PA
218 /* Fill the demangling_style_names[] array, and set the default
219 demangling style chosen at compilation time. */
fa58ee11
EZ
220 for (ndems = 0;
221 libiberty_demanglers[ndems].demangling_style != unknown_demangling;
222 ndems++)
223 ;
224c3ddb 224 demangling_style_names = XCNEWVEC (const char *, ndems + 1);
fa58ee11
EZ
225 for (i = 0;
226 libiberty_demanglers[i].demangling_style != unknown_demangling;
227 i++)
10217050
PA
228 {
229 demangling_style_names[i]
230 = xstrdup (libiberty_demanglers[i].demangling_style_name);
231
232 if (current_demangling_style_string == NULL
233 && strcmp (DEFAULT_DEMANGLING_STYLE, demangling_style_names[i]) == 0)
234 current_demangling_style_string = demangling_style_names[i];
235 }
fa58ee11 236
50f182aa
DE
237 add_setshow_boolean_cmd ("demangle", class_support, &demangle, _("\
238Set demangling of encoded C++/ObjC names when displaying symbols."), _("\
239Show demangling of encoded C++/ObjC names when displaying symbols."), NULL,
240 NULL,
241 show_demangle,
242 &setprintlist, &showprintlist);
243
244 add_setshow_boolean_cmd ("asm-demangle", class_support, &asm_demangle, _("\
245Set demangling of C++/ObjC names in disassembly listings."), _("\
246Show demangling of C++/ObjC names in disassembly listings."), NULL,
247 NULL,
248 show_asm_demangle,
249 &setprintlist, &showprintlist);
250
7ab04401
AC
251 add_setshow_enum_cmd ("demangle-style", class_support,
252 demangling_style_names,
10217050 253 &current_demangling_style_string, _("\
7ab04401
AC
254Set the current C++ demangling style."), _("\
255Show the current C++ demangling style."), _("\
256Use `set demangle-style' without arguments for a list of demangling styles."),
257 set_demangling_command,
920d2a44 258 show_demangling_style_names,
7ab04401 259 &setlist, &showlist);
439250fb
DE
260
261 add_cmd ("demangle", class_support, demangle_command, _("\
262Demangle a mangled name.\n\
48c5e7e2 263Usage: demangle [-l LANGUAGE] [--] NAME\n\
439250fb
DE
264If LANGUAGE is not specified, NAME is demangled in the current language."),
265 &cmdlist);
c906108c 266}