]> git.ipfire.org Git - thirdparty/gcc.git/blame - libiberty/cp-demangle.c
random.tcc: Define static const data members.
[thirdparty/gcc.git] / libiberty / cp-demangle.c
CommitLineData
bd6946d1 1/* Demangler for g++ V3 ABI.
8935c4b3
ILT
2 Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008
3 Free Software Foundation, Inc.
bd6946d1 4 Written by Ian Lance Taylor <ian@wasabisystems.com>.
69afa80d 5
2b81b2c9 6 This file is part of the libiberty library, which is part of GCC.
759e8187 7
2b81b2c9 8 This file is free software; you can redistribute it and/or modify
69afa80d
AS
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
12
b3dd43df
MM
13 In addition to the permissions in the GNU General Public License, the
14 Free Software Foundation gives you unlimited permission to link the
15 compiled version of this file into combinations with other programs,
16 and to distribute those combinations without any restriction coming
17 from the use of this file. (The General Public License restrictions
18 do apply in other respects; for example, they cover modification of
19 the file, and distribution when not linked into a combined
20 executable.)
21
69afa80d
AS
22 This program is distributed in the hope that it will be useful,
23 but WITHOUT ANY WARRANTY; without even the implied warranty of
24 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
25 GNU General Public License for more details.
26
27 You should have received a copy of the GNU General Public License
28 along with this program; if not, write to the Free Software
ee58dffd 29 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
69afa80d
AS
30*/
31
a51753e4
ILT
32/* This code implements a demangler for the g++ V3 ABI. The ABI is
33 described on this web page:
34 http://www.codesourcery.com/cxx-abi/abi.html#mangling
35
36 This code was written while looking at the demangler written by
37 Alex Samuel <samuel@codesourcery.com>.
38
39 This code first pulls the mangled name apart into a list of
40 components, and then walks the list generating the demangled
41 name.
42
43 This file will normally define the following functions, q.v.:
44 char *cplus_demangle_v3(const char *mangled, int options)
45 char *java_demangle_v3(const char *mangled)
456cc5cf
SB
46 int cplus_demangle_v3_callback(const char *mangled, int options,
47 demangle_callbackref callback)
48 int java_demangle_v3_callback(const char *mangled,
49 demangle_callbackref callback)
a51753e4
ILT
50 enum gnu_v3_ctor_kinds is_gnu_v3_mangled_ctor (const char *name)
51 enum gnu_v3_dtor_kinds is_gnu_v3_mangled_dtor (const char *name)
52
5e777af5
ILT
53 Also, the interface to the component list is public, and defined in
54 demangle.h. The interface consists of these types, which are
55 defined in demangle.h:
56 enum demangle_component_type
57 struct demangle_component
456cc5cf 58 demangle_callbackref
5e777af5
ILT
59 and these functions defined in this file:
60 cplus_demangle_fill_name
61 cplus_demangle_fill_extended_operator
62 cplus_demangle_fill_ctor
63 cplus_demangle_fill_dtor
64 cplus_demangle_print
456cc5cf 65 cplus_demangle_print_callback
5e777af5
ILT
66 and other functions defined in the file cp-demint.c.
67
68 This file also defines some other functions and variables which are
69 only to be used by the file cp-demint.c.
70
a51753e4
ILT
71 Preprocessor macros you can define while compiling this file:
72
73 IN_LIBGCC2
456cc5cf 74 If defined, this file defines the following functions, q.v.:
a51753e4
ILT
75 char *__cxa_demangle (const char *mangled, char *buf, size_t *len,
76 int *status)
456cc5cf
SB
77 int __gcclibcxx_demangle_callback (const char *,
78 void (*)
79 (const char *, size_t, void *),
80 void *)
81 instead of cplus_demangle_v3[_callback]() and
82 java_demangle_v3[_callback]().
a51753e4
ILT
83
84 IN_GLIBCPP_V3
456cc5cf
SB
85 If defined, this file defines only __cxa_demangle() and
86 __gcclibcxx_demangle_callback(), and no other publically visible
87 functions or variables.
a51753e4
ILT
88
89 STANDALONE_DEMANGLER
90 If defined, this file defines a main() function which demangles
91 any arguments, or, if none, demangles stdin.
92
93 CP_DEMANGLE_DEBUG
94 If defined, turns on debugging mode, which prints information on
95 stdout about the mangled string. This is not generally useful.
96*/
97
456cc5cf
SB
98#if defined (_AIX) && !defined (__GNUC__)
99 #pragma alloca
100#endif
101
69afa80d
AS
102#ifdef HAVE_CONFIG_H
103#include "config.h"
104#endif
105
bd6946d1 106#include <stdio.h>
8502a100 107
69afa80d
AS
108#ifdef HAVE_STDLIB_H
109#include <stdlib.h>
110#endif
69afa80d
AS
111#ifdef HAVE_STRING_H
112#include <string.h>
113#endif
114
456cc5cf
SB
115#ifdef HAVE_ALLOCA_H
116# include <alloca.h>
117#else
118# ifndef alloca
119# ifdef __GNUC__
120# define alloca __builtin_alloca
121# else
122extern char *alloca ();
123# endif /* __GNUC__ */
124# endif /* alloca */
125#endif /* HAVE_ALLOCA_H */
126
69afa80d
AS
127#include "ansidecl.h"
128#include "libiberty.h"
7eb23b1f 129#include "demangle.h"
5e777af5
ILT
130#include "cp-demangle.h"
131
132/* If IN_GLIBCPP_V3 is defined, some functions are made static. We
133 also rename them via #define to avoid compiler errors when the
134 static definition conflicts with the extern declaration in a header
135 file. */
136#ifdef IN_GLIBCPP_V3
137
138#define CP_STATIC_IF_GLIBCPP_V3 static
139
140#define cplus_demangle_fill_name d_fill_name
9486db4f 141static int d_fill_name (struct demangle_component *, const char *, int);
5e777af5
ILT
142
143#define cplus_demangle_fill_extended_operator d_fill_extended_operator
144static int
9486db4f
GDR
145d_fill_extended_operator (struct demangle_component *, int,
146 struct demangle_component *);
5e777af5
ILT
147
148#define cplus_demangle_fill_ctor d_fill_ctor
149static int
9486db4f
GDR
150d_fill_ctor (struct demangle_component *, enum gnu_v3_ctor_kinds,
151 struct demangle_component *);
5e777af5
ILT
152
153#define cplus_demangle_fill_dtor d_fill_dtor
154static int
9486db4f
GDR
155d_fill_dtor (struct demangle_component *, enum gnu_v3_dtor_kinds,
156 struct demangle_component *);
5e777af5
ILT
157
158#define cplus_demangle_mangled_name d_mangled_name
9486db4f 159static struct demangle_component *d_mangled_name (struct d_info *, int);
5e777af5
ILT
160
161#define cplus_demangle_type d_type
9486db4f 162static struct demangle_component *d_type (struct d_info *);
5e777af5
ILT
163
164#define cplus_demangle_print d_print
9486db4f 165static char *d_print (int, const struct demangle_component *, int, size_t *);
5e777af5 166
456cc5cf
SB
167#define cplus_demangle_print_callback d_print_callback
168static int d_print_callback (int, const struct demangle_component *,
169 demangle_callbackref, void *);
170
5e777af5 171#define cplus_demangle_init_info d_init_info
9486db4f 172static void d_init_info (const char *, int, size_t, struct d_info *);
5e777af5
ILT
173
174#else /* ! defined(IN_GLIBCPP_V3) */
175#define CP_STATIC_IF_GLIBCPP_V3
176#endif /* ! defined(IN_GLIBCPP_V3) */
69afa80d 177
2d6c4025
ILT
178/* See if the compiler supports dynamic arrays. */
179
180#ifdef __GNUC__
181#define CP_DYNAMIC_ARRAYS
182#else
183#ifdef __STDC__
184#ifdef __STDC_VERSION__
185#if __STDC_VERSION__ >= 199901L
186#define CP_DYNAMIC_ARRAYS
187#endif /* __STDC__VERSION >= 199901L */
188#endif /* defined (__STDC_VERSION__) */
189#endif /* defined (__STDC__) */
190#endif /* ! defined (__GNUC__) */
191
a51753e4
ILT
192/* We avoid pulling in the ctype tables, to prevent pulling in
193 additional unresolved symbols when this code is used in a library.
194 FIXME: Is this really a valid reason? This comes from the original
195 V3 demangler code.
bd6946d1 196
a51753e4 197 As of this writing this file has the following undefined references
456cc5cf
SB
198 when compiled with -DIN_GLIBCPP_V3: realloc, free, memcpy, strcpy,
199 strcat, strlen. */
bd6946d1 200
bd6946d1 201#define IS_DIGIT(c) ((c) >= '0' && (c) <= '9')
a51753e4
ILT
202#define IS_UPPER(c) ((c) >= 'A' && (c) <= 'Z')
203#define IS_LOWER(c) ((c) >= 'a' && (c) <= 'z')
051664b0 204
31e0ab1f
AS
205/* The prefix prepended by GCC to an identifier represnting the
206 anonymous namespace. */
207#define ANONYMOUS_NAMESPACE_PREFIX "_GLOBAL_"
bd6946d1
ILT
208#define ANONYMOUS_NAMESPACE_PREFIX_LEN \
209 (sizeof (ANONYMOUS_NAMESPACE_PREFIX) - 1)
31e0ab1f 210
374caa50
ILT
211/* Information we keep for the standard substitutions. */
212
213struct d_standard_sub_info
214{
215 /* The code for this substitution. */
216 char code;
217 /* The simple string it expands to. */
218 const char *simple_expansion;
2d6c4025
ILT
219 /* The length of the simple expansion. */
220 int simple_len;
374caa50
ILT
221 /* The results of a full, verbose, expansion. This is used when
222 qualifying a constructor/destructor, or when in verbose mode. */
223 const char *full_expansion;
2d6c4025
ILT
224 /* The length of the full expansion. */
225 int full_len;
374caa50
ILT
226 /* What to set the last_name field of d_info to; NULL if we should
227 not set it. This is only relevant when qualifying a
228 constructor/destructor. */
229 const char *set_last_name;
2d6c4025
ILT
230 /* The length of set_last_name. */
231 int set_last_name_len;
374caa50
ILT
232};
233
5e777af5 234/* Accessors for subtrees of struct demangle_component. */
69afa80d 235
bd6946d1
ILT
236#define d_left(dc) ((dc)->u.s_binary.left)
237#define d_right(dc) ((dc)->u.s_binary.right)
238
bd6946d1 239/* A list of templates. This is used while printing. */
69afa80d 240
bd6946d1
ILT
241struct d_print_template
242{
243 /* Next template on the list. */
244 struct d_print_template *next;
245 /* This template. */
d7cf8390 246 const struct demangle_component *template_decl;
bd6946d1 247};
69afa80d 248
bd6946d1 249/* A list of type modifiers. This is used while printing. */
69afa80d 250
bd6946d1
ILT
251struct d_print_mod
252{
253 /* Next modifier on the list. These are in the reverse of the order
254 in which they appeared in the mangled string. */
255 struct d_print_mod *next;
256 /* The modifier. */
5e777af5 257 const struct demangle_component *mod;
bd6946d1
ILT
258 /* Whether this modifier was printed. */
259 int printed;
81dc098b
ILT
260 /* The list of templates which applies to this modifier. */
261 struct d_print_template *templates;
bd6946d1 262};
69afa80d 263
456cc5cf 264/* We use these structures to hold information during printing. */
bd6946d1 265
456cc5cf 266struct d_growable_string
bd6946d1 267{
bd6946d1
ILT
268 /* Buffer holding the result. */
269 char *buf;
270 /* Current length of data in buffer. */
271 size_t len;
272 /* Allocated size of buffer. */
273 size_t alc;
456cc5cf
SB
274 /* Set to 1 if we had a memory allocation failure. */
275 int allocation_failure;
276};
277
278enum { D_PRINT_BUFFER_LENGTH = 256 };
279struct d_print_info
280{
281 /* The options passed to the demangler. */
282 int options;
283 /* Fixed-length allocated buffer for demangled data, flushed to the
284 callback with a NUL termination once full. */
285 char buf[D_PRINT_BUFFER_LENGTH];
286 /* Current length of data in buffer. */
287 size_t len;
288 /* The last character printed, saved individually so that it survives
289 any buffer flush. */
290 char last_char;
291 /* Callback function to handle demangled buffer flush. */
292 demangle_callbackref callback;
293 /* Opaque callback argument. */
294 void *opaque;
bd6946d1
ILT
295 /* The current list of templates, if any. */
296 struct d_print_template *templates;
297 /* The current list of modifiers (e.g., pointer, reference, etc.),
298 if any. */
299 struct d_print_mod *modifiers;
456cc5cf
SB
300 /* Set to 1 if we saw a demangling error. */
301 int demangle_failure;
38179091
JM
302 /* The current index into any template argument packs we are using
303 for printing. */
304 int pack_index;
bd6946d1 305};
7dce2eff 306
69afa80d 307#ifdef CP_DEMANGLE_DEBUG
9486db4f 308static void d_dump (struct demangle_component *, int);
69afa80d 309#endif
5e777af5
ILT
310
311static struct demangle_component *
9486db4f 312d_make_empty (struct d_info *);
5e777af5
ILT
313
314static struct demangle_component *
9486db4f
GDR
315d_make_comp (struct d_info *, enum demangle_component_type,
316 struct demangle_component *,
317 struct demangle_component *);
5e777af5
ILT
318
319static struct demangle_component *
9486db4f 320d_make_name (struct d_info *, const char *, int);
5e777af5
ILT
321
322static struct demangle_component *
9486db4f
GDR
323d_make_builtin_type (struct d_info *,
324 const struct demangle_builtin_type_info *);
5e777af5
ILT
325
326static struct demangle_component *
9486db4f
GDR
327d_make_operator (struct d_info *,
328 const struct demangle_operator_info *);
5e777af5
ILT
329
330static struct demangle_component *
9486db4f
GDR
331d_make_extended_operator (struct d_info *, int,
332 struct demangle_component *);
5e777af5
ILT
333
334static struct demangle_component *
9486db4f
GDR
335d_make_ctor (struct d_info *, enum gnu_v3_ctor_kinds,
336 struct demangle_component *);
5e777af5
ILT
337
338static struct demangle_component *
9486db4f
GDR
339d_make_dtor (struct d_info *, enum gnu_v3_dtor_kinds,
340 struct demangle_component *);
5e777af5
ILT
341
342static struct demangle_component *
9486db4f 343d_make_template_param (struct d_info *, long);
5e777af5
ILT
344
345static struct demangle_component *
9486db4f 346d_make_sub (struct d_info *, const char *, int);
5e777af5
ILT
347
348static int
9486db4f 349has_return_type (struct demangle_component *);
5e777af5
ILT
350
351static int
9486db4f 352is_ctor_dtor_or_conversion (struct demangle_component *);
5e777af5 353
9486db4f 354static struct demangle_component *d_encoding (struct d_info *, int);
5e777af5 355
9486db4f 356static struct demangle_component *d_name (struct d_info *);
5e777af5 357
9486db4f 358static struct demangle_component *d_nested_name (struct d_info *);
5e777af5 359
9486db4f 360static struct demangle_component *d_prefix (struct d_info *);
5e777af5 361
9486db4f 362static struct demangle_component *d_unqualified_name (struct d_info *);
5e777af5 363
9486db4f 364static struct demangle_component *d_source_name (struct d_info *);
5e777af5 365
9486db4f 366static long d_number (struct d_info *);
5e777af5 367
9486db4f 368static struct demangle_component *d_identifier (struct d_info *, int);
5e777af5 369
9486db4f 370static struct demangle_component *d_operator_name (struct d_info *);
5e777af5 371
9486db4f 372static struct demangle_component *d_special_name (struct d_info *);
5e777af5 373
9486db4f 374static int d_call_offset (struct d_info *, int);
5e777af5 375
9486db4f 376static struct demangle_component *d_ctor_dtor_name (struct d_info *);
5e777af5
ILT
377
378static struct demangle_component **
9486db4f 379d_cv_qualifiers (struct d_info *, struct demangle_component **, int);
5e777af5
ILT
380
381static struct demangle_component *
9486db4f 382d_function_type (struct d_info *);
5e777af5
ILT
383
384static struct demangle_component *
9486db4f 385d_bare_function_type (struct d_info *, int);
5e777af5
ILT
386
387static struct demangle_component *
9486db4f 388d_class_enum_type (struct d_info *);
5e777af5 389
9486db4f 390static struct demangle_component *d_array_type (struct d_info *);
5e777af5
ILT
391
392static struct demangle_component *
9486db4f 393d_pointer_to_member_type (struct d_info *);
5e777af5
ILT
394
395static struct demangle_component *
9486db4f 396d_template_param (struct d_info *);
5e777af5 397
9486db4f 398static struct demangle_component *d_template_args (struct d_info *);
5e777af5
ILT
399
400static struct demangle_component *
9486db4f 401d_template_arg (struct d_info *);
5e777af5 402
9486db4f 403static struct demangle_component *d_expression (struct d_info *);
5e777af5 404
9486db4f 405static struct demangle_component *d_expr_primary (struct d_info *);
5e777af5 406
9486db4f 407static struct demangle_component *d_local_name (struct d_info *);
5e777af5 408
9486db4f 409static int d_discriminator (struct d_info *);
5e777af5
ILT
410
411static int
9486db4f 412d_add_substitution (struct d_info *, struct demangle_component *);
5e777af5 413
9486db4f 414static struct demangle_component *d_substitution (struct d_info *, int);
5e777af5 415
456cc5cf 416static void d_growable_string_init (struct d_growable_string *, size_t);
5e777af5 417
456cc5cf
SB
418static inline void
419d_growable_string_resize (struct d_growable_string *, size_t);
5e777af5 420
456cc5cf
SB
421static inline void
422d_growable_string_append_buffer (struct d_growable_string *,
423 const char *, size_t);
5e777af5 424static void
456cc5cf
SB
425d_growable_string_callback_adapter (const char *, size_t, void *);
426
427static void
428d_print_init (struct d_print_info *, int, demangle_callbackref, void *);
429
430static inline void d_print_error (struct d_print_info *);
431
432static inline int d_print_saw_error (struct d_print_info *);
433
434static inline void d_print_flush (struct d_print_info *);
435
436static inline void d_append_char (struct d_print_info *, char);
5e777af5 437
456cc5cf
SB
438static inline void d_append_buffer (struct d_print_info *,
439 const char *, size_t);
440
441static inline void d_append_string (struct d_print_info *, const char *);
442
443static inline char d_last_char (struct d_print_info *);
5e777af5
ILT
444
445static void
9486db4f 446d_print_comp (struct d_print_info *, const struct demangle_component *);
5e777af5
ILT
447
448static void
9486db4f 449d_print_java_identifier (struct d_print_info *, const char *, int);
5e777af5
ILT
450
451static void
9486db4f 452d_print_mod_list (struct d_print_info *, struct d_print_mod *, int);
5e777af5
ILT
453
454static void
9486db4f 455d_print_mod (struct d_print_info *, const struct demangle_component *);
5e777af5
ILT
456
457static void
9486db4f
GDR
458d_print_function_type (struct d_print_info *,
459 const struct demangle_component *,
460 struct d_print_mod *);
5e777af5
ILT
461
462static void
9486db4f
GDR
463d_print_array_type (struct d_print_info *,
464 const struct demangle_component *,
465 struct d_print_mod *);
5e777af5
ILT
466
467static void
9486db4f 468d_print_expr_op (struct d_print_info *, const struct demangle_component *);
5e777af5
ILT
469
470static void
9486db4f 471d_print_cast (struct d_print_info *, const struct demangle_component *);
5e777af5 472
456cc5cf
SB
473static int d_demangle_callback (const char *, int,
474 demangle_callbackref, void *);
9486db4f 475static char *d_demangle (const char *, int, size_t *);
bd6946d1 476
69afa80d 477#ifdef CP_DEMANGLE_DEBUG
bd6946d1
ILT
478
479static void
9486db4f 480d_dump (struct demangle_component *dc, int indent)
69afa80d
AS
481{
482 int i;
69afa80d 483
bd6946d1 484 if (dc == NULL)
456cc5cf
SB
485 {
486 if (indent == 0)
487 printf ("failed demangling\n");
488 return;
489 }
bd6946d1
ILT
490
491 for (i = 0; i < indent; ++i)
492 putchar (' ');
493
494 switch (dc->type)
495 {
5e777af5 496 case DEMANGLE_COMPONENT_NAME:
bd6946d1
ILT
497 printf ("name '%.*s'\n", dc->u.s_name.len, dc->u.s_name.s);
498 return;
5e777af5 499 case DEMANGLE_COMPONENT_TEMPLATE_PARAM:
bd6946d1
ILT
500 printf ("template parameter %ld\n", dc->u.s_number.number);
501 return;
5e777af5 502 case DEMANGLE_COMPONENT_CTOR:
bd6946d1
ILT
503 printf ("constructor %d\n", (int) dc->u.s_ctor.kind);
504 d_dump (dc->u.s_ctor.name, indent + 2);
505 return;
5e777af5 506 case DEMANGLE_COMPONENT_DTOR:
bd6946d1
ILT
507 printf ("destructor %d\n", (int) dc->u.s_dtor.kind);
508 d_dump (dc->u.s_dtor.name, indent + 2);
509 return;
5e777af5 510 case DEMANGLE_COMPONENT_SUB_STD:
bd6946d1
ILT
511 printf ("standard substitution %s\n", dc->u.s_string.string);
512 return;
5e777af5 513 case DEMANGLE_COMPONENT_BUILTIN_TYPE:
bd6946d1
ILT
514 printf ("builtin type %s\n", dc->u.s_builtin.type->name);
515 return;
5e777af5 516 case DEMANGLE_COMPONENT_OPERATOR:
bd6946d1
ILT
517 printf ("operator %s\n", dc->u.s_operator.op->name);
518 return;
5e777af5 519 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
bd6946d1
ILT
520 printf ("extended operator with %d args\n",
521 dc->u.s_extended_operator.args);
522 d_dump (dc->u.s_extended_operator.name, indent + 2);
523 return;
524
5e777af5 525 case DEMANGLE_COMPONENT_QUAL_NAME:
bd6946d1
ILT
526 printf ("qualified name\n");
527 break;
5e777af5 528 case DEMANGLE_COMPONENT_LOCAL_NAME:
a91d1af0
ILT
529 printf ("local name\n");
530 break;
5e777af5 531 case DEMANGLE_COMPONENT_TYPED_NAME:
bd6946d1
ILT
532 printf ("typed name\n");
533 break;
5e777af5 534 case DEMANGLE_COMPONENT_TEMPLATE:
bd6946d1
ILT
535 printf ("template\n");
536 break;
5e777af5 537 case DEMANGLE_COMPONENT_VTABLE:
bd6946d1
ILT
538 printf ("vtable\n");
539 break;
5e777af5 540 case DEMANGLE_COMPONENT_VTT:
bd6946d1
ILT
541 printf ("VTT\n");
542 break;
5e777af5 543 case DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE:
bd6946d1
ILT
544 printf ("construction vtable\n");
545 break;
5e777af5 546 case DEMANGLE_COMPONENT_TYPEINFO:
bd6946d1
ILT
547 printf ("typeinfo\n");
548 break;
5e777af5 549 case DEMANGLE_COMPONENT_TYPEINFO_NAME:
bd6946d1
ILT
550 printf ("typeinfo name\n");
551 break;
5e777af5 552 case DEMANGLE_COMPONENT_TYPEINFO_FN:
bd6946d1
ILT
553 printf ("typeinfo function\n");
554 break;
5e777af5 555 case DEMANGLE_COMPONENT_THUNK:
bd6946d1
ILT
556 printf ("thunk\n");
557 break;
5e777af5 558 case DEMANGLE_COMPONENT_VIRTUAL_THUNK:
bd6946d1
ILT
559 printf ("virtual thunk\n");
560 break;
5e777af5 561 case DEMANGLE_COMPONENT_COVARIANT_THUNK:
bd6946d1
ILT
562 printf ("covariant thunk\n");
563 break;
5e777af5 564 case DEMANGLE_COMPONENT_JAVA_CLASS:
bd6946d1
ILT
565 printf ("java class\n");
566 break;
5e777af5 567 case DEMANGLE_COMPONENT_GUARD:
bd6946d1
ILT
568 printf ("guard\n");
569 break;
5e777af5 570 case DEMANGLE_COMPONENT_REFTEMP:
bd6946d1
ILT
571 printf ("reference temporary\n");
572 break;
15da2806
RH
573 case DEMANGLE_COMPONENT_HIDDEN_ALIAS:
574 printf ("hidden alias\n");
575 break;
5e777af5 576 case DEMANGLE_COMPONENT_RESTRICT:
bd6946d1
ILT
577 printf ("restrict\n");
578 break;
5e777af5 579 case DEMANGLE_COMPONENT_VOLATILE:
bd6946d1
ILT
580 printf ("volatile\n");
581 break;
5e777af5 582 case DEMANGLE_COMPONENT_CONST:
bd6946d1
ILT
583 printf ("const\n");
584 break;
5e777af5 585 case DEMANGLE_COMPONENT_RESTRICT_THIS:
a51753e4
ILT
586 printf ("restrict this\n");
587 break;
5e777af5 588 case DEMANGLE_COMPONENT_VOLATILE_THIS:
a51753e4
ILT
589 printf ("volatile this\n");
590 break;
5e777af5 591 case DEMANGLE_COMPONENT_CONST_THIS:
a51753e4
ILT
592 printf ("const this\n");
593 break;
5e777af5 594 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
bd6946d1
ILT
595 printf ("vendor type qualifier\n");
596 break;
5e777af5 597 case DEMANGLE_COMPONENT_POINTER:
bd6946d1
ILT
598 printf ("pointer\n");
599 break;
5e777af5 600 case DEMANGLE_COMPONENT_REFERENCE:
bd6946d1
ILT
601 printf ("reference\n");
602 break;
1ab28be5
DG
603 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
604 printf ("rvalue reference\n");
605 break;
5e777af5 606 case DEMANGLE_COMPONENT_COMPLEX:
bd6946d1
ILT
607 printf ("complex\n");
608 break;
5e777af5 609 case DEMANGLE_COMPONENT_IMAGINARY:
bd6946d1
ILT
610 printf ("imaginary\n");
611 break;
5e777af5 612 case DEMANGLE_COMPONENT_VENDOR_TYPE:
bd6946d1
ILT
613 printf ("vendor type\n");
614 break;
5e777af5 615 case DEMANGLE_COMPONENT_FUNCTION_TYPE:
bd6946d1
ILT
616 printf ("function type\n");
617 break;
5e777af5 618 case DEMANGLE_COMPONENT_ARRAY_TYPE:
bd6946d1
ILT
619 printf ("array type\n");
620 break;
5e777af5 621 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
bd6946d1
ILT
622 printf ("pointer to member type\n");
623 break;
07523e7c
JM
624 case DEMANGLE_COMPONENT_FIXED_TYPE:
625 printf ("fixed-point type\n");
626 break;
5e777af5 627 case DEMANGLE_COMPONENT_ARGLIST:
bd6946d1
ILT
628 printf ("argument list\n");
629 break;
5e777af5 630 case DEMANGLE_COMPONENT_TEMPLATE_ARGLIST:
bd6946d1
ILT
631 printf ("template argument list\n");
632 break;
5e777af5 633 case DEMANGLE_COMPONENT_CAST:
bd6946d1
ILT
634 printf ("cast\n");
635 break;
5e777af5 636 case DEMANGLE_COMPONENT_UNARY:
bd6946d1
ILT
637 printf ("unary operator\n");
638 break;
5e777af5 639 case DEMANGLE_COMPONENT_BINARY:
bd6946d1
ILT
640 printf ("binary operator\n");
641 break;
5e777af5 642 case DEMANGLE_COMPONENT_BINARY_ARGS:
bd6946d1
ILT
643 printf ("binary operator arguments\n");
644 break;
5e777af5 645 case DEMANGLE_COMPONENT_TRINARY:
bd6946d1
ILT
646 printf ("trinary operator\n");
647 break;
5e777af5 648 case DEMANGLE_COMPONENT_TRINARY_ARG1:
bd6946d1
ILT
649 printf ("trinary operator arguments 1\n");
650 break;
5e777af5 651 case DEMANGLE_COMPONENT_TRINARY_ARG2:
bd6946d1
ILT
652 printf ("trinary operator arguments 1\n");
653 break;
5e777af5 654 case DEMANGLE_COMPONENT_LITERAL:
bd6946d1
ILT
655 printf ("literal\n");
656 break;
5e777af5 657 case DEMANGLE_COMPONENT_LITERAL_NEG:
374caa50
ILT
658 printf ("negative literal\n");
659 break;
e5df4fb1
DD
660 case DEMANGLE_COMPONENT_JAVA_RESOURCE:
661 printf ("java resource\n");
662 break;
663 case DEMANGLE_COMPONENT_COMPOUND_NAME:
664 printf ("compound name\n");
665 break;
666 case DEMANGLE_COMPONENT_CHARACTER:
667 printf ("character '%c'\n", dc->u.s_character.character);
668 return;
5a3d7e74
JM
669 case DEMANGLE_COMPONENT_DECLTYPE:
670 printf ("decltype\n");
671 break;
38179091
JM
672 case DEMANGLE_COMPONENT_PACK_EXPANSION:
673 printf ("pack expansion\n");
674 break;
69afa80d
AS
675 }
676
bd6946d1
ILT
677 d_dump (d_left (dc), indent + 2);
678 d_dump (d_right (dc), indent + 2);
679}
680
681#endif /* CP_DEMANGLE_DEBUG */
682
5e777af5
ILT
683/* Fill in a DEMANGLE_COMPONENT_NAME. */
684
685CP_STATIC_IF_GLIBCPP_V3
686int
9486db4f 687cplus_demangle_fill_name (struct demangle_component *p, const char *s, int len)
5e777af5
ILT
688{
689 if (p == NULL || s == NULL || len == 0)
690 return 0;
691 p->type = DEMANGLE_COMPONENT_NAME;
692 p->u.s_name.s = s;
693 p->u.s_name.len = len;
694 return 1;
695}
696
697/* Fill in a DEMANGLE_COMPONENT_EXTENDED_OPERATOR. */
698
699CP_STATIC_IF_GLIBCPP_V3
700int
9486db4f
GDR
701cplus_demangle_fill_extended_operator (struct demangle_component *p, int args,
702 struct demangle_component *name)
5e777af5
ILT
703{
704 if (p == NULL || args < 0 || name == NULL)
705 return 0;
706 p->type = DEMANGLE_COMPONENT_EXTENDED_OPERATOR;
707 p->u.s_extended_operator.args = args;
708 p->u.s_extended_operator.name = name;
709 return 1;
710}
711
712/* Fill in a DEMANGLE_COMPONENT_CTOR. */
713
714CP_STATIC_IF_GLIBCPP_V3
715int
9486db4f
GDR
716cplus_demangle_fill_ctor (struct demangle_component *p,
717 enum gnu_v3_ctor_kinds kind,
718 struct demangle_component *name)
5e777af5
ILT
719{
720 if (p == NULL
721 || name == NULL
7859dde7
ILT
722 || (int) kind < gnu_v3_complete_object_ctor
723 || (int) kind > gnu_v3_complete_object_allocating_ctor)
5e777af5
ILT
724 return 0;
725 p->type = DEMANGLE_COMPONENT_CTOR;
726 p->u.s_ctor.kind = kind;
727 p->u.s_ctor.name = name;
728 return 1;
729}
730
731/* Fill in a DEMANGLE_COMPONENT_DTOR. */
732
733CP_STATIC_IF_GLIBCPP_V3
734int
9486db4f
GDR
735cplus_demangle_fill_dtor (struct demangle_component *p,
736 enum gnu_v3_dtor_kinds kind,
737 struct demangle_component *name)
5e777af5
ILT
738{
739 if (p == NULL
740 || name == NULL
7859dde7
ILT
741 || (int) kind < gnu_v3_deleting_dtor
742 || (int) kind > gnu_v3_base_object_dtor)
5e777af5
ILT
743 return 0;
744 p->type = DEMANGLE_COMPONENT_DTOR;
745 p->u.s_dtor.kind = kind;
746 p->u.s_dtor.name = name;
747 return 1;
748}
749
bd6946d1
ILT
750/* Add a new component. */
751
5e777af5 752static struct demangle_component *
9486db4f 753d_make_empty (struct d_info *di)
bd6946d1 754{
5e777af5 755 struct demangle_component *p;
bd6946d1
ILT
756
757 if (di->next_comp >= di->num_comps)
758 return NULL;
759 p = &di->comps[di->next_comp];
bd6946d1
ILT
760 ++di->next_comp;
761 return p;
762}
763
764/* Add a new generic component. */
765
5e777af5 766static struct demangle_component *
9486db4f
GDR
767d_make_comp (struct d_info *di, enum demangle_component_type type,
768 struct demangle_component *left,
769 struct demangle_component *right)
bd6946d1 770{
5e777af5 771 struct demangle_component *p;
bd6946d1
ILT
772
773 /* We check for errors here. A typical error would be a NULL return
81dc098b
ILT
774 from a subroutine. We catch those here, and return NULL
775 upward. */
bd6946d1
ILT
776 switch (type)
777 {
778 /* These types require two parameters. */
5e777af5
ILT
779 case DEMANGLE_COMPONENT_QUAL_NAME:
780 case DEMANGLE_COMPONENT_LOCAL_NAME:
781 case DEMANGLE_COMPONENT_TYPED_NAME:
782 case DEMANGLE_COMPONENT_TEMPLATE:
d4f3ce5c 783 case DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE:
5e777af5
ILT
784 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
785 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
786 case DEMANGLE_COMPONENT_UNARY:
787 case DEMANGLE_COMPONENT_BINARY:
788 case DEMANGLE_COMPONENT_BINARY_ARGS:
789 case DEMANGLE_COMPONENT_TRINARY:
790 case DEMANGLE_COMPONENT_TRINARY_ARG1:
791 case DEMANGLE_COMPONENT_TRINARY_ARG2:
792 case DEMANGLE_COMPONENT_LITERAL:
793 case DEMANGLE_COMPONENT_LITERAL_NEG:
e5df4fb1 794 case DEMANGLE_COMPONENT_COMPOUND_NAME:
bd6946d1
ILT
795 if (left == NULL || right == NULL)
796 return NULL;
797 break;
798
799 /* These types only require one parameter. */
5e777af5
ILT
800 case DEMANGLE_COMPONENT_VTABLE:
801 case DEMANGLE_COMPONENT_VTT:
5e777af5
ILT
802 case DEMANGLE_COMPONENT_TYPEINFO:
803 case DEMANGLE_COMPONENT_TYPEINFO_NAME:
804 case DEMANGLE_COMPONENT_TYPEINFO_FN:
805 case DEMANGLE_COMPONENT_THUNK:
806 case DEMANGLE_COMPONENT_VIRTUAL_THUNK:
807 case DEMANGLE_COMPONENT_COVARIANT_THUNK:
808 case DEMANGLE_COMPONENT_JAVA_CLASS:
809 case DEMANGLE_COMPONENT_GUARD:
810 case DEMANGLE_COMPONENT_REFTEMP:
15da2806 811 case DEMANGLE_COMPONENT_HIDDEN_ALIAS:
5e777af5
ILT
812 case DEMANGLE_COMPONENT_POINTER:
813 case DEMANGLE_COMPONENT_REFERENCE:
1ab28be5 814 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
5e777af5
ILT
815 case DEMANGLE_COMPONENT_COMPLEX:
816 case DEMANGLE_COMPONENT_IMAGINARY:
817 case DEMANGLE_COMPONENT_VENDOR_TYPE:
5e777af5 818 case DEMANGLE_COMPONENT_CAST:
e5df4fb1 819 case DEMANGLE_COMPONENT_JAVA_RESOURCE:
5a3d7e74 820 case DEMANGLE_COMPONENT_DECLTYPE:
38179091 821 case DEMANGLE_COMPONENT_PACK_EXPANSION:
23b1a789
JK
822 case DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS:
823 case DEMANGLE_COMPONENT_GLOBAL_DESTRUCTORS:
bd6946d1
ILT
824 if (left == NULL)
825 return NULL;
826 break;
827
828 /* This needs a right parameter, but the left parameter can be
829 empty. */
5e777af5 830 case DEMANGLE_COMPONENT_ARRAY_TYPE:
bd6946d1
ILT
831 if (right == NULL)
832 return NULL;
833 break;
834
835 /* These are allowed to have no parameters--in some cases they
836 will be filled in later. */
5e777af5
ILT
837 case DEMANGLE_COMPONENT_FUNCTION_TYPE:
838 case DEMANGLE_COMPONENT_RESTRICT:
839 case DEMANGLE_COMPONENT_VOLATILE:
840 case DEMANGLE_COMPONENT_CONST:
841 case DEMANGLE_COMPONENT_RESTRICT_THIS:
842 case DEMANGLE_COMPONENT_VOLATILE_THIS:
843 case DEMANGLE_COMPONENT_CONST_THIS:
38179091
JM
844 case DEMANGLE_COMPONENT_ARGLIST:
845 case DEMANGLE_COMPONENT_TEMPLATE_ARGLIST:
bd6946d1
ILT
846 break;
847
848 /* Other types should not be seen here. */
849 default:
850 return NULL;
69afa80d 851 }
bd6946d1 852
5e777af5 853 p = d_make_empty (di);
bd6946d1 854 if (p != NULL)
69afa80d 855 {
5e777af5 856 p->type = type;
bd6946d1
ILT
857 p->u.s_binary.left = left;
858 p->u.s_binary.right = right;
69afa80d 859 }
bd6946d1
ILT
860 return p;
861}
69afa80d 862
bd6946d1 863/* Add a new name component. */
051664b0 864
5e777af5 865static struct demangle_component *
9486db4f 866d_make_name (struct d_info *di, const char *s, int len)
bd6946d1 867{
5e777af5 868 struct demangle_component *p;
051664b0 869
5e777af5
ILT
870 p = d_make_empty (di);
871 if (! cplus_demangle_fill_name (p, s, len))
a51753e4 872 return NULL;
bd6946d1 873 return p;
69afa80d
AS
874}
875
bd6946d1 876/* Add a new builtin type component. */
69afa80d 877
5e777af5 878static struct demangle_component *
9486db4f
GDR
879d_make_builtin_type (struct d_info *di,
880 const struct demangle_builtin_type_info *type)
69afa80d 881{
5e777af5 882 struct demangle_component *p;
bd6946d1 883
81dc098b
ILT
884 if (type == NULL)
885 return NULL;
5e777af5 886 p = d_make_empty (di);
bd6946d1 887 if (p != NULL)
5e777af5
ILT
888 {
889 p->type = DEMANGLE_COMPONENT_BUILTIN_TYPE;
890 p->u.s_builtin.type = type;
891 }
bd6946d1
ILT
892 return p;
893}
69afa80d 894
bd6946d1 895/* Add a new operator component. */
69afa80d 896
5e777af5 897static struct demangle_component *
9486db4f 898d_make_operator (struct d_info *di, const struct demangle_operator_info *op)
69afa80d 899{
5e777af5 900 struct demangle_component *p;
bd6946d1 901
5e777af5 902 p = d_make_empty (di);
bd6946d1 903 if (p != NULL)
5e777af5
ILT
904 {
905 p->type = DEMANGLE_COMPONENT_OPERATOR;
906 p->u.s_operator.op = op;
907 }
bd6946d1 908 return p;
69afa80d
AS
909}
910
bd6946d1 911/* Add a new extended operator component. */
69afa80d 912
5e777af5 913static struct demangle_component *
9486db4f
GDR
914d_make_extended_operator (struct d_info *di, int args,
915 struct demangle_component *name)
69afa80d 916{
5e777af5 917 struct demangle_component *p;
051664b0 918
5e777af5
ILT
919 p = d_make_empty (di);
920 if (! cplus_demangle_fill_extended_operator (p, args, name))
81dc098b 921 return NULL;
bd6946d1 922 return p;
69afa80d
AS
923}
924
bd6946d1 925/* Add a new constructor component. */
69afa80d 926
5e777af5 927static struct demangle_component *
9486db4f
GDR
928d_make_ctor (struct d_info *di, enum gnu_v3_ctor_kinds kind,
929 struct demangle_component *name)
69afa80d 930{
5e777af5 931 struct demangle_component *p;
bd6946d1 932
5e777af5
ILT
933 p = d_make_empty (di);
934 if (! cplus_demangle_fill_ctor (p, kind, name))
81dc098b 935 return NULL;
bd6946d1 936 return p;
69afa80d
AS
937}
938
bd6946d1 939/* Add a new destructor component. */
69afa80d 940
5e777af5 941static struct demangle_component *
9486db4f
GDR
942d_make_dtor (struct d_info *di, enum gnu_v3_dtor_kinds kind,
943 struct demangle_component *name)
69afa80d 944{
5e777af5 945 struct demangle_component *p;
bd6946d1 946
5e777af5
ILT
947 p = d_make_empty (di);
948 if (! cplus_demangle_fill_dtor (p, kind, name))
81dc098b 949 return NULL;
bd6946d1 950 return p;
69afa80d
AS
951}
952
bd6946d1 953/* Add a new template parameter. */
0870bfd6 954
5e777af5 955static struct demangle_component *
9486db4f 956d_make_template_param (struct d_info *di, long i)
0870bfd6 957{
5e777af5 958 struct demangle_component *p;
bd6946d1 959
5e777af5 960 p = d_make_empty (di);
bd6946d1 961 if (p != NULL)
5e777af5
ILT
962 {
963 p->type = DEMANGLE_COMPONENT_TEMPLATE_PARAM;
964 p->u.s_number.number = i;
965 }
bd6946d1 966 return p;
0870bfd6
AS
967}
968
448545cb
JM
969/* Add a new function parameter. */
970
971static struct demangle_component *
972d_make_function_param (struct d_info *di, long i)
973{
974 struct demangle_component *p;
975
976 p = d_make_empty (di);
977 if (p != NULL)
978 {
979 p->type = DEMANGLE_COMPONENT_FUNCTION_PARAM;
980 p->u.s_number.number = i;
981 }
982 return p;
983}
984
bd6946d1 985/* Add a new standard substitution component. */
0870bfd6 986
5e777af5 987static struct demangle_component *
9486db4f 988d_make_sub (struct d_info *di, const char *name, int len)
0870bfd6 989{
5e777af5 990 struct demangle_component *p;
bd6946d1 991
5e777af5 992 p = d_make_empty (di);
bd6946d1 993 if (p != NULL)
2d6c4025 994 {
5e777af5 995 p->type = DEMANGLE_COMPONENT_SUB_STD;
2d6c4025
ILT
996 p->u.s_string.string = name;
997 p->u.s_string.len = len;
998 }
bd6946d1 999 return p;
0870bfd6
AS
1000}
1001
81dc098b
ILT
1002/* <mangled-name> ::= _Z <encoding>
1003
1004 TOP_LEVEL is non-zero when called at the top level. */
0870bfd6 1005
5e777af5
ILT
1006CP_STATIC_IF_GLIBCPP_V3
1007struct demangle_component *
9486db4f 1008cplus_demangle_mangled_name (struct d_info *di, int top_level)
0870bfd6 1009{
448545cb
JM
1010 if (! d_check_char (di, '_')
1011 /* Allow missing _ if not at toplevel to work around a
1012 bug in G++ abi-version=2 mangling; see the comment in
1013 write_template_arg. */
1014 && top_level)
bd6946d1 1015 return NULL;
5165f125 1016 if (! d_check_char (di, 'Z'))
bd6946d1 1017 return NULL;
81dc098b 1018 return d_encoding (di, top_level);
0870bfd6
AS
1019}
1020
bd6946d1
ILT
1021/* Return whether a function should have a return type. The argument
1022 is the function name, which may be qualified in various ways. The
1023 rules are that template functions have return types with some
1024 exceptions, function types which are not part of a function name
1025 mangling have return types with some exceptions, and non-template
1026 function names do not have return types. The exceptions are that
1027 constructors, destructors, and conversion operators do not have
1028 return types. */
0870bfd6
AS
1029
1030static int
9486db4f 1031has_return_type (struct demangle_component *dc)
0870bfd6 1032{
bd6946d1
ILT
1033 if (dc == NULL)
1034 return 0;
1035 switch (dc->type)
1036 {
1037 default:
1038 return 0;
5e777af5 1039 case DEMANGLE_COMPONENT_TEMPLATE:
bd6946d1 1040 return ! is_ctor_dtor_or_conversion (d_left (dc));
5e777af5
ILT
1041 case DEMANGLE_COMPONENT_RESTRICT_THIS:
1042 case DEMANGLE_COMPONENT_VOLATILE_THIS:
1043 case DEMANGLE_COMPONENT_CONST_THIS:
0ba5c8a2 1044 return has_return_type (d_left (dc));
bd6946d1 1045 }
0870bfd6
AS
1046}
1047
bd6946d1
ILT
1048/* Return whether a name is a constructor, a destructor, or a
1049 conversion operator. */
69afa80d
AS
1050
1051static int
9486db4f 1052is_ctor_dtor_or_conversion (struct demangle_component *dc)
69afa80d 1053{
bd6946d1
ILT
1054 if (dc == NULL)
1055 return 0;
1056 switch (dc->type)
1057 {
1058 default:
1059 return 0;
5e777af5
ILT
1060 case DEMANGLE_COMPONENT_QUAL_NAME:
1061 case DEMANGLE_COMPONENT_LOCAL_NAME:
bd6946d1 1062 return is_ctor_dtor_or_conversion (d_right (dc));
5e777af5
ILT
1063 case DEMANGLE_COMPONENT_CTOR:
1064 case DEMANGLE_COMPONENT_DTOR:
1065 case DEMANGLE_COMPONENT_CAST:
bd6946d1
ILT
1066 return 1;
1067 }
69afa80d
AS
1068}
1069
bd6946d1
ILT
1070/* <encoding> ::= <(function) name> <bare-function-type>
1071 ::= <(data) name>
ad07f5e5
ILT
1072 ::= <special-name>
1073
1074 TOP_LEVEL is non-zero when called at the top level, in which case
1075 if DMGL_PARAMS is not set we do not demangle the function
1076 parameters. We only set this at the top level, because otherwise
1077 we would not correctly demangle names in local scopes. */
69afa80d 1078
5e777af5 1079static struct demangle_component *
9486db4f 1080d_encoding (struct d_info *di, int top_level)
69afa80d 1081{
bd6946d1 1082 char peek = d_peek_char (di);
051664b0 1083
bd6946d1
ILT
1084 if (peek == 'G' || peek == 'T')
1085 return d_special_name (di);
1086 else
051664b0 1087 {
5e777af5 1088 struct demangle_component *dc;
bd6946d1
ILT
1089
1090 dc = d_name (di);
81dc098b
ILT
1091
1092 if (dc != NULL && top_level && (di->options & DMGL_PARAMS) == 0)
1093 {
1094 /* Strip off any initial CV-qualifiers, as they really apply
1095 to the `this' parameter, and they were not output by the
1096 v2 demangler without DMGL_PARAMS. */
5e777af5
ILT
1097 while (dc->type == DEMANGLE_COMPONENT_RESTRICT_THIS
1098 || dc->type == DEMANGLE_COMPONENT_VOLATILE_THIS
1099 || dc->type == DEMANGLE_COMPONENT_CONST_THIS)
81dc098b 1100 dc = d_left (dc);
e4796f1c 1101
5e777af5
ILT
1102 /* If the top level is a DEMANGLE_COMPONENT_LOCAL_NAME, then
1103 there may be CV-qualifiers on its right argument which
1104 really apply here; this happens when parsing a class
1105 which is local to a function. */
1106 if (dc->type == DEMANGLE_COMPONENT_LOCAL_NAME)
e4796f1c 1107 {
5e777af5 1108 struct demangle_component *dcr;
e4796f1c
ILT
1109
1110 dcr = d_right (dc);
5e777af5
ILT
1111 while (dcr->type == DEMANGLE_COMPONENT_RESTRICT_THIS
1112 || dcr->type == DEMANGLE_COMPONENT_VOLATILE_THIS
1113 || dcr->type == DEMANGLE_COMPONENT_CONST_THIS)
e4796f1c
ILT
1114 dcr = d_left (dcr);
1115 dc->u.s_binary.right = dcr;
1116 }
1117
81dc098b
ILT
1118 return dc;
1119 }
1120
bd6946d1 1121 peek = d_peek_char (di);
771904f1 1122 if (dc == NULL || peek == '\0' || peek == 'E')
bd6946d1 1123 return dc;
5e777af5 1124 return d_make_comp (di, DEMANGLE_COMPONENT_TYPED_NAME, dc,
bd6946d1 1125 d_bare_function_type (di, has_return_type (dc)));
051664b0 1126 }
bd6946d1
ILT
1127}
1128
1129/* <name> ::= <nested-name>
1130 ::= <unscoped-name>
1131 ::= <unscoped-template-name> <template-args>
1132 ::= <local-name>
1133
1134 <unscoped-name> ::= <unqualified-name>
1135 ::= St <unqualified-name>
69afa80d 1136
bd6946d1
ILT
1137 <unscoped-template-name> ::= <unscoped-name>
1138 ::= <substitution>
1139*/
1140
5e777af5 1141static struct demangle_component *
9486db4f 1142d_name (struct d_info *di)
bd6946d1
ILT
1143{
1144 char peek = d_peek_char (di);
5e777af5 1145 struct demangle_component *dc;
bd6946d1
ILT
1146
1147 switch (peek)
69afa80d 1148 {
bd6946d1
ILT
1149 case 'N':
1150 return d_nested_name (di);
1151
1152 case 'Z':
1153 return d_local_name (di);
1154
a2aa65f0
GK
1155 case 'L':
1156 return d_unqualified_name (di);
1157
bd6946d1
ILT
1158 case 'S':
1159 {
1160 int subst;
1161
1162 if (d_peek_next_char (di) != 't')
1163 {
374caa50 1164 dc = d_substitution (di, 0);
bd6946d1
ILT
1165 subst = 1;
1166 }
1167 else
1168 {
1169 d_advance (di, 2);
5e777af5
ILT
1170 dc = d_make_comp (di, DEMANGLE_COMPONENT_QUAL_NAME,
1171 d_make_name (di, "std", 3),
bd6946d1 1172 d_unqualified_name (di));
2d6c4025 1173 di->expansion += 3;
bd6946d1
ILT
1174 subst = 0;
1175 }
1176
1177 if (d_peek_char (di) != 'I')
1178 {
1179 /* The grammar does not permit this case to occur if we
1180 called d_substitution() above (i.e., subst == 1). We
1181 don't bother to check. */
1182 }
1183 else
1184 {
1185 /* This is <template-args>, which means that we just saw
1186 <unscoped-template-name>, which is a substitution
1187 candidate if we didn't just get it from a
1188 substitution. */
1189 if (! subst)
1190 {
1191 if (! d_add_substitution (di, dc))
1192 return NULL;
1193 }
5e777af5
ILT
1194 dc = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, dc,
1195 d_template_args (di));
bd6946d1
ILT
1196 }
1197
1198 return dc;
1199 }
1200
1201 default:
1202 dc = d_unqualified_name (di);
1203 if (d_peek_char (di) == 'I')
051664b0 1204 {
bd6946d1
ILT
1205 /* This is <template-args>, which means that we just saw
1206 <unscoped-template-name>, which is a substitution
1207 candidate. */
1208 if (! d_add_substitution (di, dc))
1209 return NULL;
5e777af5
ILT
1210 dc = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, dc,
1211 d_template_args (di));
051664b0 1212 }
bd6946d1 1213 return dc;
69afa80d 1214 }
bd6946d1 1215}
69afa80d 1216
bd6946d1
ILT
1217/* <nested-name> ::= N [<CV-qualifiers>] <prefix> <unqualified-name> E
1218 ::= N [<CV-qualifiers>] <template-prefix> <template-args> E
1219*/
69afa80d 1220
5e777af5 1221static struct demangle_component *
9486db4f 1222d_nested_name (struct d_info *di)
bd6946d1 1223{
5e777af5
ILT
1224 struct demangle_component *ret;
1225 struct demangle_component **pret;
051664b0 1226
5165f125 1227 if (! d_check_char (di, 'N'))
bd6946d1 1228 return NULL;
69afa80d 1229
a51753e4 1230 pret = d_cv_qualifiers (di, &ret, 1);
bd6946d1
ILT
1231 if (pret == NULL)
1232 return NULL;
1233
1234 *pret = d_prefix (di);
1235 if (*pret == NULL)
1236 return NULL;
69afa80d 1237
5165f125 1238 if (! d_check_char (di, 'E'))
69afa80d
AS
1239 return NULL;
1240
bd6946d1 1241 return ret;
69afa80d
AS
1242}
1243
bd6946d1
ILT
1244/* <prefix> ::= <prefix> <unqualified-name>
1245 ::= <template-prefix> <template-args>
1246 ::= <template-param>
1247 ::=
1248 ::= <substitution>
69afa80d 1249
bd6946d1
ILT
1250 <template-prefix> ::= <prefix> <(template) unqualified-name>
1251 ::= <template-param>
1252 ::= <substitution>
1253*/
1254
5e777af5 1255static struct demangle_component *
9486db4f 1256d_prefix (struct d_info *di)
69afa80d 1257{
5e777af5 1258 struct demangle_component *ret = NULL;
69afa80d 1259
bd6946d1 1260 while (1)
69afa80d 1261 {
bd6946d1 1262 char peek;
5e777af5
ILT
1263 enum demangle_component_type comb_type;
1264 struct demangle_component *dc;
bd6946d1
ILT
1265
1266 peek = d_peek_char (di);
1267 if (peek == '\0')
1268 return NULL;
1269
1270 /* The older code accepts a <local-name> here, but I don't see
1271 that in the grammar. The older code does not accept a
1272 <template-param> here. */
69afa80d 1273
5e777af5 1274 comb_type = DEMANGLE_COMPONENT_QUAL_NAME;
bd6946d1 1275 if (IS_DIGIT (peek)
a51753e4 1276 || IS_LOWER (peek)
bd6946d1 1277 || peek == 'C'
a2aa65f0
GK
1278 || peek == 'D'
1279 || peek == 'L')
bd6946d1
ILT
1280 dc = d_unqualified_name (di);
1281 else if (peek == 'S')
374caa50 1282 dc = d_substitution (di, 1);
bd6946d1
ILT
1283 else if (peek == 'I')
1284 {
1285 if (ret == NULL)
1286 return NULL;
5e777af5 1287 comb_type = DEMANGLE_COMPONENT_TEMPLATE;
bd6946d1
ILT
1288 dc = d_template_args (di);
1289 }
1290 else if (peek == 'T')
1291 dc = d_template_param (di);
1292 else if (peek == 'E')
1293 return ret;
1294 else
1295 return NULL;
1296
1297 if (ret == NULL)
1298 ret = dc;
69afa80d 1299 else
bd6946d1
ILT
1300 ret = d_make_comp (di, comb_type, ret, dc);
1301
1302 if (peek != 'S' && d_peek_char (di) != 'E')
1303 {
1304 if (! d_add_substitution (di, ret))
1305 return NULL;
1306 }
69afa80d
AS
1307 }
1308}
1309
bd6946d1
ILT
1310/* <unqualified-name> ::= <operator-name>
1311 ::= <ctor-dtor-name>
1312 ::= <source-name>
a2aa65f0
GK
1313 ::= <local-source-name>
1314
1315 <local-source-name> ::= L <source-name> <discriminator>
bd6946d1 1316*/
69afa80d 1317
5e777af5 1318static struct demangle_component *
9486db4f 1319d_unqualified_name (struct d_info *di)
69afa80d 1320{
bd6946d1
ILT
1321 char peek;
1322
1323 peek = d_peek_char (di);
1324 if (IS_DIGIT (peek))
1325 return d_source_name (di);
a51753e4 1326 else if (IS_LOWER (peek))
2d6c4025 1327 {
5e777af5 1328 struct demangle_component *ret;
2d6c4025
ILT
1329
1330 ret = d_operator_name (di);
5e777af5 1331 if (ret != NULL && ret->type == DEMANGLE_COMPONENT_OPERATOR)
2d6c4025
ILT
1332 di->expansion += sizeof "operator" + ret->u.s_operator.op->len - 2;
1333 return ret;
1334 }
bd6946d1
ILT
1335 else if (peek == 'C' || peek == 'D')
1336 return d_ctor_dtor_name (di);
a2aa65f0
GK
1337 else if (peek == 'L')
1338 {
1339 struct demangle_component * ret;
1340
1341 d_advance (di, 1);
1342
1343 ret = d_source_name (di);
1344 if (ret == NULL)
1345 return NULL;
1346 if (! d_discriminator (di))
1347 return NULL;
1348 return ret;
1349 }
bd6946d1 1350 else
051664b0 1351 return NULL;
69afa80d
AS
1352}
1353
bd6946d1 1354/* <source-name> ::= <(positive length) number> <identifier> */
69afa80d 1355
5e777af5 1356static struct demangle_component *
9486db4f 1357d_source_name (struct d_info *di)
69afa80d 1358{
bd6946d1 1359 long len;
5e777af5 1360 struct demangle_component *ret;
bd6946d1
ILT
1361
1362 len = d_number (di);
1363 if (len <= 0)
1364 return NULL;
1365 ret = d_identifier (di, len);
1366 di->last_name = ret;
1367 return ret;
69afa80d
AS
1368}
1369
bd6946d1 1370/* number ::= [n] <(non-negative decimal integer)> */
69afa80d 1371
bd6946d1 1372static long
9486db4f 1373d_number (struct d_info *di)
69afa80d 1374{
2d6c4025 1375 int negative;
bd6946d1
ILT
1376 char peek;
1377 long ret;
69afa80d 1378
2d6c4025 1379 negative = 0;
bd6946d1
ILT
1380 peek = d_peek_char (di);
1381 if (peek == 'n')
1382 {
2d6c4025 1383 negative = 1;
bd6946d1
ILT
1384 d_advance (di, 1);
1385 peek = d_peek_char (di);
1386 }
69afa80d 1387
bd6946d1
ILT
1388 ret = 0;
1389 while (1)
69afa80d 1390 {
bd6946d1 1391 if (! IS_DIGIT (peek))
2d6c4025
ILT
1392 {
1393 if (negative)
1394 ret = - ret;
1395 return ret;
1396 }
bd6946d1
ILT
1397 ret = ret * 10 + peek - '0';
1398 d_advance (di, 1);
1399 peek = d_peek_char (di);
69afa80d 1400 }
69afa80d
AS
1401}
1402
bd6946d1 1403/* identifier ::= <(unqualified source code identifier)> */
69afa80d 1404
5e777af5 1405static struct demangle_component *
9486db4f 1406d_identifier (struct d_info *di, int len)
69afa80d 1407{
bd6946d1 1408 const char *name;
69afa80d 1409
bd6946d1 1410 name = d_str (di);
2d6c4025
ILT
1411
1412 if (di->send - name < len)
1413 return NULL;
1414
bd6946d1 1415 d_advance (di, len);
69afa80d 1416
2307e075
ILT
1417 /* A Java mangled name may have a trailing '$' if it is a C++
1418 keyword. This '$' is not included in the length count. We just
1419 ignore the '$'. */
1420 if ((di->options & DMGL_JAVA) != 0
1421 && d_peek_char (di) == '$')
1422 d_advance (di, 1);
1423
bd6946d1
ILT
1424 /* Look for something which looks like a gcc encoding of an
1425 anonymous namespace, and replace it with a more user friendly
1426 name. */
1427 if (len >= (int) ANONYMOUS_NAMESPACE_PREFIX_LEN + 2
1428 && memcmp (name, ANONYMOUS_NAMESPACE_PREFIX,
1429 ANONYMOUS_NAMESPACE_PREFIX_LEN) == 0)
69afa80d 1430 {
bd6946d1
ILT
1431 const char *s;
1432
1433 s = name + ANONYMOUS_NAMESPACE_PREFIX_LEN;
1434 if ((*s == '.' || *s == '_' || *s == '$')
1435 && s[1] == 'N')
2d6c4025
ILT
1436 {
1437 di->expansion -= len - sizeof "(anonymous namespace)";
1438 return d_make_name (di, "(anonymous namespace)",
1439 sizeof "(anonymous namespace)" - 1);
1440 }
69afa80d 1441 }
bd6946d1
ILT
1442
1443 return d_make_name (di, name, len);
69afa80d
AS
1444}
1445
bd6946d1
ILT
1446/* operator_name ::= many different two character encodings.
1447 ::= cv <type>
1448 ::= v <digit> <source-name>
1449*/
69afa80d 1450
2d6c4025
ILT
1451#define NL(s) s, (sizeof s) - 1
1452
5e777af5
ILT
1453CP_STATIC_IF_GLIBCPP_V3
1454const struct demangle_operator_info cplus_demangle_operators[] =
bd6946d1 1455{
2d6c4025
ILT
1456 { "aN", NL ("&="), 2 },
1457 { "aS", NL ("="), 2 },
1458 { "aa", NL ("&&"), 2 },
1459 { "ad", NL ("&"), 1 },
1460 { "an", NL ("&"), 2 },
5a3d7e74 1461 { "cl", NL ("()"), 2 },
2d6c4025
ILT
1462 { "cm", NL (","), 2 },
1463 { "co", NL ("~"), 1 },
1464 { "dV", NL ("/="), 2 },
1465 { "da", NL ("delete[]"), 1 },
1466 { "de", NL ("*"), 1 },
1467 { "dl", NL ("delete"), 1 },
38179091 1468 { "dt", NL ("."), 2 },
2d6c4025
ILT
1469 { "dv", NL ("/"), 2 },
1470 { "eO", NL ("^="), 2 },
1471 { "eo", NL ("^"), 2 },
1472 { "eq", NL ("=="), 2 },
1473 { "ge", NL (">="), 2 },
1474 { "gt", NL (">"), 2 },
1475 { "ix", NL ("[]"), 2 },
1476 { "lS", NL ("<<="), 2 },
1477 { "le", NL ("<="), 2 },
1478 { "ls", NL ("<<"), 2 },
1479 { "lt", NL ("<"), 2 },
1480 { "mI", NL ("-="), 2 },
1481 { "mL", NL ("*="), 2 },
1482 { "mi", NL ("-"), 2 },
1483 { "ml", NL ("*"), 2 },
1484 { "mm", NL ("--"), 1 },
1485 { "na", NL ("new[]"), 1 },
1486 { "ne", NL ("!="), 2 },
1487 { "ng", NL ("-"), 1 },
1488 { "nt", NL ("!"), 1 },
1489 { "nw", NL ("new"), 1 },
1490 { "oR", NL ("|="), 2 },
1491 { "oo", NL ("||"), 2 },
1492 { "or", NL ("|"), 2 },
1493 { "pL", NL ("+="), 2 },
1494 { "pl", NL ("+"), 2 },
1495 { "pm", NL ("->*"), 2 },
1496 { "pp", NL ("++"), 1 },
1497 { "ps", NL ("+"), 1 },
1498 { "pt", NL ("->"), 2 },
1499 { "qu", NL ("?"), 3 },
1500 { "rM", NL ("%="), 2 },
1501 { "rS", NL (">>="), 2 },
1502 { "rm", NL ("%"), 2 },
1503 { "rs", NL (">>"), 2 },
1504 { "st", NL ("sizeof "), 1 },
5e777af5 1505 { "sz", NL ("sizeof "), 1 },
448545cb
JM
1506 { "at", NL ("alignof "), 1 },
1507 { "az", NL ("alignof "), 1 },
5e777af5 1508 { NULL, NULL, 0, 0 }
bd6946d1 1509};
69afa80d 1510
5e777af5 1511static struct demangle_component *
9486db4f 1512d_operator_name (struct d_info *di)
69afa80d 1513{
bd6946d1
ILT
1514 char c1;
1515 char c2;
69afa80d 1516
bd6946d1
ILT
1517 c1 = d_next_char (di);
1518 c2 = d_next_char (di);
1519 if (c1 == 'v' && IS_DIGIT (c2))
1520 return d_make_extended_operator (di, c2 - '0', d_source_name (di));
1521 else if (c1 == 'c' && c2 == 'v')
5e777af5
ILT
1522 return d_make_comp (di, DEMANGLE_COMPONENT_CAST,
1523 cplus_demangle_type (di), NULL);
bd6946d1 1524 else
69afa80d 1525 {
5e777af5 1526 /* LOW is the inclusive lower bound. */
bd6946d1 1527 int low = 0;
5e777af5
ILT
1528 /* HIGH is the exclusive upper bound. We subtract one to ignore
1529 the sentinel at the end of the array. */
1530 int high = ((sizeof (cplus_demangle_operators)
1531 / sizeof (cplus_demangle_operators[0]))
1532 - 1);
69afa80d 1533
bd6946d1
ILT
1534 while (1)
1535 {
1536 int i;
5e777af5 1537 const struct demangle_operator_info *p;
69afa80d 1538
bd6946d1 1539 i = low + (high - low) / 2;
5e777af5 1540 p = cplus_demangle_operators + i;
69afa80d 1541
bd6946d1
ILT
1542 if (c1 == p->code[0] && c2 == p->code[1])
1543 return d_make_operator (di, p);
1544
1545 if (c1 < p->code[0] || (c1 == p->code[0] && c2 < p->code[1]))
1546 high = i;
1547 else
1548 low = i + 1;
1549 if (low == high)
1550 return NULL;
1551 }
1552 }
69afa80d
AS
1553}
1554
e5df4fb1
DD
1555static struct demangle_component *
1556d_make_character (struct d_info *di, int c)
1557{
1558 struct demangle_component *p;
1559 p = d_make_empty (di);
1560 if (p != NULL)
1561 {
1562 p->type = DEMANGLE_COMPONENT_CHARACTER;
1563 p->u.s_character.character = c;
1564 }
1565 return p;
1566}
1567
1568static struct demangle_component *
1569d_java_resource (struct d_info *di)
1570{
1571 struct demangle_component *p = NULL;
1572 struct demangle_component *next = NULL;
1573 long len, i;
1574 char c;
1575 const char *str;
1576
1577 len = d_number (di);
1578 if (len <= 1)
1579 return NULL;
1580
1581 /* Eat the leading '_'. */
1582 if (d_next_char (di) != '_')
1583 return NULL;
1584 len--;
1585
1586 str = d_str (di);
1587 i = 0;
1588
1589 while (len > 0)
1590 {
1591 c = str[i];
1592 if (!c)
1593 return NULL;
1594
1595 /* Each chunk is either a '$' escape... */
1596 if (c == '$')
1597 {
1598 i++;
1599 switch (str[i++])
1600 {
1601 case 'S':
1602 c = '/';
1603 break;
1604 case '_':
1605 c = '.';
1606 break;
1607 case '$':
1608 c = '$';
1609 break;
1610 default:
1611 return NULL;
1612 }
1613 next = d_make_character (di, c);
1614 d_advance (di, i);
1615 str = d_str (di);
1616 len -= i;
1617 i = 0;
1618 if (next == NULL)
1619 return NULL;
1620 }
1621 /* ... or a sequence of characters. */
1622 else
1623 {
1624 while (i < len && str[i] && str[i] != '$')
1625 i++;
1626
1627 next = d_make_name (di, str, i);
1628 d_advance (di, i);
1629 str = d_str (di);
1630 len -= i;
1631 i = 0;
1632 if (next == NULL)
1633 return NULL;
1634 }
1635
1636 if (p == NULL)
1637 p = next;
1638 else
1639 {
1640 p = d_make_comp (di, DEMANGLE_COMPONENT_COMPOUND_NAME, p, next);
1641 if (p == NULL)
1642 return NULL;
1643 }
1644 }
1645
1646 p = d_make_comp (di, DEMANGLE_COMPONENT_JAVA_RESOURCE, p, NULL);
1647
1648 return p;
1649}
1650
bd6946d1
ILT
1651/* <special-name> ::= TV <type>
1652 ::= TT <type>
1653 ::= TI <type>
1654 ::= TS <type>
1655 ::= GV <(object) name>
1656 ::= T <call-offset> <(base) encoding>
1657 ::= Tc <call-offset> <call-offset> <(base) encoding>
1658 Also g++ extensions:
1659 ::= TC <type> <(offset) number> _ <(base) type>
1660 ::= TF <type>
1661 ::= TJ <type>
1662 ::= GR <name>
15da2806 1663 ::= GA <encoding>
e5df4fb1 1664 ::= Gr <resource name>
bd6946d1 1665*/
69afa80d 1666
5e777af5 1667static struct demangle_component *
9486db4f 1668d_special_name (struct d_info *di)
69afa80d 1669{
2d6c4025 1670 di->expansion += 20;
5165f125 1671 if (d_check_char (di, 'T'))
051664b0 1672 {
bd6946d1
ILT
1673 switch (d_next_char (di))
1674 {
1675 case 'V':
2d6c4025 1676 di->expansion -= 5;
5e777af5
ILT
1677 return d_make_comp (di, DEMANGLE_COMPONENT_VTABLE,
1678 cplus_demangle_type (di), NULL);
bd6946d1 1679 case 'T':
2d6c4025 1680 di->expansion -= 10;
5e777af5
ILT
1681 return d_make_comp (di, DEMANGLE_COMPONENT_VTT,
1682 cplus_demangle_type (di), NULL);
bd6946d1 1683 case 'I':
5e777af5
ILT
1684 return d_make_comp (di, DEMANGLE_COMPONENT_TYPEINFO,
1685 cplus_demangle_type (di), NULL);
bd6946d1 1686 case 'S':
5e777af5
ILT
1687 return d_make_comp (di, DEMANGLE_COMPONENT_TYPEINFO_NAME,
1688 cplus_demangle_type (di), NULL);
69afa80d 1689
bd6946d1
ILT
1690 case 'h':
1691 if (! d_call_offset (di, 'h'))
1692 return NULL;
5e777af5
ILT
1693 return d_make_comp (di, DEMANGLE_COMPONENT_THUNK,
1694 d_encoding (di, 0), NULL);
69afa80d 1695
bd6946d1
ILT
1696 case 'v':
1697 if (! d_call_offset (di, 'v'))
1698 return NULL;
5e777af5
ILT
1699 return d_make_comp (di, DEMANGLE_COMPONENT_VIRTUAL_THUNK,
1700 d_encoding (di, 0), NULL);
69afa80d 1701
bd6946d1
ILT
1702 case 'c':
1703 if (! d_call_offset (di, '\0'))
1704 return NULL;
1705 if (! d_call_offset (di, '\0'))
1706 return NULL;
5e777af5
ILT
1707 return d_make_comp (di, DEMANGLE_COMPONENT_COVARIANT_THUNK,
1708 d_encoding (di, 0), NULL);
69afa80d 1709
bd6946d1
ILT
1710 case 'C':
1711 {
5e777af5 1712 struct demangle_component *derived_type;
bd6946d1 1713 long offset;
5e777af5 1714 struct demangle_component *base_type;
bd6946d1 1715
5e777af5 1716 derived_type = cplus_demangle_type (di);
bd6946d1
ILT
1717 offset = d_number (di);
1718 if (offset < 0)
1719 return NULL;
5165f125 1720 if (! d_check_char (di, '_'))
bd6946d1 1721 return NULL;
5e777af5 1722 base_type = cplus_demangle_type (di);
bd6946d1
ILT
1723 /* We don't display the offset. FIXME: We should display
1724 it in verbose mode. */
2d6c4025 1725 di->expansion += 5;
5e777af5
ILT
1726 return d_make_comp (di, DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE,
1727 base_type, derived_type);
bd6946d1 1728 }
69afa80d 1729
bd6946d1 1730 case 'F':
5e777af5
ILT
1731 return d_make_comp (di, DEMANGLE_COMPONENT_TYPEINFO_FN,
1732 cplus_demangle_type (di), NULL);
bd6946d1 1733 case 'J':
5e777af5
ILT
1734 return d_make_comp (di, DEMANGLE_COMPONENT_JAVA_CLASS,
1735 cplus_demangle_type (di), NULL);
69afa80d 1736
bd6946d1
ILT
1737 default:
1738 return NULL;
1739 }
69afa80d 1740 }
5165f125 1741 else if (d_check_char (di, 'G'))
69afa80d 1742 {
bd6946d1
ILT
1743 switch (d_next_char (di))
1744 {
1745 case 'V':
5e777af5 1746 return d_make_comp (di, DEMANGLE_COMPONENT_GUARD, d_name (di), NULL);
bd6946d1
ILT
1747
1748 case 'R':
5e777af5
ILT
1749 return d_make_comp (di, DEMANGLE_COMPONENT_REFTEMP, d_name (di),
1750 NULL);
bd6946d1 1751
15da2806
RH
1752 case 'A':
1753 return d_make_comp (di, DEMANGLE_COMPONENT_HIDDEN_ALIAS,
1754 d_encoding (di, 0), NULL);
1755
e5df4fb1
DD
1756 case 'r':
1757 return d_java_resource (di);
1758
bd6946d1
ILT
1759 default:
1760 return NULL;
1761 }
69afa80d 1762 }
bd6946d1
ILT
1763 else
1764 return NULL;
69afa80d
AS
1765}
1766
bd6946d1
ILT
1767/* <call-offset> ::= h <nv-offset> _
1768 ::= v <v-offset> _
69afa80d 1769
bd6946d1 1770 <nv-offset> ::= <(offset) number>
69afa80d 1771
bd6946d1 1772 <v-offset> ::= <(offset) number> _ <(virtual offset) number>
69afa80d 1773
bd6946d1
ILT
1774 The C parameter, if not '\0', is a character we just read which is
1775 the start of the <call-offset>.
69afa80d 1776
bd6946d1
ILT
1777 We don't display the offset information anywhere. FIXME: We should
1778 display it in verbose mode. */
69afa80d 1779
bd6946d1 1780static int
9486db4f 1781d_call_offset (struct d_info *di, int c)
69afa80d 1782{
bd6946d1
ILT
1783 if (c == '\0')
1784 c = d_next_char (di);
69afa80d 1785
bd6946d1 1786 if (c == 'h')
0b167d51 1787 d_number (di);
bd6946d1 1788 else if (c == 'v')
69afa80d 1789 {
0b167d51 1790 d_number (di);
5165f125 1791 if (! d_check_char (di, '_'))
bd6946d1 1792 return 0;
0b167d51 1793 d_number (di);
69afa80d 1794 }
bd6946d1
ILT
1795 else
1796 return 0;
69afa80d 1797
5165f125 1798 if (! d_check_char (di, '_'))
bd6946d1 1799 return 0;
69afa80d 1800
bd6946d1 1801 return 1;
69afa80d
AS
1802}
1803
bd6946d1
ILT
1804/* <ctor-dtor-name> ::= C1
1805 ::= C2
1806 ::= C3
1807 ::= D0
1808 ::= D1
1809 ::= D2
1810*/
1811
5e777af5 1812static struct demangle_component *
9486db4f 1813d_ctor_dtor_name (struct d_info *di)
bd6946d1 1814{
2d6c4025
ILT
1815 if (di->last_name != NULL)
1816 {
5e777af5 1817 if (di->last_name->type == DEMANGLE_COMPONENT_NAME)
2d6c4025 1818 di->expansion += di->last_name->u.s_name.len;
5e777af5 1819 else if (di->last_name->type == DEMANGLE_COMPONENT_SUB_STD)
2d6c4025
ILT
1820 di->expansion += di->last_name->u.s_string.len;
1821 }
5165f125 1822 switch (d_peek_char (di))
bd6946d1
ILT
1823 {
1824 case 'C':
1825 {
1826 enum gnu_v3_ctor_kinds kind;
1827
5165f125 1828 switch (d_peek_next_char (di))
bd6946d1
ILT
1829 {
1830 case '1':
1831 kind = gnu_v3_complete_object_ctor;
1832 break;
1833 case '2':
1834 kind = gnu_v3_base_object_ctor;
1835 break;
1836 case '3':
1837 kind = gnu_v3_complete_object_allocating_ctor;
1838 break;
1839 default:
1840 return NULL;
1841 }
5165f125 1842 d_advance (di, 2);
bd6946d1
ILT
1843 return d_make_ctor (di, kind, di->last_name);
1844 }
1845
1846 case 'D':
1847 {
1848 enum gnu_v3_dtor_kinds kind;
1849
5165f125 1850 switch (d_peek_next_char (di))
bd6946d1
ILT
1851 {
1852 case '0':
1853 kind = gnu_v3_deleting_dtor;
1854 break;
1855 case '1':
1856 kind = gnu_v3_complete_object_dtor;
1857 break;
1858 case '2':
1859 kind = gnu_v3_base_object_dtor;
1860 break;
1861 default:
1862 return NULL;
1863 }
5165f125 1864 d_advance (di, 2);
bd6946d1
ILT
1865 return d_make_dtor (di, kind, di->last_name);
1866 }
69afa80d 1867
bd6946d1
ILT
1868 default:
1869 return NULL;
1870 }
1871}
69afa80d 1872
bd6946d1
ILT
1873/* <type> ::= <builtin-type>
1874 ::= <function-type>
1875 ::= <class-enum-type>
1876 ::= <array-type>
1877 ::= <pointer-to-member-type>
1878 ::= <template-param>
1879 ::= <template-template-param> <template-args>
1880 ::= <substitution>
1881 ::= <CV-qualifiers> <type>
1882 ::= P <type>
1883 ::= R <type>
1ab28be5 1884 ::= O <type> (C++0x)
bd6946d1
ILT
1885 ::= C <type>
1886 ::= G <type>
1887 ::= U <source-name> <type>
1888
1889 <builtin-type> ::= various one letter codes
1890 ::= u <source-name>
1891*/
69afa80d 1892
5e777af5
ILT
1893CP_STATIC_IF_GLIBCPP_V3
1894const struct demangle_builtin_type_info
1895cplus_demangle_builtin_types[D_BUILTIN_TYPE_COUNT] =
bd6946d1 1896{
31058ee3 1897 /* a */ { NL ("signed char"), NL ("signed char"), D_PRINT_DEFAULT },
2d6c4025 1898 /* b */ { NL ("bool"), NL ("boolean"), D_PRINT_BOOL },
31058ee3
ILT
1899 /* c */ { NL ("char"), NL ("byte"), D_PRINT_DEFAULT },
1900 /* d */ { NL ("double"), NL ("double"), D_PRINT_FLOAT },
1901 /* e */ { NL ("long double"), NL ("long double"), D_PRINT_FLOAT },
1902 /* f */ { NL ("float"), NL ("float"), D_PRINT_FLOAT },
1903 /* g */ { NL ("__float128"), NL ("__float128"), D_PRINT_FLOAT },
1904 /* h */ { NL ("unsigned char"), NL ("unsigned char"), D_PRINT_DEFAULT },
2d6c4025 1905 /* i */ { NL ("int"), NL ("int"), D_PRINT_INT },
31058ee3 1906 /* j */ { NL ("unsigned int"), NL ("unsigned"), D_PRINT_UNSIGNED },
2d6c4025
ILT
1907 /* k */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
1908 /* l */ { NL ("long"), NL ("long"), D_PRINT_LONG },
31058ee3 1909 /* m */ { NL ("unsigned long"), NL ("unsigned long"), D_PRINT_UNSIGNED_LONG },
2d6c4025 1910 /* n */ { NL ("__int128"), NL ("__int128"), D_PRINT_DEFAULT },
31058ee3
ILT
1911 /* o */ { NL ("unsigned __int128"), NL ("unsigned __int128"),
1912 D_PRINT_DEFAULT },
38179091
JM
1913 /* p */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
1914 /* q */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
1915 /* r */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
31058ee3
ILT
1916 /* s */ { NL ("short"), NL ("short"), D_PRINT_DEFAULT },
1917 /* t */ { NL ("unsigned short"), NL ("unsigned short"), D_PRINT_DEFAULT },
38179091 1918 /* u */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
2d6c4025 1919 /* v */ { NL ("void"), NL ("void"), D_PRINT_VOID },
31058ee3
ILT
1920 /* w */ { NL ("wchar_t"), NL ("char"), D_PRINT_DEFAULT },
1921 /* x */ { NL ("long long"), NL ("long"), D_PRINT_LONG_LONG },
1922 /* y */ { NL ("unsigned long long"), NL ("unsigned long long"),
1923 D_PRINT_UNSIGNED_LONG_LONG },
2d6c4025 1924 /* z */ { NL ("..."), NL ("..."), D_PRINT_DEFAULT },
38179091
JM
1925 /* 26 */ { NL ("decimal32"), NL ("decimal32"), D_PRINT_DEFAULT },
1926 /* 27 */ { NL ("decimal64"), NL ("decimal64"), D_PRINT_DEFAULT },
1927 /* 28 */ { NL ("decimal128"), NL ("decimal128"), D_PRINT_DEFAULT },
1928 /* 29 */ { NL ("half"), NL ("half"), D_PRINT_FLOAT },
1929 /* 30 */ { NL ("char16_t"), NL ("char16_t"), D_PRINT_DEFAULT },
1930 /* 31 */ { NL ("char32_t"), NL ("char32_t"), D_PRINT_DEFAULT },
bd6946d1 1931};
69afa80d 1932
5e777af5
ILT
1933CP_STATIC_IF_GLIBCPP_V3
1934struct demangle_component *
9486db4f 1935cplus_demangle_type (struct d_info *di)
69afa80d 1936{
bd6946d1 1937 char peek;
5e777af5 1938 struct demangle_component *ret;
bd6946d1
ILT
1939 int can_subst;
1940
1941 /* The ABI specifies that when CV-qualifiers are used, the base type
1942 is substitutable, and the fully qualified type is substitutable,
1943 but the base type with a strict subset of the CV-qualifiers is
1944 not substitutable. The natural recursive implementation of the
1945 CV-qualifiers would cause subsets to be substitutable, so instead
1946 we pull them all off now.
1947
81dc098b
ILT
1948 FIXME: The ABI says that order-insensitive vendor qualifiers
1949 should be handled in the same way, but we have no way to tell
1950 which vendor qualifiers are order-insensitive and which are
1951 order-sensitive. So we just assume that they are all
1952 order-sensitive. g++ 3.4 supports only one vendor qualifier,
1953 __vector, and it treats it as order-sensitive when mangling
1954 names. */
bd6946d1
ILT
1955
1956 peek = d_peek_char (di);
1957 if (peek == 'r' || peek == 'V' || peek == 'K')
1958 {
5e777af5 1959 struct demangle_component **pret;
69afa80d 1960
a51753e4 1961 pret = d_cv_qualifiers (di, &ret, 0);
81dc098b
ILT
1962 if (pret == NULL)
1963 return NULL;
5e777af5 1964 *pret = cplus_demangle_type (di);
771904f1 1965 if (! *pret || ! d_add_substitution (di, ret))
bd6946d1
ILT
1966 return NULL;
1967 return ret;
1968 }
1056d228 1969
bd6946d1 1970 can_subst = 1;
69afa80d 1971
a440fd19 1972 switch (peek)
69afa80d 1973 {
bd6946d1
ILT
1974 case 'a': case 'b': case 'c': case 'd': case 'e': case 'f': case 'g':
1975 case 'h': case 'i': case 'j': case 'l': case 'm': case 'n':
1976 case 'o': case 's': case 't':
1977 case 'v': case 'w': case 'x': case 'y': case 'z':
5e777af5
ILT
1978 ret = d_make_builtin_type (di,
1979 &cplus_demangle_builtin_types[peek - 'a']);
2d6c4025 1980 di->expansion += ret->u.s_builtin.type->len;
bd6946d1
ILT
1981 can_subst = 0;
1982 d_advance (di, 1);
1983 break;
1984
1985 case 'u':
1986 d_advance (di, 1);
5e777af5
ILT
1987 ret = d_make_comp (di, DEMANGLE_COMPONENT_VENDOR_TYPE,
1988 d_source_name (di), NULL);
bd6946d1
ILT
1989 break;
1990
1991 case 'F':
1992 ret = d_function_type (di);
69afa80d
AS
1993 break;
1994
bd6946d1
ILT
1995 case '0': case '1': case '2': case '3': case '4':
1996 case '5': case '6': case '7': case '8': case '9':
1997 case 'N':
69afa80d 1998 case 'Z':
bd6946d1 1999 ret = d_class_enum_type (di);
69afa80d
AS
2000 break;
2001
bd6946d1
ILT
2002 case 'A':
2003 ret = d_array_type (di);
2004 break;
2005
2006 case 'M':
2007 ret = d_pointer_to_member_type (di);
2008 break;
2009
2010 case 'T':
2011 ret = d_template_param (di);
2012 if (d_peek_char (di) == 'I')
bece74bd 2013 {
bd6946d1
ILT
2014 /* This is <template-template-param> <template-args>. The
2015 <template-template-param> part is a substitution
2016 candidate. */
2017 if (! d_add_substitution (di, ret))
2018 return NULL;
5e777af5
ILT
2019 ret = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, ret,
2020 d_template_args (di));
bece74bd 2021 }
bd6946d1
ILT
2022 break;
2023
2024 case 'S':
2025 /* If this is a special substitution, then it is the start of
2026 <class-enum-type>. */
2027 {
2028 char peek_next;
d01ce591 2029
bd6946d1
ILT
2030 peek_next = d_peek_next_char (di);
2031 if (IS_DIGIT (peek_next)
2032 || peek_next == '_'
a51753e4 2033 || IS_UPPER (peek_next))
bd6946d1 2034 {
374caa50 2035 ret = d_substitution (di, 0);
bd6946d1
ILT
2036 /* The substituted name may have been a template name and
2037 may be followed by tepmlate args. */
2038 if (d_peek_char (di) == 'I')
5e777af5 2039 ret = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, ret,
bd6946d1
ILT
2040 d_template_args (di));
2041 else
2042 can_subst = 0;
2043 }
2044 else
2045 {
2046 ret = d_class_enum_type (di);
2047 /* If the substitution was a complete type, then it is not
2048 a new substitution candidate. However, if the
2049 substitution was followed by template arguments, then
2050 the whole thing is a substitution candidate. */
5e777af5 2051 if (ret != NULL && ret->type == DEMANGLE_COMPONENT_SUB_STD)
bd6946d1
ILT
2052 can_subst = 0;
2053 }
2054 }
69afa80d
AS
2055 break;
2056
1ab28be5
DG
2057 case 'O':
2058 d_advance (di, 1);
2059 ret = d_make_comp (di, DEMANGLE_COMPONENT_RVALUE_REFERENCE,
2060 cplus_demangle_type (di), NULL);
2061 break;
2062
bd6946d1
ILT
2063 case 'P':
2064 d_advance (di, 1);
5e777af5
ILT
2065 ret = d_make_comp (di, DEMANGLE_COMPONENT_POINTER,
2066 cplus_demangle_type (di), NULL);
bd6946d1 2067 break;
69afa80d 2068
bd6946d1
ILT
2069 case 'R':
2070 d_advance (di, 1);
5e777af5 2071 ret = d_make_comp (di, DEMANGLE_COMPONENT_REFERENCE,
1ab28be5 2072 cplus_demangle_type (di), NULL);
bd6946d1 2073 break;
69afa80d 2074
bd6946d1
ILT
2075 case 'C':
2076 d_advance (di, 1);
5e777af5
ILT
2077 ret = d_make_comp (di, DEMANGLE_COMPONENT_COMPLEX,
2078 cplus_demangle_type (di), NULL);
bd6946d1
ILT
2079 break;
2080
2081 case 'G':
2082 d_advance (di, 1);
5e777af5
ILT
2083 ret = d_make_comp (di, DEMANGLE_COMPONENT_IMAGINARY,
2084 cplus_demangle_type (di), NULL);
bd6946d1 2085 break;
69afa80d 2086
bd6946d1
ILT
2087 case 'U':
2088 d_advance (di, 1);
2089 ret = d_source_name (di);
5e777af5
ILT
2090 ret = d_make_comp (di, DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL,
2091 cplus_demangle_type (di), ret);
69afa80d 2092 break;
bd6946d1 2093
5a3d7e74
JM
2094 case 'D':
2095 can_subst = 0;
2096 d_advance (di, 1);
2097 peek = d_next_char (di);
2098 switch (peek)
2099 {
2100 case 'T':
2101 case 't':
2102 /* decltype (expression) */
2103 ret = d_make_comp (di, DEMANGLE_COMPONENT_DECLTYPE,
2104 d_expression (di), NULL);
2105 if (ret && d_next_char (di) != 'E')
2106 ret = NULL;
2107 break;
2108
2109 case 'p':
2110 /* Pack expansion. */
38179091
JM
2111 ret = d_make_comp (di, DEMANGLE_COMPONENT_PACK_EXPANSION,
2112 cplus_demangle_type (di), NULL);
2113 break;
5a3d7e74
JM
2114
2115 case 'f':
38179091
JM
2116 /* 32-bit decimal floating point */
2117 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[26]);
5a3d7e74
JM
2118 di->expansion += ret->u.s_builtin.type->len;
2119 break;
2120 case 'd':
38179091
JM
2121 /* 64-bit DFP */
2122 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[27]);
5a3d7e74
JM
2123 di->expansion += ret->u.s_builtin.type->len;
2124 break;
2125 case 'e':
2126 /* 128-bit DFP */
38179091 2127 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[28]);
5a3d7e74
JM
2128 di->expansion += ret->u.s_builtin.type->len;
2129 break;
2130 case 'h':
2131 /* 16-bit half-precision FP */
38179091
JM
2132 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[29]);
2133 di->expansion += ret->u.s_builtin.type->len;
2134 break;
2135 case 's':
2136 /* char16_t */
2137 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[30]);
2138 di->expansion += ret->u.s_builtin.type->len;
2139 break;
2140 case 'i':
2141 /* char32_t */
2142 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[31]);
5a3d7e74
JM
2143 di->expansion += ret->u.s_builtin.type->len;
2144 break;
07523e7c
JM
2145
2146 case 'F':
2147 /* Fixed point types. DF<int bits><length><fract bits><sat> */
2148 ret = d_make_empty (di);
2149 ret->type = DEMANGLE_COMPONENT_FIXED_TYPE;
2150 if ((ret->u.s_fixed.accum = IS_DIGIT (d_peek_char (di))))
2151 /* For demangling we don't care about the bits. */
2152 d_number (di);
2153 ret->u.s_fixed.length = cplus_demangle_type (di);
2154 d_number (di);
2155 peek = d_next_char (di);
2156 ret->u.s_fixed.sat = (peek == 's');
2157 break;
381009fe
BE
2158
2159 default:
2160 return NULL;
5a3d7e74
JM
2161 }
2162 break;
2163
bd6946d1
ILT
2164 default:
2165 return NULL;
69afa80d
AS
2166 }
2167
bd6946d1
ILT
2168 if (can_subst)
2169 {
2170 if (! d_add_substitution (di, ret))
2171 return NULL;
2172 }
69afa80d 2173
bd6946d1
ILT
2174 return ret;
2175}
69afa80d 2176
bd6946d1 2177/* <CV-qualifiers> ::= [r] [V] [K] */
69afa80d 2178
5e777af5 2179static struct demangle_component **
9486db4f
GDR
2180d_cv_qualifiers (struct d_info *di,
2181 struct demangle_component **pret, int member_fn)
69afa80d
AS
2182{
2183 char peek;
2184
bd6946d1
ILT
2185 peek = d_peek_char (di);
2186 while (peek == 'r' || peek == 'V' || peek == 'K')
69afa80d 2187 {
5e777af5 2188 enum demangle_component_type t;
0870bfd6 2189
bd6946d1
ILT
2190 d_advance (di, 1);
2191 if (peek == 'r')
2d6c4025 2192 {
5e777af5
ILT
2193 t = (member_fn
2194 ? DEMANGLE_COMPONENT_RESTRICT_THIS
2195 : DEMANGLE_COMPONENT_RESTRICT);
2d6c4025
ILT
2196 di->expansion += sizeof "restrict";
2197 }
bd6946d1 2198 else if (peek == 'V')
2d6c4025 2199 {
5e777af5
ILT
2200 t = (member_fn
2201 ? DEMANGLE_COMPONENT_VOLATILE_THIS
2202 : DEMANGLE_COMPONENT_VOLATILE);
2d6c4025
ILT
2203 di->expansion += sizeof "volatile";
2204 }
bd6946d1 2205 else
2d6c4025 2206 {
5e777af5
ILT
2207 t = (member_fn
2208 ? DEMANGLE_COMPONENT_CONST_THIS
2209 : DEMANGLE_COMPONENT_CONST);
2d6c4025
ILT
2210 di->expansion += sizeof "const";
2211 }
69afa80d 2212
bd6946d1
ILT
2213 *pret = d_make_comp (di, t, NULL, NULL);
2214 if (*pret == NULL)
2215 return NULL;
2216 pret = &d_left (*pret);
69afa80d 2217
bd6946d1
ILT
2218 peek = d_peek_char (di);
2219 }
69afa80d 2220
bd6946d1
ILT
2221 return pret;
2222}
69afa80d 2223
bd6946d1 2224/* <function-type> ::= F [Y] <bare-function-type> E */
69afa80d 2225
5e777af5 2226static struct demangle_component *
9486db4f 2227d_function_type (struct d_info *di)
69afa80d 2228{
5e777af5 2229 struct demangle_component *ret;
69afa80d 2230
5165f125 2231 if (! d_check_char (di, 'F'))
bd6946d1
ILT
2232 return NULL;
2233 if (d_peek_char (di) == 'Y')
2234 {
2235 /* Function has C linkage. We don't print this information.
2236 FIXME: We should print it in verbose mode. */
2237 d_advance (di, 1);
2238 }
2239 ret = d_bare_function_type (di, 1);
5165f125 2240 if (! d_check_char (di, 'E'))
bd6946d1
ILT
2241 return NULL;
2242 return ret;
2243}
e282c9c9 2244
92aed1cb 2245/* <bare-function-type> ::= [J]<type>+ */
69afa80d 2246
5e777af5 2247static struct demangle_component *
9486db4f 2248d_bare_function_type (struct d_info *di, int has_return_type)
bd6946d1 2249{
5e777af5
ILT
2250 struct demangle_component *return_type;
2251 struct demangle_component *tl;
2252 struct demangle_component **ptl;
92aed1cb
TL
2253 char peek;
2254
2255 /* Detect special qualifier indicating that the first argument
2256 is the return type. */
2257 peek = d_peek_char (di);
2258 if (peek == 'J')
2259 {
2260 d_advance (di, 1);
2261 has_return_type = 1;
2262 }
69afa80d 2263
bd6946d1
ILT
2264 return_type = NULL;
2265 tl = NULL;
2266 ptl = &tl;
69afa80d
AS
2267 while (1)
2268 {
5e777af5 2269 struct demangle_component *type;
69afa80d 2270
bd6946d1
ILT
2271 peek = d_peek_char (di);
2272 if (peek == '\0' || peek == 'E')
2273 break;
5e777af5 2274 type = cplus_demangle_type (di);
bd6946d1
ILT
2275 if (type == NULL)
2276 return NULL;
2277 if (has_return_type)
69afa80d 2278 {
bd6946d1
ILT
2279 return_type = type;
2280 has_return_type = 0;
69afa80d 2281 }
bd6946d1 2282 else
69afa80d 2283 {
5e777af5 2284 *ptl = d_make_comp (di, DEMANGLE_COMPONENT_ARGLIST, type, NULL);
81dc098b
ILT
2285 if (*ptl == NULL)
2286 return NULL;
bd6946d1 2287 ptl = &d_right (*ptl);
69afa80d 2288 }
69afa80d 2289 }
69afa80d 2290
bd6946d1
ILT
2291 /* There should be at least one parameter type besides the optional
2292 return type. A function which takes no arguments will have a
2293 single parameter type void. */
2294 if (tl == NULL)
2295 return NULL;
69afa80d 2296
bd6946d1
ILT
2297 /* If we have a single parameter type void, omit it. */
2298 if (d_right (tl) == NULL
5e777af5 2299 && d_left (tl)->type == DEMANGLE_COMPONENT_BUILTIN_TYPE
bd6946d1 2300 && d_left (tl)->u.s_builtin.type->print == D_PRINT_VOID)
2d6c4025
ILT
2301 {
2302 di->expansion -= d_left (tl)->u.s_builtin.type->len;
2303 tl = NULL;
2304 }
69afa80d 2305
5e777af5 2306 return d_make_comp (di, DEMANGLE_COMPONENT_FUNCTION_TYPE, return_type, tl);
bd6946d1 2307}
69afa80d 2308
bd6946d1 2309/* <class-enum-type> ::= <name> */
69afa80d 2310
5e777af5 2311static struct demangle_component *
9486db4f 2312d_class_enum_type (struct d_info *di)
bd6946d1
ILT
2313{
2314 return d_name (di);
2315}
1056d228 2316
bd6946d1
ILT
2317/* <array-type> ::= A <(positive dimension) number> _ <(element) type>
2318 ::= A [<(dimension) expression>] _ <(element) type>
2319*/
1056d228 2320
5e777af5 2321static struct demangle_component *
9486db4f 2322d_array_type (struct d_info *di)
bd6946d1
ILT
2323{
2324 char peek;
5e777af5 2325 struct demangle_component *dim;
1056d228 2326
5165f125 2327 if (! d_check_char (di, 'A'))
bd6946d1
ILT
2328 return NULL;
2329
2330 peek = d_peek_char (di);
2331 if (peek == '_')
2332 dim = NULL;
2333 else if (IS_DIGIT (peek))
1056d228 2334 {
bd6946d1 2335 const char *s;
1056d228 2336
bd6946d1
ILT
2337 s = d_str (di);
2338 do
2339 {
2340 d_advance (di, 1);
2341 peek = d_peek_char (di);
2342 }
2343 while (IS_DIGIT (peek));
2344 dim = d_make_name (di, s, d_str (di) - s);
81dc098b
ILT
2345 if (dim == NULL)
2346 return NULL;
1056d228 2347 }
69afa80d 2348 else
bd6946d1
ILT
2349 {
2350 dim = d_expression (di);
2351 if (dim == NULL)
2352 return NULL;
2353 }
69afa80d 2354
5165f125 2355 if (! d_check_char (di, '_'))
bd6946d1 2356 return NULL;
69afa80d 2357
5e777af5
ILT
2358 return d_make_comp (di, DEMANGLE_COMPONENT_ARRAY_TYPE, dim,
2359 cplus_demangle_type (di));
bd6946d1 2360}
69afa80d 2361
bd6946d1 2362/* <pointer-to-member-type> ::= M <(class) type> <(member) type> */
69afa80d 2363
5e777af5 2364static struct demangle_component *
9486db4f 2365d_pointer_to_member_type (struct d_info *di)
69afa80d 2366{
5e777af5
ILT
2367 struct demangle_component *cl;
2368 struct demangle_component *mem;
2369 struct demangle_component **pmem;
69afa80d 2370
5165f125 2371 if (! d_check_char (di, 'M'))
bd6946d1 2372 return NULL;
69afa80d 2373
5e777af5 2374 cl = cplus_demangle_type (di);
69afa80d 2375
bd6946d1
ILT
2376 /* The ABI specifies that any type can be a substitution source, and
2377 that M is followed by two types, and that when a CV-qualified
2378 type is seen both the base type and the CV-qualified types are
2379 substitution sources. The ABI also specifies that for a pointer
2380 to a CV-qualified member function, the qualifiers are attached to
2381 the second type. Given the grammar, a plain reading of the ABI
2382 suggests that both the CV-qualified member function and the
2383 non-qualified member function are substitution sources. However,
2384 g++ does not work that way. g++ treats only the CV-qualified
2385 member function as a substitution source. FIXME. So to work
2386 with g++, we need to pull off the CV-qualifiers here, in order to
022d4166
ILT
2387 avoid calling add_substitution() in cplus_demangle_type(). But
2388 for a CV-qualified member which is not a function, g++ does
2389 follow the ABI, so we need to handle that case here by calling
2390 d_add_substitution ourselves. */
69afa80d 2391
a51753e4 2392 pmem = d_cv_qualifiers (di, &mem, 1);
81dc098b
ILT
2393 if (pmem == NULL)
2394 return NULL;
5e777af5 2395 *pmem = cplus_demangle_type (di);
771904f1
GK
2396 if (*pmem == NULL)
2397 return NULL;
69afa80d 2398
022d4166
ILT
2399 if (pmem != &mem && (*pmem)->type != DEMANGLE_COMPONENT_FUNCTION_TYPE)
2400 {
2401 if (! d_add_substitution (di, mem))
2402 return NULL;
2403 }
2404
5e777af5 2405 return d_make_comp (di, DEMANGLE_COMPONENT_PTRMEM_TYPE, cl, mem);
69afa80d
AS
2406}
2407
bd6946d1
ILT
2408/* <template-param> ::= T_
2409 ::= T <(parameter-2 non-negative) number> _
2410*/
69afa80d 2411
5e777af5 2412static struct demangle_component *
9486db4f 2413d_template_param (struct d_info *di)
69afa80d 2414{
bd6946d1 2415 long param;
69afa80d 2416
5165f125 2417 if (! d_check_char (di, 'T'))
bd6946d1 2418 return NULL;
69afa80d 2419
bd6946d1
ILT
2420 if (d_peek_char (di) == '_')
2421 param = 0;
2422 else
2423 {
2424 param = d_number (di);
2425 if (param < 0)
2426 return NULL;
2427 param += 1;
2428 }
051664b0 2429
5165f125 2430 if (! d_check_char (di, '_'))
bd6946d1 2431 return NULL;
69afa80d 2432
2d6c4025
ILT
2433 ++di->did_subs;
2434
bd6946d1 2435 return d_make_template_param (di, param);
69afa80d
AS
2436}
2437
bd6946d1
ILT
2438/* <template-args> ::= I <template-arg>+ E */
2439
5e777af5 2440static struct demangle_component *
9486db4f 2441d_template_args (struct d_info *di)
69afa80d 2442{
5e777af5
ILT
2443 struct demangle_component *hold_last_name;
2444 struct demangle_component *al;
2445 struct demangle_component **pal;
69afa80d 2446
bd6946d1
ILT
2447 /* Preserve the last name we saw--don't let the template arguments
2448 clobber it, as that would give us the wrong name for a subsequent
2449 constructor or destructor. */
2450 hold_last_name = di->last_name;
69afa80d 2451
5165f125 2452 if (! d_check_char (di, 'I'))
bd6946d1 2453 return NULL;
69afa80d 2454
38179091
JM
2455 if (d_peek_char (di) == 'E')
2456 {
2457 /* An argument pack can be empty. */
2458 d_advance (di, 1);
2459 return d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE_ARGLIST, NULL, NULL);
2460 }
2461
bd6946d1
ILT
2462 al = NULL;
2463 pal = &al;
69afa80d
AS
2464 while (1)
2465 {
5e777af5 2466 struct demangle_component *a;
bd6946d1
ILT
2467
2468 a = d_template_arg (di);
2469 if (a == NULL)
2470 return NULL;
2471
5e777af5 2472 *pal = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE_ARGLIST, a, NULL);
81dc098b
ILT
2473 if (*pal == NULL)
2474 return NULL;
bd6946d1
ILT
2475 pal = &d_right (*pal);
2476
2477 if (d_peek_char (di) == 'E')
051664b0 2478 {
bd6946d1
ILT
2479 d_advance (di, 1);
2480 break;
051664b0 2481 }
69afa80d
AS
2482 }
2483
bd6946d1
ILT
2484 di->last_name = hold_last_name;
2485
2486 return al;
69afa80d
AS
2487}
2488
bd6946d1
ILT
2489/* <template-arg> ::= <type>
2490 ::= X <expression> E
2491 ::= <expr-primary>
2492*/
69afa80d 2493
5e777af5 2494static struct demangle_component *
9486db4f 2495d_template_arg (struct d_info *di)
69afa80d 2496{
5e777af5 2497 struct demangle_component *ret;
051664b0 2498
bd6946d1 2499 switch (d_peek_char (di))
69afa80d 2500 {
bd6946d1
ILT
2501 case 'X':
2502 d_advance (di, 1);
2503 ret = d_expression (di);
5165f125 2504 if (! d_check_char (di, 'E'))
bd6946d1
ILT
2505 return NULL;
2506 return ret;
28a34ec1 2507
bd6946d1
ILT
2508 case 'L':
2509 return d_expr_primary (di);
69afa80d 2510
38179091
JM
2511 case 'I':
2512 /* An argument pack. */
2513 return d_template_args (di);
2514
bd6946d1 2515 default:
5e777af5 2516 return cplus_demangle_type (di);
31e0ab1f 2517 }
69afa80d
AS
2518}
2519
5a3d7e74
JM
2520/* Subroutine of <expression> ::= cl <expression>+ E */
2521
2522static struct demangle_component *
2523d_exprlist (struct d_info *di)
2524{
2525 struct demangle_component *list = NULL;
2526 struct demangle_component **p = &list;
2527
38179091
JM
2528 if (d_peek_char (di) == 'E')
2529 {
2530 d_advance (di, 1);
2531 return d_make_comp (di, DEMANGLE_COMPONENT_ARGLIST, NULL, NULL);
2532 }
2533
5a3d7e74
JM
2534 while (1)
2535 {
2536 struct demangle_component *arg = d_expression (di);
2537 if (arg == NULL)
2538 return NULL;
2539
2540 *p = d_make_comp (di, DEMANGLE_COMPONENT_ARGLIST, arg, NULL);
2541 if (*p == NULL)
2542 return NULL;
2543 p = &d_right (*p);
2544
2545 if (d_peek_char (di) == 'E')
2546 {
2547 d_advance (di, 1);
2548 break;
2549 }
2550 }
2551
2552 return list;
2553}
2554
bd6946d1
ILT
2555/* <expression> ::= <(unary) operator-name> <expression>
2556 ::= <(binary) operator-name> <expression> <expression>
2557 ::= <(trinary) operator-name> <expression> <expression> <expression>
5a3d7e74 2558 ::= cl <expression>+ E
bd6946d1
ILT
2559 ::= st <type>
2560 ::= <template-param>
2561 ::= sr <type> <unqualified-name>
2562 ::= sr <type> <unqualified-name> <template-args>
2563 ::= <expr-primary>
2564*/
2565
5e777af5 2566static struct demangle_component *
9486db4f 2567d_expression (struct d_info *di)
69afa80d 2568{
bd6946d1 2569 char peek;
69afa80d 2570
bd6946d1
ILT
2571 peek = d_peek_char (di);
2572 if (peek == 'L')
2573 return d_expr_primary (di);
2574 else if (peek == 'T')
2575 return d_template_param (di);
2576 else if (peek == 's' && d_peek_next_char (di) == 'r')
69afa80d 2577 {
5e777af5
ILT
2578 struct demangle_component *type;
2579 struct demangle_component *name;
69afa80d 2580
bd6946d1 2581 d_advance (di, 2);
5e777af5 2582 type = cplus_demangle_type (di);
bd6946d1
ILT
2583 name = d_unqualified_name (di);
2584 if (d_peek_char (di) != 'I')
5e777af5 2585 return d_make_comp (di, DEMANGLE_COMPONENT_QUAL_NAME, type, name);
bd6946d1 2586 else
5e777af5
ILT
2587 return d_make_comp (di, DEMANGLE_COMPONENT_QUAL_NAME, type,
2588 d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, name,
bd6946d1 2589 d_template_args (di)));
5d69ba1f 2590 }
6afcfe0a
JM
2591 else if (peek == 's' && d_peek_next_char (di) == 'p')
2592 {
2593 d_advance (di, 2);
2594 return d_make_comp (di, DEMANGLE_COMPONENT_PACK_EXPANSION,
2595 d_expression (di), NULL);
2596 }
448545cb 2597 else if (peek == 'f' && d_peek_next_char (di) == 'p')
5a3d7e74 2598 {
448545cb
JM
2599 /* Function parameter used in a late-specified return type. */
2600 int index;
5a3d7e74 2601 d_advance (di, 2);
448545cb
JM
2602 if (d_peek_char (di) == '_')
2603 index = 1;
2604 else
2605 {
2606 index = d_number (di);
2607 if (index < 0)
2608 return NULL;
2609 index += 2;
2610 }
2611
2612 if (! d_check_char (di, '_'))
2613 return NULL;
2614
2615 return d_make_function_param (di, index);
5a3d7e74 2616 }
38179091
JM
2617 else if (IS_DIGIT (peek))
2618 {
2619 /* We can get an unqualified name as an expression in the case of
2620 a dependent member access, i.e. decltype(T().i). */
2621 struct demangle_component *name = d_unqualified_name (di);
2622 if (name == NULL)
2623 return NULL;
2624 if (d_peek_char (di) == 'I')
2625 return d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, name,
2626 d_template_args (di));
2627 else
2628 return name;
2629 }
bd6946d1 2630 else
69afa80d 2631 {
5e777af5 2632 struct demangle_component *op;
bd6946d1 2633 int args;
69afa80d 2634
bd6946d1
ILT
2635 op = d_operator_name (di);
2636 if (op == NULL)
2637 return NULL;
69afa80d 2638
5e777af5 2639 if (op->type == DEMANGLE_COMPONENT_OPERATOR)
2d6c4025
ILT
2640 di->expansion += op->u.s_operator.op->len - 2;
2641
5e777af5 2642 if (op->type == DEMANGLE_COMPONENT_OPERATOR
bd6946d1 2643 && strcmp (op->u.s_operator.op->code, "st") == 0)
5e777af5
ILT
2644 return d_make_comp (di, DEMANGLE_COMPONENT_UNARY, op,
2645 cplus_demangle_type (di));
69afa80d 2646
bd6946d1
ILT
2647 switch (op->type)
2648 {
2649 default:
2650 return NULL;
5e777af5 2651 case DEMANGLE_COMPONENT_OPERATOR:
bd6946d1
ILT
2652 args = op->u.s_operator.op->args;
2653 break;
5e777af5 2654 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
bd6946d1
ILT
2655 args = op->u.s_extended_operator.args;
2656 break;
5e777af5 2657 case DEMANGLE_COMPONENT_CAST:
30471e01 2658 args = 1;
bd6946d1
ILT
2659 break;
2660 }
2661
2662 switch (args)
2663 {
2664 case 1:
448545cb
JM
2665 {
2666 struct demangle_component *operand;
2667 if (op->type == DEMANGLE_COMPONENT_CAST
2668 && d_check_char (di, '_'))
2669 operand = d_exprlist (di);
2670 else
2671 operand = d_expression (di);
2672 return d_make_comp (di, DEMANGLE_COMPONENT_UNARY, op,
2673 operand);
2674 }
bd6946d1
ILT
2675 case 2:
2676 {
5e777af5 2677 struct demangle_component *left;
5a3d7e74 2678 struct demangle_component *right;
bd6946d1
ILT
2679
2680 left = d_expression (di);
5a3d7e74
JM
2681 if (!strcmp (op->u.s_operator.op->code, "cl"))
2682 right = d_exprlist (di);
2683 else
2684 right = d_expression (di);
2685
5e777af5
ILT
2686 return d_make_comp (di, DEMANGLE_COMPONENT_BINARY, op,
2687 d_make_comp (di,
2688 DEMANGLE_COMPONENT_BINARY_ARGS,
5a3d7e74 2689 left, right));
bd6946d1
ILT
2690 }
2691 case 3:
2692 {
5e777af5
ILT
2693 struct demangle_component *first;
2694 struct demangle_component *second;
bd6946d1
ILT
2695
2696 first = d_expression (di);
2697 second = d_expression (di);
5e777af5
ILT
2698 return d_make_comp (di, DEMANGLE_COMPONENT_TRINARY, op,
2699 d_make_comp (di,
2700 DEMANGLE_COMPONENT_TRINARY_ARG1,
2701 first,
bd6946d1 2702 d_make_comp (di,
5e777af5 2703 DEMANGLE_COMPONENT_TRINARY_ARG2,
bd6946d1
ILT
2704 second,
2705 d_expression (di))));
2706 }
2707 default:
2708 return NULL;
2709 }
69afa80d
AS
2710 }
2711}
2712
bd6946d1
ILT
2713/* <expr-primary> ::= L <type> <(value) number> E
2714 ::= L <type> <(value) float> E
2715 ::= L <mangled-name> E
2716*/
92a16bbe 2717
5e777af5 2718static struct demangle_component *
9486db4f 2719d_expr_primary (struct d_info *di)
92a16bbe 2720{
5e777af5 2721 struct demangle_component *ret;
92a16bbe 2722
5165f125 2723 if (! d_check_char (di, 'L'))
bd6946d1 2724 return NULL;
448545cb
JM
2725 if (d_peek_char (di) == '_'
2726 /* Workaround for G++ bug; see comment in write_template_arg. */
2727 || d_peek_char (di) == 'Z')
5e777af5 2728 ret = cplus_demangle_mangled_name (di, 0);
bd6946d1 2729 else
92a16bbe 2730 {
5e777af5
ILT
2731 struct demangle_component *type;
2732 enum demangle_component_type t;
bd6946d1
ILT
2733 const char *s;
2734
5e777af5 2735 type = cplus_demangle_type (di);
00a5aa9c
ILT
2736 if (type == NULL)
2737 return NULL;
bd6946d1 2738
2d6c4025
ILT
2739 /* If we have a type we know how to print, we aren't going to
2740 print the type name itself. */
5e777af5 2741 if (type->type == DEMANGLE_COMPONENT_BUILTIN_TYPE
2d6c4025
ILT
2742 && type->u.s_builtin.type->print != D_PRINT_DEFAULT)
2743 di->expansion -= type->u.s_builtin.type->len;
2744
bd6946d1
ILT
2745 /* Rather than try to interpret the literal value, we just
2746 collect it as a string. Note that it's possible to have a
2747 floating point literal here. The ABI specifies that the
2748 format of such literals is machine independent. That's fine,
2749 but what's not fine is that versions of g++ up to 3.2 with
2750 -fabi-version=1 used upper case letters in the hex constant,
2751 and dumped out gcc's internal representation. That makes it
2752 hard to tell where the constant ends, and hard to dump the
2753 constant in any readable form anyhow. We don't attempt to
2754 handle these cases. */
2755
5e777af5 2756 t = DEMANGLE_COMPONENT_LITERAL;
374caa50
ILT
2757 if (d_peek_char (di) == 'n')
2758 {
5e777af5 2759 t = DEMANGLE_COMPONENT_LITERAL_NEG;
374caa50
ILT
2760 d_advance (di, 1);
2761 }
bd6946d1
ILT
2762 s = d_str (di);
2763 while (d_peek_char (di) != 'E')
8c7262af
ILT
2764 {
2765 if (d_peek_char (di) == '\0')
2766 return NULL;
2767 d_advance (di, 1);
2768 }
374caa50 2769 ret = d_make_comp (di, t, type, d_make_name (di, s, d_str (di) - s));
bd6946d1 2770 }
5165f125 2771 if (! d_check_char (di, 'E'))
bd6946d1
ILT
2772 return NULL;
2773 return ret;
92a16bbe
AS
2774}
2775
bd6946d1
ILT
2776/* <local-name> ::= Z <(function) encoding> E <(entity) name> [<discriminator>]
2777 ::= Z <(function) encoding> E s [<discriminator>]
2778*/
92a16bbe 2779
5e777af5 2780static struct demangle_component *
9486db4f 2781d_local_name (struct d_info *di)
92a16bbe 2782{
5e777af5 2783 struct demangle_component *function;
92a16bbe 2784
5165f125 2785 if (! d_check_char (di, 'Z'))
bd6946d1 2786 return NULL;
92a16bbe 2787
ad07f5e5 2788 function = d_encoding (di, 0);
92a16bbe 2789
5165f125 2790 if (! d_check_char (di, 'E'))
bd6946d1 2791 return NULL;
92a16bbe 2792
bd6946d1 2793 if (d_peek_char (di) == 's')
92a16bbe 2794 {
bd6946d1
ILT
2795 d_advance (di, 1);
2796 if (! d_discriminator (di))
2797 return NULL;
5e777af5 2798 return d_make_comp (di, DEMANGLE_COMPONENT_LOCAL_NAME, function,
bd6946d1
ILT
2799 d_make_name (di, "string literal",
2800 sizeof "string literal" - 1));
92a16bbe 2801 }
bd6946d1 2802 else
92a16bbe 2803 {
5e777af5 2804 struct demangle_component *name;
92a16bbe 2805
bd6946d1
ILT
2806 name = d_name (di);
2807 if (! d_discriminator (di))
2808 return NULL;
5e777af5 2809 return d_make_comp (di, DEMANGLE_COMPONENT_LOCAL_NAME, function, name);
92a16bbe 2810 }
92a16bbe
AS
2811}
2812
bd6946d1 2813/* <discriminator> ::= _ <(non-negative) number>
69afa80d 2814
bd6946d1
ILT
2815 We demangle the discriminator, but we don't print it out. FIXME:
2816 We should print it out in verbose mode. */
92a16bbe 2817
bd6946d1 2818static int
9486db4f 2819d_discriminator (struct d_info *di)
bd6946d1
ILT
2820{
2821 long discrim;
92a16bbe 2822
bd6946d1
ILT
2823 if (d_peek_char (di) != '_')
2824 return 1;
2825 d_advance (di, 1);
2826 discrim = d_number (di);
2827 if (discrim < 0)
2828 return 0;
2829 return 1;
2830}
69afa80d 2831
bd6946d1 2832/* Add a new substitution. */
69afa80d 2833
bd6946d1 2834static int
9486db4f 2835d_add_substitution (struct d_info *di, struct demangle_component *dc)
69afa80d 2836{
81dc098b
ILT
2837 if (dc == NULL)
2838 return 0;
bd6946d1
ILT
2839 if (di->next_sub >= di->num_subs)
2840 return 0;
2841 di->subs[di->next_sub] = dc;
2842 ++di->next_sub;
2843 return 1;
2844}
2845
2846/* <substitution> ::= S <seq-id> _
2847 ::= S_
2848 ::= St
2849 ::= Sa
2850 ::= Sb
2851 ::= Ss
2852 ::= Si
2853 ::= So
2854 ::= Sd
374caa50
ILT
2855
2856 If PREFIX is non-zero, then this type is being used as a prefix in
2857 a qualified name. In this case, for the standard substitutions, we
2858 need to check whether we are being used as a prefix for a
2859 constructor or destructor, and return a full template name.
2860 Otherwise we will get something like std::iostream::~iostream()
2861 which does not correspond particularly well to any function which
2862 actually appears in the source.
bd6946d1 2863*/
69afa80d 2864
374caa50
ILT
2865static const struct d_standard_sub_info standard_subs[] =
2866{
2d6c4025
ILT
2867 { 't', NL ("std"),
2868 NL ("std"),
2869 NULL, 0 },
2870 { 'a', NL ("std::allocator"),
2871 NL ("std::allocator"),
2872 NL ("allocator") },
2873 { 'b', NL ("std::basic_string"),
2874 NL ("std::basic_string"),
2875 NL ("basic_string") },
2876 { 's', NL ("std::string"),
2877 NL ("std::basic_string<char, std::char_traits<char>, std::allocator<char> >"),
2878 NL ("basic_string") },
2879 { 'i', NL ("std::istream"),
2880 NL ("std::basic_istream<char, std::char_traits<char> >"),
2881 NL ("basic_istream") },
2882 { 'o', NL ("std::ostream"),
2883 NL ("std::basic_ostream<char, std::char_traits<char> >"),
2884 NL ("basic_ostream") },
2885 { 'd', NL ("std::iostream"),
2886 NL ("std::basic_iostream<char, std::char_traits<char> >"),
2887 NL ("basic_iostream") }
374caa50
ILT
2888};
2889
5e777af5 2890static struct demangle_component *
9486db4f 2891d_substitution (struct d_info *di, int prefix)
bd6946d1
ILT
2892{
2893 char c;
69afa80d 2894
5165f125 2895 if (! d_check_char (di, 'S'))
bd6946d1 2896 return NULL;
056400f1 2897
bd6946d1 2898 c = d_next_char (di);
a51753e4 2899 if (c == '_' || IS_DIGIT (c) || IS_UPPER (c))
69afa80d 2900 {
eeda7b98 2901 unsigned int id;
69afa80d 2902
bd6946d1
ILT
2903 id = 0;
2904 if (c != '_')
69afa80d 2905 {
bd6946d1 2906 do
69afa80d 2907 {
eeda7b98
ILT
2908 unsigned int new_id;
2909
bd6946d1 2910 if (IS_DIGIT (c))
eeda7b98 2911 new_id = id * 36 + c - '0';
a51753e4 2912 else if (IS_UPPER (c))
eeda7b98 2913 new_id = id * 36 + c - 'A' + 10;
bd6946d1
ILT
2914 else
2915 return NULL;
eeda7b98 2916 if (new_id < id)
53e3e587 2917 return NULL;
eeda7b98 2918 id = new_id;
bd6946d1 2919 c = d_next_char (di);
69afa80d 2920 }
bd6946d1 2921 while (c != '_');
69afa80d 2922
bd6946d1 2923 ++id;
69afa80d 2924 }
69afa80d 2925
eeda7b98 2926 if (id >= (unsigned int) di->next_sub)
bd6946d1 2927 return NULL;
69afa80d 2928
2d6c4025
ILT
2929 ++di->did_subs;
2930
bd6946d1 2931 return di->subs[id];
69afa80d 2932 }
bd6946d1 2933 else
69afa80d 2934 {
374caa50
ILT
2935 int verbose;
2936 const struct d_standard_sub_info *p;
2937 const struct d_standard_sub_info *pend;
2938
2939 verbose = (di->options & DMGL_VERBOSE) != 0;
2940 if (! verbose && prefix)
7dce2eff 2941 {
374caa50
ILT
2942 char peek;
2943
2944 peek = d_peek_char (di);
2945 if (peek == 'C' || peek == 'D')
2946 verbose = 1;
69afa80d 2947 }
374caa50
ILT
2948
2949 pend = (&standard_subs[0]
2950 + sizeof standard_subs / sizeof standard_subs[0]);
2951 for (p = &standard_subs[0]; p < pend; ++p)
2952 {
2953 if (c == p->code)
2954 {
2d6c4025
ILT
2955 const char *s;
2956 int len;
2957
374caa50 2958 if (p->set_last_name != NULL)
2d6c4025
ILT
2959 di->last_name = d_make_sub (di, p->set_last_name,
2960 p->set_last_name_len);
374caa50 2961 if (verbose)
2d6c4025
ILT
2962 {
2963 s = p->full_expansion;
2964 len = p->full_len;
2965 }
374caa50 2966 else
2d6c4025
ILT
2967 {
2968 s = p->simple_expansion;
2969 len = p->simple_len;
2970 }
2971 di->expansion += len;
2972 return d_make_sub (di, s, len);
374caa50
ILT
2973 }
2974 }
2975
2976 return NULL;
69afa80d 2977 }
69afa80d
AS
2978}
2979
456cc5cf 2980/* Initialize a growable string. */
69afa80d 2981
bd6946d1 2982static void
456cc5cf 2983d_growable_string_init (struct d_growable_string *dgs, size_t estimate)
bd6946d1 2984{
456cc5cf
SB
2985 dgs->buf = NULL;
2986 dgs->len = 0;
2987 dgs->alc = 0;
2988 dgs->allocation_failure = 0;
69afa80d 2989
456cc5cf
SB
2990 if (estimate > 0)
2991 d_growable_string_resize (dgs, estimate);
2992}
2993
2994/* Grow a growable string to a given size. */
2995
2996static inline void
2997d_growable_string_resize (struct d_growable_string *dgs, size_t need)
2998{
2999 size_t newalc;
3000 char *newbuf;
3001
3002 if (dgs->allocation_failure)
81dc098b 3003 return;
0870bfd6 3004
456cc5cf
SB
3005 /* Start allocation at two bytes to avoid any possibility of confusion
3006 with the special value of 1 used as a return in *palc to indicate
3007 allocation failures. */
3008 newalc = dgs->alc > 0 ? dgs->alc : 2;
3009 while (newalc < need)
3010 newalc <<= 1;
3011
3012 newbuf = (char *) realloc (dgs->buf, newalc);
3013 if (newbuf == NULL)
3014 {
3015 free (dgs->buf);
3016 dgs->buf = NULL;
3017 dgs->len = 0;
3018 dgs->alc = 0;
3019 dgs->allocation_failure = 1;
3020 return;
31e0ab1f 3021 }
456cc5cf
SB
3022 dgs->buf = newbuf;
3023 dgs->alc = newalc;
bd6946d1 3024}
820555e6 3025
456cc5cf 3026/* Append a buffer to a growable string. */
820555e6 3027
456cc5cf
SB
3028static inline void
3029d_growable_string_append_buffer (struct d_growable_string *dgs,
3030 const char *s, size_t l)
bd6946d1 3031{
456cc5cf 3032 size_t need;
820555e6 3033
456cc5cf
SB
3034 need = dgs->len + l + 1;
3035 if (need > dgs->alc)
3036 d_growable_string_resize (dgs, need);
3037
3038 if (dgs->allocation_failure)
3039 return;
3040
3041 memcpy (dgs->buf + dgs->len, s, l);
3042 dgs->buf[dgs->len + l] = '\0';
3043 dgs->len += l;
69afa80d
AS
3044}
3045
456cc5cf 3046/* Bridge growable strings to the callback mechanism. */
bd6946d1
ILT
3047
3048static void
456cc5cf 3049d_growable_string_callback_adapter (const char *s, size_t l, void *opaque)
69afa80d 3050{
456cc5cf 3051 struct d_growable_string *dgs = (struct d_growable_string*) opaque;
69afa80d 3052
456cc5cf 3053 d_growable_string_append_buffer (dgs, s, l);
69afa80d
AS
3054}
3055
456cc5cf 3056/* Initialize a print information structure. */
69afa80d 3057
bd6946d1 3058static void
456cc5cf
SB
3059d_print_init (struct d_print_info *dpi, int options,
3060 demangle_callbackref callback, void *opaque)
3061{
3062 dpi->options = options;
3063 dpi->len = 0;
3064 dpi->last_char = '\0';
3065 dpi->templates = NULL;
3066 dpi->modifiers = NULL;
3067
3068 dpi->callback = callback;
3069 dpi->opaque = opaque;
3070
3071 dpi->demangle_failure = 0;
3072}
3073
3074/* Indicate that an error occurred during printing, and test for error. */
3075
3076static inline void
9486db4f 3077d_print_error (struct d_print_info *dpi)
3b60dd8e 3078{
456cc5cf
SB
3079 dpi->demangle_failure = 1;
3080}
3081
3082static inline int
3083d_print_saw_error (struct d_print_info *dpi)
3084{
3085 return dpi->demangle_failure != 0;
3086}
3087
3088/* Flush buffered characters to the callback. */
3089
3090static inline void
3091d_print_flush (struct d_print_info *dpi)
3092{
3093 dpi->buf[dpi->len] = '\0';
3094 dpi->callback (dpi->buf, dpi->len, dpi->opaque);
3095 dpi->len = 0;
3096}
3097
3098/* Append characters and buffers for printing. */
3099
3100static inline void
3101d_append_char (struct d_print_info *dpi, char c)
3102{
3103 if (dpi->len == sizeof (dpi->buf) - 1)
3104 d_print_flush (dpi);
3105
3106 dpi->buf[dpi->len++] = c;
3107 dpi->last_char = c;
3108}
3109
3110static inline void
3111d_append_buffer (struct d_print_info *dpi, const char *s, size_t l)
3112{
3113 size_t i;
3114
3115 for (i = 0; i < l; i++)
3116 d_append_char (dpi, s[i]);
3117}
3118
3119static inline void
3120d_append_string (struct d_print_info *dpi, const char *s)
3121{
3122 d_append_buffer (dpi, s, strlen (s));
3123}
3124
3125static inline char
3126d_last_char (struct d_print_info *dpi)
3127{
3128 return dpi->last_char;
3129}
3130
3131/* Turn components into a human readable string. OPTIONS is the
3132 options bits passed to the demangler. DC is the tree to print.
3133 CALLBACK is a function to call to flush demangled string segments
3134 as they fill the intermediate buffer, and OPAQUE is a generalized
3135 callback argument. On success, this returns 1. On failure,
3136 it returns 0, indicating a bad parse. It does not use heap
3137 memory to build an output string, so cannot encounter memory
3138 allocation failure. */
3139
3140CP_STATIC_IF_GLIBCPP_V3
3141int
3142cplus_demangle_print_callback (int options,
3143 const struct demangle_component *dc,
3144 demangle_callbackref callback, void *opaque)
3145{
3146 struct d_print_info dpi;
3147
3148 d_print_init (&dpi, options, callback, opaque);
3149
3150 d_print_comp (&dpi, dc);
3151
3152 d_print_flush (&dpi);
3153
3154 return ! d_print_saw_error (&dpi);
bd6946d1 3155}
3b60dd8e 3156
2d6c4025
ILT
3157/* Turn components into a human readable string. OPTIONS is the
3158 options bits passed to the demangler. DC is the tree to print.
3159 ESTIMATE is a guess at the length of the result. This returns a
3160 string allocated by malloc, or NULL on error. On success, this
3161 sets *PALC to the size of the allocated buffer. On failure, this
3162 sets *PALC to 0 for a bad parse, or to 1 for a memory allocation
3163 failure. */
69afa80d 3164
5e777af5
ILT
3165CP_STATIC_IF_GLIBCPP_V3
3166char *
9486db4f
GDR
3167cplus_demangle_print (int options, const struct demangle_component *dc,
3168 int estimate, size_t *palc)
bd6946d1 3169{
456cc5cf 3170 struct d_growable_string dgs;
69afa80d 3171
456cc5cf 3172 d_growable_string_init (&dgs, estimate);
69afa80d 3173
456cc5cf
SB
3174 if (! cplus_demangle_print_callback (options, dc,
3175 d_growable_string_callback_adapter,
3176 &dgs))
69afa80d 3177 {
456cc5cf
SB
3178 free (dgs.buf);
3179 *palc = 0;
bd6946d1 3180 return NULL;
69afa80d 3181 }
69afa80d 3182
456cc5cf
SB
3183 *palc = dgs.allocation_failure ? 1 : dgs.alc;
3184 return dgs.buf;
69afa80d
AS
3185}
3186
38179091
JM
3187/* Returns the I'th element of the template arglist ARGS, or NULL on
3188 failure. */
3189
3190static struct demangle_component *
3191d_index_template_argument (struct demangle_component *args, int i)
3192{
3193 struct demangle_component *a;
3194
3195 for (a = args;
3196 a != NULL;
3197 a = d_right (a))
3198 {
3199 if (a->type != DEMANGLE_COMPONENT_TEMPLATE_ARGLIST)
3200 return NULL;
3201 if (i <= 0)
3202 break;
3203 --i;
3204 }
3205 if (i != 0 || a == NULL)
3206 return NULL;
3207
3208 return d_left (a);
3209}
3210
3211/* Returns the template argument from the current context indicated by DC,
3212 which is a DEMANGLE_COMPONENT_TEMPLATE_PARAM, or NULL. */
3213
3214static struct demangle_component *
3215d_lookup_template_argument (struct d_print_info *dpi,
3216 const struct demangle_component *dc)
3217{
3218 if (dpi->templates == NULL)
3219 {
3220 d_print_error (dpi);
3221 return NULL;
3222 }
3223
3224 return d_index_template_argument
3225 (d_right (dpi->templates->template_decl),
3226 dc->u.s_number.number);
3227}
3228
3229/* Returns a template argument pack used in DC (any will do), or NULL. */
3230
3231static struct demangle_component *
3232d_find_pack (struct d_print_info *dpi,
3233 const struct demangle_component *dc)
3234{
3235 struct demangle_component *a;
3236 if (dc == NULL)
3237 return NULL;
3238
3239 switch (dc->type)
3240 {
3241 case DEMANGLE_COMPONENT_TEMPLATE_PARAM:
3242 a = d_lookup_template_argument (dpi, dc);
3243 if (a && a->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST)
3244 return a;
3245 return NULL;
3246
3247 case DEMANGLE_COMPONENT_PACK_EXPANSION:
3248 return NULL;
3249
3250 case DEMANGLE_COMPONENT_NAME:
3251 case DEMANGLE_COMPONENT_OPERATOR:
3252 case DEMANGLE_COMPONENT_BUILTIN_TYPE:
3253 case DEMANGLE_COMPONENT_SUB_STD:
3254 case DEMANGLE_COMPONENT_CHARACTER:
6afcfe0a 3255 case DEMANGLE_COMPONENT_FUNCTION_PARAM:
38179091
JM
3256 return NULL;
3257
3258 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
3259 return d_find_pack (dpi, dc->u.s_extended_operator.name);
3260 case DEMANGLE_COMPONENT_CTOR:
3261 return d_find_pack (dpi, dc->u.s_ctor.name);
3262 case DEMANGLE_COMPONENT_DTOR:
3263 return d_find_pack (dpi, dc->u.s_dtor.name);
3264
3265 default:
3266 a = d_find_pack (dpi, d_left (dc));
3267 if (a)
3268 return a;
3269 return d_find_pack (dpi, d_right (dc));
3270 }
3271}
3272
3273/* Returns the length of the template argument pack DC. */
3274
3275static int
3276d_pack_length (const struct demangle_component *dc)
3277{
3278 int count = 0;
3279 while (dc && dc->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST
3280 && d_left (dc) != NULL)
3281 {
3282 ++count;
3283 dc = d_right (dc);
3284 }
3285 return count;
3286}
3287
3288/* DC is a component of a mangled expression. Print it, wrapped in parens
3289 if needed. */
3290
3291static void
3292d_print_subexpr (struct d_print_info *dpi,
3293 const struct demangle_component *dc)
3294{
3295 int simple = 0;
6afcfe0a
JM
3296 if (dc->type == DEMANGLE_COMPONENT_NAME
3297 || dc->type == DEMANGLE_COMPONENT_FUNCTION_PARAM)
38179091
JM
3298 simple = 1;
3299 if (!simple)
3300 d_append_char (dpi, '(');
3301 d_print_comp (dpi, dc);
3302 if (!simple)
3303 d_append_char (dpi, ')');
3304}
3305
bd6946d1 3306/* Subroutine to handle components. */
69afa80d 3307
bd6946d1 3308static void
9486db4f
GDR
3309d_print_comp (struct d_print_info *dpi,
3310 const struct demangle_component *dc)
69afa80d 3311{
bd6946d1 3312 if (dc == NULL)
69afa80d 3313 {
bd6946d1
ILT
3314 d_print_error (dpi);
3315 return;
69afa80d 3316 }
bd6946d1
ILT
3317 if (d_print_saw_error (dpi))
3318 return;
69afa80d 3319
bd6946d1 3320 switch (dc->type)
69afa80d 3321 {
5e777af5 3322 case DEMANGLE_COMPONENT_NAME:
2d6c4025
ILT
3323 if ((dpi->options & DMGL_JAVA) == 0)
3324 d_append_buffer (dpi, dc->u.s_name.s, dc->u.s_name.len);
3325 else
3326 d_print_java_identifier (dpi, dc->u.s_name.s, dc->u.s_name.len);
bd6946d1 3327 return;
69afa80d 3328
5e777af5
ILT
3329 case DEMANGLE_COMPONENT_QUAL_NAME:
3330 case DEMANGLE_COMPONENT_LOCAL_NAME:
bd6946d1 3331 d_print_comp (dpi, d_left (dc));
2d6c4025 3332 if ((dpi->options & DMGL_JAVA) == 0)
456cc5cf 3333 d_append_string (dpi, "::");
2d6c4025
ILT
3334 else
3335 d_append_char (dpi, '.');
bd6946d1
ILT
3336 d_print_comp (dpi, d_right (dc));
3337 return;
69afa80d 3338
5e777af5 3339 case DEMANGLE_COMPONENT_TYPED_NAME:
bd6946d1 3340 {
a51753e4 3341 struct d_print_mod *hold_modifiers;
5e777af5 3342 struct demangle_component *typed_name;
a51753e4
ILT
3343 struct d_print_mod adpm[4];
3344 unsigned int i;
bd6946d1
ILT
3345 struct d_print_template dpt;
3346
3347 /* Pass the name down to the type so that it can be printed in
a51753e4
ILT
3348 the right place for the type. We also have to pass down
3349 any CV-qualifiers, which apply to the this parameter. */
3350 hold_modifiers = dpi->modifiers;
448545cb 3351 dpi->modifiers = 0;
a51753e4 3352 i = 0;
bd6946d1 3353 typed_name = d_left (dc);
a51753e4
ILT
3354 while (typed_name != NULL)
3355 {
3356 if (i >= sizeof adpm / sizeof adpm[0])
3357 {
3358 d_print_error (dpi);
3359 return;
3360 }
bd6946d1 3361
a51753e4
ILT
3362 adpm[i].next = dpi->modifiers;
3363 dpi->modifiers = &adpm[i];
3364 adpm[i].mod = typed_name;
3365 adpm[i].printed = 0;
3366 adpm[i].templates = dpi->templates;
3367 ++i;
3368
5e777af5
ILT
3369 if (typed_name->type != DEMANGLE_COMPONENT_RESTRICT_THIS
3370 && typed_name->type != DEMANGLE_COMPONENT_VOLATILE_THIS
3371 && typed_name->type != DEMANGLE_COMPONENT_CONST_THIS)
a51753e4
ILT
3372 break;
3373
3374 typed_name = d_left (typed_name);
3375 }
bd6946d1 3376
ac847e32
MS
3377 if (typed_name == NULL)
3378 {
3379 d_print_error (dpi);
3380 return;
3381 }
3382
bd6946d1
ILT
3383 /* If typed_name is a template, then it applies to the
3384 function type as well. */
5e777af5 3385 if (typed_name->type == DEMANGLE_COMPONENT_TEMPLATE)
bd6946d1
ILT
3386 {
3387 dpt.next = dpi->templates;
3388 dpi->templates = &dpt;
d7cf8390 3389 dpt.template_decl = typed_name;
bd6946d1 3390 }
69afa80d 3391
5e777af5
ILT
3392 /* If typed_name is a DEMANGLE_COMPONENT_LOCAL_NAME, then
3393 there may be CV-qualifiers on its right argument which
3394 really apply here; this happens when parsing a class which
3395 is local to a function. */
3396 if (typed_name->type == DEMANGLE_COMPONENT_LOCAL_NAME)
a91d1af0 3397 {
5e777af5 3398 struct demangle_component *local_name;
a91d1af0
ILT
3399
3400 local_name = d_right (typed_name);
5e777af5
ILT
3401 while (local_name->type == DEMANGLE_COMPONENT_RESTRICT_THIS
3402 || local_name->type == DEMANGLE_COMPONENT_VOLATILE_THIS
3403 || local_name->type == DEMANGLE_COMPONENT_CONST_THIS)
a91d1af0
ILT
3404 {
3405 if (i >= sizeof adpm / sizeof adpm[0])
3406 {
3407 d_print_error (dpi);
3408 return;
3409 }
3410
3411 adpm[i] = adpm[i - 1];
3412 adpm[i].next = &adpm[i - 1];
3413 dpi->modifiers = &adpm[i];
3414
3415 adpm[i - 1].mod = local_name;
3416 adpm[i - 1].printed = 0;
3417 adpm[i - 1].templates = dpi->templates;
3418 ++i;
3419
3420 local_name = d_left (local_name);
3421 }
3422 }
3423
bd6946d1 3424 d_print_comp (dpi, d_right (dc));
1056d228 3425
5e777af5 3426 if (typed_name->type == DEMANGLE_COMPONENT_TEMPLATE)
bd6946d1 3427 dpi->templates = dpt.next;
69afa80d 3428
a51753e4 3429 /* If the modifiers didn't get printed by the type, print them
bd6946d1 3430 now. */
a51753e4 3431 while (i > 0)
bd6946d1 3432 {
a51753e4
ILT
3433 --i;
3434 if (! adpm[i].printed)
3435 {
3436 d_append_char (dpi, ' ');
3437 d_print_mod (dpi, adpm[i].mod);
3438 }
bd6946d1 3439 }
69afa80d 3440
a51753e4 3441 dpi->modifiers = hold_modifiers;
69afa80d 3442
bd6946d1
ILT
3443 return;
3444 }
69afa80d 3445
5e777af5 3446 case DEMANGLE_COMPONENT_TEMPLATE:
81dc098b
ILT
3447 {
3448 struct d_print_mod *hold_dpm;
456cc5cf 3449 struct demangle_component *dcl;
81dc098b
ILT
3450
3451 /* Don't push modifiers into a template definition. Doing so
3452 could give the wrong definition for a template argument.
3453 Instead, treat the template essentially as a name. */
3454
3455 hold_dpm = dpi->modifiers;
3456 dpi->modifiers = NULL;
3457
456cc5cf
SB
3458 dcl = d_left (dc);
3459
3460 if ((dpi->options & DMGL_JAVA) != 0
3461 && dcl->type == DEMANGLE_COMPONENT_NAME
3462 && dcl->u.s_name.len == 6
3463 && strncmp (dcl->u.s_name.s, "JArray", 6) == 0)
3464 {
3465 /* Special-case Java arrays, so that JArray<TYPE> appears
3466 instead as TYPE[]. */
3467
3468 d_print_comp (dpi, d_right (dc));
3469 d_append_string (dpi, "[]");
3470 }
3471 else
3472 {
3473 d_print_comp (dpi, dcl);
3474 if (d_last_char (dpi) == '<')
3475 d_append_char (dpi, ' ');
3476 d_append_char (dpi, '<');
3477 d_print_comp (dpi, d_right (dc));
3478 /* Avoid generating two consecutive '>' characters, to avoid
3479 the C++ syntactic ambiguity. */
3480 if (d_last_char (dpi) == '>')
3481 d_append_char (dpi, ' ');
3482 d_append_char (dpi, '>');
3483 }
81dc098b
ILT
3484
3485 dpi->modifiers = hold_dpm;
3486
3487 return;
3488 }
bd6946d1 3489
5e777af5 3490 case DEMANGLE_COMPONENT_TEMPLATE_PARAM:
bd6946d1 3491 {
bd6946d1 3492 struct d_print_template *hold_dpt;
38179091 3493 struct demangle_component *a = d_lookup_template_argument (dpi, dc);
69afa80d 3494
38179091
JM
3495 if (a && a->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST)
3496 a = d_index_template_argument (a, dpi->pack_index);
3497
3498 if (a == NULL)
bd6946d1
ILT
3499 {
3500 d_print_error (dpi);
3501 return;
3502 }
0870bfd6 3503
bd6946d1
ILT
3504 /* While processing this parameter, we need to pop the list of
3505 templates. This is because the template parameter may
3506 itself be a reference to a parameter of an outer
3507 template. */
0870bfd6 3508
bd6946d1
ILT
3509 hold_dpt = dpi->templates;
3510 dpi->templates = hold_dpt->next;
69afa80d 3511
38179091 3512 d_print_comp (dpi, a);
051664b0 3513
bd6946d1 3514 dpi->templates = hold_dpt;
0870bfd6 3515
bd6946d1
ILT
3516 return;
3517 }
69afa80d 3518
5e777af5 3519 case DEMANGLE_COMPONENT_CTOR:
bd6946d1
ILT
3520 d_print_comp (dpi, dc->u.s_ctor.name);
3521 return;
3522
5e777af5 3523 case DEMANGLE_COMPONENT_DTOR:
bd6946d1
ILT
3524 d_append_char (dpi, '~');
3525 d_print_comp (dpi, dc->u.s_dtor.name);
3526 return;
3527
5e777af5 3528 case DEMANGLE_COMPONENT_VTABLE:
456cc5cf 3529 d_append_string (dpi, "vtable for ");
bd6946d1
ILT
3530 d_print_comp (dpi, d_left (dc));
3531 return;
3532
5e777af5 3533 case DEMANGLE_COMPONENT_VTT:
456cc5cf 3534 d_append_string (dpi, "VTT for ");
bd6946d1
ILT
3535 d_print_comp (dpi, d_left (dc));
3536 return;
3537
5e777af5 3538 case DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE:
456cc5cf 3539 d_append_string (dpi, "construction vtable for ");
bd6946d1 3540 d_print_comp (dpi, d_left (dc));
456cc5cf 3541 d_append_string (dpi, "-in-");
bd6946d1
ILT
3542 d_print_comp (dpi, d_right (dc));
3543 return;
3544
5e777af5 3545 case DEMANGLE_COMPONENT_TYPEINFO:
456cc5cf 3546 d_append_string (dpi, "typeinfo for ");
bd6946d1
ILT
3547 d_print_comp (dpi, d_left (dc));
3548 return;
3549
5e777af5 3550 case DEMANGLE_COMPONENT_TYPEINFO_NAME:
456cc5cf 3551 d_append_string (dpi, "typeinfo name for ");
bd6946d1
ILT
3552 d_print_comp (dpi, d_left (dc));
3553 return;
3554
5e777af5 3555 case DEMANGLE_COMPONENT_TYPEINFO_FN:
456cc5cf 3556 d_append_string (dpi, "typeinfo fn for ");
bd6946d1
ILT
3557 d_print_comp (dpi, d_left (dc));
3558 return;
3559
5e777af5 3560 case DEMANGLE_COMPONENT_THUNK:
456cc5cf 3561 d_append_string (dpi, "non-virtual thunk to ");
bd6946d1
ILT
3562 d_print_comp (dpi, d_left (dc));
3563 return;
3564
5e777af5 3565 case DEMANGLE_COMPONENT_VIRTUAL_THUNK:
456cc5cf 3566 d_append_string (dpi, "virtual thunk to ");
bd6946d1
ILT
3567 d_print_comp (dpi, d_left (dc));
3568 return;
3569
5e777af5 3570 case DEMANGLE_COMPONENT_COVARIANT_THUNK:
456cc5cf 3571 d_append_string (dpi, "covariant return thunk to ");
bd6946d1
ILT
3572 d_print_comp (dpi, d_left (dc));
3573 return;
3574
5e777af5 3575 case DEMANGLE_COMPONENT_JAVA_CLASS:
456cc5cf 3576 d_append_string (dpi, "java Class for ");
bd6946d1
ILT
3577 d_print_comp (dpi, d_left (dc));
3578 return;
3579
5e777af5 3580 case DEMANGLE_COMPONENT_GUARD:
456cc5cf 3581 d_append_string (dpi, "guard variable for ");
bd6946d1
ILT
3582 d_print_comp (dpi, d_left (dc));
3583 return;
3584
5e777af5 3585 case DEMANGLE_COMPONENT_REFTEMP:
456cc5cf 3586 d_append_string (dpi, "reference temporary for ");
bd6946d1
ILT
3587 d_print_comp (dpi, d_left (dc));
3588 return;
3589
15da2806 3590 case DEMANGLE_COMPONENT_HIDDEN_ALIAS:
456cc5cf 3591 d_append_string (dpi, "hidden alias for ");
15da2806
RH
3592 d_print_comp (dpi, d_left (dc));
3593 return;
3594
5e777af5 3595 case DEMANGLE_COMPONENT_SUB_STD:
2d6c4025 3596 d_append_buffer (dpi, dc->u.s_string.string, dc->u.s_string.len);
bd6946d1
ILT
3597 return;
3598
5e777af5
ILT
3599 case DEMANGLE_COMPONENT_RESTRICT:
3600 case DEMANGLE_COMPONENT_VOLATILE:
3601 case DEMANGLE_COMPONENT_CONST:
80a19ac8
ILT
3602 {
3603 struct d_print_mod *pdpm;
3604
3605 /* When printing arrays, it's possible to have cases where the
3606 same CV-qualifier gets pushed on the stack multiple times.
3607 We only need to print it once. */
3608
3609 for (pdpm = dpi->modifiers; pdpm != NULL; pdpm = pdpm->next)
3610 {
3611 if (! pdpm->printed)
3612 {
3613 if (pdpm->mod->type != DEMANGLE_COMPONENT_RESTRICT
3614 && pdpm->mod->type != DEMANGLE_COMPONENT_VOLATILE
3615 && pdpm->mod->type != DEMANGLE_COMPONENT_CONST)
3616 break;
3617 if (pdpm->mod->type == dc->type)
3618 {
3619 d_print_comp (dpi, d_left (dc));
3620 return;
3621 }
3622 }
3623 }
3624 }
3625 /* Fall through. */
5e777af5
ILT
3626 case DEMANGLE_COMPONENT_RESTRICT_THIS:
3627 case DEMANGLE_COMPONENT_VOLATILE_THIS:
3628 case DEMANGLE_COMPONENT_CONST_THIS:
3629 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
3630 case DEMANGLE_COMPONENT_POINTER:
3631 case DEMANGLE_COMPONENT_REFERENCE:
1ab28be5 3632 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
5e777af5
ILT
3633 case DEMANGLE_COMPONENT_COMPLEX:
3634 case DEMANGLE_COMPONENT_IMAGINARY:
bd6946d1
ILT
3635 {
3636 /* We keep a list of modifiers on the stack. */
3637 struct d_print_mod dpm;
69afa80d 3638
bd6946d1
ILT
3639 dpm.next = dpi->modifiers;
3640 dpi->modifiers = &dpm;
3641 dpm.mod = dc;
3642 dpm.printed = 0;
81dc098b 3643 dpm.templates = dpi->templates;
69afa80d 3644
bd6946d1 3645 d_print_comp (dpi, d_left (dc));
0870bfd6 3646
bd6946d1
ILT
3647 /* If the modifier didn't get printed by the type, print it
3648 now. */
3649 if (! dpm.printed)
3650 d_print_mod (dpi, dc);
69afa80d 3651
bd6946d1 3652 dpi->modifiers = dpm.next;
69afa80d 3653
bd6946d1
ILT
3654 return;
3655 }
69afa80d 3656
5e777af5 3657 case DEMANGLE_COMPONENT_BUILTIN_TYPE:
bd6946d1 3658 if ((dpi->options & DMGL_JAVA) == 0)
2d6c4025
ILT
3659 d_append_buffer (dpi, dc->u.s_builtin.type->name,
3660 dc->u.s_builtin.type->len);
bd6946d1 3661 else
2d6c4025
ILT
3662 d_append_buffer (dpi, dc->u.s_builtin.type->java_name,
3663 dc->u.s_builtin.type->java_len);
bd6946d1 3664 return;
69afa80d 3665
5e777af5 3666 case DEMANGLE_COMPONENT_VENDOR_TYPE:
bd6946d1
ILT
3667 d_print_comp (dpi, d_left (dc));
3668 return;
69afa80d 3669
5e777af5 3670 case DEMANGLE_COMPONENT_FUNCTION_TYPE:
bd6946d1 3671 {
92aed1cb
TL
3672 if ((dpi->options & DMGL_RET_POSTFIX) != 0)
3673 d_print_function_type (dpi, dc, dpi->modifiers);
3674
3675 /* Print return type if present */
bd6946d1
ILT
3676 if (d_left (dc) != NULL)
3677 {
3678 struct d_print_mod dpm;
69afa80d 3679
bd6946d1
ILT
3680 /* We must pass this type down as a modifier in order to
3681 print it in the right location. */
bd6946d1
ILT
3682 dpm.next = dpi->modifiers;
3683 dpi->modifiers = &dpm;
3684 dpm.mod = dc;
3685 dpm.printed = 0;
81dc098b 3686 dpm.templates = dpi->templates;
69afa80d 3687
bd6946d1 3688 d_print_comp (dpi, d_left (dc));
69afa80d 3689
bd6946d1 3690 dpi->modifiers = dpm.next;
69afa80d 3691
bd6946d1
ILT
3692 if (dpm.printed)
3693 return;
69afa80d 3694
92aed1cb
TL
3695 /* In standard prefix notation, there is a space between the
3696 return type and the function signature. */
3697 if ((dpi->options & DMGL_RET_POSTFIX) == 0)
3698 d_append_char (dpi, ' ');
bd6946d1 3699 }
69afa80d 3700
92aed1cb
TL
3701 if ((dpi->options & DMGL_RET_POSTFIX) == 0)
3702 d_print_function_type (dpi, dc, dpi->modifiers);
051664b0 3703
bd6946d1
ILT
3704 return;
3705 }
69afa80d 3706
5e777af5 3707 case DEMANGLE_COMPONENT_ARRAY_TYPE:
bd6946d1 3708 {
80a19ac8
ILT
3709 struct d_print_mod *hold_modifiers;
3710 struct d_print_mod adpm[4];
3711 unsigned int i;
3712 struct d_print_mod *pdpm;
69afa80d 3713
bd6946d1 3714 /* We must pass this type down as a modifier in order to print
80a19ac8
ILT
3715 multi-dimensional arrays correctly. If the array itself is
3716 CV-qualified, we act as though the element type were
3717 CV-qualified. We do this by copying the modifiers down
3718 rather than fiddling pointers, so that we don't wind up
3719 with a d_print_mod higher on the stack pointing into our
3720 stack frame after we return. */
051664b0 3721
80a19ac8
ILT
3722 hold_modifiers = dpi->modifiers;
3723
3724 adpm[0].next = hold_modifiers;
3725 dpi->modifiers = &adpm[0];
3726 adpm[0].mod = dc;
3727 adpm[0].printed = 0;
3728 adpm[0].templates = dpi->templates;
3729
3730 i = 1;
3731 pdpm = hold_modifiers;
3732 while (pdpm != NULL
3733 && (pdpm->mod->type == DEMANGLE_COMPONENT_RESTRICT
3734 || pdpm->mod->type == DEMANGLE_COMPONENT_VOLATILE
3735 || pdpm->mod->type == DEMANGLE_COMPONENT_CONST))
3736 {
3737 if (! pdpm->printed)
3738 {
3739 if (i >= sizeof adpm / sizeof adpm[0])
3740 {
3741 d_print_error (dpi);
3742 return;
3743 }
3744
3745 adpm[i] = *pdpm;
3746 adpm[i].next = dpi->modifiers;
3747 dpi->modifiers = &adpm[i];
3748 pdpm->printed = 1;
3749 ++i;
3750 }
3751
3752 pdpm = pdpm->next;
3753 }
69afa80d 3754
bd6946d1 3755 d_print_comp (dpi, d_right (dc));
69afa80d 3756
80a19ac8 3757 dpi->modifiers = hold_modifiers;
69afa80d 3758
80a19ac8 3759 if (adpm[0].printed)
bd6946d1 3760 return;
69afa80d 3761
80a19ac8
ILT
3762 while (i > 1)
3763 {
3764 --i;
3765 d_print_mod (dpi, adpm[i].mod);
3766 }
3767
bd6946d1 3768 d_print_array_type (dpi, dc, dpi->modifiers);
69afa80d 3769
bd6946d1
ILT
3770 return;
3771 }
69afa80d 3772
5e777af5 3773 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
bd6946d1 3774 {
bd6946d1
ILT
3775 struct d_print_mod dpm;
3776
bd6946d1
ILT
3777 dpm.next = dpi->modifiers;
3778 dpi->modifiers = &dpm;
3779 dpm.mod = dc;
3780 dpm.printed = 0;
81dc098b 3781 dpm.templates = dpi->templates;
bd6946d1 3782
a51753e4 3783 d_print_comp (dpi, d_right (dc));
bd6946d1
ILT
3784
3785 /* If the modifier didn't get printed by the type, print it
3786 now. */
3787 if (! dpm.printed)
3788 {
3789 d_append_char (dpi, ' ');
3790 d_print_comp (dpi, d_left (dc));
456cc5cf 3791 d_append_string (dpi, "::*");
bd6946d1 3792 }
69afa80d 3793
bd6946d1 3794 dpi->modifiers = dpm.next;
69afa80d 3795
bd6946d1
ILT
3796 return;
3797 }
69afa80d 3798
07523e7c
JM
3799 case DEMANGLE_COMPONENT_FIXED_TYPE:
3800 if (dc->u.s_fixed.sat)
3801 d_append_string (dpi, "_Sat ");
3802 /* Don't print "int _Accum". */
3803 if (dc->u.s_fixed.length->u.s_builtin.type
3804 != &cplus_demangle_builtin_types['i'-'a'])
3805 {
3806 d_print_comp (dpi, dc->u.s_fixed.length);
3807 d_append_char (dpi, ' ');
3808 }
3809 if (dc->u.s_fixed.accum)
3810 d_append_string (dpi, "_Accum");
3811 else
3812 d_append_string (dpi, "_Fract");
3813 return;
3814
5e777af5
ILT
3815 case DEMANGLE_COMPONENT_ARGLIST:
3816 case DEMANGLE_COMPONENT_TEMPLATE_ARGLIST:
38179091
JM
3817 if (d_left (dc) != NULL)
3818 d_print_comp (dpi, d_left (dc));
bd6946d1
ILT
3819 if (d_right (dc) != NULL)
3820 {
a77f94e2 3821 size_t len;
456cc5cf 3822 d_append_string (dpi, ", ");
a77f94e2 3823 len = dpi->len;
bd6946d1 3824 d_print_comp (dpi, d_right (dc));
a77f94e2
JM
3825 /* If that didn't print anything (which can happen with empty
3826 template argument packs), remove the comma and space. */
3827 if (dpi->len == len)
3828 dpi->len -= 2;
bd6946d1
ILT
3829 }
3830 return;
69afa80d 3831
5e777af5 3832 case DEMANGLE_COMPONENT_OPERATOR:
bd6946d1
ILT
3833 {
3834 char c;
3835
456cc5cf 3836 d_append_string (dpi, "operator");
bd6946d1 3837 c = dc->u.s_operator.op->name[0];
a51753e4 3838 if (IS_LOWER (c))
bd6946d1 3839 d_append_char (dpi, ' ');
2d6c4025
ILT
3840 d_append_buffer (dpi, dc->u.s_operator.op->name,
3841 dc->u.s_operator.op->len);
bd6946d1
ILT
3842 return;
3843 }
69afa80d 3844
5e777af5 3845 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
456cc5cf 3846 d_append_string (dpi, "operator ");
bd6946d1
ILT
3847 d_print_comp (dpi, dc->u.s_extended_operator.name);
3848 return;
69afa80d 3849
5e777af5 3850 case DEMANGLE_COMPONENT_CAST:
456cc5cf 3851 d_append_string (dpi, "operator ");
bd6946d1
ILT
3852 d_print_cast (dpi, dc);
3853 return;
69afa80d 3854
5e777af5
ILT
3855 case DEMANGLE_COMPONENT_UNARY:
3856 if (d_left (dc)->type != DEMANGLE_COMPONENT_CAST)
bd6946d1
ILT
3857 d_print_expr_op (dpi, d_left (dc));
3858 else
69afa80d 3859 {
93f20626 3860 d_append_char (dpi, '(');
bd6946d1
ILT
3861 d_print_cast (dpi, d_left (dc));
3862 d_append_char (dpi, ')');
69afa80d 3863 }
30471e01 3864 d_print_subexpr (dpi, d_right (dc));
bd6946d1
ILT
3865 return;
3866
5e777af5
ILT
3867 case DEMANGLE_COMPONENT_BINARY:
3868 if (d_right (dc)->type != DEMANGLE_COMPONENT_BINARY_ARGS)
69afa80d 3869 {
bd6946d1
ILT
3870 d_print_error (dpi);
3871 return;
69afa80d 3872 }
a51753e4
ILT
3873
3874 /* We wrap an expression which uses the greater-than operator in
3875 an extra layer of parens so that it does not get confused
3876 with the '>' which ends the template parameters. */
5e777af5 3877 if (d_left (dc)->type == DEMANGLE_COMPONENT_OPERATOR
2d6c4025
ILT
3878 && d_left (dc)->u.s_operator.op->len == 1
3879 && d_left (dc)->u.s_operator.op->name[0] == '>')
a51753e4
ILT
3880 d_append_char (dpi, '(');
3881
38179091
JM
3882 d_print_subexpr (dpi, d_left (d_right (dc)));
3883 if (strcmp (d_left (dc)->u.s_operator.op->code, "cl") != 0)
3884 d_print_expr_op (dpi, d_left (dc));
3885 d_print_subexpr (dpi, d_right (d_right (dc)));
a51753e4 3886
5e777af5 3887 if (d_left (dc)->type == DEMANGLE_COMPONENT_OPERATOR
2d6c4025
ILT
3888 && d_left (dc)->u.s_operator.op->len == 1
3889 && d_left (dc)->u.s_operator.op->name[0] == '>')
a51753e4
ILT
3890 d_append_char (dpi, ')');
3891
bd6946d1
ILT
3892 return;
3893
5e777af5
ILT
3894 case DEMANGLE_COMPONENT_BINARY_ARGS:
3895 /* We should only see this as part of DEMANGLE_COMPONENT_BINARY. */
bd6946d1
ILT
3896 d_print_error (dpi);
3897 return;
3898
5e777af5
ILT
3899 case DEMANGLE_COMPONENT_TRINARY:
3900 if (d_right (dc)->type != DEMANGLE_COMPONENT_TRINARY_ARG1
3901 || d_right (d_right (dc))->type != DEMANGLE_COMPONENT_TRINARY_ARG2)
bd6946d1
ILT
3902 {
3903 d_print_error (dpi);
3904 return;
3905 }
38179091 3906 d_print_subexpr (dpi, d_left (d_right (dc)));
bd6946d1 3907 d_print_expr_op (dpi, d_left (dc));
38179091
JM
3908 d_print_subexpr (dpi, d_left (d_right (d_right (dc))));
3909 d_append_string (dpi, " : ");
3910 d_print_subexpr (dpi, d_right (d_right (d_right (dc))));
bd6946d1
ILT
3911 return;
3912
5e777af5
ILT
3913 case DEMANGLE_COMPONENT_TRINARY_ARG1:
3914 case DEMANGLE_COMPONENT_TRINARY_ARG2:
3915 /* We should only see these are part of DEMANGLE_COMPONENT_TRINARY. */
bd6946d1
ILT
3916 d_print_error (dpi);
3917 return;
3918
5e777af5
ILT
3919 case DEMANGLE_COMPONENT_LITERAL:
3920 case DEMANGLE_COMPONENT_LITERAL_NEG:
31058ee3
ILT
3921 {
3922 enum d_builtin_type_print tp;
bd6946d1 3923
31058ee3
ILT
3924 /* For some builtin types, produce simpler output. */
3925 tp = D_PRINT_DEFAULT;
3926 if (d_left (dc)->type == DEMANGLE_COMPONENT_BUILTIN_TYPE)
3927 {
3928 tp = d_left (dc)->u.s_builtin.type->print;
3929 switch (tp)
3930 {
3931 case D_PRINT_INT:
3932 case D_PRINT_UNSIGNED:
3933 case D_PRINT_LONG:
3934 case D_PRINT_UNSIGNED_LONG:
3935 case D_PRINT_LONG_LONG:
3936 case D_PRINT_UNSIGNED_LONG_LONG:
3937 if (d_right (dc)->type == DEMANGLE_COMPONENT_NAME)
3938 {
3939 if (dc->type == DEMANGLE_COMPONENT_LITERAL_NEG)
3940 d_append_char (dpi, '-');
3941 d_print_comp (dpi, d_right (dc));
3942 switch (tp)
3943 {
3944 default:
3945 break;
3946 case D_PRINT_UNSIGNED:
3947 d_append_char (dpi, 'u');
3948 break;
3949 case D_PRINT_LONG:
3950 d_append_char (dpi, 'l');
3951 break;
3952 case D_PRINT_UNSIGNED_LONG:
456cc5cf 3953 d_append_string (dpi, "ul");
31058ee3
ILT
3954 break;
3955 case D_PRINT_LONG_LONG:
456cc5cf 3956 d_append_string (dpi, "ll");
31058ee3
ILT
3957 break;
3958 case D_PRINT_UNSIGNED_LONG_LONG:
456cc5cf 3959 d_append_string (dpi, "ull");
31058ee3
ILT
3960 break;
3961 }
3962 return;
3963 }
3964 break;
69afa80d 3965
31058ee3
ILT
3966 case D_PRINT_BOOL:
3967 if (d_right (dc)->type == DEMANGLE_COMPONENT_NAME
3968 && d_right (dc)->u.s_name.len == 1
3969 && dc->type == DEMANGLE_COMPONENT_LITERAL)
3970 {
3971 switch (d_right (dc)->u.s_name.s[0])
3972 {
3973 case '0':
456cc5cf 3974 d_append_string (dpi, "false");
31058ee3
ILT
3975 return;
3976 case '1':
456cc5cf 3977 d_append_string (dpi, "true");
31058ee3
ILT
3978 return;
3979 default:
3980 break;
3981 }
3982 }
3983 break;
051664b0 3984
31058ee3
ILT
3985 default:
3986 break;
3987 }
3988 }
69afa80d 3989
31058ee3
ILT
3990 d_append_char (dpi, '(');
3991 d_print_comp (dpi, d_left (dc));
3992 d_append_char (dpi, ')');
3993 if (dc->type == DEMANGLE_COMPONENT_LITERAL_NEG)
3994 d_append_char (dpi, '-');
3995 if (tp == D_PRINT_FLOAT)
3996 d_append_char (dpi, '[');
3997 d_print_comp (dpi, d_right (dc));
3998 if (tp == D_PRINT_FLOAT)
3999 d_append_char (dpi, ']');
4000 }
bd6946d1 4001 return;
69afa80d 4002
e5df4fb1
DD
4003 case DEMANGLE_COMPONENT_JAVA_RESOURCE:
4004 d_append_string (dpi, "java resource ");
4005 d_print_comp (dpi, d_left (dc));
4006 return;
4007
4008 case DEMANGLE_COMPONENT_COMPOUND_NAME:
4009 d_print_comp (dpi, d_left (dc));
4010 d_print_comp (dpi, d_right (dc));
4011 return;
4012
4013 case DEMANGLE_COMPONENT_CHARACTER:
4014 d_append_char (dpi, dc->u.s_character.character);
4015 return;
4016
5a3d7e74
JM
4017 case DEMANGLE_COMPONENT_DECLTYPE:
4018 d_append_string (dpi, "decltype (");
4019 d_print_comp (dpi, d_left (dc));
4020 d_append_char (dpi, ')');
4021 return;
4022
38179091
JM
4023 case DEMANGLE_COMPONENT_PACK_EXPANSION:
4024 {
6afcfe0a 4025 int len;
38179091 4026 int i;
6afcfe0a
JM
4027 struct demangle_component *a = d_find_pack (dpi, d_left (dc));
4028 if (a == NULL)
4029 {
4030 /* d_find_pack won't find anything if the only packs involved
4031 in this expansion are function parameter packs; in that
4032 case, just print the pattern and "...". */
4033 d_print_subexpr (dpi, d_left (dc));
4034 d_append_string (dpi, "...");
4035 return;
4036 }
38179091 4037
6afcfe0a 4038 len = d_pack_length (a);
38179091
JM
4039 dc = d_left (dc);
4040 for (i = 0; i < len; ++i)
4041 {
4042 dpi->pack_index = i;
4043 d_print_comp (dpi, dc);
4044 if (i < len-1)
4045 d_append_string (dpi, ", ");
4046 }
4047 }
4048 return;
4049
448545cb
JM
4050 case DEMANGLE_COMPONENT_FUNCTION_PARAM:
4051 {
4052 char buf[25];
4053 d_append_string (dpi, "parm#");
4054 sprintf(buf,"%ld", dc->u.s_number.number);
4055 d_append_string (dpi, buf);
4056 return;
4057 }
4058
23b1a789
JK
4059 case DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS:
4060 d_append_string (dpi, "global constructors keyed to ");
4061 d_print_comp (dpi, dc->u.s_binary.left);
4062 return;
4063
4064 case DEMANGLE_COMPONENT_GLOBAL_DESTRUCTORS:
4065 d_append_string (dpi, "global destructors keyed to ");
4066 d_print_comp (dpi, dc->u.s_binary.left);
4067 return;
4068
bd6946d1
ILT
4069 default:
4070 d_print_error (dpi);
4071 return;
4072 }
69afa80d
AS
4073}
4074
2d6c4025
ILT
4075/* Print a Java dentifier. For Java we try to handle encoded extended
4076 Unicode characters. The C++ ABI doesn't mention Unicode encoding,
4077 so we don't it for C++. Characters are encoded as
4078 __U<hex-char>+_. */
69afa80d 4079
bd6946d1 4080static void
9486db4f 4081d_print_java_identifier (struct d_print_info *dpi, const char *name, int len)
69afa80d 4082{
2d6c4025
ILT
4083 const char *p;
4084 const char *end;
69afa80d 4085
2d6c4025
ILT
4086 end = name + len;
4087 for (p = name; p < end; ++p)
4088 {
4089 if (end - p > 3
4090 && p[0] == '_'
4091 && p[1] == '_'
4092 && p[2] == 'U')
69afa80d 4093 {
2d6c4025
ILT
4094 unsigned long c;
4095 const char *q;
4096
4097 c = 0;
4098 for (q = p + 3; q < end; ++q)
bd6946d1 4099 {
2d6c4025
ILT
4100 int dig;
4101
4102 if (IS_DIGIT (*q))
4103 dig = *q - '0';
4104 else if (*q >= 'A' && *q <= 'F')
4105 dig = *q - 'A' + 10;
4106 else if (*q >= 'a' && *q <= 'f')
4107 dig = *q - 'a' + 10;
4108 else
4109 break;
69afa80d 4110
2d6c4025
ILT
4111 c = c * 16 + dig;
4112 }
4113 /* If the Unicode character is larger than 256, we don't try
4114 to deal with it here. FIXME. */
4115 if (q < end && *q == '_' && c < 256)
4116 {
4117 d_append_char (dpi, c);
4118 p = q;
4119 continue;
bd6946d1 4120 }
bd6946d1 4121 }
2d6c4025
ILT
4122
4123 d_append_char (dpi, *p);
69afa80d 4124 }
69afa80d
AS
4125}
4126
a51753e4
ILT
4127/* Print a list of modifiers. SUFFIX is 1 if we are printing
4128 qualifiers on this after printing a function. */
69afa80d 4129
bd6946d1 4130static void
9486db4f
GDR
4131d_print_mod_list (struct d_print_info *dpi,
4132 struct d_print_mod *mods, int suffix)
69afa80d 4133{
81dc098b
ILT
4134 struct d_print_template *hold_dpt;
4135
a51753e4 4136 if (mods == NULL || d_print_saw_error (dpi))
bd6946d1 4137 return;
69afa80d 4138
a51753e4
ILT
4139 if (mods->printed
4140 || (! suffix
5e777af5
ILT
4141 && (mods->mod->type == DEMANGLE_COMPONENT_RESTRICT_THIS
4142 || mods->mod->type == DEMANGLE_COMPONENT_VOLATILE_THIS
4143 || mods->mod->type == DEMANGLE_COMPONENT_CONST_THIS)))
a51753e4
ILT
4144 {
4145 d_print_mod_list (dpi, mods->next, suffix);
4146 return;
4147 }
4148
81dc098b
ILT
4149 mods->printed = 1;
4150
4151 hold_dpt = dpi->templates;
4152 dpi->templates = mods->templates;
4153
5e777af5 4154 if (mods->mod->type == DEMANGLE_COMPONENT_FUNCTION_TYPE)
69afa80d 4155 {
bd6946d1 4156 d_print_function_type (dpi, mods->mod, mods->next);
81dc098b 4157 dpi->templates = hold_dpt;
bd6946d1
ILT
4158 return;
4159 }
5e777af5 4160 else if (mods->mod->type == DEMANGLE_COMPONENT_ARRAY_TYPE)
bd6946d1 4161 {
bd6946d1 4162 d_print_array_type (dpi, mods->mod, mods->next);
81dc098b 4163 dpi->templates = hold_dpt;
bd6946d1
ILT
4164 return;
4165 }
5e777af5 4166 else if (mods->mod->type == DEMANGLE_COMPONENT_LOCAL_NAME)
a91d1af0
ILT
4167 {
4168 struct d_print_mod *hold_modifiers;
5e777af5 4169 struct demangle_component *dc;
a91d1af0
ILT
4170
4171 /* When this is on the modifier stack, we have pulled any
4172 qualifiers off the right argument already. Otherwise, we
4173 print it as usual, but don't let the left argument see any
4174 modifiers. */
4175
4176 hold_modifiers = dpi->modifiers;
4177 dpi->modifiers = NULL;
4178 d_print_comp (dpi, d_left (mods->mod));
4179 dpi->modifiers = hold_modifiers;
4180
2d6c4025 4181 if ((dpi->options & DMGL_JAVA) == 0)
456cc5cf 4182 d_append_string (dpi, "::");
2d6c4025
ILT
4183 else
4184 d_append_char (dpi, '.');
a91d1af0
ILT
4185
4186 dc = d_right (mods->mod);
5e777af5
ILT
4187 while (dc->type == DEMANGLE_COMPONENT_RESTRICT_THIS
4188 || dc->type == DEMANGLE_COMPONENT_VOLATILE_THIS
4189 || dc->type == DEMANGLE_COMPONENT_CONST_THIS)
a91d1af0
ILT
4190 dc = d_left (dc);
4191
4192 d_print_comp (dpi, dc);
4193
4194 dpi->templates = hold_dpt;
4195 return;
4196 }
69afa80d 4197
bd6946d1 4198 d_print_mod (dpi, mods->mod);
69afa80d 4199
81dc098b
ILT
4200 dpi->templates = hold_dpt;
4201
a51753e4 4202 d_print_mod_list (dpi, mods->next, suffix);
69afa80d 4203}
81dc098b 4204
bd6946d1 4205/* Print a modifier. */
69afa80d 4206
bd6946d1 4207static void
9486db4f
GDR
4208d_print_mod (struct d_print_info *dpi,
4209 const struct demangle_component *mod)
bd6946d1
ILT
4210{
4211 switch (mod->type)
4212 {
5e777af5
ILT
4213 case DEMANGLE_COMPONENT_RESTRICT:
4214 case DEMANGLE_COMPONENT_RESTRICT_THIS:
456cc5cf 4215 d_append_string (dpi, " restrict");
bd6946d1 4216 return;
5e777af5
ILT
4217 case DEMANGLE_COMPONENT_VOLATILE:
4218 case DEMANGLE_COMPONENT_VOLATILE_THIS:
456cc5cf 4219 d_append_string (dpi, " volatile");
bd6946d1 4220 return;
5e777af5
ILT
4221 case DEMANGLE_COMPONENT_CONST:
4222 case DEMANGLE_COMPONENT_CONST_THIS:
456cc5cf 4223 d_append_string (dpi, " const");
bd6946d1 4224 return;
5e777af5 4225 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
bd6946d1
ILT
4226 d_append_char (dpi, ' ');
4227 d_print_comp (dpi, d_right (mod));
4228 return;
5e777af5 4229 case DEMANGLE_COMPONENT_POINTER:
bd6946d1
ILT
4230 /* There is no pointer symbol in Java. */
4231 if ((dpi->options & DMGL_JAVA) == 0)
4232 d_append_char (dpi, '*');
4233 return;
5e777af5 4234 case DEMANGLE_COMPONENT_REFERENCE:
bd6946d1
ILT
4235 d_append_char (dpi, '&');
4236 return;
1ab28be5
DG
4237 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
4238 d_append_string (dpi, "&&");
4239 return;
5e777af5 4240 case DEMANGLE_COMPONENT_COMPLEX:
456cc5cf 4241 d_append_string (dpi, "complex ");
bd6946d1 4242 return;
5e777af5 4243 case DEMANGLE_COMPONENT_IMAGINARY:
456cc5cf 4244 d_append_string (dpi, "imaginary ");
bd6946d1 4245 return;
5e777af5 4246 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
a51753e4 4247 if (d_last_char (dpi) != '(')
bd6946d1
ILT
4248 d_append_char (dpi, ' ');
4249 d_print_comp (dpi, d_left (mod));
456cc5cf 4250 d_append_string (dpi, "::*");
bd6946d1 4251 return;
5e777af5 4252 case DEMANGLE_COMPONENT_TYPED_NAME:
bd6946d1
ILT
4253 d_print_comp (dpi, d_left (mod));
4254 return;
4255 default:
4256 /* Otherwise, we have something that won't go back on the
4257 modifier stack, so we can just print it. */
4258 d_print_comp (dpi, mod);
4259 return;
4260 }
4261}
69afa80d 4262
bd6946d1 4263/* Print a function type, except for the return type. */
69afa80d 4264
bd6946d1 4265static void
9486db4f
GDR
4266d_print_function_type (struct d_print_info *dpi,
4267 const struct demangle_component *dc,
4268 struct d_print_mod *mods)
69afa80d 4269{
81dc098b
ILT
4270 int need_paren;
4271 int saw_mod;
31058ee3 4272 int need_space;
81dc098b 4273 struct d_print_mod *p;
a91d1af0 4274 struct d_print_mod *hold_modifiers;
81dc098b
ILT
4275
4276 need_paren = 0;
4277 saw_mod = 0;
31058ee3 4278 need_space = 0;
81dc098b 4279 for (p = mods; p != NULL; p = p->next)
bd6946d1 4280 {
81dc098b
ILT
4281 if (p->printed)
4282 break;
69afa80d 4283
81dc098b
ILT
4284 saw_mod = 1;
4285 switch (p->mod->type)
bd6946d1 4286 {
31058ee3
ILT
4287 case DEMANGLE_COMPONENT_POINTER:
4288 case DEMANGLE_COMPONENT_REFERENCE:
1ab28be5 4289 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
31058ee3
ILT
4290 need_paren = 1;
4291 break;
5e777af5
ILT
4292 case DEMANGLE_COMPONENT_RESTRICT:
4293 case DEMANGLE_COMPONENT_VOLATILE:
4294 case DEMANGLE_COMPONENT_CONST:
4295 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
5e777af5
ILT
4296 case DEMANGLE_COMPONENT_COMPLEX:
4297 case DEMANGLE_COMPONENT_IMAGINARY:
4298 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
31058ee3 4299 need_space = 1;
81dc098b
ILT
4300 need_paren = 1;
4301 break;
5e777af5
ILT
4302 case DEMANGLE_COMPONENT_RESTRICT_THIS:
4303 case DEMANGLE_COMPONENT_VOLATILE_THIS:
4304 case DEMANGLE_COMPONENT_CONST_THIS:
a51753e4 4305 break;
81dc098b
ILT
4306 default:
4307 break;
bd6946d1 4308 }
81dc098b
ILT
4309 if (need_paren)
4310 break;
4311 }
69afa80d 4312
81dc098b
ILT
4313 if (d_left (dc) != NULL && ! saw_mod)
4314 need_paren = 1;
69afa80d 4315
81dc098b 4316 if (need_paren)
a51753e4 4317 {
31058ee3 4318 if (! need_space)
a51753e4 4319 {
31058ee3
ILT
4320 if (d_last_char (dpi) != '('
4321 && d_last_char (dpi) != '*')
4322 need_space = 1;
a51753e4 4323 }
31058ee3
ILT
4324 if (need_space && d_last_char (dpi) != ' ')
4325 d_append_char (dpi, ' ');
a51753e4
ILT
4326 d_append_char (dpi, '(');
4327 }
69afa80d 4328
a91d1af0
ILT
4329 hold_modifiers = dpi->modifiers;
4330 dpi->modifiers = NULL;
4331
a51753e4 4332 d_print_mod_list (dpi, mods, 0);
69afa80d 4333
81dc098b
ILT
4334 if (need_paren)
4335 d_append_char (dpi, ')');
69afa80d 4336
bd6946d1 4337 d_append_char (dpi, '(');
69afa80d 4338
bd6946d1 4339 if (d_right (dc) != NULL)
a91d1af0 4340 d_print_comp (dpi, d_right (dc));
69afa80d 4341
bd6946d1 4342 d_append_char (dpi, ')');
a51753e4
ILT
4343
4344 d_print_mod_list (dpi, mods, 1);
a91d1af0
ILT
4345
4346 dpi->modifiers = hold_modifiers;
bd6946d1 4347}
69afa80d 4348
bd6946d1 4349/* Print an array type, except for the element type. */
69afa80d 4350
bd6946d1 4351static void
9486db4f
GDR
4352d_print_array_type (struct d_print_info *dpi,
4353 const struct demangle_component *dc,
4354 struct d_print_mod *mods)
bd6946d1
ILT
4355{
4356 int need_space;
69afa80d 4357
bd6946d1
ILT
4358 need_space = 1;
4359 if (mods != NULL)
69afa80d 4360 {
bd6946d1
ILT
4361 int need_paren;
4362 struct d_print_mod *p;
051664b0 4363
bd6946d1
ILT
4364 need_paren = 0;
4365 for (p = mods; p != NULL; p = p->next)
69afa80d 4366 {
80a19ac8 4367 if (! p->printed)
69afa80d 4368 {
80a19ac8
ILT
4369 if (p->mod->type == DEMANGLE_COMPONENT_ARRAY_TYPE)
4370 {
4371 need_space = 0;
4372 break;
4373 }
4374 else
4375 {
4376 need_paren = 1;
4377 need_space = 1;
4378 break;
4379 }
69afa80d 4380 }
bd6946d1 4381 }
69afa80d 4382
bd6946d1 4383 if (need_paren)
456cc5cf 4384 d_append_string (dpi, " (");
69afa80d 4385
a51753e4 4386 d_print_mod_list (dpi, mods, 0);
69afa80d 4387
bd6946d1
ILT
4388 if (need_paren)
4389 d_append_char (dpi, ')');
4390 }
69afa80d 4391
bd6946d1
ILT
4392 if (need_space)
4393 d_append_char (dpi, ' ');
051664b0 4394
bd6946d1 4395 d_append_char (dpi, '[');
051664b0 4396
bd6946d1
ILT
4397 if (d_left (dc) != NULL)
4398 d_print_comp (dpi, d_left (dc));
69afa80d 4399
bd6946d1
ILT
4400 d_append_char (dpi, ']');
4401}
69afa80d 4402
bd6946d1 4403/* Print an operator in an expression. */
69afa80d 4404
bd6946d1 4405static void
9486db4f
GDR
4406d_print_expr_op (struct d_print_info *dpi,
4407 const struct demangle_component *dc)
bd6946d1 4408{
5e777af5 4409 if (dc->type == DEMANGLE_COMPONENT_OPERATOR)
2d6c4025
ILT
4410 d_append_buffer (dpi, dc->u.s_operator.op->name,
4411 dc->u.s_operator.op->len);
bd6946d1
ILT
4412 else
4413 d_print_comp (dpi, dc);
69afa80d
AS
4414}
4415
bd6946d1 4416/* Print a cast. */
69afa80d 4417
bd6946d1 4418static void
9486db4f
GDR
4419d_print_cast (struct d_print_info *dpi,
4420 const struct demangle_component *dc)
69afa80d 4421{
5e777af5 4422 if (d_left (dc)->type != DEMANGLE_COMPONENT_TEMPLATE)
bd6946d1
ILT
4423 d_print_comp (dpi, d_left (dc));
4424 else
4425 {
81dc098b 4426 struct d_print_mod *hold_dpm;
bd6946d1 4427 struct d_print_template dpt;
820555e6 4428
bd6946d1
ILT
4429 /* It appears that for a templated cast operator, we need to put
4430 the template parameters in scope for the operator name, but
4431 not for the parameters. The effect is that we need to handle
f26deb3d 4432 the template printing here. */
69afa80d 4433
81dc098b
ILT
4434 hold_dpm = dpi->modifiers;
4435 dpi->modifiers = NULL;
4436
bd6946d1
ILT
4437 dpt.next = dpi->templates;
4438 dpi->templates = &dpt;
d7cf8390 4439 dpt.template_decl = d_left (dc);
820555e6 4440
bd6946d1 4441 d_print_comp (dpi, d_left (d_left (dc)));
820555e6 4442
bd6946d1 4443 dpi->templates = dpt.next;
69afa80d 4444
a51753e4
ILT
4445 if (d_last_char (dpi) == '<')
4446 d_append_char (dpi, ' ');
bd6946d1
ILT
4447 d_append_char (dpi, '<');
4448 d_print_comp (dpi, d_right (d_left (dc)));
4449 /* Avoid generating two consecutive '>' characters, to avoid
4450 the C++ syntactic ambiguity. */
a51753e4 4451 if (d_last_char (dpi) == '>')
bd6946d1
ILT
4452 d_append_char (dpi, ' ');
4453 d_append_char (dpi, '>');
81dc098b
ILT
4454
4455 dpi->modifiers = hold_dpm;
69afa80d 4456 }
bd6946d1
ILT
4457}
4458
4459/* Initialize the information structure we use to pass around
4460 information. */
4461
5e777af5
ILT
4462CP_STATIC_IF_GLIBCPP_V3
4463void
9486db4f
GDR
4464cplus_demangle_init_info (const char *mangled, int options, size_t len,
4465 struct d_info *di)
69afa80d 4466{
bd6946d1 4467 di->s = mangled;
2d6c4025 4468 di->send = mangled + len;
bd6946d1 4469 di->options = options;
69afa80d 4470
bd6946d1
ILT
4471 di->n = mangled;
4472
4473 /* We can not need more components than twice the number of chars in
4474 the mangled string. Most components correspond directly to
4475 chars, but the ARGLIST types are exceptions. */
4476 di->num_comps = 2 * len;
bd6946d1
ILT
4477 di->next_comp = 0;
4478
4479 /* Similarly, we can not need more substitutions than there are
81dc098b
ILT
4480 chars in the mangled string. */
4481 di->num_subs = len;
bd6946d1 4482 di->next_sub = 0;
2d6c4025 4483 di->did_subs = 0;
bd6946d1
ILT
4484
4485 di->last_name = NULL;
4486
2d6c4025 4487 di->expansion = 0;
69afa80d
AS
4488}
4489
456cc5cf
SB
4490/* Internal implementation for the demangler. If MANGLED is a g++ v3 ABI
4491 mangled name, return strings in repeated callback giving the demangled
4492 name. OPTIONS is the usual libiberty demangler options. On success,
4493 this returns 1. On failure, returns 0. */
69afa80d 4494
456cc5cf
SB
4495static int
4496d_demangle_callback (const char *mangled, int options,
4497 demangle_callbackref callback, void *opaque)
69afa80d 4498{
23b1a789
JK
4499 enum
4500 {
4501 DCT_TYPE,
4502 DCT_MANGLED,
4503 DCT_GLOBAL_CTORS,
4504 DCT_GLOBAL_DTORS
4505 }
4506 type;
bd6946d1 4507 struct d_info di;
5e777af5 4508 struct demangle_component *dc;
456cc5cf 4509 int status;
bd6946d1
ILT
4510
4511 if (mangled[0] == '_' && mangled[1] == 'Z')
23b1a789 4512 type = DCT_MANGLED;
bd6946d1
ILT
4513 else if (strncmp (mangled, "_GLOBAL_", 8) == 0
4514 && (mangled[8] == '.' || mangled[8] == '_' || mangled[8] == '$')
4515 && (mangled[9] == 'D' || mangled[9] == 'I')
4516 && mangled[10] == '_')
23b1a789 4517 type = mangled[9] == 'I' ? DCT_GLOBAL_CTORS : DCT_GLOBAL_DTORS;
69afa80d
AS
4518 else
4519 {
bd6946d1 4520 if ((options & DMGL_TYPES) == 0)
456cc5cf 4521 return 0;
23b1a789 4522 type = DCT_TYPE;
69afa80d
AS
4523 }
4524
456cc5cf 4525 cplus_demangle_init_info (mangled, options, strlen (mangled), &di);
051664b0 4526
2d6c4025
ILT
4527 {
4528#ifdef CP_DYNAMIC_ARRAYS
5e777af5
ILT
4529 __extension__ struct demangle_component comps[di.num_comps];
4530 __extension__ struct demangle_component *subs[di.num_subs];
2d6c4025 4531
456cc5cf
SB
4532 di.comps = comps;
4533 di.subs = subs;
2d6c4025 4534#else
456cc5cf
SB
4535 di.comps = alloca (di.num_comps * sizeof (*di.comps));
4536 di.subs = alloca (di.num_subs * sizeof (*di.subs));
2d6c4025
ILT
4537#endif
4538
23b1a789
JK
4539 switch (type)
4540 {
4541 case DCT_TYPE:
4542 dc = cplus_demangle_type (&di);
4543 break;
4544 case DCT_MANGLED:
4545 dc = cplus_demangle_mangled_name (&di, 1);
4546 break;
4547 case DCT_GLOBAL_CTORS:
4548 case DCT_GLOBAL_DTORS:
4549 d_advance (&di, 11);
4550 dc = d_make_comp (&di,
4551 (type == DCT_GLOBAL_CTORS
4552 ? DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS
4553 : DEMANGLE_COMPONENT_GLOBAL_DESTRUCTORS),
4554 d_make_name (&di, d_str (&di), strlen (d_str (&di))),
4555 NULL);
4556 d_advance (&di, strlen (d_str (&di)));
4557 break;
4558 }
bd6946d1 4559
2d6c4025
ILT
4560 /* If DMGL_PARAMS is set, then if we didn't consume the entire
4561 mangled string, then we didn't successfully demangle it. If
4562 DMGL_PARAMS is not set, we didn't look at the trailing
4563 parameters. */
4564 if (((options & DMGL_PARAMS) != 0) && d_peek_char (&di) != '\0')
4565 dc = NULL;
f26deb3d 4566
bd6946d1 4567#ifdef CP_DEMANGLE_DEBUG
456cc5cf 4568 d_dump (dc, 0);
bd6946d1
ILT
4569#endif
4570
456cc5cf
SB
4571 status = (dc != NULL)
4572 ? cplus_demangle_print_callback (options, dc, callback, opaque)
4573 : 0;
4574 }
051664b0 4575
456cc5cf
SB
4576 return status;
4577}
051664b0 4578
456cc5cf
SB
4579/* Entry point for the demangler. If MANGLED is a g++ v3 ABI mangled
4580 name, return a buffer allocated with malloc holding the demangled
4581 name. OPTIONS is the usual libiberty demangler options. On
4582 success, this sets *PALC to the allocated size of the returned
4583 buffer. On failure, this sets *PALC to 0 for a bad name, or 1 for
4584 a memory allocation failure, and returns NULL. */
2d6c4025 4585
456cc5cf
SB
4586static char *
4587d_demangle (const char *mangled, int options, size_t *palc)
4588{
4589 struct d_growable_string dgs;
4590 int status;
051664b0 4591
456cc5cf
SB
4592 d_growable_string_init (&dgs, 0);
4593
4594 status = d_demangle_callback (mangled, options,
4595 d_growable_string_callback_adapter, &dgs);
4596 if (status == 0)
4597 {
4598 free (dgs.buf);
4599 *palc = 0;
4600 return NULL;
4601 }
4602
4603 *palc = dgs.allocation_failure ? 1 : 0;
4604 return dgs.buf;
69afa80d
AS
4605}
4606
bd7e6f2d 4607#if defined(IN_LIBGCC2) || defined(IN_GLIBCPP_V3)
bd6946d1 4608
9486db4f 4609extern char *__cxa_demangle (const char *, char *, size_t *, int *);
051664b0 4610
bd6946d1
ILT
4611/* ia64 ABI-mandated entry point in the C++ runtime library for
4612 performing demangling. MANGLED_NAME is a NUL-terminated character
4613 string containing the name to be demangled.
051664b0
AS
4614
4615 OUTPUT_BUFFER is a region of memory, allocated with malloc, of
4616 *LENGTH bytes, into which the demangled name is stored. If
4617 OUTPUT_BUFFER is not long enough, it is expanded using realloc.
4618 OUTPUT_BUFFER may instead be NULL; in that case, the demangled name
bd6946d1 4619 is placed in a region of memory allocated with malloc.
051664b0 4620
456cc5cf 4621 If LENGTH is non-NULL, the length of the buffer containing the
bd6946d1 4622 demangled name, is placed in *LENGTH.
051664b0
AS
4623
4624 The return value is a pointer to the start of the NUL-terminated
4625 demangled name, or NULL if the demangling fails. The caller is
bd6946d1 4626 responsible for deallocating this memory using free.
051664b0
AS
4627
4628 *STATUS is set to one of the following values:
4629 0: The demangling operation succeeded.
bd6946d1 4630 -1: A memory allocation failure occurred.
051664b0
AS
4631 -2: MANGLED_NAME is not a valid name under the C++ ABI mangling rules.
4632 -3: One of the arguments is invalid.
4633
bd6946d1 4634 The demangling is performed using the C++ ABI mangling rules, with
051664b0
AS
4635 GNU extensions. */
4636
4637char *
9486db4f
GDR
4638__cxa_demangle (const char *mangled_name, char *output_buffer,
4639 size_t *length, int *status)
051664b0 4640{
bd6946d1
ILT
4641 char *demangled;
4642 size_t alc;
051664b0 4643
bd6946d1
ILT
4644 if (mangled_name == NULL)
4645 {
4a368ffd
ILT
4646 if (status != NULL)
4647 *status = -3;
051664b0
AS
4648 return NULL;
4649 }
051664b0 4650
bd6946d1 4651 if (output_buffer != NULL && length == NULL)
051664b0 4652 {
4a368ffd
ILT
4653 if (status != NULL)
4654 *status = -3;
4655 return NULL;
4656 }
4657
dbd6ec2b 4658 demangled = d_demangle (mangled_name, DMGL_PARAMS | DMGL_TYPES, &alc);
bd6946d1
ILT
4659
4660 if (demangled == NULL)
051664b0 4661 {
4a368ffd
ILT
4662 if (status != NULL)
4663 {
4664 if (alc == 1)
4665 *status = -1;
4666 else
4667 *status = -2;
4668 }
051664b0
AS
4669 return NULL;
4670 }
bd6946d1
ILT
4671
4672 if (output_buffer == NULL)
4673 {
4674 if (length != NULL)
4675 *length = alc;
4676 }
051664b0 4677 else
051664b0 4678 {
bd6946d1
ILT
4679 if (strlen (demangled) < *length)
4680 {
4681 strcpy (output_buffer, demangled);
4682 free (demangled);
4683 demangled = output_buffer;
4684 }
4685 else
4686 {
4687 free (output_buffer);
4688 *length = alc;
4689 }
051664b0 4690 }
bd6946d1 4691
4a368ffd
ILT
4692 if (status != NULL)
4693 *status = 0;
bd6946d1
ILT
4694
4695 return demangled;
051664b0
AS
4696}
4697
456cc5cf
SB
4698extern int __gcclibcxx_demangle_callback (const char *,
4699 void (*)
4700 (const char *, size_t, void *),
4701 void *);
4702
4703/* Alternative, allocationless entry point in the C++ runtime library
4704 for performing demangling. MANGLED_NAME is a NUL-terminated character
4705 string containing the name to be demangled.
4706
4707 CALLBACK is a callback function, called with demangled string
4708 segments as demangling progresses; it is called at least once,
4709 but may be called more than once. OPAQUE is a generalized pointer
4710 used as a callback argument.
4711
4712 The return code is one of the following values, equivalent to
4713 the STATUS values of __cxa_demangle() (excluding -1, since this
4714 function performs no memory allocations):
4715 0: The demangling operation succeeded.
4716 -2: MANGLED_NAME is not a valid name under the C++ ABI mangling rules.
4717 -3: One of the arguments is invalid.
4718
4719 The demangling is performed using the C++ ABI mangling rules, with
4720 GNU extensions. */
4721
4722int
4723__gcclibcxx_demangle_callback (const char *mangled_name,
4724 void (*callback) (const char *, size_t, void *),
4725 void *opaque)
4726{
4727 int status;
4728
4729 if (mangled_name == NULL || callback == NULL)
4730 return -3;
4731
4732 status = d_demangle_callback (mangled_name, DMGL_PARAMS | DMGL_TYPES,
4733 callback, opaque);
4734 if (status == 0)
4735 return -2;
4736
4737 return 0;
4738}
4739
bd7e6f2d 4740#else /* ! (IN_LIBGCC2 || IN_GLIBCPP_V3) */
051664b0 4741
bd6946d1
ILT
4742/* Entry point for libiberty demangler. If MANGLED is a g++ v3 ABI
4743 mangled name, return a buffer allocated with malloc holding the
4744 demangled name. Otherwise, return NULL. */
69afa80d
AS
4745
4746char *
456cc5cf 4747cplus_demangle_v3 (const char *mangled, int options)
69afa80d 4748{
bd6946d1 4749 size_t alc;
b5d1497d 4750
bd6946d1 4751 return d_demangle (mangled, options, &alc);
69afa80d
AS
4752}
4753
456cc5cf
SB
4754int
4755cplus_demangle_v3_callback (const char *mangled, int options,
4756 demangle_callbackref callback, void *opaque)
4757{
4758 return d_demangle_callback (mangled, options, callback, opaque);
4759}
4760
3b60dd8e
BM
4761/* Demangle a Java symbol. Java uses a subset of the V3 ABI C++ mangling
4762 conventions, but the output formatting is a little different.
456cc5cf
SB
4763 This instructs the C++ demangler not to emit pointer characters ("*"), to
4764 use Java's namespace separator symbol ("." instead of "::"), and to output
4765 JArray<TYPE> as TYPE[]. */
3b60dd8e
BM
4766
4767char *
456cc5cf 4768java_demangle_v3 (const char *mangled)
3b60dd8e 4769{
bd6946d1 4770 size_t alc;
3b60dd8e 4771
456cc5cf
SB
4772 return d_demangle (mangled, DMGL_JAVA | DMGL_PARAMS | DMGL_RET_POSTFIX, &alc);
4773}
a8f55e51 4774
456cc5cf
SB
4775int
4776java_demangle_v3_callback (const char *mangled,
4777 demangle_callbackref callback, void *opaque)
4778{
4779 return d_demangle_callback (mangled,
4780 DMGL_JAVA | DMGL_PARAMS | DMGL_RET_POSTFIX,
4781 callback, opaque);
3b60dd8e
BM
4782}
4783
bd7e6f2d 4784#endif /* IN_LIBGCC2 || IN_GLIBCPP_V3 */
051664b0 4785
84326592 4786#ifndef IN_GLIBCPP_V3
bd6946d1
ILT
4787
4788/* Demangle a string in order to find out whether it is a constructor
4789 or destructor. Return non-zero on success. Set *CTOR_KIND and
4790 *DTOR_KIND appropriately. */
4791
4792static int
9486db4f
GDR
4793is_ctor_or_dtor (const char *mangled,
4794 enum gnu_v3_ctor_kinds *ctor_kind,
4795 enum gnu_v3_dtor_kinds *dtor_kind)
7dce2eff 4796{
bd6946d1 4797 struct d_info di;
5e777af5 4798 struct demangle_component *dc;
a51753e4 4799 int ret;
7dce2eff 4800
bd6946d1
ILT
4801 *ctor_kind = (enum gnu_v3_ctor_kinds) 0;
4802 *dtor_kind = (enum gnu_v3_dtor_kinds) 0;
4803
5e777af5 4804 cplus_demangle_init_info (mangled, DMGL_GNU_V3, strlen (mangled), &di);
7dce2eff 4805
2d6c4025
ILT
4806 {
4807#ifdef CP_DYNAMIC_ARRAYS
5e777af5
ILT
4808 __extension__ struct demangle_component comps[di.num_comps];
4809 __extension__ struct demangle_component *subs[di.num_subs];
2d6c4025 4810
456cc5cf
SB
4811 di.comps = comps;
4812 di.subs = subs;
2d6c4025 4813#else
456cc5cf
SB
4814 di.comps = alloca (di.num_comps * sizeof (*di.comps));
4815 di.subs = alloca (di.num_subs * sizeof (*di.subs));
2d6c4025 4816#endif
bd6946d1 4817
5e777af5 4818 dc = cplus_demangle_mangled_name (&di, 1);
8d686df2 4819
2d6c4025
ILT
4820 /* Note that because we did not pass DMGL_PARAMS, we don't expect
4821 to demangle the entire string. */
7dce2eff 4822
2d6c4025
ILT
4823 ret = 0;
4824 while (dc != NULL)
4825 {
4826 switch (dc->type)
4827 {
4828 default:
4829 dc = NULL;
4830 break;
5e777af5
ILT
4831 case DEMANGLE_COMPONENT_TYPED_NAME:
4832 case DEMANGLE_COMPONENT_TEMPLATE:
4833 case DEMANGLE_COMPONENT_RESTRICT_THIS:
4834 case DEMANGLE_COMPONENT_VOLATILE_THIS:
4835 case DEMANGLE_COMPONENT_CONST_THIS:
2d6c4025
ILT
4836 dc = d_left (dc);
4837 break;
5e777af5
ILT
4838 case DEMANGLE_COMPONENT_QUAL_NAME:
4839 case DEMANGLE_COMPONENT_LOCAL_NAME:
2d6c4025
ILT
4840 dc = d_right (dc);
4841 break;
5e777af5 4842 case DEMANGLE_COMPONENT_CTOR:
2d6c4025
ILT
4843 *ctor_kind = dc->u.s_ctor.kind;
4844 ret = 1;
4845 dc = NULL;
4846 break;
5e777af5 4847 case DEMANGLE_COMPONENT_DTOR:
2d6c4025
ILT
4848 *dtor_kind = dc->u.s_dtor.kind;
4849 ret = 1;
4850 dc = NULL;
4851 break;
4852 }
4853 }
2d6c4025 4854 }
a51753e4
ILT
4855
4856 return ret;
7dce2eff
JB
4857}
4858
bd6946d1
ILT
4859/* Return whether NAME is the mangled form of a g++ V3 ABI constructor
4860 name. A non-zero return indicates the type of constructor. */
7dce2eff 4861
7dce2eff 4862enum gnu_v3_ctor_kinds
9486db4f 4863is_gnu_v3_mangled_ctor (const char *name)
7dce2eff 4864{
bd6946d1
ILT
4865 enum gnu_v3_ctor_kinds ctor_kind;
4866 enum gnu_v3_dtor_kinds dtor_kind;
7dce2eff 4867
bd6946d1 4868 if (! is_ctor_or_dtor (name, &ctor_kind, &dtor_kind))
f08b7eee 4869 return (enum gnu_v3_ctor_kinds) 0;
bd6946d1 4870 return ctor_kind;
7dce2eff
JB
4871}
4872
4873
bd6946d1
ILT
4874/* Return whether NAME is the mangled form of a g++ V3 ABI destructor
4875 name. A non-zero return indicates the type of destructor. */
4876
7dce2eff 4877enum gnu_v3_dtor_kinds
9486db4f 4878is_gnu_v3_mangled_dtor (const char *name)
7dce2eff 4879{
bd6946d1
ILT
4880 enum gnu_v3_ctor_kinds ctor_kind;
4881 enum gnu_v3_dtor_kinds dtor_kind;
7dce2eff 4882
bd6946d1 4883 if (! is_ctor_or_dtor (name, &ctor_kind, &dtor_kind))
f08b7eee 4884 return (enum gnu_v3_dtor_kinds) 0;
bd6946d1 4885 return dtor_kind;
7dce2eff
JB
4886}
4887
bd6946d1 4888#endif /* IN_GLIBCPP_V3 */
7dce2eff 4889
69afa80d
AS
4890#ifdef STANDALONE_DEMANGLER
4891
4892#include "getopt.h"
bd6946d1
ILT
4893#include "dyn-string.h"
4894
93079c81 4895static void print_usage (FILE* fp, int exit_value);
69afa80d 4896
bd6946d1
ILT
4897#define IS_ALPHA(CHAR) \
4898 (((CHAR) >= 'a' && (CHAR) <= 'z') \
4899 || ((CHAR) >= 'A' && (CHAR) <= 'Z'))
69afa80d
AS
4900
4901/* Non-zero if CHAR is a character than can occur in a mangled name. */
3faa108c 4902#define is_mangled_char(CHAR) \
31e0ab1f
AS
4903 (IS_ALPHA (CHAR) || IS_DIGIT (CHAR) \
4904 || (CHAR) == '_' || (CHAR) == '.' || (CHAR) == '$')
69afa80d
AS
4905
4906/* The name of this program, as invoked. */
4907const char* program_name;
4908
4909/* Prints usage summary to FP and then exits with EXIT_VALUE. */
4910
4911static void
9486db4f 4912print_usage (FILE* fp, int exit_value)
69afa80d
AS
4913{
4914 fprintf (fp, "Usage: %s [options] [names ...]\n", program_name);
d01ce591 4915 fprintf (fp, "Options:\n");
69afa80d 4916 fprintf (fp, " -h,--help Display this message.\n");
ad07f5e5 4917 fprintf (fp, " -p,--no-params Don't display function parameters\n");
69afa80d
AS
4918 fprintf (fp, " -v,--verbose Produce verbose demanglings.\n");
4919 fprintf (fp, "If names are provided, they are demangled. Otherwise filters standard input.\n");
4920
4921 exit (exit_value);
4922}
4923
4924/* Option specification for getopt_long. */
5e65297b 4925static const struct option long_options[] =
69afa80d 4926{
ad07f5e5
ILT
4927 { "help", no_argument, NULL, 'h' },
4928 { "no-params", no_argument, NULL, 'p' },
4929 { "verbose", no_argument, NULL, 'v' },
4930 { NULL, no_argument, NULL, 0 },
69afa80d
AS
4931};
4932
4933/* Main entry for a demangling filter executable. It will demangle
4934 its command line arguments, if any. If none are provided, it will
4935 filter stdin to stdout, replacing any recognized mangled C++ names
4936 with their demangled equivalents. */
4937
4938int
9486db4f 4939main (int argc, char *argv[])
69afa80d 4940{
69afa80d
AS
4941 int i;
4942 int opt_char;
bd6946d1 4943 int options = DMGL_PARAMS | DMGL_ANSI | DMGL_TYPES;
69afa80d
AS
4944
4945 /* Use the program name of this program, as invoked. */
4946 program_name = argv[0];
4947
4948 /* Parse options. */
4949 do
4950 {
ad07f5e5 4951 opt_char = getopt_long (argc, argv, "hpv", long_options, NULL);
69afa80d
AS
4952 switch (opt_char)
4953 {
4954 case '?': /* Unrecognized option. */
4955 print_usage (stderr, 1);
4956 break;
4957
4958 case 'h':
4959 print_usage (stdout, 0);
4960 break;
4961
ad07f5e5
ILT
4962 case 'p':
4963 options &= ~ DMGL_PARAMS;
4964 break;
4965
69afa80d 4966 case 'v':
bd6946d1 4967 options |= DMGL_VERBOSE;
69afa80d
AS
4968 break;
4969 }
4970 }
4971 while (opt_char != -1);
4972
4973 if (optind == argc)
4974 /* No command line arguments were provided. Filter stdin. */
4975 {
4976 dyn_string_t mangled = dyn_string_new (3);
bd6946d1 4977 char *s;
69afa80d
AS
4978
4979 /* Read all of input. */
4980 while (!feof (stdin))
4981 {
bd6946d1 4982 char c;
69afa80d
AS
4983
4984 /* Pile characters into mangled until we hit one that can't
4985 occur in a mangled name. */
4986 c = getchar ();
4987 while (!feof (stdin) && is_mangled_char (c))
4988 {
4989 dyn_string_append_char (mangled, c);
4990 if (feof (stdin))
4991 break;
4992 c = getchar ();
4993 }
4994
bd6946d1 4995 if (dyn_string_length (mangled) > 0)
051664b0 4996 {
4a368ffd
ILT
4997#ifdef IN_GLIBCPP_V3
4998 s = __cxa_demangle (dyn_string_buf (mangled), NULL, NULL, NULL);
4999#else
bd6946d1 5000 s = cplus_demangle_v3 (dyn_string_buf (mangled), options);
4a368ffd 5001#endif
bd6946d1
ILT
5002
5003 if (s != NULL)
5004 {
5005 fputs (s, stdout);
5006 free (s);
5007 }
5008 else
5009 {
5010 /* It might not have been a mangled name. Print the
5011 original text. */
5012 fputs (dyn_string_buf (mangled), stdout);
5013 }
5014
5015 dyn_string_clear (mangled);
051664b0 5016 }
69afa80d
AS
5017
5018 /* If we haven't hit EOF yet, we've read one character that
5019 can't occur in a mangled name, so print it out. */
5020 if (!feof (stdin))
5021 putchar (c);
69afa80d
AS
5022 }
5023
5024 dyn_string_delete (mangled);
69afa80d
AS
5025 }
5026 else
5027 /* Demangle command line arguments. */
5028 {
69afa80d
AS
5029 /* Loop over command line arguments. */
5030 for (i = optind; i < argc; ++i)
5031 {
bd6946d1 5032 char *s;
4a368ffd
ILT
5033#ifdef IN_GLIBCPP_V3
5034 int status;
5035#endif
bd6946d1 5036
69afa80d 5037 /* Attempt to demangle. */
4a368ffd
ILT
5038#ifdef IN_GLIBCPP_V3
5039 s = __cxa_demangle (argv[i], NULL, NULL, &status);
5040#else
bd6946d1 5041 s = cplus_demangle_v3 (argv[i], options);
4a368ffd 5042#endif
69afa80d
AS
5043
5044 /* If it worked, print the demangled name. */
bd6946d1 5045 if (s != NULL)
051664b0 5046 {
bd6946d1
ILT
5047 printf ("%s\n", s);
5048 free (s);
051664b0 5049 }
bd6946d1 5050 else
4a368ffd
ILT
5051 {
5052#ifdef IN_GLIBCPP_V3
5053 fprintf (stderr, "Failed: %s (status %d)\n", argv[i], status);
5054#else
5055 fprintf (stderr, "Failed: %s\n", argv[i]);
5056#endif
5057 }
69afa80d 5058 }
69afa80d
AS
5059 }
5060
5061 return 0;
5062}
5063
5064#endif /* STANDALONE_DEMANGLER */