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