]> git.ipfire.org Git - thirdparty/gcc.git/blob - libiberty/cp-demangle.c
c++: Fix templated convertion operator demangling
[thirdparty/gcc.git] / libiberty / cp-demangle.c
1 /* Demangler for g++ V3 ABI.
2 Copyright (C) 2003-2023 Free Software Foundation, Inc.
3 Written by Ian Lance Taylor <ian@wasabisystems.com>.
4
5 This file is part of the libiberty library, which is part of GCC.
6
7 This file is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
11
12 In addition to the permissions in the GNU General Public License, the
13 Free Software Foundation gives you unlimited permission to link the
14 compiled version of this file into combinations with other programs,
15 and to distribute those combinations without any restriction coming
16 from the use of this file. (The General Public License restrictions
17 do apply in other respects; for example, they cover modification of
18 the file, and distribution when not linked into a combined
19 executable.)
20
21 This program is distributed in the hope that it will be useful,
22 but WITHOUT ANY WARRANTY; without even the implied warranty of
23 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
24 GNU General Public License for more details.
25
26 You should have received a copy of the GNU General Public License
27 along with this program; if not, write to the Free Software
28 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
29 */
30
31 /* This code implements a demangler for the g++ V3 ABI. The ABI is
32 described on this web page:
33 https://itanium-cxx-abi.github.io/cxx-abi/abi.html#mangling
34
35 This code was written while looking at the demangler written by
36 Alex Samuel <samuel@codesourcery.com>.
37
38 This code first pulls the mangled name apart into a list of
39 components, and then walks the list generating the demangled
40 name.
41
42 This file will normally define the following functions, q.v.:
43 char *cplus_demangle_v3(const char *mangled, int options)
44 char *java_demangle_v3(const char *mangled)
45 int cplus_demangle_v3_callback(const char *mangled, int options,
46 demangle_callbackref callback)
47 int java_demangle_v3_callback(const char *mangled,
48 demangle_callbackref callback)
49 enum gnu_v3_ctor_kinds is_gnu_v3_mangled_ctor (const char *name)
50 enum gnu_v3_dtor_kinds is_gnu_v3_mangled_dtor (const char *name)
51
52 Also, the interface to the component list is public, and defined in
53 demangle.h. The interface consists of these types, which are
54 defined in demangle.h:
55 enum demangle_component_type
56 struct demangle_component
57 demangle_callbackref
58 and these functions defined in this file:
59 cplus_demangle_fill_name
60 cplus_demangle_fill_extended_operator
61 cplus_demangle_fill_ctor
62 cplus_demangle_fill_dtor
63 cplus_demangle_print
64 cplus_demangle_print_callback
65 and other functions defined in the file cp-demint.c.
66
67 This file also defines some other functions and variables which are
68 only to be used by the file cp-demint.c.
69
70 Preprocessor macros you can define while compiling this file:
71
72 IN_LIBGCC2
73 If defined, this file defines the following functions, q.v.:
74 char *__cxa_demangle (const char *mangled, char *buf, size_t *len,
75 int *status)
76 int __gcclibcxx_demangle_callback (const char *,
77 void (*)
78 (const char *, size_t, void *),
79 void *)
80 instead of cplus_demangle_v3[_callback]() and
81 java_demangle_v3[_callback]().
82
83 IN_GLIBCPP_V3
84 If defined, this file defines only __cxa_demangle() and
85 __gcclibcxx_demangle_callback(), and no other publically visible
86 functions or variables.
87
88 STANDALONE_DEMANGLER
89 If defined, this file defines a main() function which demangles
90 any arguments, or, if none, demangles stdin.
91
92 CP_DEMANGLE_DEBUG
93 If defined, turns on debugging mode, which prints information on
94 stdout about the mangled string. This is not generally useful.
95
96 CHECK_DEMANGLER
97 If defined, additional sanity checks will be performed. It will
98 cause some slowdown, but will allow to catch out-of-bound access
99 errors earlier. This macro is intended for testing and debugging. */
100
101 #if defined (_AIX) && !defined (__GNUC__)
102 #pragma alloca
103 #endif
104
105 #ifdef HAVE_CONFIG_H
106 #include "config.h"
107 #endif
108
109 #include <stdio.h>
110
111 #ifdef HAVE_STDLIB_H
112 #include <stdlib.h>
113 #endif
114 #ifdef HAVE_STRING_H
115 #include <string.h>
116 #endif
117
118 #ifdef HAVE_ALLOCA_H
119 # include <alloca.h>
120 #else
121 # ifndef alloca
122 # ifdef __GNUC__
123 # define alloca __builtin_alloca
124 # else
125 extern char *alloca ();
126 # endif /* __GNUC__ */
127 # endif /* alloca */
128 #endif /* HAVE_ALLOCA_H */
129
130 #ifdef HAVE_LIMITS_H
131 #include <limits.h>
132 #endif
133 #ifndef INT_MAX
134 # define INT_MAX (int)(((unsigned int) ~0) >> 1) /* 0x7FFFFFFF */
135 #endif
136
137 #include "ansidecl.h"
138 #include "libiberty.h"
139 #include "demangle.h"
140 #include "cp-demangle.h"
141
142 /* If IN_GLIBCPP_V3 is defined, some functions are made static. We
143 also rename them via #define to avoid compiler errors when the
144 static definition conflicts with the extern declaration in a header
145 file. */
146 #ifdef IN_GLIBCPP_V3
147
148 #define CP_STATIC_IF_GLIBCPP_V3 static
149
150 #define cplus_demangle_fill_name d_fill_name
151 static int d_fill_name (struct demangle_component *, const char *, int);
152
153 #define cplus_demangle_fill_extended_operator d_fill_extended_operator
154 static int
155 d_fill_extended_operator (struct demangle_component *, int,
156 struct demangle_component *);
157
158 #define cplus_demangle_fill_ctor d_fill_ctor
159 static int
160 d_fill_ctor (struct demangle_component *, enum gnu_v3_ctor_kinds,
161 struct demangle_component *);
162
163 #define cplus_demangle_fill_dtor d_fill_dtor
164 static int
165 d_fill_dtor (struct demangle_component *, enum gnu_v3_dtor_kinds,
166 struct demangle_component *);
167
168 #define cplus_demangle_mangled_name d_mangled_name
169 static struct demangle_component *d_mangled_name (struct d_info *, int);
170
171 #define cplus_demangle_type d_type
172 static struct demangle_component *d_type (struct d_info *);
173
174 #define cplus_demangle_print d_print
175 static char *d_print (int, struct demangle_component *, int, size_t *);
176
177 #define cplus_demangle_print_callback d_print_callback
178 static int d_print_callback (int, struct demangle_component *,
179 demangle_callbackref, void *);
180
181 #define cplus_demangle_init_info d_init_info
182 static void d_init_info (const char *, int, size_t, struct d_info *);
183
184 #else /* ! defined(IN_GLIBCPP_V3) */
185 #define CP_STATIC_IF_GLIBCPP_V3
186 #endif /* ! defined(IN_GLIBCPP_V3) */
187
188 /* See if the compiler supports dynamic arrays. */
189
190 #ifdef __GNUC__
191 #define CP_DYNAMIC_ARRAYS
192 #else
193 #ifdef __STDC__
194 #ifdef __STDC_VERSION__
195 #if __STDC_VERSION__ >= 199901L && !__STDC_NO_VLA__
196 #define CP_DYNAMIC_ARRAYS
197 #endif /* __STDC_VERSION__ >= 199901L && !__STDC_NO_VLA__ */
198 #endif /* defined (__STDC_VERSION__) */
199 #endif /* defined (__STDC__) */
200 #endif /* ! defined (__GNUC__) */
201
202 /* We avoid pulling in the ctype tables, to prevent pulling in
203 additional unresolved symbols when this code is used in a library.
204 FIXME: Is this really a valid reason? This comes from the original
205 V3 demangler code.
206
207 As of this writing this file has the following undefined references
208 when compiled with -DIN_GLIBCPP_V3: realloc, free, memcpy, strcpy,
209 strcat, strlen. */
210
211 #define IS_DIGIT(c) ((c) >= '0' && (c) <= '9')
212 #define IS_UPPER(c) ((c) >= 'A' && (c) <= 'Z')
213 #define IS_LOWER(c) ((c) >= 'a' && (c) <= 'z')
214
215 /* The prefix prepended by GCC to an identifier represnting the
216 anonymous namespace. */
217 #define ANONYMOUS_NAMESPACE_PREFIX "_GLOBAL_"
218 #define ANONYMOUS_NAMESPACE_PREFIX_LEN \
219 (sizeof (ANONYMOUS_NAMESPACE_PREFIX) - 1)
220
221 /* Information we keep for the standard substitutions. */
222
223 struct d_standard_sub_info
224 {
225 /* The code for this substitution. */
226 char code;
227 /* The simple string it expands to. */
228 const char *simple_expansion;
229 /* The length of the simple expansion. */
230 int simple_len;
231 /* The results of a full, verbose, expansion. This is used when
232 qualifying a constructor/destructor, or when in verbose mode. */
233 const char *full_expansion;
234 /* The length of the full expansion. */
235 int full_len;
236 /* What to set the last_name field of d_info to; NULL if we should
237 not set it. This is only relevant when qualifying a
238 constructor/destructor. */
239 const char *set_last_name;
240 /* The length of set_last_name. */
241 int set_last_name_len;
242 };
243
244 /* Accessors for subtrees of struct demangle_component. */
245
246 #define d_left(dc) ((dc)->u.s_binary.left)
247 #define d_right(dc) ((dc)->u.s_binary.right)
248
249 /* A list of templates. This is used while printing. */
250
251 struct d_print_template
252 {
253 /* Next template on the list. */
254 struct d_print_template *next;
255 /* This template. */
256 const struct demangle_component *template_decl;
257 };
258
259 /* A list of type modifiers. This is used while printing. */
260
261 struct d_print_mod
262 {
263 /* Next modifier on the list. These are in the reverse of the order
264 in which they appeared in the mangled string. */
265 struct d_print_mod *next;
266 /* The modifier. */
267 struct demangle_component *mod;
268 /* Whether this modifier was printed. */
269 int printed;
270 /* The list of templates which applies to this modifier. */
271 struct d_print_template *templates;
272 };
273
274 /* We use these structures to hold information during printing. */
275
276 struct d_growable_string
277 {
278 /* Buffer holding the result. */
279 char *buf;
280 /* Current length of data in buffer. */
281 size_t len;
282 /* Allocated size of buffer. */
283 size_t alc;
284 /* Set to 1 if we had a memory allocation failure. */
285 int allocation_failure;
286 };
287
288 /* Stack of components, innermost first, used to avoid loops. */
289
290 struct d_component_stack
291 {
292 /* This component. */
293 const struct demangle_component *dc;
294 /* This component's parent. */
295 const struct d_component_stack *parent;
296 };
297
298 /* A demangle component and some scope captured when it was first
299 traversed. */
300
301 struct d_saved_scope
302 {
303 /* The component whose scope this is. */
304 const struct demangle_component *container;
305 /* The list of templates, if any, that was current when this
306 scope was captured. */
307 struct d_print_template *templates;
308 };
309
310 /* Checkpoint structure to allow backtracking. This holds copies
311 of the fields of struct d_info that need to be restored
312 if a trial parse needs to be backtracked over. */
313
314 struct d_info_checkpoint
315 {
316 const char *n;
317 int next_comp;
318 int next_sub;
319 int expansion;
320 };
321
322 /* Maximum number of times d_print_comp may be called recursively. */
323 #define MAX_RECURSION_COUNT 1024
324
325 enum { D_PRINT_BUFFER_LENGTH = 256 };
326 struct d_print_info
327 {
328 /* Fixed-length allocated buffer for demangled data, flushed to the
329 callback with a NUL termination once full. */
330 char buf[D_PRINT_BUFFER_LENGTH];
331 /* Current length of data in buffer. */
332 size_t len;
333 /* The last character printed, saved individually so that it survives
334 any buffer flush. */
335 char last_char;
336 /* Callback function to handle demangled buffer flush. */
337 demangle_callbackref callback;
338 /* Opaque callback argument. */
339 void *opaque;
340 /* The current list of templates, if any. */
341 struct d_print_template *templates;
342 /* The current list of modifiers (e.g., pointer, reference, etc.),
343 if any. */
344 struct d_print_mod *modifiers;
345 /* Set to 1 if we saw a demangling error. */
346 int demangle_failure;
347 /* Number of times d_print_comp was recursively called. Should not
348 be bigger than MAX_RECURSION_COUNT. */
349 int recursion;
350 /* 1 more than the number of explicit template parms of a lambda. Template
351 parm references >= are actually 'auto'. */
352 int lambda_tpl_parms;
353 /* The current index into any template argument packs we are using
354 for printing, or -1 to print the whole pack. */
355 int pack_index;
356 /* Number of d_print_flush calls so far. */
357 unsigned long int flush_count;
358 /* Stack of components, innermost first, used to avoid loops. */
359 const struct d_component_stack *component_stack;
360 /* Array of saved scopes for evaluating substitutions. */
361 struct d_saved_scope *saved_scopes;
362 /* Index of the next unused saved scope in the above array. */
363 int next_saved_scope;
364 /* Number of saved scopes in the above array. */
365 int num_saved_scopes;
366 /* Array of templates for saving into scopes. */
367 struct d_print_template *copy_templates;
368 /* Index of the next unused copy template in the above array. */
369 int next_copy_template;
370 /* Number of copy templates in the above array. */
371 int num_copy_templates;
372 /* The nearest enclosing template, if any. */
373 const struct demangle_component *current_template;
374 };
375
376 #ifdef CP_DEMANGLE_DEBUG
377 static void d_dump (struct demangle_component *, int);
378 #endif
379
380 static struct demangle_component *
381 d_make_empty (struct d_info *);
382
383 static struct demangle_component *
384 d_make_comp (struct d_info *, enum demangle_component_type,
385 struct demangle_component *,
386 struct demangle_component *);
387
388 static struct demangle_component *
389 d_make_name (struct d_info *, const char *, int);
390
391 static struct demangle_component *
392 d_make_demangle_mangled_name (struct d_info *, const char *);
393
394 static struct demangle_component *
395 d_make_builtin_type (struct d_info *,
396 const struct demangle_builtin_type_info *);
397
398 static struct demangle_component *
399 d_make_operator (struct d_info *,
400 const struct demangle_operator_info *);
401
402 static struct demangle_component *
403 d_make_extended_operator (struct d_info *, int,
404 struct demangle_component *);
405
406 static struct demangle_component *
407 d_make_ctor (struct d_info *, enum gnu_v3_ctor_kinds,
408 struct demangle_component *);
409
410 static struct demangle_component *
411 d_make_dtor (struct d_info *, enum gnu_v3_dtor_kinds,
412 struct demangle_component *);
413
414 static struct demangle_component *
415 d_make_template_param (struct d_info *, int);
416
417 static struct demangle_component *
418 d_make_sub (struct d_info *, const char *, int);
419
420 static int
421 has_return_type (struct demangle_component *);
422
423 static int
424 is_ctor_dtor_or_conversion (struct demangle_component *);
425
426 static struct demangle_component *d_encoding (struct d_info *, int);
427
428 static struct demangle_component *d_name (struct d_info *, int substable);
429
430 static struct demangle_component *d_nested_name (struct d_info *);
431
432 static int d_maybe_module_name (struct d_info *, struct demangle_component **);
433
434 static struct demangle_component *d_prefix (struct d_info *, int);
435
436 static struct demangle_component *d_unqualified_name (struct d_info *,
437 struct demangle_component *scope, struct demangle_component *module);
438
439 static struct demangle_component *d_source_name (struct d_info *);
440
441 static int d_number (struct d_info *);
442
443 static struct demangle_component *d_identifier (struct d_info *, int);
444
445 static struct demangle_component *d_operator_name (struct d_info *);
446
447 static struct demangle_component *d_special_name (struct d_info *);
448
449 static struct demangle_component *d_parmlist (struct d_info *);
450
451 static int d_call_offset (struct d_info *, int);
452
453 static struct demangle_component *d_ctor_dtor_name (struct d_info *);
454
455 static struct demangle_component **
456 d_cv_qualifiers (struct d_info *, struct demangle_component **, int);
457
458 static struct demangle_component *
459 d_ref_qualifier (struct d_info *, struct demangle_component *);
460
461 static struct demangle_component *
462 d_function_type (struct d_info *);
463
464 static struct demangle_component *
465 d_bare_function_type (struct d_info *, int);
466
467 static struct demangle_component *
468 d_class_enum_type (struct d_info *, int);
469
470 static struct demangle_component *d_array_type (struct d_info *);
471
472 static struct demangle_component *d_vector_type (struct d_info *);
473
474 static struct demangle_component *
475 d_pointer_to_member_type (struct d_info *);
476
477 static struct demangle_component *
478 d_template_param (struct d_info *);
479
480 static struct demangle_component *d_template_args (struct d_info *);
481 static struct demangle_component *d_template_args_1 (struct d_info *);
482
483 static struct demangle_component *
484 d_template_arg (struct d_info *);
485
486 static struct demangle_component *d_expression (struct d_info *);
487
488 static struct demangle_component *d_expr_primary (struct d_info *);
489
490 static struct demangle_component *d_local_name (struct d_info *);
491
492 static int d_discriminator (struct d_info *);
493
494 static struct demangle_component *d_template_parm (struct d_info *, int *bad);
495
496 static struct demangle_component *d_template_head (struct d_info *, int *bad);
497
498 static struct demangle_component *d_lambda (struct d_info *);
499
500 static struct demangle_component *d_unnamed_type (struct d_info *);
501
502 static struct demangle_component *
503 d_clone_suffix (struct d_info *, struct demangle_component *);
504
505 static int
506 d_add_substitution (struct d_info *, struct demangle_component *);
507
508 static struct demangle_component *d_substitution (struct d_info *, int);
509
510 static void d_checkpoint (struct d_info *, struct d_info_checkpoint *);
511
512 static void d_backtrack (struct d_info *, struct d_info_checkpoint *);
513
514 static void d_growable_string_init (struct d_growable_string *, size_t);
515
516 static inline void
517 d_growable_string_resize (struct d_growable_string *, size_t);
518
519 static inline void
520 d_growable_string_append_buffer (struct d_growable_string *,
521 const char *, size_t);
522 static void
523 d_growable_string_callback_adapter (const char *, size_t, void *);
524
525 static void
526 d_print_init (struct d_print_info *, demangle_callbackref, void *,
527 struct demangle_component *);
528
529 static inline void d_print_error (struct d_print_info *);
530
531 static inline int d_print_saw_error (struct d_print_info *);
532
533 static inline void d_print_flush (struct d_print_info *);
534
535 static inline void d_append_char (struct d_print_info *, char);
536
537 static inline void d_append_buffer (struct d_print_info *,
538 const char *, size_t);
539
540 static inline void d_append_string (struct d_print_info *, const char *);
541
542 static inline char d_last_char (struct d_print_info *);
543
544 static void
545 d_print_comp (struct d_print_info *, int, struct demangle_component *);
546
547 static void
548 d_print_java_identifier (struct d_print_info *, const char *, int);
549
550 static void
551 d_print_mod_list (struct d_print_info *, int, struct d_print_mod *, int);
552
553 static void
554 d_print_mod (struct d_print_info *, int, struct demangle_component *);
555
556 static void
557 d_print_function_type (struct d_print_info *, int,
558 struct demangle_component *,
559 struct d_print_mod *);
560
561 static void
562 d_print_array_type (struct d_print_info *, int,
563 struct demangle_component *,
564 struct d_print_mod *);
565
566 static void
567 d_print_expr_op (struct d_print_info *, int, struct demangle_component *);
568
569 static void d_print_cast (struct d_print_info *, int,
570 struct demangle_component *);
571 static void d_print_conversion (struct d_print_info *, int,
572 struct demangle_component *);
573
574 static int d_demangle_callback (const char *, int,
575 demangle_callbackref, void *);
576 static char *d_demangle (const char *, int, size_t *);
577
578 #define FNQUAL_COMPONENT_CASE \
579 case DEMANGLE_COMPONENT_RESTRICT_THIS: \
580 case DEMANGLE_COMPONENT_VOLATILE_THIS: \
581 case DEMANGLE_COMPONENT_CONST_THIS: \
582 case DEMANGLE_COMPONENT_REFERENCE_THIS: \
583 case DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS: \
584 case DEMANGLE_COMPONENT_TRANSACTION_SAFE: \
585 case DEMANGLE_COMPONENT_NOEXCEPT: \
586 case DEMANGLE_COMPONENT_THROW_SPEC
587
588 /* True iff TYPE is a demangling component representing a
589 function-type-qualifier. */
590
591 static int
592 is_fnqual_component_type (enum demangle_component_type type)
593 {
594 switch (type)
595 {
596 FNQUAL_COMPONENT_CASE:
597 return 1;
598 default:
599 break;
600 }
601 return 0;
602 }
603
604
605 #ifdef CP_DEMANGLE_DEBUG
606
607 static void
608 d_dump (struct demangle_component *dc, int indent)
609 {
610 int i;
611
612 if (dc == NULL)
613 {
614 if (indent == 0)
615 printf ("failed demangling\n");
616 return;
617 }
618
619 for (i = 0; i < indent; ++i)
620 putchar (' ');
621
622 switch (dc->type)
623 {
624 case DEMANGLE_COMPONENT_NAME:
625 printf ("name '%.*s'\n", dc->u.s_name.len, dc->u.s_name.s);
626 return;
627 case DEMANGLE_COMPONENT_TAGGED_NAME:
628 printf ("tagged name\n");
629 d_dump (dc->u.s_binary.left, indent + 2);
630 d_dump (dc->u.s_binary.right, indent + 2);
631 return;
632 case DEMANGLE_COMPONENT_TEMPLATE_PARAM:
633 printf ("template parameter %ld\n", dc->u.s_number.number);
634 return;
635 case DEMANGLE_COMPONENT_TPARM_OBJ:
636 printf ("template parameter object\n");
637 break;
638 case DEMANGLE_COMPONENT_FUNCTION_PARAM:
639 printf ("function parameter %ld\n", dc->u.s_number.number);
640 return;
641 case DEMANGLE_COMPONENT_CTOR:
642 printf ("constructor %d\n", (int) dc->u.s_ctor.kind);
643 d_dump (dc->u.s_ctor.name, indent + 2);
644 return;
645 case DEMANGLE_COMPONENT_DTOR:
646 printf ("destructor %d\n", (int) dc->u.s_dtor.kind);
647 d_dump (dc->u.s_dtor.name, indent + 2);
648 return;
649 case DEMANGLE_COMPONENT_SUB_STD:
650 printf ("standard substitution %s\n", dc->u.s_string.string);
651 return;
652 case DEMANGLE_COMPONENT_BUILTIN_TYPE:
653 printf ("builtin type %s\n", dc->u.s_builtin.type->name);
654 return;
655 case DEMANGLE_COMPONENT_EXTENDED_BUILTIN_TYPE:
656 {
657 char suffix[2] = { dc->u.s_extended_builtin.type->suffix, 0 };
658 printf ("builtin type %s%d%s\n", dc->u.s_extended_builtin.type->name,
659 dc->u.s_extended_builtin.type->arg, suffix);
660 }
661 return;
662 case DEMANGLE_COMPONENT_OPERATOR:
663 printf ("operator %s\n", dc->u.s_operator.op->name);
664 return;
665 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
666 printf ("extended operator with %d args\n",
667 dc->u.s_extended_operator.args);
668 d_dump (dc->u.s_extended_operator.name, indent + 2);
669 return;
670
671 case DEMANGLE_COMPONENT_QUAL_NAME:
672 printf ("qualified name\n");
673 break;
674 case DEMANGLE_COMPONENT_LOCAL_NAME:
675 printf ("local name\n");
676 break;
677 case DEMANGLE_COMPONENT_TYPED_NAME:
678 printf ("typed name\n");
679 break;
680 case DEMANGLE_COMPONENT_TEMPLATE:
681 printf ("template\n");
682 break;
683 case DEMANGLE_COMPONENT_VTABLE:
684 printf ("vtable\n");
685 break;
686 case DEMANGLE_COMPONENT_VTT:
687 printf ("VTT\n");
688 break;
689 case DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE:
690 printf ("construction vtable\n");
691 break;
692 case DEMANGLE_COMPONENT_TYPEINFO:
693 printf ("typeinfo\n");
694 break;
695 case DEMANGLE_COMPONENT_TYPEINFO_NAME:
696 printf ("typeinfo name\n");
697 break;
698 case DEMANGLE_COMPONENT_TYPEINFO_FN:
699 printf ("typeinfo function\n");
700 break;
701 case DEMANGLE_COMPONENT_THUNK:
702 printf ("thunk\n");
703 break;
704 case DEMANGLE_COMPONENT_VIRTUAL_THUNK:
705 printf ("virtual thunk\n");
706 break;
707 case DEMANGLE_COMPONENT_COVARIANT_THUNK:
708 printf ("covariant thunk\n");
709 break;
710 case DEMANGLE_COMPONENT_JAVA_CLASS:
711 printf ("java class\n");
712 break;
713 case DEMANGLE_COMPONENT_GUARD:
714 printf ("guard\n");
715 break;
716 case DEMANGLE_COMPONENT_REFTEMP:
717 printf ("reference temporary\n");
718 break;
719 case DEMANGLE_COMPONENT_HIDDEN_ALIAS:
720 printf ("hidden alias\n");
721 break;
722 case DEMANGLE_COMPONENT_TRANSACTION_CLONE:
723 printf ("transaction clone\n");
724 break;
725 case DEMANGLE_COMPONENT_NONTRANSACTION_CLONE:
726 printf ("non-transaction clone\n");
727 break;
728 case DEMANGLE_COMPONENT_RESTRICT:
729 printf ("restrict\n");
730 break;
731 case DEMANGLE_COMPONENT_VOLATILE:
732 printf ("volatile\n");
733 break;
734 case DEMANGLE_COMPONENT_CONST:
735 printf ("const\n");
736 break;
737 case DEMANGLE_COMPONENT_RESTRICT_THIS:
738 printf ("restrict this\n");
739 break;
740 case DEMANGLE_COMPONENT_VOLATILE_THIS:
741 printf ("volatile this\n");
742 break;
743 case DEMANGLE_COMPONENT_CONST_THIS:
744 printf ("const this\n");
745 break;
746 case DEMANGLE_COMPONENT_REFERENCE_THIS:
747 printf ("reference this\n");
748 break;
749 case DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS:
750 printf ("rvalue reference this\n");
751 break;
752 case DEMANGLE_COMPONENT_TRANSACTION_SAFE:
753 printf ("transaction_safe this\n");
754 break;
755 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
756 printf ("vendor type qualifier\n");
757 break;
758 case DEMANGLE_COMPONENT_POINTER:
759 printf ("pointer\n");
760 break;
761 case DEMANGLE_COMPONENT_REFERENCE:
762 printf ("reference\n");
763 break;
764 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
765 printf ("rvalue reference\n");
766 break;
767 case DEMANGLE_COMPONENT_COMPLEX:
768 printf ("complex\n");
769 break;
770 case DEMANGLE_COMPONENT_IMAGINARY:
771 printf ("imaginary\n");
772 break;
773 case DEMANGLE_COMPONENT_VENDOR_TYPE:
774 printf ("vendor type\n");
775 break;
776 case DEMANGLE_COMPONENT_FUNCTION_TYPE:
777 printf ("function type\n");
778 break;
779 case DEMANGLE_COMPONENT_ARRAY_TYPE:
780 printf ("array type\n");
781 break;
782 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
783 printf ("pointer to member type\n");
784 break;
785 case DEMANGLE_COMPONENT_ARGLIST:
786 printf ("argument list\n");
787 break;
788 case DEMANGLE_COMPONENT_TEMPLATE_ARGLIST:
789 printf ("template argument list\n");
790 break;
791 case DEMANGLE_COMPONENT_INITIALIZER_LIST:
792 printf ("initializer list\n");
793 break;
794 case DEMANGLE_COMPONENT_CAST:
795 printf ("cast\n");
796 break;
797 case DEMANGLE_COMPONENT_CONVERSION:
798 printf ("conversion operator\n");
799 break;
800 case DEMANGLE_COMPONENT_NULLARY:
801 printf ("nullary operator\n");
802 break;
803 case DEMANGLE_COMPONENT_UNARY:
804 printf ("unary operator\n");
805 break;
806 case DEMANGLE_COMPONENT_BINARY:
807 printf ("binary operator\n");
808 break;
809 case DEMANGLE_COMPONENT_BINARY_ARGS:
810 printf ("binary operator arguments\n");
811 break;
812 case DEMANGLE_COMPONENT_TRINARY:
813 printf ("trinary operator\n");
814 break;
815 case DEMANGLE_COMPONENT_TRINARY_ARG1:
816 printf ("trinary operator arguments 1\n");
817 break;
818 case DEMANGLE_COMPONENT_TRINARY_ARG2:
819 printf ("trinary operator arguments 1\n");
820 break;
821 case DEMANGLE_COMPONENT_LITERAL:
822 printf ("literal\n");
823 break;
824 case DEMANGLE_COMPONENT_LITERAL_NEG:
825 printf ("negative literal\n");
826 break;
827 case DEMANGLE_COMPONENT_VENDOR_EXPR:
828 printf ("vendor expression\n");
829 break;
830 case DEMANGLE_COMPONENT_JAVA_RESOURCE:
831 printf ("java resource\n");
832 break;
833 case DEMANGLE_COMPONENT_COMPOUND_NAME:
834 printf ("compound name\n");
835 break;
836 case DEMANGLE_COMPONENT_CHARACTER:
837 printf ("character '%c'\n", dc->u.s_character.character);
838 return;
839 case DEMANGLE_COMPONENT_NUMBER:
840 printf ("number %ld\n", dc->u.s_number.number);
841 return;
842 case DEMANGLE_COMPONENT_DECLTYPE:
843 printf ("decltype\n");
844 break;
845 case DEMANGLE_COMPONENT_PACK_EXPANSION:
846 printf ("pack expansion\n");
847 break;
848 case DEMANGLE_COMPONENT_TLS_INIT:
849 printf ("tls init function\n");
850 break;
851 case DEMANGLE_COMPONENT_TLS_WRAPPER:
852 printf ("tls wrapper function\n");
853 break;
854 case DEMANGLE_COMPONENT_DEFAULT_ARG:
855 printf ("default argument %d\n", dc->u.s_unary_num.num);
856 d_dump (dc->u.s_unary_num.sub, indent+2);
857 return;
858 case DEMANGLE_COMPONENT_LAMBDA:
859 printf ("lambda %d\n", dc->u.s_unary_num.num);
860 d_dump (dc->u.s_unary_num.sub, indent+2);
861 return;
862 }
863
864 d_dump (d_left (dc), indent + 2);
865 d_dump (d_right (dc), indent + 2);
866 }
867
868 #endif /* CP_DEMANGLE_DEBUG */
869
870 /* Fill in a DEMANGLE_COMPONENT_NAME. */
871
872 CP_STATIC_IF_GLIBCPP_V3
873 int
874 cplus_demangle_fill_name (struct demangle_component *p, const char *s, int len)
875 {
876 if (p == NULL || s == NULL || len <= 0)
877 return 0;
878 p->d_printing = 0;
879 p->d_counting = 0;
880 p->type = DEMANGLE_COMPONENT_NAME;
881 p->u.s_name.s = s;
882 p->u.s_name.len = len;
883 return 1;
884 }
885
886 /* Fill in a DEMANGLE_COMPONENT_EXTENDED_OPERATOR. */
887
888 CP_STATIC_IF_GLIBCPP_V3
889 int
890 cplus_demangle_fill_extended_operator (struct demangle_component *p, int args,
891 struct demangle_component *name)
892 {
893 if (p == NULL || args < 0 || name == NULL)
894 return 0;
895 p->d_printing = 0;
896 p->d_counting = 0;
897 p->type = DEMANGLE_COMPONENT_EXTENDED_OPERATOR;
898 p->u.s_extended_operator.args = args;
899 p->u.s_extended_operator.name = name;
900 return 1;
901 }
902
903 /* Fill in a DEMANGLE_COMPONENT_CTOR. */
904
905 CP_STATIC_IF_GLIBCPP_V3
906 int
907 cplus_demangle_fill_ctor (struct demangle_component *p,
908 enum gnu_v3_ctor_kinds kind,
909 struct demangle_component *name)
910 {
911 if (p == NULL
912 || name == NULL
913 || (int) kind < gnu_v3_complete_object_ctor
914 || (int) kind > gnu_v3_object_ctor_group)
915 return 0;
916 p->d_printing = 0;
917 p->d_counting = 0;
918 p->type = DEMANGLE_COMPONENT_CTOR;
919 p->u.s_ctor.kind = kind;
920 p->u.s_ctor.name = name;
921 return 1;
922 }
923
924 /* Fill in a DEMANGLE_COMPONENT_DTOR. */
925
926 CP_STATIC_IF_GLIBCPP_V3
927 int
928 cplus_demangle_fill_dtor (struct demangle_component *p,
929 enum gnu_v3_dtor_kinds kind,
930 struct demangle_component *name)
931 {
932 if (p == NULL
933 || name == NULL
934 || (int) kind < gnu_v3_deleting_dtor
935 || (int) kind > gnu_v3_object_dtor_group)
936 return 0;
937 p->d_printing = 0;
938 p->d_counting = 0;
939 p->type = DEMANGLE_COMPONENT_DTOR;
940 p->u.s_dtor.kind = kind;
941 p->u.s_dtor.name = name;
942 return 1;
943 }
944
945 /* Add a new component. */
946
947 static struct demangle_component *
948 d_make_empty (struct d_info *di)
949 {
950 struct demangle_component *p;
951
952 if (di->next_comp >= di->num_comps)
953 return NULL;
954 p = &di->comps[di->next_comp];
955 p->d_printing = 0;
956 p->d_counting = 0;
957 ++di->next_comp;
958 return p;
959 }
960
961 /* Add a new generic component. */
962
963 static struct demangle_component *
964 d_make_comp (struct d_info *di, enum demangle_component_type type,
965 struct demangle_component *left,
966 struct demangle_component *right)
967 {
968 struct demangle_component *p;
969
970 /* We check for errors here. A typical error would be a NULL return
971 from a subroutine. We catch those here, and return NULL
972 upward. */
973 switch (type)
974 {
975 /* These types require two parameters. */
976 case DEMANGLE_COMPONENT_QUAL_NAME:
977 case DEMANGLE_COMPONENT_LOCAL_NAME:
978 case DEMANGLE_COMPONENT_TYPED_NAME:
979 case DEMANGLE_COMPONENT_TAGGED_NAME:
980 case DEMANGLE_COMPONENT_TEMPLATE:
981 case DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE:
982 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
983 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
984 case DEMANGLE_COMPONENT_UNARY:
985 case DEMANGLE_COMPONENT_BINARY:
986 case DEMANGLE_COMPONENT_BINARY_ARGS:
987 case DEMANGLE_COMPONENT_TRINARY:
988 case DEMANGLE_COMPONENT_TRINARY_ARG1:
989 case DEMANGLE_COMPONENT_LITERAL:
990 case DEMANGLE_COMPONENT_LITERAL_NEG:
991 case DEMANGLE_COMPONENT_VENDOR_EXPR:
992 case DEMANGLE_COMPONENT_COMPOUND_NAME:
993 case DEMANGLE_COMPONENT_VECTOR_TYPE:
994 case DEMANGLE_COMPONENT_CLONE:
995 case DEMANGLE_COMPONENT_MODULE_ENTITY:
996 if (left == NULL || right == NULL)
997 return NULL;
998 break;
999
1000 /* These types only require one parameter. */
1001 case DEMANGLE_COMPONENT_VTABLE:
1002 case DEMANGLE_COMPONENT_VTT:
1003 case DEMANGLE_COMPONENT_TYPEINFO:
1004 case DEMANGLE_COMPONENT_TYPEINFO_NAME:
1005 case DEMANGLE_COMPONENT_TYPEINFO_FN:
1006 case DEMANGLE_COMPONENT_THUNK:
1007 case DEMANGLE_COMPONENT_VIRTUAL_THUNK:
1008 case DEMANGLE_COMPONENT_COVARIANT_THUNK:
1009 case DEMANGLE_COMPONENT_JAVA_CLASS:
1010 case DEMANGLE_COMPONENT_GUARD:
1011 case DEMANGLE_COMPONENT_TLS_INIT:
1012 case DEMANGLE_COMPONENT_TLS_WRAPPER:
1013 case DEMANGLE_COMPONENT_REFTEMP:
1014 case DEMANGLE_COMPONENT_HIDDEN_ALIAS:
1015 case DEMANGLE_COMPONENT_TRANSACTION_CLONE:
1016 case DEMANGLE_COMPONENT_NONTRANSACTION_CLONE:
1017 case DEMANGLE_COMPONENT_POINTER:
1018 case DEMANGLE_COMPONENT_REFERENCE:
1019 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
1020 case DEMANGLE_COMPONENT_COMPLEX:
1021 case DEMANGLE_COMPONENT_IMAGINARY:
1022 case DEMANGLE_COMPONENT_VENDOR_TYPE:
1023 case DEMANGLE_COMPONENT_CAST:
1024 case DEMANGLE_COMPONENT_CONVERSION:
1025 case DEMANGLE_COMPONENT_JAVA_RESOURCE:
1026 case DEMANGLE_COMPONENT_DECLTYPE:
1027 case DEMANGLE_COMPONENT_PACK_EXPANSION:
1028 case DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS:
1029 case DEMANGLE_COMPONENT_GLOBAL_DESTRUCTORS:
1030 case DEMANGLE_COMPONENT_NULLARY:
1031 case DEMANGLE_COMPONENT_TRINARY_ARG2:
1032 case DEMANGLE_COMPONENT_TPARM_OBJ:
1033 case DEMANGLE_COMPONENT_STRUCTURED_BINDING:
1034 case DEMANGLE_COMPONENT_MODULE_INIT:
1035 case DEMANGLE_COMPONENT_TEMPLATE_HEAD:
1036 case DEMANGLE_COMPONENT_TEMPLATE_NON_TYPE_PARM:
1037 case DEMANGLE_COMPONENT_TEMPLATE_TEMPLATE_PARM:
1038 case DEMANGLE_COMPONENT_TEMPLATE_PACK_PARM:
1039 if (left == NULL)
1040 return NULL;
1041 break;
1042
1043 /* This needs a right parameter, but the left parameter can be
1044 empty. */
1045 case DEMANGLE_COMPONENT_ARRAY_TYPE:
1046 case DEMANGLE_COMPONENT_INITIALIZER_LIST:
1047 case DEMANGLE_COMPONENT_MODULE_NAME:
1048 case DEMANGLE_COMPONENT_MODULE_PARTITION:
1049 if (right == NULL)
1050 return NULL;
1051 break;
1052
1053 /* These are allowed to have no parameters--in some cases they
1054 will be filled in later. */
1055 case DEMANGLE_COMPONENT_FUNCTION_TYPE:
1056 case DEMANGLE_COMPONENT_RESTRICT:
1057 case DEMANGLE_COMPONENT_VOLATILE:
1058 case DEMANGLE_COMPONENT_CONST:
1059 case DEMANGLE_COMPONENT_ARGLIST:
1060 case DEMANGLE_COMPONENT_TEMPLATE_ARGLIST:
1061 case DEMANGLE_COMPONENT_TEMPLATE_TYPE_PARM:
1062 FNQUAL_COMPONENT_CASE:
1063 break;
1064
1065 /* Other types should not be seen here. */
1066 default:
1067 return NULL;
1068 }
1069
1070 p = d_make_empty (di);
1071 if (p != NULL)
1072 {
1073 p->type = type;
1074 p->u.s_binary.left = left;
1075 p->u.s_binary.right = right;
1076 }
1077 return p;
1078 }
1079
1080 /* Add a new demangle mangled name component. */
1081
1082 static struct demangle_component *
1083 d_make_demangle_mangled_name (struct d_info *di, const char *s)
1084 {
1085 if (d_peek_char (di) != '_' || d_peek_next_char (di) != 'Z')
1086 return d_make_name (di, s, strlen (s));
1087 d_advance (di, 2);
1088 return d_encoding (di, 0);
1089 }
1090
1091 /* Add a new name component. */
1092
1093 static struct demangle_component *
1094 d_make_name (struct d_info *di, const char *s, int len)
1095 {
1096 struct demangle_component *p;
1097
1098 p = d_make_empty (di);
1099 if (! cplus_demangle_fill_name (p, s, len))
1100 return NULL;
1101 return p;
1102 }
1103
1104 /* Add a new builtin type component. */
1105
1106 static struct demangle_component *
1107 d_make_builtin_type (struct d_info *di,
1108 const struct demangle_builtin_type_info *type)
1109 {
1110 struct demangle_component *p;
1111
1112 if (type == NULL)
1113 return NULL;
1114 p = d_make_empty (di);
1115 if (p != NULL)
1116 {
1117 p->type = DEMANGLE_COMPONENT_BUILTIN_TYPE;
1118 p->u.s_builtin.type = type;
1119 }
1120 return p;
1121 }
1122
1123 /* Add a new extended builtin type component. */
1124
1125 static struct demangle_component *
1126 d_make_extended_builtin_type (struct d_info *di,
1127 const struct demangle_builtin_type_info *type,
1128 short arg, char suffix)
1129 {
1130 struct demangle_component *p;
1131
1132 if (type == NULL)
1133 return NULL;
1134 p = d_make_empty (di);
1135 if (p != NULL)
1136 {
1137 p->type = DEMANGLE_COMPONENT_EXTENDED_BUILTIN_TYPE;
1138 p->u.s_extended_builtin.type = type;
1139 p->u.s_extended_builtin.arg = arg;
1140 p->u.s_extended_builtin.suffix = suffix;
1141 }
1142 return p;
1143 }
1144
1145 /* Add a new operator component. */
1146
1147 static struct demangle_component *
1148 d_make_operator (struct d_info *di, const struct demangle_operator_info *op)
1149 {
1150 struct demangle_component *p;
1151
1152 p = d_make_empty (di);
1153 if (p != NULL)
1154 {
1155 p->type = DEMANGLE_COMPONENT_OPERATOR;
1156 p->u.s_operator.op = op;
1157 }
1158 return p;
1159 }
1160
1161 /* Add a new extended operator component. */
1162
1163 static struct demangle_component *
1164 d_make_extended_operator (struct d_info *di, int args,
1165 struct demangle_component *name)
1166 {
1167 struct demangle_component *p;
1168
1169 p = d_make_empty (di);
1170 if (! cplus_demangle_fill_extended_operator (p, args, name))
1171 return NULL;
1172 return p;
1173 }
1174
1175 static struct demangle_component *
1176 d_make_default_arg (struct d_info *di, int num,
1177 struct demangle_component *sub)
1178 {
1179 struct demangle_component *p = d_make_empty (di);
1180 if (p)
1181 {
1182 p->type = DEMANGLE_COMPONENT_DEFAULT_ARG;
1183 p->u.s_unary_num.num = num;
1184 p->u.s_unary_num.sub = sub;
1185 }
1186 return p;
1187 }
1188
1189 /* Add a new constructor component. */
1190
1191 static struct demangle_component *
1192 d_make_ctor (struct d_info *di, enum gnu_v3_ctor_kinds kind,
1193 struct demangle_component *name)
1194 {
1195 struct demangle_component *p;
1196
1197 p = d_make_empty (di);
1198 if (! cplus_demangle_fill_ctor (p, kind, name))
1199 return NULL;
1200 return p;
1201 }
1202
1203 /* Add a new destructor component. */
1204
1205 static struct demangle_component *
1206 d_make_dtor (struct d_info *di, enum gnu_v3_dtor_kinds kind,
1207 struct demangle_component *name)
1208 {
1209 struct demangle_component *p;
1210
1211 p = d_make_empty (di);
1212 if (! cplus_demangle_fill_dtor (p, kind, name))
1213 return NULL;
1214 return p;
1215 }
1216
1217 /* Add a new template parameter. */
1218
1219 static struct demangle_component *
1220 d_make_template_param (struct d_info *di, int i)
1221 {
1222 struct demangle_component *p;
1223
1224 p = d_make_empty (di);
1225 if (p != NULL)
1226 {
1227 p->type = DEMANGLE_COMPONENT_TEMPLATE_PARAM;
1228 p->u.s_number.number = i;
1229 }
1230 return p;
1231 }
1232
1233 /* Add a new function parameter. */
1234
1235 static struct demangle_component *
1236 d_make_function_param (struct d_info *di, int i)
1237 {
1238 struct demangle_component *p;
1239
1240 p = d_make_empty (di);
1241 if (p != NULL)
1242 {
1243 p->type = DEMANGLE_COMPONENT_FUNCTION_PARAM;
1244 p->u.s_number.number = i;
1245 }
1246 return p;
1247 }
1248
1249 /* Add a new standard substitution component. */
1250
1251 static struct demangle_component *
1252 d_make_sub (struct d_info *di, const char *name, int len)
1253 {
1254 struct demangle_component *p;
1255
1256 p = d_make_empty (di);
1257 if (p != NULL)
1258 {
1259 p->type = DEMANGLE_COMPONENT_SUB_STD;
1260 p->u.s_string.string = name;
1261 p->u.s_string.len = len;
1262 }
1263 return p;
1264 }
1265
1266 /* <mangled-name> ::= _Z <encoding> [<clone-suffix>]*
1267
1268 TOP_LEVEL is non-zero when called at the top level. */
1269
1270 CP_STATIC_IF_GLIBCPP_V3
1271 struct demangle_component *
1272 cplus_demangle_mangled_name (struct d_info *di, int top_level)
1273 {
1274 struct demangle_component *p;
1275
1276 if (! d_check_char (di, '_')
1277 /* Allow missing _ if not at toplevel to work around a
1278 bug in G++ abi-version=2 mangling; see the comment in
1279 write_template_arg. */
1280 && top_level)
1281 return NULL;
1282 if (! d_check_char (di, 'Z'))
1283 return NULL;
1284 p = d_encoding (di, top_level);
1285
1286 /* If at top level and parsing parameters, check for a clone
1287 suffix. */
1288 if (top_level && (di->options & DMGL_PARAMS) != 0)
1289 while (d_peek_char (di) == '.'
1290 && (IS_LOWER (d_peek_next_char (di))
1291 || d_peek_next_char (di) == '_'
1292 || IS_DIGIT (d_peek_next_char (di))))
1293 p = d_clone_suffix (di, p);
1294
1295 return p;
1296 }
1297
1298 /* Return whether a function should have a return type. The argument
1299 is the function name, which may be qualified in various ways. The
1300 rules are that template functions have return types with some
1301 exceptions, function types which are not part of a function name
1302 mangling have return types with some exceptions, and non-template
1303 function names do not have return types. The exceptions are that
1304 constructors, destructors, and conversion operators do not have
1305 return types. */
1306
1307 static int
1308 has_return_type (struct demangle_component *dc)
1309 {
1310 if (dc == NULL)
1311 return 0;
1312 switch (dc->type)
1313 {
1314 default:
1315 return 0;
1316 case DEMANGLE_COMPONENT_LOCAL_NAME:
1317 return has_return_type (d_right (dc));
1318 case DEMANGLE_COMPONENT_TEMPLATE:
1319 return ! is_ctor_dtor_or_conversion (d_left (dc));
1320 FNQUAL_COMPONENT_CASE:
1321 return has_return_type (d_left (dc));
1322 }
1323 }
1324
1325 /* Return whether a name is a constructor, a destructor, or a
1326 conversion operator. */
1327
1328 static int
1329 is_ctor_dtor_or_conversion (struct demangle_component *dc)
1330 {
1331 if (dc == NULL)
1332 return 0;
1333 switch (dc->type)
1334 {
1335 default:
1336 return 0;
1337 case DEMANGLE_COMPONENT_QUAL_NAME:
1338 case DEMANGLE_COMPONENT_LOCAL_NAME:
1339 return is_ctor_dtor_or_conversion (d_right (dc));
1340 case DEMANGLE_COMPONENT_CTOR:
1341 case DEMANGLE_COMPONENT_DTOR:
1342 case DEMANGLE_COMPONENT_CONVERSION:
1343 return 1;
1344 }
1345 }
1346
1347 /* <encoding> ::= <(function) name> <bare-function-type>
1348 ::= <(data) name>
1349 ::= <special-name>
1350
1351 TOP_LEVEL is non-zero when called at the top level, in which case
1352 if DMGL_PARAMS is not set we do not demangle the function
1353 parameters. We only set this at the top level, because otherwise
1354 we would not correctly demangle names in local scopes. */
1355
1356 static struct demangle_component *
1357 d_encoding (struct d_info *di, int top_level)
1358 {
1359 char peek = d_peek_char (di);
1360 struct demangle_component *dc;
1361
1362 if (peek == 'G' || peek == 'T')
1363 dc = d_special_name (di);
1364 else
1365 {
1366 dc = d_name (di, 0);
1367
1368 if (!dc)
1369 /* Failed already. */;
1370 else if (top_level && (di->options & DMGL_PARAMS) == 0)
1371 {
1372 /* Strip off any initial CV-qualifiers, as they really apply
1373 to the `this' parameter, and they were not output by the
1374 v2 demangler without DMGL_PARAMS. */
1375 while (is_fnqual_component_type (dc->type))
1376 dc = d_left (dc);
1377
1378 /* If the top level is a DEMANGLE_COMPONENT_LOCAL_NAME, then
1379 there may be function-qualifiers on its right argument which
1380 really apply here; this happens when parsing a class
1381 which is local to a function. */
1382 if (dc->type == DEMANGLE_COMPONENT_LOCAL_NAME)
1383 {
1384 while (d_right (dc) != NULL
1385 && is_fnqual_component_type (d_right (dc)->type))
1386 d_right (dc) = d_left (d_right (dc));
1387
1388 if (d_right (dc) == NULL)
1389 dc = NULL;
1390 }
1391 }
1392 else
1393 {
1394 peek = d_peek_char (di);
1395 if (peek != '\0' && peek != 'E')
1396 {
1397 struct demangle_component *ftype;
1398
1399 ftype = d_bare_function_type (di, has_return_type (dc));
1400 if (ftype)
1401 {
1402 /* If this is a non-top-level local-name, clear the
1403 return type, so it doesn't confuse the user by
1404 being confused with the return type of whaever
1405 this is nested within. */
1406 if (!top_level && dc->type == DEMANGLE_COMPONENT_LOCAL_NAME
1407 && ftype->type == DEMANGLE_COMPONENT_FUNCTION_TYPE)
1408 d_left (ftype) = NULL;
1409
1410 dc = d_make_comp (di, DEMANGLE_COMPONENT_TYPED_NAME,
1411 dc, ftype);
1412 }
1413 else
1414 dc = NULL;
1415 }
1416 }
1417 }
1418
1419 return dc;
1420 }
1421
1422 /* <tagged-name> ::= <name> B <source-name> */
1423
1424 static struct demangle_component *
1425 d_abi_tags (struct d_info *di, struct demangle_component *dc)
1426 {
1427 struct demangle_component *hold_last_name;
1428 char peek;
1429
1430 /* Preserve the last name, so the ABI tag doesn't clobber it. */
1431 hold_last_name = di->last_name;
1432
1433 while (peek = d_peek_char (di),
1434 peek == 'B')
1435 {
1436 struct demangle_component *tag;
1437 d_advance (di, 1);
1438 tag = d_source_name (di);
1439 dc = d_make_comp (di, DEMANGLE_COMPONENT_TAGGED_NAME, dc, tag);
1440 }
1441
1442 di->last_name = hold_last_name;
1443
1444 return dc;
1445 }
1446
1447 /* <name> ::= <nested-name>
1448 ::= <unscoped-name>
1449 ::= <unscoped-template-name> <template-args>
1450 ::= <local-name>
1451
1452 <unscoped-name> ::= <unqualified-name>
1453 ::= St <unqualified-name>
1454
1455 <unscoped-template-name> ::= <unscoped-name>
1456 ::= <substitution>
1457 */
1458
1459 static struct demangle_component *
1460 d_name (struct d_info *di, int substable)
1461 {
1462 char peek = d_peek_char (di);
1463 struct demangle_component *dc = NULL;
1464 struct demangle_component *module = NULL;
1465 int subst = 0;
1466
1467 switch (peek)
1468 {
1469 case 'N':
1470 dc = d_nested_name (di);
1471 break;
1472
1473 case 'Z':
1474 dc = d_local_name (di);
1475 break;
1476
1477 case 'U':
1478 dc = d_unqualified_name (di, NULL, NULL);
1479 break;
1480
1481 case 'S':
1482 {
1483 if (d_peek_next_char (di) == 't')
1484 {
1485 d_advance (di, 2);
1486 dc = d_make_name (di, "std", 3);
1487 di->expansion += 3;
1488 }
1489
1490 if (d_peek_char (di) == 'S')
1491 {
1492 module = d_substitution (di, 0);
1493 if (!module)
1494 return NULL;
1495 if (!(module->type == DEMANGLE_COMPONENT_MODULE_NAME
1496 || module->type == DEMANGLE_COMPONENT_MODULE_PARTITION))
1497 {
1498 if (dc)
1499 return NULL;
1500 subst = 1;
1501 dc = module;
1502 module = NULL;
1503 }
1504 }
1505 }
1506 /* FALLTHROUGH */
1507
1508 case 'L':
1509 default:
1510 if (!subst)
1511 dc = d_unqualified_name (di, dc, module);
1512 if (d_peek_char (di) == 'I')
1513 {
1514 /* This is <template-args>, which means that we just saw
1515 <unscoped-template-name>, which is a substitution
1516 candidate. */
1517 if (!subst && !d_add_substitution (di, dc))
1518 return NULL;
1519 dc = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, dc,
1520 d_template_args (di));
1521 subst = 0;
1522 }
1523 break;
1524 }
1525 if (substable && !subst && !d_add_substitution (di, dc))
1526 return NULL;
1527 return dc;
1528 }
1529
1530 /* <nested-name> ::= N [<CV-qualifiers>] [<ref-qualifier>] <prefix> <unqualified-name> E
1531 ::= N [<CV-qualifiers>] [<ref-qualifier>] <template-prefix> <template-args> E
1532 */
1533
1534 static struct demangle_component *
1535 d_nested_name (struct d_info *di)
1536 {
1537 struct demangle_component *ret;
1538 struct demangle_component **pret;
1539 struct demangle_component *rqual;
1540
1541 if (! d_check_char (di, 'N'))
1542 return NULL;
1543
1544 pret = d_cv_qualifiers (di, &ret, 1);
1545 if (pret == NULL)
1546 return NULL;
1547
1548 /* Parse the ref-qualifier now and then attach it
1549 once we have something to attach it to. */
1550 rqual = d_ref_qualifier (di, NULL);
1551
1552 *pret = d_prefix (di, 1);
1553 if (*pret == NULL)
1554 return NULL;
1555
1556 if (rqual)
1557 {
1558 d_left (rqual) = ret;
1559 ret = rqual;
1560 }
1561
1562 if (! d_check_char (di, 'E'))
1563 return NULL;
1564
1565 return ret;
1566 }
1567
1568 /* <prefix> ::= <prefix> <unqualified-name>
1569 ::= <template-prefix> <template-args>
1570 ::= <template-param>
1571 ::= <decltype>
1572 ::=
1573 ::= <substitution>
1574
1575 <template-prefix> ::= <prefix> <(template) unqualified-name>
1576 ::= <template-param>
1577 ::= <substitution>
1578
1579 SUBST is true if we should add substitutions (as normal), false
1580 if not (in an unresolved-name). */
1581
1582 static struct demangle_component *
1583 d_prefix (struct d_info *di, int substable)
1584 {
1585 struct demangle_component *ret = NULL;
1586
1587 for (;;)
1588 {
1589 char peek = d_peek_char (di);
1590
1591 /* The older code accepts a <local-name> here, but I don't see
1592 that in the grammar. The older code does not accept a
1593 <template-param> here. */
1594
1595 if (peek == 'D'
1596 && (d_peek_next_char (di) == 'T'
1597 || d_peek_next_char (di) == 't'))
1598 {
1599 /* Decltype. */
1600 if (ret)
1601 return NULL;
1602 ret = cplus_demangle_type (di);
1603 }
1604 else if (peek == 'I')
1605 {
1606 if (ret == NULL)
1607 return NULL;
1608 struct demangle_component *dc = d_template_args (di);
1609 if (!dc)
1610 return NULL;
1611 ret = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, ret, dc);
1612 }
1613 else if (peek == 'T')
1614 {
1615 if (ret)
1616 return NULL;
1617 ret = d_template_param (di);
1618 }
1619 else if (peek == 'M')
1620 {
1621 /* Initializer scope for a lambda. We already added it as a
1622 substitution candidate, don't do that again. */
1623 d_advance (di, 1);
1624 continue;
1625 }
1626 else
1627 {
1628 struct demangle_component *module = NULL;
1629 if (peek == 'S')
1630 {
1631 module = d_substitution (di, 1);
1632 if (!module)
1633 return NULL;
1634 if (!(module->type == DEMANGLE_COMPONENT_MODULE_NAME
1635 || module->type == DEMANGLE_COMPONENT_MODULE_PARTITION))
1636 {
1637 if (ret)
1638 return NULL;
1639 ret = module;
1640 continue;
1641 }
1642 }
1643 ret = d_unqualified_name (di, ret, module);
1644 }
1645
1646 if (!ret)
1647 break;
1648
1649 if (d_peek_char (di) == 'E')
1650 break;
1651
1652 if (substable && !d_add_substitution (di, ret))
1653 return NULL;
1654 }
1655
1656 return ret;
1657 }
1658
1659 static int
1660 d_maybe_module_name (struct d_info *di, struct demangle_component **name)
1661 {
1662 while (d_peek_char (di) == 'W')
1663 {
1664 d_advance (di, 1);
1665 enum demangle_component_type code = DEMANGLE_COMPONENT_MODULE_NAME;
1666 if (d_peek_char (di) == 'P')
1667 {
1668 code = DEMANGLE_COMPONENT_MODULE_PARTITION;
1669 d_advance (di, 1);
1670 }
1671
1672 *name = d_make_comp (di, code, *name, d_source_name (di));
1673 if (!*name)
1674 return 0;
1675 if (!d_add_substitution (di, *name))
1676 return 0;
1677 }
1678 return 1;
1679 }
1680
1681 /* <unqualified-name> ::= [<module-name>] <operator-name> [<abi-tags>]
1682 ::= [<module-name>] <ctor-dtor-name> [<abi-tags>]
1683 ::= [<module-name>] <source-name> [<abi-tags>]
1684 ::= [<module-name>] <local-source-name> [<abi-tags>]
1685 ::= [<module-name>] DC <source-name>+ E [<abi-tags>]
1686 <local-source-name> ::= L <source-name> <discriminator> [<abi-tags>]
1687 */
1688
1689 static struct demangle_component *
1690 d_unqualified_name (struct d_info *di, struct demangle_component *scope,
1691 struct demangle_component *module)
1692 {
1693 struct demangle_component *ret;
1694 char peek;
1695
1696 if (!d_maybe_module_name (di, &module))
1697 return NULL;
1698
1699 peek = d_peek_char (di);
1700 if (IS_DIGIT (peek))
1701 ret = d_source_name (di);
1702 else if (IS_LOWER (peek))
1703 {
1704 int was_expr = di->is_expression;
1705 if (peek == 'o' && d_peek_next_char (di) == 'n')
1706 {
1707 d_advance (di, 2);
1708 /* Treat cv as naming a conversion operator. */
1709 di->is_expression = 0;
1710 }
1711 ret = d_operator_name (di);
1712 di->is_expression = was_expr;
1713 if (ret != NULL && ret->type == DEMANGLE_COMPONENT_OPERATOR)
1714 {
1715 di->expansion += sizeof "operator" + ret->u.s_operator.op->len - 2;
1716 if (!strcmp (ret->u.s_operator.op->code, "li"))
1717 ret = d_make_comp (di, DEMANGLE_COMPONENT_UNARY, ret,
1718 d_source_name (di));
1719 }
1720 }
1721 else if (peek == 'D' && d_peek_next_char (di) == 'C')
1722 {
1723 // structured binding
1724 d_advance (di, 2);
1725 struct demangle_component *prev = NULL;
1726 do
1727 {
1728 struct demangle_component *next =
1729 d_make_comp (di, DEMANGLE_COMPONENT_STRUCTURED_BINDING,
1730 d_source_name (di), NULL);
1731 if (prev)
1732 d_right (prev) = next;
1733 else
1734 ret = next;
1735 prev = next;
1736 }
1737 while (prev && d_peek_char (di) != 'E');
1738 if (prev)
1739 d_advance (di, 1);
1740 else
1741 ret = NULL;
1742 }
1743 else if (peek == 'C' || peek == 'D')
1744 ret = d_ctor_dtor_name (di);
1745 else if (peek == 'L')
1746 {
1747 d_advance (di, 1);
1748
1749 ret = d_source_name (di);
1750 if (ret == NULL)
1751 return NULL;
1752 if (! d_discriminator (di))
1753 return NULL;
1754 }
1755 else if (peek == 'U')
1756 {
1757 switch (d_peek_next_char (di))
1758 {
1759 case 'l':
1760 ret = d_lambda (di);
1761 break;
1762 case 't':
1763 ret = d_unnamed_type (di);
1764 break;
1765 default:
1766 return NULL;
1767 }
1768 }
1769 else
1770 return NULL;
1771
1772 if (module)
1773 ret = d_make_comp (di, DEMANGLE_COMPONENT_MODULE_ENTITY, ret, module);
1774 if (d_peek_char (di) == 'B')
1775 ret = d_abi_tags (di, ret);
1776 if (scope)
1777 ret = d_make_comp (di, DEMANGLE_COMPONENT_QUAL_NAME, scope, ret);
1778
1779 return ret;
1780 }
1781
1782 /* <source-name> ::= <(positive length) number> <identifier> */
1783
1784 static struct demangle_component *
1785 d_source_name (struct d_info *di)
1786 {
1787 int len;
1788 struct demangle_component *ret;
1789
1790 len = d_number (di);
1791 if (len <= 0)
1792 return NULL;
1793 ret = d_identifier (di, len);
1794 di->last_name = ret;
1795 return ret;
1796 }
1797
1798 /* number ::= [n] <(non-negative decimal integer)> */
1799
1800 static int
1801 d_number (struct d_info *di)
1802 {
1803 int negative;
1804 char peek;
1805 int ret;
1806
1807 negative = 0;
1808 peek = d_peek_char (di);
1809 if (peek == 'n')
1810 {
1811 negative = 1;
1812 d_advance (di, 1);
1813 peek = d_peek_char (di);
1814 }
1815
1816 ret = 0;
1817 while (1)
1818 {
1819 if (! IS_DIGIT (peek))
1820 {
1821 if (negative)
1822 ret = - ret;
1823 return ret;
1824 }
1825 if (ret > ((INT_MAX - (peek - '0')) / 10))
1826 return -1;
1827 ret = ret * 10 + (peek - '0');
1828 d_advance (di, 1);
1829 peek = d_peek_char (di);
1830 }
1831 }
1832
1833 /* Like d_number, but returns a demangle_component. */
1834
1835 static struct demangle_component *
1836 d_number_component (struct d_info *di)
1837 {
1838 struct demangle_component *ret = d_make_empty (di);
1839 if (ret)
1840 {
1841 ret->type = DEMANGLE_COMPONENT_NUMBER;
1842 ret->u.s_number.number = d_number (di);
1843 }
1844 return ret;
1845 }
1846
1847 /* identifier ::= <(unqualified source code identifier)> */
1848
1849 static struct demangle_component *
1850 d_identifier (struct d_info *di, int len)
1851 {
1852 const char *name;
1853
1854 name = d_str (di);
1855
1856 if (di->send - name < len)
1857 return NULL;
1858
1859 d_advance (di, len);
1860
1861 /* A Java mangled name may have a trailing '$' if it is a C++
1862 keyword. This '$' is not included in the length count. We just
1863 ignore the '$'. */
1864 if ((di->options & DMGL_JAVA) != 0
1865 && d_peek_char (di) == '$')
1866 d_advance (di, 1);
1867
1868 /* Look for something which looks like a gcc encoding of an
1869 anonymous namespace, and replace it with a more user friendly
1870 name. */
1871 if (len >= (int) ANONYMOUS_NAMESPACE_PREFIX_LEN + 2
1872 && memcmp (name, ANONYMOUS_NAMESPACE_PREFIX,
1873 ANONYMOUS_NAMESPACE_PREFIX_LEN) == 0)
1874 {
1875 const char *s;
1876
1877 s = name + ANONYMOUS_NAMESPACE_PREFIX_LEN;
1878 if ((*s == '.' || *s == '_' || *s == '$')
1879 && s[1] == 'N')
1880 {
1881 di->expansion -= len - sizeof "(anonymous namespace)";
1882 return d_make_name (di, "(anonymous namespace)",
1883 sizeof "(anonymous namespace)" - 1);
1884 }
1885 }
1886
1887 return d_make_name (di, name, len);
1888 }
1889
1890 /* operator_name ::= many different two character encodings.
1891 ::= cv <type>
1892 ::= v <digit> <source-name>
1893
1894 This list is sorted for binary search. */
1895
1896 #define NL(s) s, (sizeof s) - 1
1897
1898 CP_STATIC_IF_GLIBCPP_V3
1899 const struct demangle_operator_info cplus_demangle_operators[] =
1900 {
1901 { "aN", NL ("&="), 2 },
1902 { "aS", NL ("="), 2 },
1903 { "aa", NL ("&&"), 2 },
1904 { "ad", NL ("&"), 1 },
1905 { "an", NL ("&"), 2 },
1906 { "at", NL ("alignof "), 1 },
1907 { "aw", NL ("co_await "), 1 },
1908 { "az", NL ("alignof "), 1 },
1909 { "cc", NL ("const_cast"), 2 },
1910 { "cl", NL ("()"), 2 },
1911 { "cm", NL (","), 2 },
1912 { "co", NL ("~"), 1 },
1913 { "dV", NL ("/="), 2 },
1914 { "dX", NL ("[...]="), 3 }, /* [expr...expr] = expr */
1915 { "da", NL ("delete[] "), 1 },
1916 { "dc", NL ("dynamic_cast"), 2 },
1917 { "de", NL ("*"), 1 },
1918 { "di", NL ("="), 2 }, /* .name = expr */
1919 { "dl", NL ("delete "), 1 },
1920 { "ds", NL (".*"), 2 },
1921 { "dt", NL ("."), 2 },
1922 { "dv", NL ("/"), 2 },
1923 { "dx", NL ("]="), 2 }, /* [expr] = expr */
1924 { "eO", NL ("^="), 2 },
1925 { "eo", NL ("^"), 2 },
1926 { "eq", NL ("=="), 2 },
1927 { "fL", NL ("..."), 3 },
1928 { "fR", NL ("..."), 3 },
1929 { "fl", NL ("..."), 2 },
1930 { "fr", NL ("..."), 2 },
1931 { "ge", NL (">="), 2 },
1932 { "gs", NL ("::"), 1 },
1933 { "gt", NL (">"), 2 },
1934 { "ix", NL ("[]"), 2 },
1935 { "lS", NL ("<<="), 2 },
1936 { "le", NL ("<="), 2 },
1937 { "li", NL ("operator\"\" "), 1 },
1938 { "ls", NL ("<<"), 2 },
1939 { "lt", NL ("<"), 2 },
1940 { "mI", NL ("-="), 2 },
1941 { "mL", NL ("*="), 2 },
1942 { "mi", NL ("-"), 2 },
1943 { "ml", NL ("*"), 2 },
1944 { "mm", NL ("--"), 1 },
1945 { "na", NL ("new[]"), 3 },
1946 { "ne", NL ("!="), 2 },
1947 { "ng", NL ("-"), 1 },
1948 { "nt", NL ("!"), 1 },
1949 { "nw", NL ("new"), 3 },
1950 { "nx", NL ("noexcept"), 1 },
1951 { "oR", NL ("|="), 2 },
1952 { "oo", NL ("||"), 2 },
1953 { "or", NL ("|"), 2 },
1954 { "pL", NL ("+="), 2 },
1955 { "pl", NL ("+"), 2 },
1956 { "pm", NL ("->*"), 2 },
1957 { "pp", NL ("++"), 1 },
1958 { "ps", NL ("+"), 1 },
1959 { "pt", NL ("->"), 2 },
1960 { "qu", NL ("?"), 3 },
1961 { "rM", NL ("%="), 2 },
1962 { "rS", NL (">>="), 2 },
1963 { "rc", NL ("reinterpret_cast"), 2 },
1964 { "rm", NL ("%"), 2 },
1965 { "rs", NL (">>"), 2 },
1966 { "sP", NL ("sizeof..."), 1 },
1967 { "sZ", NL ("sizeof..."), 1 },
1968 { "sc", NL ("static_cast"), 2 },
1969 { "ss", NL ("<=>"), 2 },
1970 { "st", NL ("sizeof "), 1 },
1971 { "sz", NL ("sizeof "), 1 },
1972 { "tr", NL ("throw"), 0 },
1973 { "tw", NL ("throw "), 1 },
1974 { NULL, NULL, 0, 0 }
1975 };
1976
1977 static struct demangle_component *
1978 d_operator_name (struct d_info *di)
1979 {
1980 char c1;
1981 char c2;
1982
1983 c1 = d_next_char (di);
1984 c2 = d_next_char (di);
1985 if (c1 == 'v' && IS_DIGIT (c2))
1986 return d_make_extended_operator (di, c2 - '0', d_source_name (di));
1987 else if (c1 == 'c' && c2 == 'v')
1988 {
1989 struct demangle_component *type;
1990 int was_conversion = di->is_conversion;
1991 struct demangle_component *res;
1992
1993 di->is_conversion = ! di->is_expression;
1994 type = cplus_demangle_type (di);
1995 if (di->is_conversion)
1996 res = d_make_comp (di, DEMANGLE_COMPONENT_CONVERSION, type, NULL);
1997 else
1998 res = d_make_comp (di, DEMANGLE_COMPONENT_CAST, type, NULL);
1999 di->is_conversion = was_conversion;
2000 return res;
2001 }
2002 else
2003 {
2004 /* LOW is the inclusive lower bound. */
2005 int low = 0;
2006 /* HIGH is the exclusive upper bound. We subtract one to ignore
2007 the sentinel at the end of the array. */
2008 int high = ((sizeof (cplus_demangle_operators)
2009 / sizeof (cplus_demangle_operators[0]))
2010 - 1);
2011
2012 while (1)
2013 {
2014 int i;
2015 const struct demangle_operator_info *p;
2016
2017 i = low + (high - low) / 2;
2018 p = cplus_demangle_operators + i;
2019
2020 if (c1 == p->code[0] && c2 == p->code[1])
2021 return d_make_operator (di, p);
2022
2023 if (c1 < p->code[0] || (c1 == p->code[0] && c2 < p->code[1]))
2024 high = i;
2025 else
2026 low = i + 1;
2027 if (low == high)
2028 return NULL;
2029 }
2030 }
2031 }
2032
2033 static struct demangle_component *
2034 d_make_character (struct d_info *di, int c)
2035 {
2036 struct demangle_component *p;
2037 p = d_make_empty (di);
2038 if (p != NULL)
2039 {
2040 p->type = DEMANGLE_COMPONENT_CHARACTER;
2041 p->u.s_character.character = c;
2042 }
2043 return p;
2044 }
2045
2046 static struct demangle_component *
2047 d_java_resource (struct d_info *di)
2048 {
2049 struct demangle_component *p = NULL;
2050 struct demangle_component *next = NULL;
2051 int len, i;
2052 char c;
2053 const char *str;
2054
2055 len = d_number (di);
2056 if (len <= 1)
2057 return NULL;
2058
2059 /* Eat the leading '_'. */
2060 if (d_next_char (di) != '_')
2061 return NULL;
2062 len--;
2063
2064 str = d_str (di);
2065 i = 0;
2066
2067 while (len > 0)
2068 {
2069 c = str[i];
2070 if (!c)
2071 return NULL;
2072
2073 /* Each chunk is either a '$' escape... */
2074 if (c == '$')
2075 {
2076 i++;
2077 switch (str[i++])
2078 {
2079 case 'S':
2080 c = '/';
2081 break;
2082 case '_':
2083 c = '.';
2084 break;
2085 case '$':
2086 c = '$';
2087 break;
2088 default:
2089 return NULL;
2090 }
2091 next = d_make_character (di, c);
2092 d_advance (di, i);
2093 str = d_str (di);
2094 len -= i;
2095 i = 0;
2096 if (next == NULL)
2097 return NULL;
2098 }
2099 /* ... or a sequence of characters. */
2100 else
2101 {
2102 while (i < len && str[i] && str[i] != '$')
2103 i++;
2104
2105 next = d_make_name (di, str, i);
2106 d_advance (di, i);
2107 str = d_str (di);
2108 len -= i;
2109 i = 0;
2110 if (next == NULL)
2111 return NULL;
2112 }
2113
2114 if (p == NULL)
2115 p = next;
2116 else
2117 {
2118 p = d_make_comp (di, DEMANGLE_COMPONENT_COMPOUND_NAME, p, next);
2119 if (p == NULL)
2120 return NULL;
2121 }
2122 }
2123
2124 p = d_make_comp (di, DEMANGLE_COMPONENT_JAVA_RESOURCE, p, NULL);
2125
2126 return p;
2127 }
2128
2129 /* <special-name> ::= TV <type>
2130 ::= TT <type>
2131 ::= TI <type>
2132 ::= TS <type>
2133 ::= TA <template-arg>
2134 ::= GV <(object) name>
2135 ::= T <call-offset> <(base) encoding>
2136 ::= Tc <call-offset> <call-offset> <(base) encoding>
2137 Also g++ extensions:
2138 ::= TC <type> <(offset) number> _ <(base) type>
2139 ::= TF <type>
2140 ::= TJ <type>
2141 ::= GR <name>
2142 ::= GA <encoding>
2143 ::= Gr <resource name>
2144 ::= GTt <encoding>
2145 ::= GTn <encoding>
2146 */
2147
2148 static struct demangle_component *
2149 d_special_name (struct d_info *di)
2150 {
2151 di->expansion += 20;
2152 if (d_check_char (di, 'T'))
2153 {
2154 switch (d_next_char (di))
2155 {
2156 case 'V':
2157 di->expansion -= 5;
2158 return d_make_comp (di, DEMANGLE_COMPONENT_VTABLE,
2159 cplus_demangle_type (di), NULL);
2160 case 'T':
2161 di->expansion -= 10;
2162 return d_make_comp (di, DEMANGLE_COMPONENT_VTT,
2163 cplus_demangle_type (di), NULL);
2164 case 'I':
2165 return d_make_comp (di, DEMANGLE_COMPONENT_TYPEINFO,
2166 cplus_demangle_type (di), NULL);
2167 case 'S':
2168 return d_make_comp (di, DEMANGLE_COMPONENT_TYPEINFO_NAME,
2169 cplus_demangle_type (di), NULL);
2170
2171 case 'h':
2172 if (! d_call_offset (di, 'h'))
2173 return NULL;
2174 return d_make_comp (di, DEMANGLE_COMPONENT_THUNK,
2175 d_encoding (di, 0), NULL);
2176
2177 case 'v':
2178 if (! d_call_offset (di, 'v'))
2179 return NULL;
2180 return d_make_comp (di, DEMANGLE_COMPONENT_VIRTUAL_THUNK,
2181 d_encoding (di, 0), NULL);
2182
2183 case 'c':
2184 if (! d_call_offset (di, '\0'))
2185 return NULL;
2186 if (! d_call_offset (di, '\0'))
2187 return NULL;
2188 return d_make_comp (di, DEMANGLE_COMPONENT_COVARIANT_THUNK,
2189 d_encoding (di, 0), NULL);
2190
2191 case 'C':
2192 {
2193 struct demangle_component *derived_type;
2194 int offset;
2195 struct demangle_component *base_type;
2196
2197 derived_type = cplus_demangle_type (di);
2198 offset = d_number (di);
2199 if (offset < 0)
2200 return NULL;
2201 if (! d_check_char (di, '_'))
2202 return NULL;
2203 base_type = cplus_demangle_type (di);
2204 /* We don't display the offset. FIXME: We should display
2205 it in verbose mode. */
2206 di->expansion += 5;
2207 return d_make_comp (di, DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE,
2208 base_type, derived_type);
2209 }
2210
2211 case 'F':
2212 return d_make_comp (di, DEMANGLE_COMPONENT_TYPEINFO_FN,
2213 cplus_demangle_type (di), NULL);
2214 case 'J':
2215 return d_make_comp (di, DEMANGLE_COMPONENT_JAVA_CLASS,
2216 cplus_demangle_type (di), NULL);
2217
2218 case 'H':
2219 return d_make_comp (di, DEMANGLE_COMPONENT_TLS_INIT,
2220 d_name (di, 0), NULL);
2221
2222 case 'W':
2223 return d_make_comp (di, DEMANGLE_COMPONENT_TLS_WRAPPER,
2224 d_name (di, 0), NULL);
2225
2226 case 'A':
2227 return d_make_comp (di, DEMANGLE_COMPONENT_TPARM_OBJ,
2228 d_template_arg (di), NULL);
2229
2230 default:
2231 return NULL;
2232 }
2233 }
2234 else if (d_check_char (di, 'G'))
2235 {
2236 switch (d_next_char (di))
2237 {
2238 case 'V':
2239 return d_make_comp (di, DEMANGLE_COMPONENT_GUARD,
2240 d_name (di, 0), NULL);
2241
2242 case 'R':
2243 {
2244 struct demangle_component *name = d_name (di, 0);
2245 return d_make_comp (di, DEMANGLE_COMPONENT_REFTEMP, name,
2246 d_number_component (di));
2247 }
2248
2249 case 'A':
2250 return d_make_comp (di, DEMANGLE_COMPONENT_HIDDEN_ALIAS,
2251 d_encoding (di, 0), NULL);
2252
2253 case 'I':
2254 {
2255 struct demangle_component *module = NULL;
2256 if (!d_maybe_module_name (di, &module) || !module)
2257 return NULL;
2258 return d_make_comp (di, DEMANGLE_COMPONENT_MODULE_INIT,
2259 module, NULL);
2260 }
2261 case 'T':
2262 switch (d_next_char (di))
2263 {
2264 case 'n':
2265 return d_make_comp (di, DEMANGLE_COMPONENT_NONTRANSACTION_CLONE,
2266 d_encoding (di, 0), NULL);
2267 default:
2268 /* ??? The proposal is that other letters (such as 'h') stand
2269 for different variants of transaction cloning, such as
2270 compiling directly for hardware transaction support. But
2271 they still should all be transactional clones of some sort
2272 so go ahead and call them that. */
2273 case 't':
2274 return d_make_comp (di, DEMANGLE_COMPONENT_TRANSACTION_CLONE,
2275 d_encoding (di, 0), NULL);
2276 }
2277
2278 case 'r':
2279 return d_java_resource (di);
2280
2281 default:
2282 return NULL;
2283 }
2284 }
2285 else
2286 return NULL;
2287 }
2288
2289 /* <call-offset> ::= h <nv-offset> _
2290 ::= v <v-offset> _
2291
2292 <nv-offset> ::= <(offset) number>
2293
2294 <v-offset> ::= <(offset) number> _ <(virtual offset) number>
2295
2296 The C parameter, if not '\0', is a character we just read which is
2297 the start of the <call-offset>.
2298
2299 We don't display the offset information anywhere. FIXME: We should
2300 display it in verbose mode. */
2301
2302 static int
2303 d_call_offset (struct d_info *di, int c)
2304 {
2305 if (c == '\0')
2306 c = d_next_char (di);
2307
2308 if (c == 'h')
2309 d_number (di);
2310 else if (c == 'v')
2311 {
2312 d_number (di);
2313 if (! d_check_char (di, '_'))
2314 return 0;
2315 d_number (di);
2316 }
2317 else
2318 return 0;
2319
2320 if (! d_check_char (di, '_'))
2321 return 0;
2322
2323 return 1;
2324 }
2325
2326 /* <ctor-dtor-name> ::= C1
2327 ::= C2
2328 ::= C3
2329 ::= D0
2330 ::= D1
2331 ::= D2
2332 */
2333
2334 static struct demangle_component *
2335 d_ctor_dtor_name (struct d_info *di)
2336 {
2337 if (di->last_name != NULL)
2338 {
2339 if (di->last_name->type == DEMANGLE_COMPONENT_NAME)
2340 di->expansion += di->last_name->u.s_name.len;
2341 else if (di->last_name->type == DEMANGLE_COMPONENT_SUB_STD)
2342 di->expansion += di->last_name->u.s_string.len;
2343 }
2344 switch (d_peek_char (di))
2345 {
2346 case 'C':
2347 {
2348 enum gnu_v3_ctor_kinds kind;
2349 int inheriting = 0;
2350
2351 if (d_peek_next_char (di) == 'I')
2352 {
2353 inheriting = 1;
2354 d_advance (di, 1);
2355 }
2356
2357 switch (d_peek_next_char (di))
2358 {
2359 case '1':
2360 kind = gnu_v3_complete_object_ctor;
2361 break;
2362 case '2':
2363 kind = gnu_v3_base_object_ctor;
2364 break;
2365 case '3':
2366 kind = gnu_v3_complete_object_allocating_ctor;
2367 break;
2368 case '4':
2369 kind = gnu_v3_unified_ctor;
2370 break;
2371 case '5':
2372 kind = gnu_v3_object_ctor_group;
2373 break;
2374 default:
2375 return NULL;
2376 }
2377
2378 d_advance (di, 2);
2379
2380 if (inheriting)
2381 cplus_demangle_type (di);
2382
2383 return d_make_ctor (di, kind, di->last_name);
2384 }
2385
2386 case 'D':
2387 {
2388 enum gnu_v3_dtor_kinds kind;
2389
2390 switch (d_peek_next_char (di))
2391 {
2392 case '0':
2393 kind = gnu_v3_deleting_dtor;
2394 break;
2395 case '1':
2396 kind = gnu_v3_complete_object_dtor;
2397 break;
2398 case '2':
2399 kind = gnu_v3_base_object_dtor;
2400 break;
2401 /* digit '3' is not used */
2402 case '4':
2403 kind = gnu_v3_unified_dtor;
2404 break;
2405 case '5':
2406 kind = gnu_v3_object_dtor_group;
2407 break;
2408 default:
2409 return NULL;
2410 }
2411 d_advance (di, 2);
2412 return d_make_dtor (di, kind, di->last_name);
2413 }
2414
2415 default:
2416 return NULL;
2417 }
2418 }
2419
2420 /* True iff we're looking at an order-insensitive type-qualifier, including
2421 function-type-qualifiers. */
2422
2423 static int
2424 next_is_type_qual (struct d_info *di)
2425 {
2426 char peek = d_peek_char (di);
2427 if (peek == 'r' || peek == 'V' || peek == 'K')
2428 return 1;
2429 if (peek == 'D')
2430 {
2431 peek = d_peek_next_char (di);
2432 if (peek == 'x' || peek == 'o' || peek == 'O' || peek == 'w')
2433 return 1;
2434 }
2435 return 0;
2436 }
2437
2438 /* <type> ::= <builtin-type>
2439 ::= <function-type>
2440 ::= <class-enum-type>
2441 ::= <array-type>
2442 ::= <pointer-to-member-type>
2443 ::= <template-param>
2444 ::= <template-template-param> <template-args>
2445 ::= <substitution>
2446 ::= <CV-qualifiers> <type>
2447 ::= P <type>
2448 ::= R <type>
2449 ::= O <type> (C++0x)
2450 ::= C <type>
2451 ::= G <type>
2452 ::= U <source-name> <type>
2453
2454 <builtin-type> ::= various one letter codes
2455 ::= u <source-name>
2456 */
2457
2458 CP_STATIC_IF_GLIBCPP_V3
2459 const struct demangle_builtin_type_info
2460 cplus_demangle_builtin_types[D_BUILTIN_TYPE_COUNT] =
2461 {
2462 /* a */ { NL ("signed char"), NL ("signed char"), D_PRINT_DEFAULT },
2463 /* b */ { NL ("bool"), NL ("boolean"), D_PRINT_BOOL },
2464 /* c */ { NL ("char"), NL ("byte"), D_PRINT_DEFAULT },
2465 /* d */ { NL ("double"), NL ("double"), D_PRINT_FLOAT },
2466 /* e */ { NL ("long double"), NL ("long double"), D_PRINT_FLOAT },
2467 /* f */ { NL ("float"), NL ("float"), D_PRINT_FLOAT },
2468 /* g */ { NL ("__float128"), NL ("__float128"), D_PRINT_FLOAT },
2469 /* h */ { NL ("unsigned char"), NL ("unsigned char"), D_PRINT_DEFAULT },
2470 /* i */ { NL ("int"), NL ("int"), D_PRINT_INT },
2471 /* j */ { NL ("unsigned int"), NL ("unsigned"), D_PRINT_UNSIGNED },
2472 /* k */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
2473 /* l */ { NL ("long"), NL ("long"), D_PRINT_LONG },
2474 /* m */ { NL ("unsigned long"), NL ("unsigned long"), D_PRINT_UNSIGNED_LONG },
2475 /* n */ { NL ("__int128"), NL ("__int128"), D_PRINT_DEFAULT },
2476 /* o */ { NL ("unsigned __int128"), NL ("unsigned __int128"),
2477 D_PRINT_DEFAULT },
2478 /* p */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
2479 /* q */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
2480 /* r */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
2481 /* s */ { NL ("short"), NL ("short"), D_PRINT_DEFAULT },
2482 /* t */ { NL ("unsigned short"), NL ("unsigned short"), D_PRINT_DEFAULT },
2483 /* u */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
2484 /* v */ { NL ("void"), NL ("void"), D_PRINT_VOID },
2485 /* w */ { NL ("wchar_t"), NL ("char"), D_PRINT_DEFAULT },
2486 /* x */ { NL ("long long"), NL ("long"), D_PRINT_LONG_LONG },
2487 /* y */ { NL ("unsigned long long"), NL ("unsigned long long"),
2488 D_PRINT_UNSIGNED_LONG_LONG },
2489 /* z */ { NL ("..."), NL ("..."), D_PRINT_DEFAULT },
2490 /* 26 */ { NL ("decimal32"), NL ("decimal32"), D_PRINT_DEFAULT },
2491 /* 27 */ { NL ("decimal64"), NL ("decimal64"), D_PRINT_DEFAULT },
2492 /* 28 */ { NL ("decimal128"), NL ("decimal128"), D_PRINT_DEFAULT },
2493 /* 29 */ { NL ("half"), NL ("half"), D_PRINT_FLOAT },
2494 /* 30 */ { NL ("char8_t"), NL ("char8_t"), D_PRINT_DEFAULT },
2495 /* 31 */ { NL ("char16_t"), NL ("char16_t"), D_PRINT_DEFAULT },
2496 /* 32 */ { NL ("char32_t"), NL ("char32_t"), D_PRINT_DEFAULT },
2497 /* 33 */ { NL ("decltype(nullptr)"), NL ("decltype(nullptr)"),
2498 D_PRINT_DEFAULT },
2499 /* 34 */ { NL ("_Float"), NL ("_Float"), D_PRINT_FLOAT },
2500 /* 35 */ { NL ("std::bfloat16_t"), NL ("std::bfloat16_t"), D_PRINT_FLOAT },
2501 };
2502
2503 CP_STATIC_IF_GLIBCPP_V3
2504 struct demangle_component *
2505 cplus_demangle_type (struct d_info *di)
2506 {
2507 char peek;
2508 struct demangle_component *ret;
2509 int can_subst;
2510
2511 /* The ABI specifies that when CV-qualifiers are used, the base type
2512 is substitutable, and the fully qualified type is substitutable,
2513 but the base type with a strict subset of the CV-qualifiers is
2514 not substitutable. The natural recursive implementation of the
2515 CV-qualifiers would cause subsets to be substitutable, so instead
2516 we pull them all off now.
2517
2518 FIXME: The ABI says that order-insensitive vendor qualifiers
2519 should be handled in the same way, but we have no way to tell
2520 which vendor qualifiers are order-insensitive and which are
2521 order-sensitive. So we just assume that they are all
2522 order-sensitive. g++ 3.4 supports only one vendor qualifier,
2523 __vector, and it treats it as order-sensitive when mangling
2524 names. */
2525
2526 if (next_is_type_qual (di))
2527 {
2528 struct demangle_component **pret;
2529
2530 pret = d_cv_qualifiers (di, &ret, 0);
2531 if (pret == NULL)
2532 return NULL;
2533 if (d_peek_char (di) == 'F')
2534 {
2535 /* cv-qualifiers before a function type apply to 'this',
2536 so avoid adding the unqualified function type to
2537 the substitution list. */
2538 *pret = d_function_type (di);
2539 }
2540 else
2541 *pret = cplus_demangle_type (di);
2542 if (!*pret)
2543 return NULL;
2544 if ((*pret)->type == DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS
2545 || (*pret)->type == DEMANGLE_COMPONENT_REFERENCE_THIS)
2546 {
2547 /* Move the ref-qualifier outside the cv-qualifiers so that
2548 they are printed in the right order. */
2549 struct demangle_component *fn = d_left (*pret);
2550 d_left (*pret) = ret;
2551 ret = *pret;
2552 *pret = fn;
2553 }
2554 if (! d_add_substitution (di, ret))
2555 return NULL;
2556 return ret;
2557 }
2558
2559 can_subst = 1;
2560
2561 peek = d_peek_char (di);
2562 switch (peek)
2563 {
2564 case 'a': case 'b': case 'c': case 'd': case 'e': case 'f': case 'g':
2565 case 'h': case 'i': case 'j': case 'l': case 'm': case 'n':
2566 case 'o': case 's': case 't':
2567 case 'v': case 'w': case 'x': case 'y': case 'z':
2568 ret = d_make_builtin_type (di,
2569 &cplus_demangle_builtin_types[peek - 'a']);
2570 di->expansion += ret->u.s_builtin.type->len;
2571 can_subst = 0;
2572 d_advance (di, 1);
2573 break;
2574
2575 case 'u':
2576 d_advance (di, 1);
2577 ret = d_make_comp (di, DEMANGLE_COMPONENT_VENDOR_TYPE,
2578 d_source_name (di), NULL);
2579 break;
2580
2581 case 'F':
2582 ret = d_function_type (di);
2583 break;
2584
2585 case 'A':
2586 ret = d_array_type (di);
2587 break;
2588
2589 case 'M':
2590 ret = d_pointer_to_member_type (di);
2591 break;
2592
2593 case 'T':
2594 ret = d_template_param (di);
2595 if (d_peek_char (di) == 'I')
2596 {
2597 /* This may be <template-template-param> <template-args>.
2598 If this is the type for a conversion operator, we can
2599 have a <template-template-param> here only by following
2600 a derivation like this:
2601
2602 <nested-name>
2603 -> <template-prefix> <template-args>
2604 -> <prefix> <template-unqualified-name> <template-args>
2605 -> <unqualified-name> <template-unqualified-name> <template-args>
2606 -> <source-name> <template-unqualified-name> <template-args>
2607 -> <source-name> <operator-name> <template-args>
2608 -> <source-name> cv <type> <template-args>
2609 -> <source-name> cv <template-template-param> <template-args> <template-args>
2610
2611 where the <template-args> is followed by another.
2612 Otherwise, we must have a derivation like this:
2613
2614 <nested-name>
2615 -> <template-prefix> <template-args>
2616 -> <prefix> <template-unqualified-name> <template-args>
2617 -> <unqualified-name> <template-unqualified-name> <template-args>
2618 -> <source-name> <template-unqualified-name> <template-args>
2619 -> <source-name> <operator-name> <template-args>
2620 -> <source-name> cv <type> <template-args>
2621 -> <source-name> cv <template-param> <template-args>
2622
2623 where we need to leave the <template-args> to be processed
2624 by d_prefix (following the <template-prefix>).
2625
2626 The <template-template-param> part is a substitution
2627 candidate. */
2628 if (! di->is_conversion)
2629 {
2630 if (! d_add_substitution (di, ret))
2631 return NULL;
2632 ret = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, ret,
2633 d_template_args (di));
2634 }
2635 else
2636 {
2637 struct demangle_component *args;
2638 struct d_info_checkpoint checkpoint;
2639
2640 d_checkpoint (di, &checkpoint);
2641 args = d_template_args (di);
2642 if (d_peek_char (di) == 'I')
2643 {
2644 if (! d_add_substitution (di, ret))
2645 return NULL;
2646 ret = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, ret,
2647 args);
2648 }
2649 else
2650 d_backtrack (di, &checkpoint);
2651 }
2652 }
2653 break;
2654
2655 case 'O':
2656 d_advance (di, 1);
2657 ret = d_make_comp (di, DEMANGLE_COMPONENT_RVALUE_REFERENCE,
2658 cplus_demangle_type (di), NULL);
2659 break;
2660
2661 case 'P':
2662 d_advance (di, 1);
2663 ret = d_make_comp (di, DEMANGLE_COMPONENT_POINTER,
2664 cplus_demangle_type (di), NULL);
2665 break;
2666
2667 case 'R':
2668 d_advance (di, 1);
2669 ret = d_make_comp (di, DEMANGLE_COMPONENT_REFERENCE,
2670 cplus_demangle_type (di), NULL);
2671 break;
2672
2673 case 'C':
2674 d_advance (di, 1);
2675 ret = d_make_comp (di, DEMANGLE_COMPONENT_COMPLEX,
2676 cplus_demangle_type (di), NULL);
2677 break;
2678
2679 case 'G':
2680 d_advance (di, 1);
2681 ret = d_make_comp (di, DEMANGLE_COMPONENT_IMAGINARY,
2682 cplus_demangle_type (di), NULL);
2683 break;
2684
2685 case 'U':
2686 d_advance (di, 1);
2687 ret = d_source_name (di);
2688 if (d_peek_char (di) == 'I')
2689 ret = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, ret,
2690 d_template_args (di));
2691 ret = d_make_comp (di, DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL,
2692 cplus_demangle_type (di), ret);
2693 break;
2694
2695 case 'D':
2696 can_subst = 0;
2697 d_advance (di, 1);
2698 peek = d_next_char (di);
2699 switch (peek)
2700 {
2701 case 'T':
2702 case 't':
2703 /* decltype (expression) */
2704 ret = d_make_comp (di, DEMANGLE_COMPONENT_DECLTYPE,
2705 d_expression (di), NULL);
2706 if (ret && d_next_char (di) != 'E')
2707 ret = NULL;
2708 can_subst = 1;
2709 break;
2710
2711 case 'p':
2712 /* Pack expansion. */
2713 ret = d_make_comp (di, DEMANGLE_COMPONENT_PACK_EXPANSION,
2714 cplus_demangle_type (di), NULL);
2715 can_subst = 1;
2716 break;
2717
2718 case 'a':
2719 /* auto */
2720 ret = d_make_name (di, "auto", 4);
2721 break;
2722 case 'c':
2723 /* decltype(auto) */
2724 ret = d_make_name (di, "decltype(auto)", 14);
2725 break;
2726
2727 case 'f':
2728 /* 32-bit decimal floating point */
2729 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[26]);
2730 di->expansion += ret->u.s_builtin.type->len;
2731 break;
2732 case 'd':
2733 /* 64-bit DFP */
2734 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[27]);
2735 di->expansion += ret->u.s_builtin.type->len;
2736 break;
2737 case 'e':
2738 /* 128-bit DFP */
2739 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[28]);
2740 di->expansion += ret->u.s_builtin.type->len;
2741 break;
2742 case 'h':
2743 /* 16-bit half-precision FP */
2744 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[29]);
2745 di->expansion += ret->u.s_builtin.type->len;
2746 break;
2747 case 'u':
2748 /* char8_t */
2749 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[30]);
2750 di->expansion += ret->u.s_builtin.type->len;
2751 break;
2752 case 's':
2753 /* char16_t */
2754 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[31]);
2755 di->expansion += ret->u.s_builtin.type->len;
2756 break;
2757 case 'i':
2758 /* char32_t */
2759 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[32]);
2760 di->expansion += ret->u.s_builtin.type->len;
2761 break;
2762
2763 case 'F':
2764 /* DF<number>_ - _Float<number>.
2765 DF<number>x - _Float<number>x
2766 DF16b - std::bfloat16_t. */
2767 {
2768 int arg = d_number (di);
2769 char buf[12];
2770 char suffix = 0;
2771 if (d_peek_char (di) == 'b')
2772 {
2773 if (arg != 16)
2774 return NULL;
2775 d_advance (di, 1);
2776 ret = d_make_builtin_type (di,
2777 &cplus_demangle_builtin_types[35]);
2778 di->expansion += ret->u.s_builtin.type->len;
2779 break;
2780 }
2781 if (d_peek_char (di) == 'x')
2782 suffix = 'x';
2783 if (!suffix && d_peek_char (di) != '_')
2784 return NULL;
2785 ret
2786 = d_make_extended_builtin_type (di,
2787 &cplus_demangle_builtin_types[34],
2788 arg, suffix);
2789 d_advance (di, 1);
2790 sprintf (buf, "%d", arg);
2791 di->expansion += ret->u.s_extended_builtin.type->len
2792 + strlen (buf) + (suffix != 0);
2793 break;
2794 }
2795
2796 case 'v':
2797 ret = d_vector_type (di);
2798 can_subst = 1;
2799 break;
2800
2801 case 'n':
2802 /* decltype(nullptr) */
2803 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[33]);
2804 di->expansion += ret->u.s_builtin.type->len;
2805 break;
2806
2807 default:
2808 return NULL;
2809 }
2810 break;
2811
2812 default:
2813 return d_class_enum_type (di, 1);
2814 }
2815
2816 if (can_subst)
2817 {
2818 if (! d_add_substitution (di, ret))
2819 return NULL;
2820 }
2821
2822 return ret;
2823 }
2824
2825 /* <CV-qualifiers> ::= [r] [V] [K] [Dx] */
2826
2827 static struct demangle_component **
2828 d_cv_qualifiers (struct d_info *di,
2829 struct demangle_component **pret, int member_fn)
2830 {
2831 struct demangle_component **pstart;
2832 char peek;
2833
2834 pstart = pret;
2835 peek = d_peek_char (di);
2836 while (next_is_type_qual (di))
2837 {
2838 enum demangle_component_type t;
2839 struct demangle_component *right = NULL;
2840
2841 d_advance (di, 1);
2842 if (peek == 'r')
2843 {
2844 t = (member_fn
2845 ? DEMANGLE_COMPONENT_RESTRICT_THIS
2846 : DEMANGLE_COMPONENT_RESTRICT);
2847 di->expansion += sizeof "restrict";
2848 }
2849 else if (peek == 'V')
2850 {
2851 t = (member_fn
2852 ? DEMANGLE_COMPONENT_VOLATILE_THIS
2853 : DEMANGLE_COMPONENT_VOLATILE);
2854 di->expansion += sizeof "volatile";
2855 }
2856 else if (peek == 'K')
2857 {
2858 t = (member_fn
2859 ? DEMANGLE_COMPONENT_CONST_THIS
2860 : DEMANGLE_COMPONENT_CONST);
2861 di->expansion += sizeof "const";
2862 }
2863 else
2864 {
2865 peek = d_next_char (di);
2866 if (peek == 'x')
2867 {
2868 t = DEMANGLE_COMPONENT_TRANSACTION_SAFE;
2869 di->expansion += sizeof "transaction_safe";
2870 }
2871 else if (peek == 'o'
2872 || peek == 'O')
2873 {
2874 t = DEMANGLE_COMPONENT_NOEXCEPT;
2875 di->expansion += sizeof "noexcept";
2876 if (peek == 'O')
2877 {
2878 right = d_expression (di);
2879 if (right == NULL)
2880 return NULL;
2881 if (! d_check_char (di, 'E'))
2882 return NULL;
2883 }
2884 }
2885 else if (peek == 'w')
2886 {
2887 t = DEMANGLE_COMPONENT_THROW_SPEC;
2888 di->expansion += sizeof "throw";
2889 right = d_parmlist (di);
2890 if (right == NULL)
2891 return NULL;
2892 if (! d_check_char (di, 'E'))
2893 return NULL;
2894 }
2895 else
2896 return NULL;
2897 }
2898
2899 *pret = d_make_comp (di, t, NULL, right);
2900 if (*pret == NULL)
2901 return NULL;
2902 pret = &d_left (*pret);
2903
2904 peek = d_peek_char (di);
2905 }
2906
2907 if (!member_fn && peek == 'F')
2908 {
2909 while (pstart != pret)
2910 {
2911 switch ((*pstart)->type)
2912 {
2913 case DEMANGLE_COMPONENT_RESTRICT:
2914 (*pstart)->type = DEMANGLE_COMPONENT_RESTRICT_THIS;
2915 break;
2916 case DEMANGLE_COMPONENT_VOLATILE:
2917 (*pstart)->type = DEMANGLE_COMPONENT_VOLATILE_THIS;
2918 break;
2919 case DEMANGLE_COMPONENT_CONST:
2920 (*pstart)->type = DEMANGLE_COMPONENT_CONST_THIS;
2921 break;
2922 default:
2923 break;
2924 }
2925 pstart = &d_left (*pstart);
2926 }
2927 }
2928
2929 return pret;
2930 }
2931
2932 /* <ref-qualifier> ::= R
2933 ::= O */
2934
2935 static struct demangle_component *
2936 d_ref_qualifier (struct d_info *di, struct demangle_component *sub)
2937 {
2938 struct demangle_component *ret = sub;
2939 char peek;
2940
2941 peek = d_peek_char (di);
2942 if (peek == 'R' || peek == 'O')
2943 {
2944 enum demangle_component_type t;
2945 if (peek == 'R')
2946 {
2947 t = DEMANGLE_COMPONENT_REFERENCE_THIS;
2948 di->expansion += sizeof "&";
2949 }
2950 else
2951 {
2952 t = DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS;
2953 di->expansion += sizeof "&&";
2954 }
2955 d_advance (di, 1);
2956
2957 ret = d_make_comp (di, t, ret, NULL);
2958 }
2959
2960 return ret;
2961 }
2962
2963 /* <function-type> ::= F [Y] <bare-function-type> [<ref-qualifier>] [T] E */
2964
2965 static struct demangle_component *
2966 d_function_type (struct d_info *di)
2967 {
2968 struct demangle_component *ret = NULL;
2969
2970 if ((di->options & DMGL_NO_RECURSE_LIMIT) == 0)
2971 {
2972 if (di->recursion_level > DEMANGLE_RECURSION_LIMIT)
2973 /* FIXME: There ought to be a way to report
2974 that the recursion limit has been reached. */
2975 return NULL;
2976
2977 di->recursion_level ++;
2978 }
2979
2980 if (d_check_char (di, 'F'))
2981 {
2982 if (d_peek_char (di) == 'Y')
2983 {
2984 /* Function has C linkage. We don't print this information.
2985 FIXME: We should print it in verbose mode. */
2986 d_advance (di, 1);
2987 }
2988 ret = d_bare_function_type (di, 1);
2989 ret = d_ref_qualifier (di, ret);
2990
2991 if (! d_check_char (di, 'E'))
2992 ret = NULL;
2993 }
2994
2995 if ((di->options & DMGL_NO_RECURSE_LIMIT) == 0)
2996 di->recursion_level --;
2997 return ret;
2998 }
2999
3000 /* <type>+ */
3001
3002 static struct demangle_component *
3003 d_parmlist (struct d_info *di)
3004 {
3005 struct demangle_component *tl;
3006 struct demangle_component **ptl;
3007
3008 tl = NULL;
3009 ptl = &tl;
3010 while (1)
3011 {
3012 struct demangle_component *type;
3013
3014 char peek = d_peek_char (di);
3015 if (peek == '\0' || peek == 'E' || peek == '.')
3016 break;
3017 if ((peek == 'R' || peek == 'O')
3018 && d_peek_next_char (di) == 'E')
3019 /* Function ref-qualifier, not a ref prefix for a parameter type. */
3020 break;
3021 type = cplus_demangle_type (di);
3022 if (type == NULL)
3023 return NULL;
3024 *ptl = d_make_comp (di, DEMANGLE_COMPONENT_ARGLIST, type, NULL);
3025 if (*ptl == NULL)
3026 return NULL;
3027 ptl = &d_right (*ptl);
3028 }
3029
3030 /* There should be at least one parameter type besides the optional
3031 return type. A function which takes no arguments will have a
3032 single parameter type void. */
3033 if (tl == NULL)
3034 return NULL;
3035
3036 /* If we have a single parameter type void, omit it. */
3037 if (d_right (tl) == NULL
3038 && d_left (tl)->type == DEMANGLE_COMPONENT_BUILTIN_TYPE
3039 && d_left (tl)->u.s_builtin.type->print == D_PRINT_VOID)
3040 {
3041 di->expansion -= d_left (tl)->u.s_builtin.type->len;
3042 d_left (tl) = NULL;
3043 }
3044
3045 return tl;
3046 }
3047
3048 /* <bare-function-type> ::= [J]<type>+ */
3049
3050 static struct demangle_component *
3051 d_bare_function_type (struct d_info *di, int has_return_type)
3052 {
3053 struct demangle_component *return_type;
3054 struct demangle_component *tl;
3055 char peek;
3056
3057 /* Detect special qualifier indicating that the first argument
3058 is the return type. */
3059 peek = d_peek_char (di);
3060 if (peek == 'J')
3061 {
3062 d_advance (di, 1);
3063 has_return_type = 1;
3064 }
3065
3066 if (has_return_type)
3067 {
3068 return_type = cplus_demangle_type (di);
3069 if (return_type == NULL)
3070 return NULL;
3071 }
3072 else
3073 return_type = NULL;
3074
3075 tl = d_parmlist (di);
3076 if (tl == NULL)
3077 return NULL;
3078
3079 return d_make_comp (di, DEMANGLE_COMPONENT_FUNCTION_TYPE,
3080 return_type, tl);
3081 }
3082
3083 /* <class-enum-type> ::= <name> */
3084
3085 static struct demangle_component *
3086 d_class_enum_type (struct d_info *di, int substable)
3087 {
3088 return d_name (di, substable);
3089 }
3090
3091 /* <array-type> ::= A <(positive dimension) number> _ <(element) type>
3092 ::= A [<(dimension) expression>] _ <(element) type>
3093 */
3094
3095 static struct demangle_component *
3096 d_array_type (struct d_info *di)
3097 {
3098 char peek;
3099 struct demangle_component *dim;
3100
3101 if (! d_check_char (di, 'A'))
3102 return NULL;
3103
3104 peek = d_peek_char (di);
3105 if (peek == '_')
3106 dim = NULL;
3107 else if (IS_DIGIT (peek))
3108 {
3109 const char *s;
3110
3111 s = d_str (di);
3112 do
3113 {
3114 d_advance (di, 1);
3115 peek = d_peek_char (di);
3116 }
3117 while (IS_DIGIT (peek));
3118 dim = d_make_name (di, s, d_str (di) - s);
3119 if (dim == NULL)
3120 return NULL;
3121 }
3122 else
3123 {
3124 dim = d_expression (di);
3125 if (dim == NULL)
3126 return NULL;
3127 }
3128
3129 if (! d_check_char (di, '_'))
3130 return NULL;
3131
3132 return d_make_comp (di, DEMANGLE_COMPONENT_ARRAY_TYPE, dim,
3133 cplus_demangle_type (di));
3134 }
3135
3136 /* <vector-type> ::= Dv <number> _ <type>
3137 ::= Dv _ <expression> _ <type> */
3138
3139 static struct demangle_component *
3140 d_vector_type (struct d_info *di)
3141 {
3142 char peek;
3143 struct demangle_component *dim;
3144
3145 peek = d_peek_char (di);
3146 if (peek == '_')
3147 {
3148 d_advance (di, 1);
3149 dim = d_expression (di);
3150 }
3151 else
3152 dim = d_number_component (di);
3153
3154 if (dim == NULL)
3155 return NULL;
3156
3157 if (! d_check_char (di, '_'))
3158 return NULL;
3159
3160 return d_make_comp (di, DEMANGLE_COMPONENT_VECTOR_TYPE, dim,
3161 cplus_demangle_type (di));
3162 }
3163
3164 /* <pointer-to-member-type> ::= M <(class) type> <(member) type> */
3165
3166 static struct demangle_component *
3167 d_pointer_to_member_type (struct d_info *di)
3168 {
3169 struct demangle_component *cl;
3170 struct demangle_component *mem;
3171
3172 if (! d_check_char (di, 'M'))
3173 return NULL;
3174
3175 cl = cplus_demangle_type (di);
3176 if (cl == NULL)
3177 return NULL;
3178
3179 /* The ABI says, "The type of a non-static member function is considered
3180 to be different, for the purposes of substitution, from the type of a
3181 namespace-scope or static member function whose type appears
3182 similar. The types of two non-static member functions are considered
3183 to be different, for the purposes of substitution, if the functions
3184 are members of different classes. In other words, for the purposes of
3185 substitution, the class of which the function is a member is
3186 considered part of the type of function."
3187
3188 For a pointer to member function, this call to cplus_demangle_type
3189 will end up adding a (possibly qualified) non-member function type to
3190 the substitution table, which is not correct; however, the member
3191 function type will never be used in a substitution, so putting the
3192 wrong type in the substitution table is harmless. */
3193
3194 mem = cplus_demangle_type (di);
3195 if (mem == NULL)
3196 return NULL;
3197
3198 return d_make_comp (di, DEMANGLE_COMPONENT_PTRMEM_TYPE, cl, mem);
3199 }
3200
3201 /* <non-negative number> _ */
3202
3203 static int
3204 d_compact_number (struct d_info *di)
3205 {
3206 int num;
3207 if (d_peek_char (di) == '_')
3208 num = 0;
3209 else if (d_peek_char (di) == 'n')
3210 return -1;
3211 else
3212 num = d_number (di) + 1;
3213
3214 if (num < 0 || ! d_check_char (di, '_'))
3215 return -1;
3216 return num;
3217 }
3218
3219 /* <template-param> ::= T_
3220 ::= T <(parameter-2 non-negative) number> _
3221 */
3222
3223 static struct demangle_component *
3224 d_template_param (struct d_info *di)
3225 {
3226 int param;
3227
3228 if (! d_check_char (di, 'T'))
3229 return NULL;
3230
3231 param = d_compact_number (di);
3232 if (param < 0)
3233 return NULL;
3234
3235 return d_make_template_param (di, param);
3236 }
3237
3238 /* <template-args> ::= I <template-arg>+ E */
3239
3240 static struct demangle_component *
3241 d_template_args (struct d_info *di)
3242 {
3243 if (d_peek_char (di) != 'I'
3244 && d_peek_char (di) != 'J')
3245 return NULL;
3246 d_advance (di, 1);
3247
3248 return d_template_args_1 (di);
3249 }
3250
3251 /* <template-arg>* E */
3252
3253 static struct demangle_component *
3254 d_template_args_1 (struct d_info *di)
3255 {
3256 struct demangle_component *hold_last_name;
3257 struct demangle_component *al;
3258 struct demangle_component **pal;
3259
3260 /* Preserve the last name we saw--don't let the template arguments
3261 clobber it, as that would give us the wrong name for a subsequent
3262 constructor or destructor. */
3263 hold_last_name = di->last_name;
3264
3265 if (d_peek_char (di) == 'E')
3266 {
3267 /* An argument pack can be empty. */
3268 d_advance (di, 1);
3269 return d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE_ARGLIST, NULL, NULL);
3270 }
3271
3272 al = NULL;
3273 pal = &al;
3274 while (1)
3275 {
3276 struct demangle_component *a;
3277
3278 a = d_template_arg (di);
3279 if (a == NULL)
3280 return NULL;
3281
3282 *pal = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE_ARGLIST, a, NULL);
3283 if (*pal == NULL)
3284 return NULL;
3285 pal = &d_right (*pal);
3286
3287 if (d_peek_char (di) == 'E')
3288 {
3289 d_advance (di, 1);
3290 break;
3291 }
3292 }
3293
3294 di->last_name = hold_last_name;
3295
3296 return al;
3297 }
3298
3299 /* <template-arg> ::= <type>
3300 ::= X <expression> E
3301 ::= <expr-primary>
3302 */
3303
3304 static struct demangle_component *
3305 d_template_arg (struct d_info *di)
3306 {
3307 struct demangle_component *ret;
3308
3309 switch (d_peek_char (di))
3310 {
3311 case 'X':
3312 d_advance (di, 1);
3313 ret = d_expression (di);
3314 if (! d_check_char (di, 'E'))
3315 return NULL;
3316 return ret;
3317
3318 case 'L':
3319 return d_expr_primary (di);
3320
3321 case 'I':
3322 case 'J':
3323 /* An argument pack. */
3324 return d_template_args (di);
3325
3326 default:
3327 return cplus_demangle_type (di);
3328 }
3329 }
3330
3331 /* Parse a sequence of expressions until we hit the terminator
3332 character. */
3333
3334 static struct demangle_component *
3335 d_exprlist (struct d_info *di, char terminator)
3336 {
3337 struct demangle_component *list = NULL;
3338 struct demangle_component **p = &list;
3339
3340 if (d_peek_char (di) == terminator)
3341 {
3342 d_advance (di, 1);
3343 return d_make_comp (di, DEMANGLE_COMPONENT_ARGLIST, NULL, NULL);
3344 }
3345
3346 while (1)
3347 {
3348 struct demangle_component *arg = d_expression (di);
3349 if (arg == NULL)
3350 return NULL;
3351
3352 *p = d_make_comp (di, DEMANGLE_COMPONENT_ARGLIST, arg, NULL);
3353 if (*p == NULL)
3354 return NULL;
3355 p = &d_right (*p);
3356
3357 if (d_peek_char (di) == terminator)
3358 {
3359 d_advance (di, 1);
3360 break;
3361 }
3362 }
3363
3364 return list;
3365 }
3366
3367 /* Returns nonzero iff OP is an operator for a C++ cast: const_cast,
3368 dynamic_cast, static_cast or reinterpret_cast. */
3369
3370 static int
3371 op_is_new_cast (struct demangle_component *op)
3372 {
3373 const char *code = op->u.s_operator.op->code;
3374 return (code[1] == 'c'
3375 && (code[0] == 's' || code[0] == 'd'
3376 || code[0] == 'c' || code[0] == 'r'));
3377 }
3378
3379 /* <unresolved-name> ::= [gs] <base-unresolved-name> # x or (with "gs") ::x
3380 ::= sr <unresolved-type> <base-unresolved-name> # T::x / decltype(p)::x
3381 # T::N::x /decltype(p)::N::x
3382 ::= srN <unresolved-type> <unresolved-qualifier-level>+ E <base-unresolved-name>
3383 # A::x, N::y, A<T>::z; "gs" means leading "::"
3384 ::= [gs] sr <unresolved-qualifier-level>+ E <base-unresolved-name>
3385
3386 "gs" is handled elsewhere, as a unary operator. */
3387
3388 static struct demangle_component *
3389 d_unresolved_name (struct d_info *di)
3390 {
3391 struct demangle_component *type;
3392 struct demangle_component *name;
3393 char peek;
3394
3395 /* Consume the "sr". */
3396 d_advance (di, 2);
3397
3398 peek = d_peek_char (di);
3399 if (di->unresolved_name_state
3400 && (IS_DIGIT (peek)
3401 || IS_LOWER (peek)
3402 || peek == 'C'
3403 || peek == 'U'
3404 || peek == 'L'))
3405 {
3406 /* The third production is ambiguous with the old unresolved-name syntax
3407 of <type> <base-unresolved-name>; in the old mangling, A::x was mangled
3408 as sr1A1x, now sr1AE1x. So we first try to demangle using the new
3409 mangling, then with the old if that fails. */
3410 di->unresolved_name_state = -1;
3411 type = d_prefix (di, 0);
3412 if (d_peek_char (di) == 'E')
3413 d_advance (di, 1);
3414 }
3415 else
3416 type = cplus_demangle_type (di);
3417 name = d_unqualified_name (di, type, NULL);
3418 if (d_peek_char (di) == 'I')
3419 name = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, name,
3420 d_template_args (di));
3421 return name;
3422 }
3423
3424 /* <expression> ::= <(unary) operator-name> <expression>
3425 ::= <(binary) operator-name> <expression> <expression>
3426 ::= <(trinary) operator-name> <expression> <expression> <expression>
3427 ::= cl <expression>+ E
3428 ::= st <type>
3429 ::= <template-param>
3430 ::= u <source-name> <template-arg>* E # vendor extended expression
3431 ::= <unresolved-name>
3432 ::= <expr-primary>
3433
3434 <braced-expression> ::= <expression>
3435 ::= di <field source-name> <braced-expression> # .name = expr
3436 ::= dx <index expression> <braced-expression> # [expr] = expr
3437 ::= dX <range begin expression> <range end expression> <braced-expression>
3438 # [expr ... expr] = expr
3439 */
3440
3441 static struct demangle_component *
3442 d_expression_1 (struct d_info *di)
3443 {
3444 char peek;
3445
3446 peek = d_peek_char (di);
3447 if (peek == 'L')
3448 return d_expr_primary (di);
3449 else if (peek == 'T')
3450 return d_template_param (di);
3451 else if (peek == 's' && d_peek_next_char (di) == 'r')
3452 return d_unresolved_name (di);
3453 else if (peek == 's' && d_peek_next_char (di) == 'p')
3454 {
3455 d_advance (di, 2);
3456 return d_make_comp (di, DEMANGLE_COMPONENT_PACK_EXPANSION,
3457 d_expression_1 (di), NULL);
3458 }
3459 else if (peek == 'f' && d_peek_next_char (di) == 'p')
3460 {
3461 /* Function parameter used in a late-specified return type. */
3462 int index;
3463 d_advance (di, 2);
3464 if (d_peek_char (di) == 'T')
3465 {
3466 /* 'this' parameter. */
3467 d_advance (di, 1);
3468 index = 0;
3469 }
3470 else
3471 {
3472 index = d_compact_number (di);
3473 if (index == INT_MAX || index == -1)
3474 return NULL;
3475 index++;
3476 }
3477 return d_make_function_param (di, index);
3478 }
3479 else if (IS_DIGIT (peek)
3480 || (peek == 'o' && d_peek_next_char (di) == 'n'))
3481 {
3482 /* We can get an unqualified name as an expression in the case of
3483 a dependent function call, i.e. decltype(f(t)). */
3484 struct demangle_component *name;
3485
3486 if (peek == 'o')
3487 /* operator-function-id, i.e. operator+(t). */
3488 d_advance (di, 2);
3489
3490 name = d_unqualified_name (di, NULL, NULL);
3491 if (name == NULL)
3492 return NULL;
3493 if (d_peek_char (di) == 'I')
3494 return d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, name,
3495 d_template_args (di));
3496 else
3497 return name;
3498 }
3499 else if ((peek == 'i' || peek == 't')
3500 && d_peek_next_char (di) == 'l')
3501 {
3502 /* Brace-enclosed initializer list, untyped or typed. */
3503 struct demangle_component *type = NULL;
3504 d_advance (di, 2);
3505 if (peek == 't')
3506 type = cplus_demangle_type (di);
3507 if (!d_peek_char (di) || !d_peek_next_char (di))
3508 return NULL;
3509 return d_make_comp (di, DEMANGLE_COMPONENT_INITIALIZER_LIST,
3510 type, d_exprlist (di, 'E'));
3511 }
3512 else if (peek == 'u')
3513 {
3514 /* A vendor extended expression. */
3515 struct demangle_component *name, *args;
3516 d_advance (di, 1);
3517 name = d_source_name (di);
3518 args = d_template_args_1 (di);
3519 return d_make_comp (di, DEMANGLE_COMPONENT_VENDOR_EXPR, name, args);
3520 }
3521 else
3522 {
3523 struct demangle_component *op;
3524 const char *code = NULL;
3525 int args;
3526
3527 op = d_operator_name (di);
3528 if (op == NULL)
3529 return NULL;
3530
3531 if (op->type == DEMANGLE_COMPONENT_OPERATOR)
3532 {
3533 code = op->u.s_operator.op->code;
3534 di->expansion += op->u.s_operator.op->len - 2;
3535 if (strcmp (code, "st") == 0)
3536 return d_make_comp (di, DEMANGLE_COMPONENT_UNARY, op,
3537 cplus_demangle_type (di));
3538 }
3539
3540 switch (op->type)
3541 {
3542 default:
3543 return NULL;
3544 case DEMANGLE_COMPONENT_OPERATOR:
3545 args = op->u.s_operator.op->args;
3546 break;
3547 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
3548 args = op->u.s_extended_operator.args;
3549 break;
3550 case DEMANGLE_COMPONENT_CAST:
3551 args = 1;
3552 break;
3553 }
3554
3555 switch (args)
3556 {
3557 case 0:
3558 return d_make_comp (di, DEMANGLE_COMPONENT_NULLARY, op, NULL);
3559
3560 case 1:
3561 {
3562 struct demangle_component *operand;
3563 int suffix = 0;
3564
3565 if (code && (code[0] == 'p' || code[0] == 'm')
3566 && code[1] == code[0])
3567 /* pp_ and mm_ are the prefix variants. */
3568 suffix = !d_check_char (di, '_');
3569
3570 if (op->type == DEMANGLE_COMPONENT_CAST
3571 && d_check_char (di, '_'))
3572 operand = d_exprlist (di, 'E');
3573 else if (code && !strcmp (code, "sP"))
3574 operand = d_template_args_1 (di);
3575 else
3576 operand = d_expression_1 (di);
3577
3578 if (suffix)
3579 /* Indicate the suffix variant for d_print_comp. */
3580 operand = d_make_comp (di, DEMANGLE_COMPONENT_BINARY_ARGS,
3581 operand, operand);
3582
3583 return d_make_comp (di, DEMANGLE_COMPONENT_UNARY, op, operand);
3584 }
3585 case 2:
3586 {
3587 struct demangle_component *left;
3588 struct demangle_component *right;
3589
3590 if (code == NULL)
3591 return NULL;
3592 if (op_is_new_cast (op))
3593 left = cplus_demangle_type (di);
3594 else if (code[0] == 'f')
3595 /* fold-expression. */
3596 left = d_operator_name (di);
3597 else if (!strcmp (code, "di"))
3598 left = d_unqualified_name (di, NULL, NULL);
3599 else
3600 left = d_expression_1 (di);
3601 if (!strcmp (code, "cl"))
3602 right = d_exprlist (di, 'E');
3603 else if (!strcmp (code, "dt") || !strcmp (code, "pt"))
3604 {
3605 peek = d_peek_char (di);
3606 /* These codes start a qualified name. */
3607 if ((peek == 'g' && d_peek_next_char (di) == 's')
3608 || (peek == 's' && d_peek_next_char (di) == 'r'))
3609 right = d_expression_1 (di);
3610 else
3611 {
3612 /* Otherwise it's an unqualified name. We use
3613 d_unqualified_name rather than d_expression_1 here for
3614 old mangled names that didn't add 'on' before operator
3615 names. */
3616 right = d_unqualified_name (di, NULL, NULL);
3617 if (d_peek_char (di) == 'I')
3618 right = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE,
3619 right, d_template_args (di));
3620 }
3621 }
3622 else
3623 right = d_expression_1 (di);
3624
3625 return d_make_comp (di, DEMANGLE_COMPONENT_BINARY, op,
3626 d_make_comp (di,
3627 DEMANGLE_COMPONENT_BINARY_ARGS,
3628 left, right));
3629 }
3630 case 3:
3631 {
3632 struct demangle_component *first;
3633 struct demangle_component *second;
3634 struct demangle_component *third;
3635
3636 if (code == NULL)
3637 return NULL;
3638 else if (!strcmp (code, "qu")
3639 || !strcmp (code, "dX"))
3640 {
3641 /* ?: expression. */
3642 first = d_expression_1 (di);
3643 second = d_expression_1 (di);
3644 third = d_expression_1 (di);
3645 if (third == NULL)
3646 return NULL;
3647 }
3648 else if (code[0] == 'f')
3649 {
3650 /* fold-expression. */
3651 first = d_operator_name (di);
3652 second = d_expression_1 (di);
3653 third = d_expression_1 (di);
3654 if (third == NULL)
3655 return NULL;
3656 }
3657 else if (code[0] == 'n')
3658 {
3659 /* new-expression. */
3660 if (code[1] != 'w' && code[1] != 'a')
3661 return NULL;
3662 first = d_exprlist (di, '_');
3663 second = cplus_demangle_type (di);
3664 if (d_peek_char (di) == 'E')
3665 {
3666 d_advance (di, 1);
3667 third = NULL;
3668 }
3669 else if (d_peek_char (di) == 'p'
3670 && d_peek_next_char (di) == 'i')
3671 {
3672 /* Parenthesized initializer. */
3673 d_advance (di, 2);
3674 third = d_exprlist (di, 'E');
3675 }
3676 else if (d_peek_char (di) == 'i'
3677 && d_peek_next_char (di) == 'l')
3678 /* initializer-list. */
3679 third = d_expression_1 (di);
3680 else
3681 return NULL;
3682 }
3683 else
3684 return NULL;
3685 return d_make_comp (di, DEMANGLE_COMPONENT_TRINARY, op,
3686 d_make_comp (di,
3687 DEMANGLE_COMPONENT_TRINARY_ARG1,
3688 first,
3689 d_make_comp (di,
3690 DEMANGLE_COMPONENT_TRINARY_ARG2,
3691 second, third)));
3692 }
3693 default:
3694 return NULL;
3695 }
3696 }
3697 }
3698
3699 static struct demangle_component *
3700 d_expression (struct d_info *di)
3701 {
3702 struct demangle_component *ret;
3703 int was_expression = di->is_expression;
3704
3705 di->is_expression = 1;
3706 ret = d_expression_1 (di);
3707 di->is_expression = was_expression;
3708 return ret;
3709 }
3710
3711 /* <expr-primary> ::= L <type> <(value) number> E
3712 ::= L <type> <(value) float> E
3713 ::= L <mangled-name> E
3714 */
3715
3716 static struct demangle_component *
3717 d_expr_primary (struct d_info *di)
3718 {
3719 struct demangle_component *ret;
3720
3721 if (! d_check_char (di, 'L'))
3722 return NULL;
3723 if (d_peek_char (di) == '_'
3724 /* Workaround for G++ bug; see comment in write_template_arg. */
3725 || d_peek_char (di) == 'Z')
3726 ret = cplus_demangle_mangled_name (di, 0);
3727 else
3728 {
3729 struct demangle_component *type;
3730 enum demangle_component_type t;
3731 const char *s;
3732
3733 type = cplus_demangle_type (di);
3734 if (type == NULL)
3735 return NULL;
3736
3737 /* If we have a type we know how to print, we aren't going to
3738 print the type name itself. */
3739 if (type->type == DEMANGLE_COMPONENT_BUILTIN_TYPE
3740 && type->u.s_builtin.type->print != D_PRINT_DEFAULT)
3741 di->expansion -= type->u.s_builtin.type->len;
3742
3743 if (type->type == DEMANGLE_COMPONENT_BUILTIN_TYPE
3744 && strcmp (type->u.s_builtin.type->name,
3745 cplus_demangle_builtin_types[33].name) == 0)
3746 {
3747 if (d_peek_char (di) == 'E')
3748 {
3749 d_advance (di, 1);
3750 return type;
3751 }
3752 }
3753
3754 /* Rather than try to interpret the literal value, we just
3755 collect it as a string. Note that it's possible to have a
3756 floating point literal here. The ABI specifies that the
3757 format of such literals is machine independent. That's fine,
3758 but what's not fine is that versions of g++ up to 3.2 with
3759 -fabi-version=1 used upper case letters in the hex constant,
3760 and dumped out gcc's internal representation. That makes it
3761 hard to tell where the constant ends, and hard to dump the
3762 constant in any readable form anyhow. We don't attempt to
3763 handle these cases. */
3764
3765 t = DEMANGLE_COMPONENT_LITERAL;
3766 if (d_peek_char (di) == 'n')
3767 {
3768 t = DEMANGLE_COMPONENT_LITERAL_NEG;
3769 d_advance (di, 1);
3770 }
3771 s = d_str (di);
3772 while (d_peek_char (di) != 'E')
3773 {
3774 if (d_peek_char (di) == '\0')
3775 return NULL;
3776 d_advance (di, 1);
3777 }
3778 ret = d_make_comp (di, t, type, d_make_name (di, s, d_str (di) - s));
3779 }
3780 if (! d_check_char (di, 'E'))
3781 return NULL;
3782 return ret;
3783 }
3784
3785 /* <local-name> ::= Z <(function) encoding> E <(entity) name> [<discriminator>]
3786 ::= Z <(function) encoding> E s [<discriminator>]
3787 ::= Z <(function) encoding> E d [<parameter> number>] _ <entity name>
3788 */
3789
3790 static struct demangle_component *
3791 d_local_name (struct d_info *di)
3792 {
3793 struct demangle_component *function;
3794 struct demangle_component *name;
3795
3796 if (! d_check_char (di, 'Z'))
3797 return NULL;
3798
3799 function = d_encoding (di, 0);
3800 if (!function)
3801 return NULL;
3802
3803 if (! d_check_char (di, 'E'))
3804 return NULL;
3805
3806 if (d_peek_char (di) == 's')
3807 {
3808 d_advance (di, 1);
3809 if (! d_discriminator (di))
3810 return NULL;
3811 name = d_make_name (di, "string literal", sizeof "string literal" - 1);
3812 }
3813 else
3814 {
3815 int num = -1;
3816
3817 if (d_peek_char (di) == 'd')
3818 {
3819 /* Default argument scope: d <number> _. */
3820 d_advance (di, 1);
3821 num = d_compact_number (di);
3822 if (num < 0)
3823 return NULL;
3824 }
3825
3826 name = d_name (di, 0);
3827
3828 if (name
3829 /* Lambdas and unnamed types have internal discriminators
3830 and are not functions. */
3831 && name->type != DEMANGLE_COMPONENT_LAMBDA
3832 && name->type != DEMANGLE_COMPONENT_UNNAMED_TYPE)
3833 {
3834 /* Read and ignore an optional discriminator. */
3835 if (! d_discriminator (di))
3836 return NULL;
3837 }
3838
3839 if (num >= 0)
3840 name = d_make_default_arg (di, num, name);
3841 }
3842
3843 /* Elide the return type of the containing function so as to not
3844 confuse the user thinking it is the return type of whatever local
3845 function we might be containing. */
3846 if (function->type == DEMANGLE_COMPONENT_TYPED_NAME
3847 && d_right (function)->type == DEMANGLE_COMPONENT_FUNCTION_TYPE)
3848 d_left (d_right (function)) = NULL;
3849
3850 return d_make_comp (di, DEMANGLE_COMPONENT_LOCAL_NAME, function, name);
3851 }
3852
3853 /* <discriminator> ::= _ <number> # when number < 10
3854 ::= __ <number> _ # when number >= 10
3855
3856 <discriminator> ::= _ <number> # when number >=10
3857 is also accepted to support gcc versions that wrongly mangled that way.
3858
3859 We demangle the discriminator, but we don't print it out. FIXME:
3860 We should print it out in verbose mode. */
3861
3862 static int
3863 d_discriminator (struct d_info *di)
3864 {
3865 int discrim, num_underscores = 1;
3866
3867 if (d_peek_char (di) != '_')
3868 return 1;
3869 d_advance (di, 1);
3870 if (d_peek_char (di) == '_')
3871 {
3872 ++num_underscores;
3873 d_advance (di, 1);
3874 }
3875
3876 discrim = d_number (di);
3877 if (discrim < 0)
3878 return 0;
3879 if (num_underscores > 1 && discrim >= 10)
3880 {
3881 if (d_peek_char (di) == '_')
3882 d_advance (di, 1);
3883 else
3884 return 0;
3885 }
3886
3887 return 1;
3888 }
3889
3890 /* <template-parm> ::= Ty
3891 ::= Tn <type>
3892 ::= Tt <template-head> E
3893 ::= Tp <template-parm> */
3894
3895 static struct demangle_component *
3896 d_template_parm (struct d_info *di, int *bad)
3897 {
3898 if (d_peek_char (di) != 'T')
3899 return NULL;
3900
3901 struct demangle_component *op;
3902 enum demangle_component_type kind;
3903 switch (d_peek_next_char (di))
3904 {
3905 default:
3906 return NULL;
3907
3908 case 'p': /* Pack */
3909 d_advance (di, 2);
3910 op = d_template_parm (di, bad);
3911 kind = DEMANGLE_COMPONENT_TEMPLATE_PACK_PARM;
3912 if (!op)
3913 {
3914 *bad = 1;
3915 return NULL;
3916 }
3917 break;
3918
3919 case 'y': /* Typename */
3920 d_advance (di, 2);
3921 op = NULL;
3922 kind = DEMANGLE_COMPONENT_TEMPLATE_TYPE_PARM;
3923 break;
3924
3925 case 'n': /* Non-Type */
3926 d_advance (di, 2);
3927 op = cplus_demangle_type (di);
3928 kind = DEMANGLE_COMPONENT_TEMPLATE_NON_TYPE_PARM;
3929 if (!op)
3930 {
3931 *bad = 1;
3932 return NULL;
3933 }
3934 break;
3935
3936 case 't': /* Template */
3937 d_advance (di, 2);
3938 op = d_template_head (di, bad);
3939 kind = DEMANGLE_COMPONENT_TEMPLATE_TEMPLATE_PARM;
3940 if (!op || !d_check_char (di, 'E'))
3941 {
3942 *bad = 1;
3943 return NULL;
3944 }
3945 }
3946
3947 return d_make_comp (di, kind, op, NULL);
3948 }
3949
3950 /* <template-head> ::= <template-head>? <template-parm> */
3951
3952 static struct demangle_component *
3953 d_template_head (struct d_info *di, int *bad)
3954 {
3955 struct demangle_component *res = NULL, **slot = &res;
3956 struct demangle_component *op;
3957
3958 while ((op = d_template_parm (di, bad)))
3959 {
3960 *slot = op;
3961 slot = &d_right (op);
3962 }
3963
3964 /* Wrap it in a template head, to make concatenating with any parm list, and
3965 printing simpler. */
3966 if (res)
3967 res = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE_HEAD, res, NULL);
3968
3969 return res;
3970 }
3971
3972 /* <closure-type-name> ::= Ul <template-head>? <lambda-sig> E [ <nonnegative number> ] _ */
3973
3974 static struct demangle_component *
3975 d_lambda (struct d_info *di)
3976 {
3977 if (! d_check_char (di, 'U'))
3978 return NULL;
3979 if (! d_check_char (di, 'l'))
3980 return NULL;
3981
3982 int bad = 0;
3983 struct demangle_component *head = d_template_head (di, &bad);
3984 if (bad)
3985 return NULL;
3986
3987 struct demangle_component *tl = d_parmlist (di);
3988 if (tl == NULL)
3989 return NULL;
3990 if (head)
3991 {
3992 d_right (head) = tl;
3993 tl = head;
3994 }
3995
3996 if (! d_check_char (di, 'E'))
3997 return NULL;
3998
3999 int num = d_compact_number (di);
4000 if (num < 0)
4001 return NULL;
4002
4003 struct demangle_component *ret = d_make_empty (di);
4004 if (ret)
4005 {
4006 ret->type = DEMANGLE_COMPONENT_LAMBDA;
4007 ret->u.s_unary_num.sub = tl;
4008 ret->u.s_unary_num.num = num;
4009 }
4010
4011 return ret;
4012 }
4013
4014 /* <unnamed-type-name> ::= Ut [ <nonnegative number> ] _ */
4015
4016 static struct demangle_component *
4017 d_unnamed_type (struct d_info *di)
4018 {
4019 struct demangle_component *ret;
4020 int num;
4021
4022 if (! d_check_char (di, 'U'))
4023 return NULL;
4024 if (! d_check_char (di, 't'))
4025 return NULL;
4026
4027 num = d_compact_number (di);
4028 if (num < 0)
4029 return NULL;
4030
4031 ret = d_make_empty (di);
4032 if (ret)
4033 {
4034 ret->type = DEMANGLE_COMPONENT_UNNAMED_TYPE;
4035 ret->u.s_number.number = num;
4036 }
4037
4038 if (! d_add_substitution (di, ret))
4039 return NULL;
4040
4041 return ret;
4042 }
4043
4044 /* <clone-suffix> ::= [ . <clone-type-identifier> ] [ . <nonnegative number> ]*
4045 */
4046
4047 static struct demangle_component *
4048 d_clone_suffix (struct d_info *di, struct demangle_component *encoding)
4049 {
4050 const char *suffix = d_str (di);
4051 const char *pend = suffix;
4052 struct demangle_component *n;
4053
4054 if (*pend == '.' && (IS_LOWER (pend[1]) || IS_DIGIT (pend[1])
4055 || pend[1] == '_'))
4056 {
4057 pend += 2;
4058 while (IS_LOWER (*pend) || IS_DIGIT (*pend) || *pend == '_')
4059 ++pend;
4060 }
4061 while (*pend == '.' && IS_DIGIT (pend[1]))
4062 {
4063 pend += 2;
4064 while (IS_DIGIT (*pend))
4065 ++pend;
4066 }
4067 d_advance (di, pend - suffix);
4068 n = d_make_name (di, suffix, pend - suffix);
4069 return d_make_comp (di, DEMANGLE_COMPONENT_CLONE, encoding, n);
4070 }
4071
4072 /* Add a new substitution. */
4073
4074 static int
4075 d_add_substitution (struct d_info *di, struct demangle_component *dc)
4076 {
4077 if (dc == NULL)
4078 return 0;
4079 if (di->next_sub >= di->num_subs)
4080 return 0;
4081 di->subs[di->next_sub] = dc;
4082 ++di->next_sub;
4083 return 1;
4084 }
4085
4086 /* <substitution> ::= S <seq-id> _
4087 ::= S_
4088 ::= St
4089 ::= Sa
4090 ::= Sb
4091 ::= Ss
4092 ::= Si
4093 ::= So
4094 ::= Sd
4095
4096 If PREFIX is non-zero, then this type is being used as a prefix in
4097 a qualified name. In this case, for the standard substitutions, we
4098 need to check whether we are being used as a prefix for a
4099 constructor or destructor, and return a full template name.
4100 Otherwise we will get something like std::iostream::~iostream()
4101 which does not correspond particularly well to any function which
4102 actually appears in the source.
4103 */
4104
4105 static const struct d_standard_sub_info standard_subs[] =
4106 {
4107 { 't', NL ("std"),
4108 NL ("std"),
4109 NULL, 0 },
4110 { 'a', NL ("std::allocator"),
4111 NL ("std::allocator"),
4112 NL ("allocator") },
4113 { 'b', NL ("std::basic_string"),
4114 NL ("std::basic_string"),
4115 NL ("basic_string") },
4116 { 's', NL ("std::string"),
4117 NL ("std::basic_string<char, std::char_traits<char>, std::allocator<char> >"),
4118 NL ("basic_string") },
4119 { 'i', NL ("std::istream"),
4120 NL ("std::basic_istream<char, std::char_traits<char> >"),
4121 NL ("basic_istream") },
4122 { 'o', NL ("std::ostream"),
4123 NL ("std::basic_ostream<char, std::char_traits<char> >"),
4124 NL ("basic_ostream") },
4125 { 'd', NL ("std::iostream"),
4126 NL ("std::basic_iostream<char, std::char_traits<char> >"),
4127 NL ("basic_iostream") }
4128 };
4129
4130 static struct demangle_component *
4131 d_substitution (struct d_info *di, int prefix)
4132 {
4133 char c;
4134
4135 if (! d_check_char (di, 'S'))
4136 return NULL;
4137
4138 c = d_next_char (di);
4139 if (c == '_' || IS_DIGIT (c) || IS_UPPER (c))
4140 {
4141 unsigned int id;
4142
4143 id = 0;
4144 if (c != '_')
4145 {
4146 do
4147 {
4148 unsigned int new_id;
4149
4150 if (IS_DIGIT (c))
4151 new_id = id * 36 + c - '0';
4152 else if (IS_UPPER (c))
4153 new_id = id * 36 + c - 'A' + 10;
4154 else
4155 return NULL;
4156 if (new_id < id)
4157 return NULL;
4158 id = new_id;
4159 c = d_next_char (di);
4160 }
4161 while (c != '_');
4162
4163 ++id;
4164 }
4165
4166 if (id >= (unsigned int) di->next_sub)
4167 return NULL;
4168
4169 return di->subs[id];
4170 }
4171 else
4172 {
4173 int verbose;
4174 const struct d_standard_sub_info *p;
4175 const struct d_standard_sub_info *pend;
4176
4177 verbose = (di->options & DMGL_VERBOSE) != 0;
4178 if (! verbose && prefix)
4179 {
4180 char peek;
4181
4182 peek = d_peek_char (di);
4183 if (peek == 'C' || peek == 'D')
4184 verbose = 1;
4185 }
4186
4187 pend = (&standard_subs[0]
4188 + sizeof standard_subs / sizeof standard_subs[0]);
4189 for (p = &standard_subs[0]; p < pend; ++p)
4190 {
4191 if (c == p->code)
4192 {
4193 const char *s;
4194 int len;
4195 struct demangle_component *dc;
4196
4197 if (p->set_last_name != NULL)
4198 di->last_name = d_make_sub (di, p->set_last_name,
4199 p->set_last_name_len);
4200 if (verbose)
4201 {
4202 s = p->full_expansion;
4203 len = p->full_len;
4204 }
4205 else
4206 {
4207 s = p->simple_expansion;
4208 len = p->simple_len;
4209 }
4210 di->expansion += len;
4211 dc = d_make_sub (di, s, len);
4212 if (d_peek_char (di) == 'B')
4213 {
4214 /* If there are ABI tags on the abbreviation, it becomes
4215 a substitution candidate. */
4216 dc = d_abi_tags (di, dc);
4217 if (! d_add_substitution (di, dc))
4218 return NULL;
4219 }
4220 return dc;
4221 }
4222 }
4223
4224 return NULL;
4225 }
4226 }
4227
4228 static void
4229 d_checkpoint (struct d_info *di, struct d_info_checkpoint *checkpoint)
4230 {
4231 checkpoint->n = di->n;
4232 checkpoint->next_comp = di->next_comp;
4233 checkpoint->next_sub = di->next_sub;
4234 checkpoint->expansion = di->expansion;
4235 }
4236
4237 static void
4238 d_backtrack (struct d_info *di, struct d_info_checkpoint *checkpoint)
4239 {
4240 di->n = checkpoint->n;
4241 di->next_comp = checkpoint->next_comp;
4242 di->next_sub = checkpoint->next_sub;
4243 di->expansion = checkpoint->expansion;
4244 }
4245
4246 /* Initialize a growable string. */
4247
4248 static void
4249 d_growable_string_init (struct d_growable_string *dgs, size_t estimate)
4250 {
4251 dgs->buf = NULL;
4252 dgs->len = 0;
4253 dgs->alc = 0;
4254 dgs->allocation_failure = 0;
4255
4256 if (estimate > 0)
4257 d_growable_string_resize (dgs, estimate);
4258 }
4259
4260 /* Grow a growable string to a given size. */
4261
4262 static inline void
4263 d_growable_string_resize (struct d_growable_string *dgs, size_t need)
4264 {
4265 size_t newalc;
4266 char *newbuf;
4267
4268 if (dgs->allocation_failure)
4269 return;
4270
4271 /* Start allocation at two bytes to avoid any possibility of confusion
4272 with the special value of 1 used as a return in *palc to indicate
4273 allocation failures. */
4274 newalc = dgs->alc > 0 ? dgs->alc : 2;
4275 while (newalc < need)
4276 newalc <<= 1;
4277
4278 newbuf = (char *) realloc (dgs->buf, newalc);
4279 if (newbuf == NULL)
4280 {
4281 free (dgs->buf);
4282 dgs->buf = NULL;
4283 dgs->len = 0;
4284 dgs->alc = 0;
4285 dgs->allocation_failure = 1;
4286 return;
4287 }
4288 dgs->buf = newbuf;
4289 dgs->alc = newalc;
4290 }
4291
4292 /* Append a buffer to a growable string. */
4293
4294 static inline void
4295 d_growable_string_append_buffer (struct d_growable_string *dgs,
4296 const char *s, size_t l)
4297 {
4298 size_t need;
4299
4300 need = dgs->len + l + 1;
4301 if (need > dgs->alc)
4302 d_growable_string_resize (dgs, need);
4303
4304 if (dgs->allocation_failure)
4305 return;
4306
4307 memcpy (dgs->buf + dgs->len, s, l);
4308 dgs->buf[dgs->len + l] = '\0';
4309 dgs->len += l;
4310 }
4311
4312 /* Bridge growable strings to the callback mechanism. */
4313
4314 static void
4315 d_growable_string_callback_adapter (const char *s, size_t l, void *opaque)
4316 {
4317 struct d_growable_string *dgs = (struct d_growable_string*) opaque;
4318
4319 d_growable_string_append_buffer (dgs, s, l);
4320 }
4321
4322 /* Walk the tree, counting the number of templates encountered, and
4323 the number of times a scope might be saved. These counts will be
4324 used to allocate data structures for d_print_comp, so the logic
4325 here must mirror the logic d_print_comp will use. It is not
4326 important that the resulting numbers are exact, so long as they
4327 are larger than the actual numbers encountered. */
4328
4329 static void
4330 d_count_templates_scopes (struct d_print_info *dpi,
4331 struct demangle_component *dc)
4332 {
4333 if (dc == NULL || dc->d_counting > 1 || dpi->recursion > MAX_RECURSION_COUNT)
4334 return;
4335
4336 ++ dc->d_counting;
4337
4338 switch (dc->type)
4339 {
4340 case DEMANGLE_COMPONENT_NAME:
4341 case DEMANGLE_COMPONENT_TEMPLATE_PARAM:
4342 case DEMANGLE_COMPONENT_FUNCTION_PARAM:
4343 case DEMANGLE_COMPONENT_SUB_STD:
4344 case DEMANGLE_COMPONENT_BUILTIN_TYPE:
4345 case DEMANGLE_COMPONENT_EXTENDED_BUILTIN_TYPE:
4346 case DEMANGLE_COMPONENT_OPERATOR:
4347 case DEMANGLE_COMPONENT_CHARACTER:
4348 case DEMANGLE_COMPONENT_NUMBER:
4349 case DEMANGLE_COMPONENT_UNNAMED_TYPE:
4350 case DEMANGLE_COMPONENT_STRUCTURED_BINDING:
4351 case DEMANGLE_COMPONENT_MODULE_NAME:
4352 case DEMANGLE_COMPONENT_MODULE_PARTITION:
4353 case DEMANGLE_COMPONENT_MODULE_INIT:
4354 case DEMANGLE_COMPONENT_FIXED_TYPE:
4355 case DEMANGLE_COMPONENT_TEMPLATE_HEAD:
4356 case DEMANGLE_COMPONENT_TEMPLATE_TYPE_PARM:
4357 case DEMANGLE_COMPONENT_TEMPLATE_NON_TYPE_PARM:
4358 case DEMANGLE_COMPONENT_TEMPLATE_TEMPLATE_PARM:
4359 case DEMANGLE_COMPONENT_TEMPLATE_PACK_PARM:
4360 break;
4361
4362 case DEMANGLE_COMPONENT_TEMPLATE:
4363 dpi->num_copy_templates++;
4364 goto recurse_left_right;
4365
4366 case DEMANGLE_COMPONENT_REFERENCE:
4367 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
4368 if (d_left (dc)->type == DEMANGLE_COMPONENT_TEMPLATE_PARAM)
4369 dpi->num_saved_scopes++;
4370 goto recurse_left_right;
4371
4372 case DEMANGLE_COMPONENT_QUAL_NAME:
4373 case DEMANGLE_COMPONENT_LOCAL_NAME:
4374 case DEMANGLE_COMPONENT_TYPED_NAME:
4375 case DEMANGLE_COMPONENT_VTABLE:
4376 case DEMANGLE_COMPONENT_VTT:
4377 case DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE:
4378 case DEMANGLE_COMPONENT_TYPEINFO:
4379 case DEMANGLE_COMPONENT_TYPEINFO_NAME:
4380 case DEMANGLE_COMPONENT_TYPEINFO_FN:
4381 case DEMANGLE_COMPONENT_THUNK:
4382 case DEMANGLE_COMPONENT_VIRTUAL_THUNK:
4383 case DEMANGLE_COMPONENT_COVARIANT_THUNK:
4384 case DEMANGLE_COMPONENT_JAVA_CLASS:
4385 case DEMANGLE_COMPONENT_GUARD:
4386 case DEMANGLE_COMPONENT_TLS_INIT:
4387 case DEMANGLE_COMPONENT_TLS_WRAPPER:
4388 case DEMANGLE_COMPONENT_REFTEMP:
4389 case DEMANGLE_COMPONENT_HIDDEN_ALIAS:
4390 case DEMANGLE_COMPONENT_RESTRICT:
4391 case DEMANGLE_COMPONENT_VOLATILE:
4392 case DEMANGLE_COMPONENT_CONST:
4393 case DEMANGLE_COMPONENT_RESTRICT_THIS:
4394 case DEMANGLE_COMPONENT_VOLATILE_THIS:
4395 case DEMANGLE_COMPONENT_CONST_THIS:
4396 case DEMANGLE_COMPONENT_REFERENCE_THIS:
4397 case DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS:
4398 case DEMANGLE_COMPONENT_TRANSACTION_SAFE:
4399 case DEMANGLE_COMPONENT_NOEXCEPT:
4400 case DEMANGLE_COMPONENT_THROW_SPEC:
4401 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
4402 case DEMANGLE_COMPONENT_POINTER:
4403 case DEMANGLE_COMPONENT_COMPLEX:
4404 case DEMANGLE_COMPONENT_IMAGINARY:
4405 case DEMANGLE_COMPONENT_VENDOR_TYPE:
4406 case DEMANGLE_COMPONENT_FUNCTION_TYPE:
4407 case DEMANGLE_COMPONENT_ARRAY_TYPE:
4408 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
4409 case DEMANGLE_COMPONENT_VECTOR_TYPE:
4410 case DEMANGLE_COMPONENT_ARGLIST:
4411 case DEMANGLE_COMPONENT_TEMPLATE_ARGLIST:
4412 case DEMANGLE_COMPONENT_TPARM_OBJ:
4413 case DEMANGLE_COMPONENT_INITIALIZER_LIST:
4414 case DEMANGLE_COMPONENT_CAST:
4415 case DEMANGLE_COMPONENT_CONVERSION:
4416 case DEMANGLE_COMPONENT_NULLARY:
4417 case DEMANGLE_COMPONENT_UNARY:
4418 case DEMANGLE_COMPONENT_BINARY:
4419 case DEMANGLE_COMPONENT_BINARY_ARGS:
4420 case DEMANGLE_COMPONENT_TRINARY:
4421 case DEMANGLE_COMPONENT_TRINARY_ARG1:
4422 case DEMANGLE_COMPONENT_TRINARY_ARG2:
4423 case DEMANGLE_COMPONENT_LITERAL:
4424 case DEMANGLE_COMPONENT_LITERAL_NEG:
4425 case DEMANGLE_COMPONENT_VENDOR_EXPR:
4426 case DEMANGLE_COMPONENT_JAVA_RESOURCE:
4427 case DEMANGLE_COMPONENT_COMPOUND_NAME:
4428 case DEMANGLE_COMPONENT_DECLTYPE:
4429 case DEMANGLE_COMPONENT_TRANSACTION_CLONE:
4430 case DEMANGLE_COMPONENT_NONTRANSACTION_CLONE:
4431 case DEMANGLE_COMPONENT_PACK_EXPANSION:
4432 case DEMANGLE_COMPONENT_TAGGED_NAME:
4433 case DEMANGLE_COMPONENT_CLONE:
4434 recurse_left_right:
4435 /* PR 89394 - Check for too much recursion. */
4436 if (dpi->recursion > DEMANGLE_RECURSION_LIMIT)
4437 /* FIXME: There ought to be a way to report to the
4438 user that the recursion limit has been reached. */
4439 return;
4440
4441 ++ dpi->recursion;
4442 d_count_templates_scopes (dpi, d_left (dc));
4443 d_count_templates_scopes (dpi, d_right (dc));
4444 -- dpi->recursion;
4445 break;
4446
4447 case DEMANGLE_COMPONENT_CTOR:
4448 d_count_templates_scopes (dpi, dc->u.s_ctor.name);
4449 break;
4450
4451 case DEMANGLE_COMPONENT_DTOR:
4452 d_count_templates_scopes (dpi, dc->u.s_dtor.name);
4453 break;
4454
4455 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
4456 d_count_templates_scopes (dpi, dc->u.s_extended_operator.name);
4457 break;
4458
4459 case DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS:
4460 case DEMANGLE_COMPONENT_GLOBAL_DESTRUCTORS:
4461 case DEMANGLE_COMPONENT_MODULE_ENTITY:
4462 d_count_templates_scopes (dpi, d_left (dc));
4463 break;
4464
4465 case DEMANGLE_COMPONENT_LAMBDA:
4466 case DEMANGLE_COMPONENT_DEFAULT_ARG:
4467 d_count_templates_scopes (dpi, dc->u.s_unary_num.sub);
4468 break;
4469 }
4470 }
4471
4472 /* Initialize a print information structure. */
4473
4474 static void
4475 d_print_init (struct d_print_info *dpi, demangle_callbackref callback,
4476 void *opaque, struct demangle_component *dc)
4477 {
4478 dpi->len = 0;
4479 dpi->last_char = '\0';
4480 dpi->templates = NULL;
4481 dpi->modifiers = NULL;
4482 dpi->pack_index = 0;
4483 dpi->flush_count = 0;
4484
4485 dpi->callback = callback;
4486 dpi->opaque = opaque;
4487
4488 dpi->demangle_failure = 0;
4489 dpi->recursion = 0;
4490 dpi->lambda_tpl_parms = 0;
4491
4492 dpi->component_stack = NULL;
4493
4494 dpi->saved_scopes = NULL;
4495 dpi->next_saved_scope = 0;
4496 dpi->num_saved_scopes = 0;
4497
4498 dpi->copy_templates = NULL;
4499 dpi->next_copy_template = 0;
4500 dpi->num_copy_templates = 0;
4501
4502 d_count_templates_scopes (dpi, dc);
4503 /* If we did not reach the recursion limit, then reset the
4504 current recursion value back to 0, so that we can print
4505 the templates. */
4506 if (dpi->recursion < DEMANGLE_RECURSION_LIMIT)
4507 dpi->recursion = 0;
4508 dpi->num_copy_templates *= dpi->num_saved_scopes;
4509
4510 dpi->current_template = NULL;
4511 }
4512
4513 /* Indicate that an error occurred during printing, and test for error. */
4514
4515 static inline void
4516 d_print_error (struct d_print_info *dpi)
4517 {
4518 dpi->demangle_failure = 1;
4519 }
4520
4521 static inline int
4522 d_print_saw_error (struct d_print_info *dpi)
4523 {
4524 return dpi->demangle_failure != 0;
4525 }
4526
4527 /* Flush buffered characters to the callback. */
4528
4529 static inline void
4530 d_print_flush (struct d_print_info *dpi)
4531 {
4532 dpi->buf[dpi->len] = '\0';
4533 dpi->callback (dpi->buf, dpi->len, dpi->opaque);
4534 dpi->len = 0;
4535 dpi->flush_count++;
4536 }
4537
4538 /* Append characters and buffers for printing. */
4539
4540 static inline void
4541 d_append_char (struct d_print_info *dpi, char c)
4542 {
4543 if (dpi->len == sizeof (dpi->buf) - 1)
4544 d_print_flush (dpi);
4545
4546 dpi->buf[dpi->len++] = c;
4547 dpi->last_char = c;
4548 }
4549
4550 static inline void
4551 d_append_buffer (struct d_print_info *dpi, const char *s, size_t l)
4552 {
4553 size_t i;
4554
4555 for (i = 0; i < l; i++)
4556 d_append_char (dpi, s[i]);
4557 }
4558
4559 static inline void
4560 d_append_string (struct d_print_info *dpi, const char *s)
4561 {
4562 d_append_buffer (dpi, s, strlen (s));
4563 }
4564
4565 static inline void
4566 d_append_num (struct d_print_info *dpi, int l)
4567 {
4568 char buf[25];
4569 sprintf (buf,"%d", l);
4570 d_append_string (dpi, buf);
4571 }
4572
4573 static inline char
4574 d_last_char (struct d_print_info *dpi)
4575 {
4576 return dpi->last_char;
4577 }
4578
4579 /* Turn components into a human readable string. OPTIONS is the
4580 options bits passed to the demangler. DC is the tree to print.
4581 CALLBACK is a function to call to flush demangled string segments
4582 as they fill the intermediate buffer, and OPAQUE is a generalized
4583 callback argument. On success, this returns 1. On failure,
4584 it returns 0, indicating a bad parse. It does not use heap
4585 memory to build an output string, so cannot encounter memory
4586 allocation failure. */
4587
4588 CP_STATIC_IF_GLIBCPP_V3
4589 int
4590 cplus_demangle_print_callback (int options,
4591 struct demangle_component *dc,
4592 demangle_callbackref callback, void *opaque)
4593 {
4594 struct d_print_info dpi;
4595
4596 d_print_init (&dpi, callback, opaque, dc);
4597
4598 {
4599 #ifdef CP_DYNAMIC_ARRAYS
4600 /* Avoid zero-length VLAs, which are prohibited by the C99 standard
4601 and flagged as errors by Address Sanitizer. */
4602 __extension__ struct d_saved_scope scopes[(dpi.num_saved_scopes > 0)
4603 ? dpi.num_saved_scopes : 1];
4604 __extension__ struct d_print_template temps[(dpi.num_copy_templates > 0)
4605 ? dpi.num_copy_templates : 1];
4606
4607 dpi.saved_scopes = scopes;
4608 dpi.copy_templates = temps;
4609 #else
4610 dpi.saved_scopes = alloca (dpi.num_saved_scopes
4611 * sizeof (*dpi.saved_scopes));
4612 dpi.copy_templates = alloca (dpi.num_copy_templates
4613 * sizeof (*dpi.copy_templates));
4614 #endif
4615
4616 d_print_comp (&dpi, options, dc);
4617 }
4618
4619 d_print_flush (&dpi);
4620
4621 return ! d_print_saw_error (&dpi);
4622 }
4623
4624 /* Turn components into a human readable string. OPTIONS is the
4625 options bits passed to the demangler. DC is the tree to print.
4626 ESTIMATE is a guess at the length of the result. This returns a
4627 string allocated by malloc, or NULL on error. On success, this
4628 sets *PALC to the size of the allocated buffer. On failure, this
4629 sets *PALC to 0 for a bad parse, or to 1 for a memory allocation
4630 failure. */
4631
4632 CP_STATIC_IF_GLIBCPP_V3
4633 char *
4634 cplus_demangle_print (int options, struct demangle_component *dc,
4635 int estimate, size_t *palc)
4636 {
4637 struct d_growable_string dgs;
4638
4639 d_growable_string_init (&dgs, estimate);
4640
4641 if (! cplus_demangle_print_callback (options, dc,
4642 d_growable_string_callback_adapter,
4643 &dgs))
4644 {
4645 free (dgs.buf);
4646 *palc = 0;
4647 return NULL;
4648 }
4649
4650 *palc = dgs.allocation_failure ? 1 : dgs.alc;
4651 return dgs.buf;
4652 }
4653
4654 /* Returns the I'th element of the template arglist ARGS, or NULL on
4655 failure. If I is negative, return the entire arglist. */
4656
4657 static struct demangle_component *
4658 d_index_template_argument (struct demangle_component *args, int i)
4659 {
4660 struct demangle_component *a;
4661
4662 if (i < 0)
4663 /* Print the whole argument pack. */
4664 return args;
4665
4666 for (a = args;
4667 a != NULL;
4668 a = d_right (a))
4669 {
4670 if (a->type != DEMANGLE_COMPONENT_TEMPLATE_ARGLIST)
4671 return NULL;
4672 if (i <= 0)
4673 break;
4674 --i;
4675 }
4676 if (i != 0 || a == NULL)
4677 return NULL;
4678
4679 return d_left (a);
4680 }
4681
4682 /* Returns the template argument from the current context indicated by DC,
4683 which is a DEMANGLE_COMPONENT_TEMPLATE_PARAM, or NULL. */
4684
4685 static struct demangle_component *
4686 d_lookup_template_argument (struct d_print_info *dpi,
4687 const struct demangle_component *dc)
4688 {
4689 if (dpi->templates == NULL)
4690 {
4691 d_print_error (dpi);
4692 return NULL;
4693 }
4694
4695 return d_index_template_argument
4696 (d_right (dpi->templates->template_decl),
4697 dc->u.s_number.number);
4698 }
4699
4700 /* Returns a template argument pack used in DC (any will do), or NULL. */
4701
4702 static struct demangle_component *
4703 d_find_pack (struct d_print_info *dpi,
4704 const struct demangle_component *dc)
4705 {
4706 struct demangle_component *a;
4707 if (dc == NULL)
4708 return NULL;
4709
4710 switch (dc->type)
4711 {
4712 case DEMANGLE_COMPONENT_TEMPLATE_PARAM:
4713 a = d_lookup_template_argument (dpi, dc);
4714 if (a && a->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST)
4715 return a;
4716 return NULL;
4717
4718 case DEMANGLE_COMPONENT_PACK_EXPANSION:
4719 return NULL;
4720
4721 case DEMANGLE_COMPONENT_LAMBDA:
4722 case DEMANGLE_COMPONENT_NAME:
4723 case DEMANGLE_COMPONENT_TAGGED_NAME:
4724 case DEMANGLE_COMPONENT_OPERATOR:
4725 case DEMANGLE_COMPONENT_BUILTIN_TYPE:
4726 case DEMANGLE_COMPONENT_EXTENDED_BUILTIN_TYPE:
4727 case DEMANGLE_COMPONENT_SUB_STD:
4728 case DEMANGLE_COMPONENT_CHARACTER:
4729 case DEMANGLE_COMPONENT_FUNCTION_PARAM:
4730 case DEMANGLE_COMPONENT_UNNAMED_TYPE:
4731 case DEMANGLE_COMPONENT_DEFAULT_ARG:
4732 case DEMANGLE_COMPONENT_NUMBER:
4733 return NULL;
4734
4735 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
4736 return d_find_pack (dpi, dc->u.s_extended_operator.name);
4737 case DEMANGLE_COMPONENT_CTOR:
4738 return d_find_pack (dpi, dc->u.s_ctor.name);
4739 case DEMANGLE_COMPONENT_DTOR:
4740 return d_find_pack (dpi, dc->u.s_dtor.name);
4741
4742 default:
4743 a = d_find_pack (dpi, d_left (dc));
4744 if (a)
4745 return a;
4746 return d_find_pack (dpi, d_right (dc));
4747 }
4748 }
4749
4750 /* Returns the length of the template argument pack DC. */
4751
4752 static int
4753 d_pack_length (const struct demangle_component *dc)
4754 {
4755 int count = 0;
4756 while (dc && dc->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST
4757 && d_left (dc) != NULL)
4758 {
4759 ++count;
4760 dc = d_right (dc);
4761 }
4762 return count;
4763 }
4764
4765 /* Returns the number of template args in DC, expanding any pack expansions
4766 found there. */
4767
4768 static int
4769 d_args_length (struct d_print_info *dpi, const struct demangle_component *dc)
4770 {
4771 int count = 0;
4772 for (; dc && dc->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST;
4773 dc = d_right (dc))
4774 {
4775 struct demangle_component *elt = d_left (dc);
4776 if (elt == NULL)
4777 break;
4778 if (elt->type == DEMANGLE_COMPONENT_PACK_EXPANSION)
4779 {
4780 struct demangle_component *a = d_find_pack (dpi, d_left (elt));
4781 count += d_pack_length (a);
4782 }
4783 else
4784 ++count;
4785 }
4786 return count;
4787 }
4788
4789 /* DC is a component of a mangled expression. Print it, wrapped in parens
4790 if needed. */
4791
4792 static void
4793 d_print_subexpr (struct d_print_info *dpi, int options,
4794 struct demangle_component *dc)
4795 {
4796 int simple = 0;
4797 if (dc->type == DEMANGLE_COMPONENT_NAME
4798 || dc->type == DEMANGLE_COMPONENT_QUAL_NAME
4799 || dc->type == DEMANGLE_COMPONENT_INITIALIZER_LIST
4800 || dc->type == DEMANGLE_COMPONENT_FUNCTION_PARAM)
4801 simple = 1;
4802 if (!simple)
4803 d_append_char (dpi, '(');
4804 d_print_comp (dpi, options, dc);
4805 if (!simple)
4806 d_append_char (dpi, ')');
4807 }
4808
4809 /* Save the current scope. */
4810
4811 static void
4812 d_save_scope (struct d_print_info *dpi,
4813 const struct demangle_component *container)
4814 {
4815 struct d_saved_scope *scope;
4816 struct d_print_template *src, **link;
4817
4818 if (dpi->next_saved_scope >= dpi->num_saved_scopes)
4819 {
4820 d_print_error (dpi);
4821 return;
4822 }
4823 scope = &dpi->saved_scopes[dpi->next_saved_scope];
4824 dpi->next_saved_scope++;
4825
4826 scope->container = container;
4827 link = &scope->templates;
4828
4829 for (src = dpi->templates; src != NULL; src = src->next)
4830 {
4831 struct d_print_template *dst;
4832
4833 if (dpi->next_copy_template >= dpi->num_copy_templates)
4834 {
4835 d_print_error (dpi);
4836 return;
4837 }
4838 dst = &dpi->copy_templates[dpi->next_copy_template];
4839 dpi->next_copy_template++;
4840
4841 dst->template_decl = src->template_decl;
4842 *link = dst;
4843 link = &dst->next;
4844 }
4845
4846 *link = NULL;
4847 }
4848
4849 /* Attempt to locate a previously saved scope. Returns NULL if no
4850 corresponding saved scope was found. */
4851
4852 static struct d_saved_scope *
4853 d_get_saved_scope (struct d_print_info *dpi,
4854 const struct demangle_component *container)
4855 {
4856 int i;
4857
4858 for (i = 0; i < dpi->next_saved_scope; i++)
4859 if (dpi->saved_scopes[i].container == container)
4860 return &dpi->saved_scopes[i];
4861
4862 return NULL;
4863 }
4864
4865 /* If DC is a C++17 fold-expression, print it and return true; otherwise
4866 return false. */
4867
4868 static int
4869 d_maybe_print_fold_expression (struct d_print_info *dpi, int options,
4870 struct demangle_component *dc)
4871 {
4872 struct demangle_component *ops, *operator_, *op1, *op2;
4873 int save_idx;
4874
4875 const char *fold_code = d_left (dc)->u.s_operator.op->code;
4876 if (fold_code[0] != 'f')
4877 return 0;
4878
4879 ops = d_right (dc);
4880 operator_ = d_left (ops);
4881 op1 = d_right (ops);
4882 op2 = 0;
4883 if (op1->type == DEMANGLE_COMPONENT_TRINARY_ARG2)
4884 {
4885 op2 = d_right (op1);
4886 op1 = d_left (op1);
4887 }
4888
4889 /* Print the whole pack. */
4890 save_idx = dpi->pack_index;
4891 dpi->pack_index = -1;
4892
4893 switch (fold_code[1])
4894 {
4895 /* Unary left fold, (... + X). */
4896 case 'l':
4897 d_append_string (dpi, "(...");
4898 d_print_expr_op (dpi, options, operator_);
4899 d_print_subexpr (dpi, options, op1);
4900 d_append_char (dpi, ')');
4901 break;
4902
4903 /* Unary right fold, (X + ...). */
4904 case 'r':
4905 d_append_char (dpi, '(');
4906 d_print_subexpr (dpi, options, op1);
4907 d_print_expr_op (dpi, options, operator_);
4908 d_append_string (dpi, "...)");
4909 break;
4910
4911 /* Binary left fold, (42 + ... + X). */
4912 case 'L':
4913 /* Binary right fold, (X + ... + 42). */
4914 case 'R':
4915 d_append_char (dpi, '(');
4916 d_print_subexpr (dpi, options, op1);
4917 d_print_expr_op (dpi, options, operator_);
4918 d_append_string (dpi, "...");
4919 d_print_expr_op (dpi, options, operator_);
4920 d_print_subexpr (dpi, options, op2);
4921 d_append_char (dpi, ')');
4922 break;
4923 }
4924
4925 dpi->pack_index = save_idx;
4926 return 1;
4927 }
4928
4929 /* True iff DC represents a C99-style designated initializer. */
4930
4931 static int
4932 is_designated_init (struct demangle_component *dc)
4933 {
4934 if (dc->type != DEMANGLE_COMPONENT_BINARY
4935 && dc->type != DEMANGLE_COMPONENT_TRINARY)
4936 return 0;
4937
4938 struct demangle_component *op = d_left (dc);
4939 const char *code = op->u.s_operator.op->code;
4940 return (code[0] == 'd'
4941 && (code[1] == 'i' || code[1] == 'x' || code[1] == 'X'));
4942 }
4943
4944 /* If DC represents a C99-style designated initializer, print it and return
4945 true; otherwise, return false. */
4946
4947 static int
4948 d_maybe_print_designated_init (struct d_print_info *dpi, int options,
4949 struct demangle_component *dc)
4950 {
4951 if (!is_designated_init (dc))
4952 return 0;
4953
4954 const char *code = d_left (dc)->u.s_operator.op->code;
4955
4956 struct demangle_component *operands = d_right (dc);
4957 struct demangle_component *op1 = d_left (operands);
4958 struct demangle_component *op2 = d_right (operands);
4959
4960 if (code[1] == 'i')
4961 d_append_char (dpi, '.');
4962 else
4963 d_append_char (dpi, '[');
4964
4965 d_print_comp (dpi, options, op1);
4966 if (code[1] == 'X')
4967 {
4968 d_append_string (dpi, " ... ");
4969 d_print_comp (dpi, options, d_left (op2));
4970 op2 = d_right (op2);
4971 }
4972 if (code[1] != 'i')
4973 d_append_char (dpi, ']');
4974 if (is_designated_init (op2))
4975 {
4976 /* Don't put '=' or '(' between chained designators. */
4977 d_print_comp (dpi, options, op2);
4978 }
4979 else
4980 {
4981 d_append_char (dpi, '=');
4982 d_print_subexpr (dpi, options, op2);
4983 }
4984 return 1;
4985 }
4986
4987 static void
4988 d_print_lambda_parm_name (struct d_print_info *dpi, int type, unsigned index)
4989 {
4990 const char *str;
4991 switch (type)
4992 {
4993 default:
4994 dpi->demangle_failure = 1;
4995 str = "";
4996 break;
4997
4998 case DEMANGLE_COMPONENT_TEMPLATE_TYPE_PARM:
4999 str = "$T";
5000 break;
5001
5002 case DEMANGLE_COMPONENT_TEMPLATE_NON_TYPE_PARM:
5003 str = "$N";
5004 break;
5005
5006 case DEMANGLE_COMPONENT_TEMPLATE_TEMPLATE_PARM:
5007 str = "$TT";
5008 break;
5009 }
5010 d_append_string (dpi, str);
5011 d_append_num (dpi, index);
5012 }
5013
5014 /* Subroutine to handle components. */
5015
5016 static void
5017 d_print_comp_inner (struct d_print_info *dpi, int options,
5018 struct demangle_component *dc)
5019 {
5020 /* Magic variable to let reference smashing skip over the next modifier
5021 without needing to modify *dc. */
5022 struct demangle_component *mod_inner = NULL;
5023
5024 /* Variable used to store the current templates while a previously
5025 captured scope is used. */
5026 struct d_print_template *saved_templates;
5027
5028 /* Nonzero if templates have been stored in the above variable. */
5029 int need_template_restore = 0;
5030
5031 if (dc == NULL)
5032 {
5033 d_print_error (dpi);
5034 return;
5035 }
5036 if (d_print_saw_error (dpi))
5037 return;
5038
5039 switch (dc->type)
5040 {
5041 case DEMANGLE_COMPONENT_NAME:
5042 if ((options & DMGL_JAVA) == 0)
5043 d_append_buffer (dpi, dc->u.s_name.s, dc->u.s_name.len);
5044 else
5045 d_print_java_identifier (dpi, dc->u.s_name.s, dc->u.s_name.len);
5046 return;
5047
5048 case DEMANGLE_COMPONENT_TAGGED_NAME:
5049 d_print_comp (dpi, options, d_left (dc));
5050 d_append_string (dpi, "[abi:");
5051 d_print_comp (dpi, options, d_right (dc));
5052 d_append_char (dpi, ']');
5053 return;
5054
5055 case DEMANGLE_COMPONENT_STRUCTURED_BINDING:
5056 d_append_char (dpi, '[');
5057 for (;;)
5058 {
5059 d_print_comp (dpi, options, d_left (dc));
5060 dc = d_right (dc);
5061 if (!dc)
5062 break;
5063 d_append_string (dpi, ", ");
5064 }
5065 d_append_char (dpi, ']');
5066 return;
5067
5068 case DEMANGLE_COMPONENT_MODULE_ENTITY:
5069 d_print_comp (dpi, options, d_left (dc));
5070 d_append_char (dpi, '@');
5071 d_print_comp (dpi, options, d_right (dc));
5072 return;
5073
5074 case DEMANGLE_COMPONENT_MODULE_NAME:
5075 case DEMANGLE_COMPONENT_MODULE_PARTITION:
5076 {
5077 if (d_left (dc))
5078 d_print_comp (dpi, options, d_left (dc));
5079 char c = dc->type == DEMANGLE_COMPONENT_MODULE_PARTITION
5080 ? ':' : d_left (dc) ? '.' : 0;
5081 if (c)
5082 d_append_char (dpi, c);
5083 d_print_comp (dpi, options, d_right (dc));
5084 }
5085 return;
5086
5087 case DEMANGLE_COMPONENT_QUAL_NAME:
5088 case DEMANGLE_COMPONENT_LOCAL_NAME:
5089 d_print_comp (dpi, options, d_left (dc));
5090 if ((options & DMGL_JAVA) == 0)
5091 d_append_string (dpi, "::");
5092 else
5093 d_append_char (dpi, '.');
5094 {
5095 struct demangle_component *local_name = d_right (dc);
5096 if (local_name->type == DEMANGLE_COMPONENT_DEFAULT_ARG)
5097 {
5098 d_append_string (dpi, "{default arg#");
5099 d_append_num (dpi, local_name->u.s_unary_num.num + 1);
5100 d_append_string (dpi, "}::");
5101 local_name = local_name->u.s_unary_num.sub;
5102 }
5103 d_print_comp (dpi, options, local_name);
5104 }
5105 return;
5106
5107 case DEMANGLE_COMPONENT_TYPED_NAME:
5108 {
5109 struct d_print_mod *hold_modifiers;
5110 struct demangle_component *typed_name;
5111 struct d_print_mod adpm[4];
5112 unsigned int i;
5113 struct d_print_template dpt;
5114
5115 /* Pass the name down to the type so that it can be printed in
5116 the right place for the type. We also have to pass down
5117 any CV-qualifiers, which apply to the this parameter. */
5118 hold_modifiers = dpi->modifiers;
5119 dpi->modifiers = 0;
5120 i = 0;
5121 typed_name = d_left (dc);
5122 while (typed_name != NULL)
5123 {
5124 if (i >= sizeof adpm / sizeof adpm[0])
5125 {
5126 d_print_error (dpi);
5127 return;
5128 }
5129
5130 adpm[i].next = dpi->modifiers;
5131 dpi->modifiers = &adpm[i];
5132 adpm[i].mod = typed_name;
5133 adpm[i].printed = 0;
5134 adpm[i].templates = dpi->templates;
5135 ++i;
5136
5137 if (!is_fnqual_component_type (typed_name->type))
5138 break;
5139
5140 typed_name = d_left (typed_name);
5141 }
5142
5143 if (typed_name == NULL)
5144 {
5145 d_print_error (dpi);
5146 return;
5147 }
5148
5149 /* If typed_name is a DEMANGLE_COMPONENT_LOCAL_NAME, then
5150 there may be CV-qualifiers on its right argument which
5151 really apply here; this happens when parsing a class that
5152 is local to a function. */
5153 if (typed_name->type == DEMANGLE_COMPONENT_LOCAL_NAME)
5154 {
5155 typed_name = d_right (typed_name);
5156 if (typed_name->type == DEMANGLE_COMPONENT_DEFAULT_ARG)
5157 typed_name = typed_name->u.s_unary_num.sub;
5158 while (typed_name != NULL
5159 && is_fnqual_component_type (typed_name->type))
5160 {
5161 if (i >= sizeof adpm / sizeof adpm[0])
5162 {
5163 d_print_error (dpi);
5164 return;
5165 }
5166
5167 adpm[i] = adpm[i - 1];
5168 adpm[i].next = &adpm[i - 1];
5169 dpi->modifiers = &adpm[i];
5170
5171 adpm[i - 1].mod = typed_name;
5172 adpm[i - 1].printed = 0;
5173 adpm[i - 1].templates = dpi->templates;
5174 ++i;
5175
5176 typed_name = d_left (typed_name);
5177 }
5178 if (typed_name == NULL)
5179 {
5180 d_print_error (dpi);
5181 return;
5182 }
5183 }
5184
5185 /* If typed_name is a template, then it applies to the
5186 function type as well. */
5187 if (typed_name->type == DEMANGLE_COMPONENT_TEMPLATE)
5188 {
5189 dpt.next = dpi->templates;
5190 dpi->templates = &dpt;
5191 dpt.template_decl = typed_name;
5192 }
5193
5194 d_print_comp (dpi, options, d_right (dc));
5195
5196 if (typed_name->type == DEMANGLE_COMPONENT_TEMPLATE)
5197 dpi->templates = dpt.next;
5198
5199 /* If the modifiers didn't get printed by the type, print them
5200 now. */
5201 while (i > 0)
5202 {
5203 --i;
5204 if (! adpm[i].printed)
5205 {
5206 d_append_char (dpi, ' ');
5207 d_print_mod (dpi, options, adpm[i].mod);
5208 }
5209 }
5210
5211 dpi->modifiers = hold_modifiers;
5212
5213 return;
5214 }
5215
5216 case DEMANGLE_COMPONENT_TEMPLATE:
5217 {
5218 struct d_print_mod *hold_dpm;
5219 struct demangle_component *dcl;
5220 const struct demangle_component *hold_current;
5221
5222 /* This template may need to be referenced by a cast operator
5223 contained in its subtree. */
5224 hold_current = dpi->current_template;
5225 dpi->current_template = dc;
5226
5227 /* Don't push modifiers into a template definition. Doing so
5228 could give the wrong definition for a template argument.
5229 Instead, treat the template essentially as a name. */
5230
5231 hold_dpm = dpi->modifiers;
5232 dpi->modifiers = NULL;
5233
5234 dcl = d_left (dc);
5235
5236 if ((options & DMGL_JAVA) != 0
5237 && dcl->type == DEMANGLE_COMPONENT_NAME
5238 && dcl->u.s_name.len == 6
5239 && strncmp (dcl->u.s_name.s, "JArray", 6) == 0)
5240 {
5241 /* Special-case Java arrays, so that JArray<TYPE> appears
5242 instead as TYPE[]. */
5243
5244 d_print_comp (dpi, options, d_right (dc));
5245 d_append_string (dpi, "[]");
5246 }
5247 else
5248 {
5249 d_print_comp (dpi, options, dcl);
5250 if (d_last_char (dpi) == '<')
5251 d_append_char (dpi, ' ');
5252 d_append_char (dpi, '<');
5253 d_print_comp (dpi, options, d_right (dc));
5254 /* Avoid generating two consecutive '>' characters, to avoid
5255 the C++ syntactic ambiguity. */
5256 if (d_last_char (dpi) == '>')
5257 d_append_char (dpi, ' ');
5258 d_append_char (dpi, '>');
5259 }
5260
5261 dpi->modifiers = hold_dpm;
5262 dpi->current_template = hold_current;
5263
5264 return;
5265 }
5266
5267 case DEMANGLE_COMPONENT_TEMPLATE_PARAM:
5268 if (dpi->lambda_tpl_parms > dc->u.s_number.number + 1)
5269 {
5270 const struct demangle_component *a
5271 = d_left (dpi->templates->template_decl);
5272 unsigned c;
5273 for (c = dc->u.s_number.number; a && c; c--)
5274 a = d_right (a);
5275 if (a && a->type == DEMANGLE_COMPONENT_TEMPLATE_PACK_PARM)
5276 a = d_left (a);
5277 if (!a)
5278 dpi->demangle_failure = 1;
5279 else
5280 d_print_lambda_parm_name (dpi, a->type, dc->u.s_number.number);
5281 }
5282 else if (dpi->lambda_tpl_parms)
5283 {
5284 /* Show the template parm index, as that's how g++ displays
5285 these, and future proofs us against potential
5286 '[]<typename T> (T *a, T *b) {...}'. */
5287 d_append_buffer (dpi, "auto:", 5);
5288 d_append_num (dpi, dc->u.s_number.number + 1);
5289 }
5290 else
5291 {
5292 struct d_print_template *hold_dpt;
5293 struct demangle_component *a = d_lookup_template_argument (dpi, dc);
5294
5295 if (a && a->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST)
5296 a = d_index_template_argument (a, dpi->pack_index);
5297
5298 if (a == NULL)
5299 {
5300 d_print_error (dpi);
5301 return;
5302 }
5303
5304 /* While processing this parameter, we need to pop the list
5305 of templates. This is because the template parameter may
5306 itself be a reference to a parameter of an outer
5307 template. */
5308
5309 hold_dpt = dpi->templates;
5310 dpi->templates = hold_dpt->next;
5311
5312 d_print_comp (dpi, options, a);
5313
5314 dpi->templates = hold_dpt;
5315 }
5316 return;
5317
5318 case DEMANGLE_COMPONENT_TPARM_OBJ:
5319 d_append_string (dpi, "template parameter object for ");
5320 d_print_comp (dpi, options, d_left (dc));
5321 return;
5322
5323 case DEMANGLE_COMPONENT_CTOR:
5324 d_print_comp (dpi, options, dc->u.s_ctor.name);
5325 return;
5326
5327 case DEMANGLE_COMPONENT_DTOR:
5328 d_append_char (dpi, '~');
5329 d_print_comp (dpi, options, dc->u.s_dtor.name);
5330 return;
5331
5332 case DEMANGLE_COMPONENT_MODULE_INIT:
5333 d_append_string (dpi, "initializer for module ");
5334 d_print_comp (dpi, options, d_left (dc));
5335 return;
5336
5337 case DEMANGLE_COMPONENT_VTABLE:
5338 d_append_string (dpi, "vtable for ");
5339 d_print_comp (dpi, options, d_left (dc));
5340 return;
5341
5342 case DEMANGLE_COMPONENT_VTT:
5343 d_append_string (dpi, "VTT for ");
5344 d_print_comp (dpi, options, d_left (dc));
5345 return;
5346
5347 case DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE:
5348 d_append_string (dpi, "construction vtable for ");
5349 d_print_comp (dpi, options, d_left (dc));
5350 d_append_string (dpi, "-in-");
5351 d_print_comp (dpi, options, d_right (dc));
5352 return;
5353
5354 case DEMANGLE_COMPONENT_TYPEINFO:
5355 d_append_string (dpi, "typeinfo for ");
5356 d_print_comp (dpi, options, d_left (dc));
5357 return;
5358
5359 case DEMANGLE_COMPONENT_TYPEINFO_NAME:
5360 d_append_string (dpi, "typeinfo name for ");
5361 d_print_comp (dpi, options, d_left (dc));
5362 return;
5363
5364 case DEMANGLE_COMPONENT_TYPEINFO_FN:
5365 d_append_string (dpi, "typeinfo fn for ");
5366 d_print_comp (dpi, options, d_left (dc));
5367 return;
5368
5369 case DEMANGLE_COMPONENT_THUNK:
5370 d_append_string (dpi, "non-virtual thunk to ");
5371 d_print_comp (dpi, options, d_left (dc));
5372 return;
5373
5374 case DEMANGLE_COMPONENT_VIRTUAL_THUNK:
5375 d_append_string (dpi, "virtual thunk to ");
5376 d_print_comp (dpi, options, d_left (dc));
5377 return;
5378
5379 case DEMANGLE_COMPONENT_COVARIANT_THUNK:
5380 d_append_string (dpi, "covariant return thunk to ");
5381 d_print_comp (dpi, options, d_left (dc));
5382 return;
5383
5384 case DEMANGLE_COMPONENT_JAVA_CLASS:
5385 d_append_string (dpi, "java Class for ");
5386 d_print_comp (dpi, options, d_left (dc));
5387 return;
5388
5389 case DEMANGLE_COMPONENT_GUARD:
5390 d_append_string (dpi, "guard variable for ");
5391 d_print_comp (dpi, options, d_left (dc));
5392 return;
5393
5394 case DEMANGLE_COMPONENT_TLS_INIT:
5395 d_append_string (dpi, "TLS init function for ");
5396 d_print_comp (dpi, options, d_left (dc));
5397 return;
5398
5399 case DEMANGLE_COMPONENT_TLS_WRAPPER:
5400 d_append_string (dpi, "TLS wrapper function for ");
5401 d_print_comp (dpi, options, d_left (dc));
5402 return;
5403
5404 case DEMANGLE_COMPONENT_REFTEMP:
5405 d_append_string (dpi, "reference temporary #");
5406 d_print_comp (dpi, options, d_right (dc));
5407 d_append_string (dpi, " for ");
5408 d_print_comp (dpi, options, d_left (dc));
5409 return;
5410
5411 case DEMANGLE_COMPONENT_HIDDEN_ALIAS:
5412 d_append_string (dpi, "hidden alias for ");
5413 d_print_comp (dpi, options, d_left (dc));
5414 return;
5415
5416 case DEMANGLE_COMPONENT_TRANSACTION_CLONE:
5417 d_append_string (dpi, "transaction clone for ");
5418 d_print_comp (dpi, options, d_left (dc));
5419 return;
5420
5421 case DEMANGLE_COMPONENT_NONTRANSACTION_CLONE:
5422 d_append_string (dpi, "non-transaction clone for ");
5423 d_print_comp (dpi, options, d_left (dc));
5424 return;
5425
5426 case DEMANGLE_COMPONENT_SUB_STD:
5427 d_append_buffer (dpi, dc->u.s_string.string, dc->u.s_string.len);
5428 return;
5429
5430 case DEMANGLE_COMPONENT_RESTRICT:
5431 case DEMANGLE_COMPONENT_VOLATILE:
5432 case DEMANGLE_COMPONENT_CONST:
5433 {
5434 struct d_print_mod *pdpm;
5435
5436 /* When printing arrays, it's possible to have cases where the
5437 same CV-qualifier gets pushed on the stack multiple times.
5438 We only need to print it once. */
5439
5440 for (pdpm = dpi->modifiers; pdpm != NULL; pdpm = pdpm->next)
5441 {
5442 if (! pdpm->printed)
5443 {
5444 if (pdpm->mod->type != DEMANGLE_COMPONENT_RESTRICT
5445 && pdpm->mod->type != DEMANGLE_COMPONENT_VOLATILE
5446 && pdpm->mod->type != DEMANGLE_COMPONENT_CONST)
5447 break;
5448 if (pdpm->mod->type == dc->type)
5449 {
5450 d_print_comp (dpi, options, d_left (dc));
5451 return;
5452 }
5453 }
5454 }
5455 }
5456 goto modifier;
5457
5458 case DEMANGLE_COMPONENT_REFERENCE:
5459 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
5460 {
5461 /* Handle reference smashing: & + && = &. */
5462 struct demangle_component *sub = d_left (dc);
5463 if (!dpi->lambda_tpl_parms
5464 && sub->type == DEMANGLE_COMPONENT_TEMPLATE_PARAM)
5465 {
5466 struct d_saved_scope *scope = d_get_saved_scope (dpi, sub);
5467 struct demangle_component *a;
5468
5469 if (scope == NULL)
5470 {
5471 /* This is the first time SUB has been traversed.
5472 We need to capture the current templates so
5473 they can be restored if SUB is reentered as a
5474 substitution. */
5475 d_save_scope (dpi, sub);
5476 if (d_print_saw_error (dpi))
5477 return;
5478 }
5479 else
5480 {
5481 const struct d_component_stack *dcse;
5482 int found_self_or_parent = 0;
5483
5484 /* This traversal is reentering SUB as a substition.
5485 If we are not beneath SUB or DC in the tree then we
5486 need to restore SUB's template stack temporarily. */
5487 for (dcse = dpi->component_stack; dcse != NULL;
5488 dcse = dcse->parent)
5489 {
5490 if (dcse->dc == sub
5491 || (dcse->dc == dc
5492 && dcse != dpi->component_stack))
5493 {
5494 found_self_or_parent = 1;
5495 break;
5496 }
5497 }
5498
5499 if (!found_self_or_parent)
5500 {
5501 saved_templates = dpi->templates;
5502 dpi->templates = scope->templates;
5503 need_template_restore = 1;
5504 }
5505 }
5506
5507 a = d_lookup_template_argument (dpi, sub);
5508 if (a && a->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST)
5509 a = d_index_template_argument (a, dpi->pack_index);
5510
5511 if (a == NULL)
5512 {
5513 if (need_template_restore)
5514 dpi->templates = saved_templates;
5515
5516 d_print_error (dpi);
5517 return;
5518 }
5519
5520 sub = a;
5521 }
5522
5523 if (sub->type == DEMANGLE_COMPONENT_REFERENCE
5524 || sub->type == dc->type)
5525 dc = sub;
5526 else if (sub->type == DEMANGLE_COMPONENT_RVALUE_REFERENCE)
5527 mod_inner = d_left (sub);
5528 }
5529 /* Fall through. */
5530
5531 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
5532 case DEMANGLE_COMPONENT_POINTER:
5533 case DEMANGLE_COMPONENT_COMPLEX:
5534 case DEMANGLE_COMPONENT_IMAGINARY:
5535 FNQUAL_COMPONENT_CASE:
5536 modifier:
5537 {
5538 /* We keep a list of modifiers on the stack. */
5539 struct d_print_mod dpm;
5540
5541 dpm.next = dpi->modifiers;
5542 dpi->modifiers = &dpm;
5543 dpm.mod = dc;
5544 dpm.printed = 0;
5545 dpm.templates = dpi->templates;
5546
5547 if (!mod_inner)
5548 mod_inner = d_left (dc);
5549
5550 d_print_comp (dpi, options, mod_inner);
5551
5552 /* If the modifier didn't get printed by the type, print it
5553 now. */
5554 if (! dpm.printed)
5555 d_print_mod (dpi, options, dc);
5556
5557 dpi->modifiers = dpm.next;
5558
5559 if (need_template_restore)
5560 dpi->templates = saved_templates;
5561
5562 return;
5563 }
5564
5565 case DEMANGLE_COMPONENT_BUILTIN_TYPE:
5566 if ((options & DMGL_JAVA) == 0)
5567 d_append_buffer (dpi, dc->u.s_builtin.type->name,
5568 dc->u.s_builtin.type->len);
5569 else
5570 d_append_buffer (dpi, dc->u.s_builtin.type->java_name,
5571 dc->u.s_builtin.type->java_len);
5572 return;
5573
5574 case DEMANGLE_COMPONENT_EXTENDED_BUILTIN_TYPE:
5575 d_append_buffer (dpi, dc->u.s_extended_builtin.type->name,
5576 dc->u.s_extended_builtin.type->len);
5577 d_append_num (dpi, dc->u.s_extended_builtin.arg);
5578 if (dc->u.s_extended_builtin.suffix)
5579 d_append_buffer (dpi, &dc->u.s_extended_builtin.suffix, 1);
5580 return;
5581
5582 case DEMANGLE_COMPONENT_VENDOR_TYPE:
5583 d_print_comp (dpi, options, d_left (dc));
5584 return;
5585
5586 case DEMANGLE_COMPONENT_FUNCTION_TYPE:
5587 {
5588 if ((options & DMGL_RET_POSTFIX) != 0)
5589 d_print_function_type (dpi,
5590 options & ~(DMGL_RET_POSTFIX | DMGL_RET_DROP),
5591 dc, dpi->modifiers);
5592
5593 /* Print return type if present */
5594 if (d_left (dc) != NULL && (options & DMGL_RET_POSTFIX) != 0)
5595 d_print_comp (dpi, options & ~(DMGL_RET_POSTFIX | DMGL_RET_DROP),
5596 d_left (dc));
5597 else if (d_left (dc) != NULL && (options & DMGL_RET_DROP) == 0)
5598 {
5599 struct d_print_mod dpm;
5600
5601 /* We must pass this type down as a modifier in order to
5602 print it in the right location. */
5603 dpm.next = dpi->modifiers;
5604 dpi->modifiers = &dpm;
5605 dpm.mod = dc;
5606 dpm.printed = 0;
5607 dpm.templates = dpi->templates;
5608
5609 d_print_comp (dpi, options & ~(DMGL_RET_POSTFIX | DMGL_RET_DROP),
5610 d_left (dc));
5611
5612 dpi->modifiers = dpm.next;
5613
5614 if (dpm.printed)
5615 return;
5616
5617 /* In standard prefix notation, there is a space between the
5618 return type and the function signature. */
5619 if ((options & DMGL_RET_POSTFIX) == 0)
5620 d_append_char (dpi, ' ');
5621 }
5622
5623 if ((options & DMGL_RET_POSTFIX) == 0)
5624 d_print_function_type (dpi,
5625 options & ~(DMGL_RET_POSTFIX | DMGL_RET_DROP),
5626 dc, dpi->modifiers);
5627
5628 return;
5629 }
5630
5631 case DEMANGLE_COMPONENT_ARRAY_TYPE:
5632 {
5633 struct d_print_mod *hold_modifiers;
5634 struct d_print_mod adpm[4];
5635 unsigned int i;
5636 struct d_print_mod *pdpm;
5637
5638 /* We must pass this type down as a modifier in order to print
5639 multi-dimensional arrays correctly. If the array itself is
5640 CV-qualified, we act as though the element type were
5641 CV-qualified. We do this by copying the modifiers down
5642 rather than fiddling pointers, so that we don't wind up
5643 with a d_print_mod higher on the stack pointing into our
5644 stack frame after we return. */
5645
5646 hold_modifiers = dpi->modifiers;
5647
5648 adpm[0].next = hold_modifiers;
5649 dpi->modifiers = &adpm[0];
5650 adpm[0].mod = dc;
5651 adpm[0].printed = 0;
5652 adpm[0].templates = dpi->templates;
5653
5654 i = 1;
5655 pdpm = hold_modifiers;
5656 while (pdpm != NULL
5657 && (pdpm->mod->type == DEMANGLE_COMPONENT_RESTRICT
5658 || pdpm->mod->type == DEMANGLE_COMPONENT_VOLATILE
5659 || pdpm->mod->type == DEMANGLE_COMPONENT_CONST))
5660 {
5661 if (! pdpm->printed)
5662 {
5663 if (i >= sizeof adpm / sizeof adpm[0])
5664 {
5665 d_print_error (dpi);
5666 return;
5667 }
5668
5669 adpm[i] = *pdpm;
5670 adpm[i].next = dpi->modifiers;
5671 dpi->modifiers = &adpm[i];
5672 pdpm->printed = 1;
5673 ++i;
5674 }
5675
5676 pdpm = pdpm->next;
5677 }
5678
5679 d_print_comp (dpi, options, d_right (dc));
5680
5681 dpi->modifiers = hold_modifiers;
5682
5683 if (adpm[0].printed)
5684 return;
5685
5686 while (i > 1)
5687 {
5688 --i;
5689 d_print_mod (dpi, options, adpm[i].mod);
5690 }
5691
5692 d_print_array_type (dpi, options, dc, dpi->modifiers);
5693
5694 return;
5695 }
5696
5697 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
5698 case DEMANGLE_COMPONENT_VECTOR_TYPE:
5699 {
5700 struct d_print_mod dpm;
5701
5702 dpm.next = dpi->modifiers;
5703 dpi->modifiers = &dpm;
5704 dpm.mod = dc;
5705 dpm.printed = 0;
5706 dpm.templates = dpi->templates;
5707
5708 d_print_comp (dpi, options, d_right (dc));
5709
5710 /* If the modifier didn't get printed by the type, print it
5711 now. */
5712 if (! dpm.printed)
5713 d_print_mod (dpi, options, dc);
5714
5715 dpi->modifiers = dpm.next;
5716
5717 return;
5718 }
5719
5720 case DEMANGLE_COMPONENT_ARGLIST:
5721 case DEMANGLE_COMPONENT_TEMPLATE_ARGLIST:
5722 if (d_left (dc) != NULL)
5723 d_print_comp (dpi, options, d_left (dc));
5724 if (d_right (dc) != NULL)
5725 {
5726 size_t len;
5727 unsigned long int flush_count;
5728 /* Make sure ", " isn't flushed by d_append_string, otherwise
5729 dpi->len -= 2 wouldn't work. */
5730 if (dpi->len >= sizeof (dpi->buf) - 2)
5731 d_print_flush (dpi);
5732 d_append_string (dpi, ", ");
5733 len = dpi->len;
5734 flush_count = dpi->flush_count;
5735 d_print_comp (dpi, options, d_right (dc));
5736 /* If that didn't print anything (which can happen with empty
5737 template argument packs), remove the comma and space. */
5738 if (dpi->flush_count == flush_count && dpi->len == len)
5739 dpi->len -= 2;
5740 }
5741 return;
5742
5743 case DEMANGLE_COMPONENT_INITIALIZER_LIST:
5744 {
5745 struct demangle_component *type = d_left (dc);
5746 struct demangle_component *list = d_right (dc);
5747
5748 if (type)
5749 d_print_comp (dpi, options, type);
5750 d_append_char (dpi, '{');
5751 d_print_comp (dpi, options, list);
5752 d_append_char (dpi, '}');
5753 }
5754 return;
5755
5756 case DEMANGLE_COMPONENT_OPERATOR:
5757 {
5758 const struct demangle_operator_info *op = dc->u.s_operator.op;
5759 int len = op->len;
5760
5761 d_append_string (dpi, "operator");
5762 /* Add a space before new/delete. */
5763 if (IS_LOWER (op->name[0]))
5764 d_append_char (dpi, ' ');
5765 /* Omit a trailing space. */
5766 if (op->name[len-1] == ' ')
5767 --len;
5768 d_append_buffer (dpi, op->name, len);
5769 return;
5770 }
5771
5772 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
5773 d_append_string (dpi, "operator ");
5774 d_print_comp (dpi, options, dc->u.s_extended_operator.name);
5775 return;
5776
5777 case DEMANGLE_COMPONENT_CONVERSION:
5778 d_append_string (dpi, "operator ");
5779 d_print_conversion (dpi, options, dc);
5780 return;
5781
5782 case DEMANGLE_COMPONENT_NULLARY:
5783 d_print_expr_op (dpi, options, d_left (dc));
5784 return;
5785
5786 case DEMANGLE_COMPONENT_UNARY:
5787 {
5788 struct demangle_component *op = d_left (dc);
5789 struct demangle_component *operand = d_right (dc);
5790 const char *code = NULL;
5791
5792 if (op->type == DEMANGLE_COMPONENT_OPERATOR)
5793 {
5794 code = op->u.s_operator.op->code;
5795 if (!strcmp (code, "ad"))
5796 {
5797 /* Don't print the argument list for the address of a
5798 function. */
5799 if (operand->type == DEMANGLE_COMPONENT_TYPED_NAME
5800 && d_left (operand)->type == DEMANGLE_COMPONENT_QUAL_NAME
5801 && d_right (operand)->type == DEMANGLE_COMPONENT_FUNCTION_TYPE)
5802 operand = d_left (operand);
5803 }
5804 if (operand->type == DEMANGLE_COMPONENT_BINARY_ARGS)
5805 {
5806 /* This indicates a suffix operator. */
5807 operand = d_left (operand);
5808 d_print_subexpr (dpi, options, operand);
5809 d_print_expr_op (dpi, options, op);
5810 return;
5811 }
5812 }
5813
5814 /* For sizeof..., just print the pack length. */
5815 if (code && !strcmp (code, "sZ"))
5816 {
5817 struct demangle_component *a = d_find_pack (dpi, operand);
5818 int len = d_pack_length (a);
5819 d_append_num (dpi, len);
5820 return;
5821 }
5822 else if (code && !strcmp (code, "sP"))
5823 {
5824 int len = d_args_length (dpi, operand);
5825 d_append_num (dpi, len);
5826 return;
5827 }
5828
5829 if (op->type != DEMANGLE_COMPONENT_CAST)
5830 d_print_expr_op (dpi, options, op);
5831 else
5832 {
5833 d_append_char (dpi, '(');
5834 d_print_cast (dpi, options, op);
5835 d_append_char (dpi, ')');
5836 }
5837 if (code && !strcmp (code, "gs"))
5838 /* Avoid parens after '::'. */
5839 d_print_comp (dpi, options, operand);
5840 else if (code && (!strcmp (code, "st") || !strcmp (code, "nx")))
5841 /* Always print parens for sizeof (type) and noexcept(expr). */
5842 {
5843 d_append_char (dpi, '(');
5844 d_print_comp (dpi, options, operand);
5845 d_append_char (dpi, ')');
5846 }
5847 else
5848 d_print_subexpr (dpi, options, operand);
5849 }
5850 return;
5851
5852 case DEMANGLE_COMPONENT_BINARY:
5853 if (d_right (dc)->type != DEMANGLE_COMPONENT_BINARY_ARGS)
5854 {
5855 d_print_error (dpi);
5856 return;
5857 }
5858
5859 if (op_is_new_cast (d_left (dc)))
5860 {
5861 d_print_expr_op (dpi, options, d_left (dc));
5862 d_append_char (dpi, '<');
5863 d_print_comp (dpi, options, d_left (d_right (dc)));
5864 d_append_string (dpi, ">(");
5865 d_print_comp (dpi, options, d_right (d_right (dc)));
5866 d_append_char (dpi, ')');
5867 return;
5868 }
5869
5870 if (d_maybe_print_fold_expression (dpi, options, dc))
5871 return;
5872
5873 if (d_maybe_print_designated_init (dpi, options, dc))
5874 return;
5875
5876 /* We wrap an expression which uses the greater-than operator in
5877 an extra layer of parens so that it does not get confused
5878 with the '>' which ends the template parameters. */
5879 if (d_left (dc)->type == DEMANGLE_COMPONENT_OPERATOR
5880 && d_left (dc)->u.s_operator.op->len == 1
5881 && d_left (dc)->u.s_operator.op->name[0] == '>')
5882 d_append_char (dpi, '(');
5883
5884 if (strcmp (d_left (dc)->u.s_operator.op->code, "cl") == 0
5885 && d_left (d_right (dc))->type == DEMANGLE_COMPONENT_TYPED_NAME)
5886 {
5887 /* Function call used in an expression should not have printed types
5888 of the function arguments. Values of the function arguments still
5889 get printed below. */
5890
5891 const struct demangle_component *func = d_left (d_right (dc));
5892
5893 if (d_right (func)->type != DEMANGLE_COMPONENT_FUNCTION_TYPE)
5894 d_print_error (dpi);
5895 d_print_subexpr (dpi, options, d_left (func));
5896 }
5897 else
5898 d_print_subexpr (dpi, options, d_left (d_right (dc)));
5899 if (strcmp (d_left (dc)->u.s_operator.op->code, "ix") == 0)
5900 {
5901 d_append_char (dpi, '[');
5902 d_print_comp (dpi, options, d_right (d_right (dc)));
5903 d_append_char (dpi, ']');
5904 }
5905 else
5906 {
5907 if (strcmp (d_left (dc)->u.s_operator.op->code, "cl") != 0)
5908 d_print_expr_op (dpi, options, d_left (dc));
5909 d_print_subexpr (dpi, options, d_right (d_right (dc)));
5910 }
5911
5912 if (d_left (dc)->type == DEMANGLE_COMPONENT_OPERATOR
5913 && d_left (dc)->u.s_operator.op->len == 1
5914 && d_left (dc)->u.s_operator.op->name[0] == '>')
5915 d_append_char (dpi, ')');
5916
5917 return;
5918
5919 case DEMANGLE_COMPONENT_BINARY_ARGS:
5920 /* We should only see this as part of DEMANGLE_COMPONENT_BINARY. */
5921 d_print_error (dpi);
5922 return;
5923
5924 case DEMANGLE_COMPONENT_TRINARY:
5925 if (d_right (dc)->type != DEMANGLE_COMPONENT_TRINARY_ARG1
5926 || d_right (d_right (dc))->type != DEMANGLE_COMPONENT_TRINARY_ARG2)
5927 {
5928 d_print_error (dpi);
5929 return;
5930 }
5931 if (d_maybe_print_fold_expression (dpi, options, dc))
5932 return;
5933 if (d_maybe_print_designated_init (dpi, options, dc))
5934 return;
5935 {
5936 struct demangle_component *op = d_left (dc);
5937 struct demangle_component *first = d_left (d_right (dc));
5938 struct demangle_component *second = d_left (d_right (d_right (dc)));
5939 struct demangle_component *third = d_right (d_right (d_right (dc)));
5940
5941 if (!strcmp (op->u.s_operator.op->code, "qu"))
5942 {
5943 d_print_subexpr (dpi, options, first);
5944 d_print_expr_op (dpi, options, op);
5945 d_print_subexpr (dpi, options, second);
5946 d_append_string (dpi, " : ");
5947 d_print_subexpr (dpi, options, third);
5948 }
5949 else
5950 {
5951 d_append_string (dpi, "new ");
5952 if (d_left (first) != NULL)
5953 {
5954 d_print_subexpr (dpi, options, first);
5955 d_append_char (dpi, ' ');
5956 }
5957 d_print_comp (dpi, options, second);
5958 if (third)
5959 d_print_subexpr (dpi, options, third);
5960 }
5961 }
5962 return;
5963
5964 case DEMANGLE_COMPONENT_TRINARY_ARG1:
5965 case DEMANGLE_COMPONENT_TRINARY_ARG2:
5966 /* We should only see these are part of DEMANGLE_COMPONENT_TRINARY. */
5967 d_print_error (dpi);
5968 return;
5969
5970 case DEMANGLE_COMPONENT_LITERAL:
5971 case DEMANGLE_COMPONENT_LITERAL_NEG:
5972 {
5973 enum d_builtin_type_print tp;
5974
5975 /* For some builtin types, produce simpler output. */
5976 tp = D_PRINT_DEFAULT;
5977 if (d_left (dc)->type == DEMANGLE_COMPONENT_BUILTIN_TYPE)
5978 {
5979 tp = d_left (dc)->u.s_builtin.type->print;
5980 switch (tp)
5981 {
5982 case D_PRINT_INT:
5983 case D_PRINT_UNSIGNED:
5984 case D_PRINT_LONG:
5985 case D_PRINT_UNSIGNED_LONG:
5986 case D_PRINT_LONG_LONG:
5987 case D_PRINT_UNSIGNED_LONG_LONG:
5988 if (d_right (dc)->type == DEMANGLE_COMPONENT_NAME)
5989 {
5990 if (dc->type == DEMANGLE_COMPONENT_LITERAL_NEG)
5991 d_append_char (dpi, '-');
5992 d_print_comp (dpi, options, d_right (dc));
5993 switch (tp)
5994 {
5995 default:
5996 break;
5997 case D_PRINT_UNSIGNED:
5998 d_append_char (dpi, 'u');
5999 break;
6000 case D_PRINT_LONG:
6001 d_append_char (dpi, 'l');
6002 break;
6003 case D_PRINT_UNSIGNED_LONG:
6004 d_append_string (dpi, "ul");
6005 break;
6006 case D_PRINT_LONG_LONG:
6007 d_append_string (dpi, "ll");
6008 break;
6009 case D_PRINT_UNSIGNED_LONG_LONG:
6010 d_append_string (dpi, "ull");
6011 break;
6012 }
6013 return;
6014 }
6015 break;
6016
6017 case D_PRINT_BOOL:
6018 if (d_right (dc)->type == DEMANGLE_COMPONENT_NAME
6019 && d_right (dc)->u.s_name.len == 1
6020 && dc->type == DEMANGLE_COMPONENT_LITERAL)
6021 {
6022 switch (d_right (dc)->u.s_name.s[0])
6023 {
6024 case '0':
6025 d_append_string (dpi, "false");
6026 return;
6027 case '1':
6028 d_append_string (dpi, "true");
6029 return;
6030 default:
6031 break;
6032 }
6033 }
6034 break;
6035
6036 default:
6037 break;
6038 }
6039 }
6040
6041 d_append_char (dpi, '(');
6042 d_print_comp (dpi, options, d_left (dc));
6043 d_append_char (dpi, ')');
6044 if (dc->type == DEMANGLE_COMPONENT_LITERAL_NEG)
6045 d_append_char (dpi, '-');
6046 if (tp == D_PRINT_FLOAT)
6047 d_append_char (dpi, '[');
6048 d_print_comp (dpi, options, d_right (dc));
6049 if (tp == D_PRINT_FLOAT)
6050 d_append_char (dpi, ']');
6051 }
6052 return;
6053
6054 case DEMANGLE_COMPONENT_VENDOR_EXPR:
6055 d_print_comp (dpi, options, d_left (dc));
6056 d_append_char (dpi, '(');
6057 d_print_comp (dpi, options, d_right (dc));
6058 d_append_char (dpi, ')');
6059 return;
6060
6061 case DEMANGLE_COMPONENT_NUMBER:
6062 d_append_num (dpi, dc->u.s_number.number);
6063 return;
6064
6065 case DEMANGLE_COMPONENT_JAVA_RESOURCE:
6066 d_append_string (dpi, "java resource ");
6067 d_print_comp (dpi, options, d_left (dc));
6068 return;
6069
6070 case DEMANGLE_COMPONENT_COMPOUND_NAME:
6071 d_print_comp (dpi, options, d_left (dc));
6072 d_print_comp (dpi, options, d_right (dc));
6073 return;
6074
6075 case DEMANGLE_COMPONENT_CHARACTER:
6076 d_append_char (dpi, dc->u.s_character.character);
6077 return;
6078
6079 case DEMANGLE_COMPONENT_DECLTYPE:
6080 d_append_string (dpi, "decltype (");
6081 d_print_comp (dpi, options, d_left (dc));
6082 d_append_char (dpi, ')');
6083 return;
6084
6085 case DEMANGLE_COMPONENT_PACK_EXPANSION:
6086 {
6087 struct demangle_component *a = NULL;
6088
6089 if (!dpi->lambda_tpl_parms)
6090 a = d_find_pack (dpi, d_left (dc));
6091 if (a == NULL)
6092 {
6093 /* d_find_pack won't find anything if the only packs involved
6094 in this expansion are function parameter packs; in that
6095 case, just print the pattern and "...". */
6096 d_print_subexpr (dpi, options, d_left (dc));
6097 d_append_string (dpi, "...");
6098 }
6099 else
6100 {
6101 int len = d_pack_length (a);
6102 int i;
6103
6104 dc = d_left (dc);
6105 for (i = 0; i < len; ++i)
6106 {
6107 if (i)
6108 d_append_string (dpi, ", ");
6109 dpi->pack_index = i;
6110 d_print_comp (dpi, options, dc);
6111 }
6112 }
6113 }
6114 return;
6115
6116 case DEMANGLE_COMPONENT_FUNCTION_PARAM:
6117 {
6118 long num = dc->u.s_number.number;
6119 if (num == 0)
6120 d_append_string (dpi, "this");
6121 else
6122 {
6123 d_append_string (dpi, "{parm#");
6124 d_append_num (dpi, num);
6125 d_append_char (dpi, '}');
6126 }
6127 }
6128 return;
6129
6130 case DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS:
6131 d_append_string (dpi, "global constructors keyed to ");
6132 d_print_comp (dpi, options, dc->u.s_binary.left);
6133 return;
6134
6135 case DEMANGLE_COMPONENT_GLOBAL_DESTRUCTORS:
6136 d_append_string (dpi, "global destructors keyed to ");
6137 d_print_comp (dpi, options, dc->u.s_binary.left);
6138 return;
6139
6140 case DEMANGLE_COMPONENT_LAMBDA:
6141 {
6142 d_append_string (dpi, "{lambda");
6143 struct demangle_component *parms = dc->u.s_unary_num.sub;
6144 struct d_print_template dpt;
6145 /* Generic lambda auto parms are mangled as the (synthedic) template
6146 type parm they are. We need to tell the printer that (a) we're in
6147 a lambda, and (b) the number of synthetic parms. */
6148 int saved_tpl_parms = dpi->lambda_tpl_parms;
6149 dpi->lambda_tpl_parms = 0;
6150 /* Hang any lambda head as-if template args. */
6151 dpt.template_decl = NULL;
6152 dpt.next = dpi->templates;
6153 dpi->templates = &dpt;
6154 if (parms && parms->type == DEMANGLE_COMPONENT_TEMPLATE_HEAD)
6155 {
6156 dpt.template_decl = parms;
6157
6158 d_append_char (dpi, '<');
6159 struct demangle_component *parm;
6160 for (parm = d_left (parms); parm; parm = d_right (parm))
6161 {
6162 if (dpi->lambda_tpl_parms++)
6163 d_append_string (dpi, ", ");
6164 d_print_comp (dpi, options, parm);
6165 d_append_char (dpi, ' ');
6166 if (parm->type == DEMANGLE_COMPONENT_TEMPLATE_PACK_PARM)
6167 parm = d_left (parm);
6168 d_print_lambda_parm_name (dpi, parm->type,
6169 dpi->lambda_tpl_parms - 1);
6170 }
6171 d_append_char (dpi, '>');
6172
6173 parms = d_right (parms);
6174 }
6175 dpi->lambda_tpl_parms++;
6176
6177 d_append_char (dpi, '(');
6178 d_print_comp (dpi, options, parms);
6179 dpi->lambda_tpl_parms = saved_tpl_parms;
6180 dpi->templates = dpt.next;
6181 d_append_string (dpi, ")#");
6182 d_append_num (dpi, dc->u.s_unary_num.num + 1);
6183 d_append_char (dpi, '}');
6184 }
6185 return;
6186
6187 case DEMANGLE_COMPONENT_UNNAMED_TYPE:
6188 d_append_string (dpi, "{unnamed type#");
6189 d_append_num (dpi, dc->u.s_number.number + 1);
6190 d_append_char (dpi, '}');
6191 return;
6192
6193 case DEMANGLE_COMPONENT_CLONE:
6194 d_print_comp (dpi, options, d_left (dc));
6195 d_append_string (dpi, " [clone ");
6196 d_print_comp (dpi, options, d_right (dc));
6197 d_append_char (dpi, ']');
6198 return;
6199
6200 case DEMANGLE_COMPONENT_TEMPLATE_HEAD:
6201 {
6202 d_append_char (dpi, '<');
6203 int count = 0;
6204 struct demangle_component *parm;
6205 for (parm = d_left (dc); parm; parm = d_right (parm))
6206 {
6207 if (count++)
6208 d_append_string (dpi, ", ");
6209 d_print_comp (dpi, options, parm);
6210 }
6211 d_append_char (dpi, '>');
6212 }
6213 return;
6214
6215 case DEMANGLE_COMPONENT_TEMPLATE_TYPE_PARM:
6216 d_append_string (dpi, "typename");
6217 return;
6218
6219 case DEMANGLE_COMPONENT_TEMPLATE_NON_TYPE_PARM:
6220 d_print_comp (dpi, options, d_left (dc));
6221 return;
6222
6223 case DEMANGLE_COMPONENT_TEMPLATE_TEMPLATE_PARM:
6224 d_append_string (dpi, "template");
6225 d_print_comp (dpi, options, d_left (dc));
6226 d_append_string (dpi, " class");
6227 return;
6228
6229 case DEMANGLE_COMPONENT_TEMPLATE_PACK_PARM:
6230 d_print_comp (dpi, options, d_left (dc));
6231 d_append_string (dpi, "...");
6232 return;
6233
6234 default:
6235 d_print_error (dpi);
6236 return;
6237 }
6238 }
6239
6240 static void
6241 d_print_comp (struct d_print_info *dpi, int options,
6242 struct demangle_component *dc)
6243 {
6244 struct d_component_stack self;
6245 if (dc == NULL || dc->d_printing > 1 || dpi->recursion > MAX_RECURSION_COUNT)
6246 {
6247 d_print_error (dpi);
6248 return;
6249 }
6250
6251 dc->d_printing++;
6252 dpi->recursion++;
6253
6254 self.dc = dc;
6255 self.parent = dpi->component_stack;
6256 dpi->component_stack = &self;
6257
6258 d_print_comp_inner (dpi, options, dc);
6259
6260 dpi->component_stack = self.parent;
6261 dc->d_printing--;
6262 dpi->recursion--;
6263 }
6264
6265 /* Print a Java dentifier. For Java we try to handle encoded extended
6266 Unicode characters. The C++ ABI doesn't mention Unicode encoding,
6267 so we don't it for C++. Characters are encoded as
6268 __U<hex-char>+_. */
6269
6270 static void
6271 d_print_java_identifier (struct d_print_info *dpi, const char *name, int len)
6272 {
6273 const char *p;
6274 const char *end;
6275
6276 end = name + len;
6277 for (p = name; p < end; ++p)
6278 {
6279 if (end - p > 3
6280 && p[0] == '_'
6281 && p[1] == '_'
6282 && p[2] == 'U')
6283 {
6284 unsigned long c;
6285 const char *q;
6286
6287 c = 0;
6288 for (q = p + 3; q < end; ++q)
6289 {
6290 int dig;
6291
6292 if (IS_DIGIT (*q))
6293 dig = *q - '0';
6294 else if (*q >= 'A' && *q <= 'F')
6295 dig = *q - 'A' + 10;
6296 else if (*q >= 'a' && *q <= 'f')
6297 dig = *q - 'a' + 10;
6298 else
6299 break;
6300
6301 c = c * 16 + dig;
6302 }
6303 /* If the Unicode character is larger than 256, we don't try
6304 to deal with it here. FIXME. */
6305 if (q < end && *q == '_' && c < 256)
6306 {
6307 d_append_char (dpi, c);
6308 p = q;
6309 continue;
6310 }
6311 }
6312
6313 d_append_char (dpi, *p);
6314 }
6315 }
6316
6317 /* Print a list of modifiers. SUFFIX is 1 if we are printing
6318 qualifiers on this after printing a function. */
6319
6320 static void
6321 d_print_mod_list (struct d_print_info *dpi, int options,
6322 struct d_print_mod *mods, int suffix)
6323 {
6324 struct d_print_template *hold_dpt;
6325
6326 if (mods == NULL || d_print_saw_error (dpi))
6327 return;
6328
6329 if (mods->printed
6330 || (! suffix
6331 && (is_fnqual_component_type (mods->mod->type))))
6332 {
6333 d_print_mod_list (dpi, options, mods->next, suffix);
6334 return;
6335 }
6336
6337 mods->printed = 1;
6338
6339 hold_dpt = dpi->templates;
6340 dpi->templates = mods->templates;
6341
6342 if (mods->mod->type == DEMANGLE_COMPONENT_FUNCTION_TYPE)
6343 {
6344 d_print_function_type (dpi, options, mods->mod, mods->next);
6345 dpi->templates = hold_dpt;
6346 return;
6347 }
6348 else if (mods->mod->type == DEMANGLE_COMPONENT_ARRAY_TYPE)
6349 {
6350 d_print_array_type (dpi, options, mods->mod, mods->next);
6351 dpi->templates = hold_dpt;
6352 return;
6353 }
6354 else if (mods->mod->type == DEMANGLE_COMPONENT_LOCAL_NAME)
6355 {
6356 struct d_print_mod *hold_modifiers;
6357 struct demangle_component *dc;
6358
6359 /* When this is on the modifier stack, we have pulled any
6360 qualifiers off the right argument already. Otherwise, we
6361 print it as usual, but don't let the left argument see any
6362 modifiers. */
6363
6364 hold_modifiers = dpi->modifiers;
6365 dpi->modifiers = NULL;
6366 d_print_comp (dpi, options, d_left (mods->mod));
6367 dpi->modifiers = hold_modifiers;
6368
6369 if ((options & DMGL_JAVA) == 0)
6370 d_append_string (dpi, "::");
6371 else
6372 d_append_char (dpi, '.');
6373
6374 dc = d_right (mods->mod);
6375
6376 if (dc->type == DEMANGLE_COMPONENT_DEFAULT_ARG)
6377 {
6378 d_append_string (dpi, "{default arg#");
6379 d_append_num (dpi, dc->u.s_unary_num.num + 1);
6380 d_append_string (dpi, "}::");
6381 dc = dc->u.s_unary_num.sub;
6382 }
6383
6384 while (is_fnqual_component_type (dc->type))
6385 dc = d_left (dc);
6386
6387 d_print_comp (dpi, options, dc);
6388
6389 dpi->templates = hold_dpt;
6390 return;
6391 }
6392
6393 d_print_mod (dpi, options, mods->mod);
6394
6395 dpi->templates = hold_dpt;
6396
6397 d_print_mod_list (dpi, options, mods->next, suffix);
6398 }
6399
6400 /* Print a modifier. */
6401
6402 static void
6403 d_print_mod (struct d_print_info *dpi, int options,
6404 struct demangle_component *mod)
6405 {
6406 switch (mod->type)
6407 {
6408 case DEMANGLE_COMPONENT_RESTRICT:
6409 case DEMANGLE_COMPONENT_RESTRICT_THIS:
6410 d_append_string (dpi, " restrict");
6411 return;
6412 case DEMANGLE_COMPONENT_VOLATILE:
6413 case DEMANGLE_COMPONENT_VOLATILE_THIS:
6414 d_append_string (dpi, " volatile");
6415 return;
6416 case DEMANGLE_COMPONENT_CONST:
6417 case DEMANGLE_COMPONENT_CONST_THIS:
6418 d_append_string (dpi, " const");
6419 return;
6420 case DEMANGLE_COMPONENT_TRANSACTION_SAFE:
6421 d_append_string (dpi, " transaction_safe");
6422 return;
6423 case DEMANGLE_COMPONENT_NOEXCEPT:
6424 d_append_string (dpi, " noexcept");
6425 if (d_right (mod))
6426 {
6427 d_append_char (dpi, '(');
6428 d_print_comp (dpi, options, d_right (mod));
6429 d_append_char (dpi, ')');
6430 }
6431 return;
6432 case DEMANGLE_COMPONENT_THROW_SPEC:
6433 d_append_string (dpi, " throw");
6434 if (d_right (mod))
6435 {
6436 d_append_char (dpi, '(');
6437 d_print_comp (dpi, options, d_right (mod));
6438 d_append_char (dpi, ')');
6439 }
6440 return;
6441 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
6442 d_append_char (dpi, ' ');
6443 d_print_comp (dpi, options, d_right (mod));
6444 return;
6445 case DEMANGLE_COMPONENT_POINTER:
6446 /* There is no pointer symbol in Java. */
6447 if ((options & DMGL_JAVA) == 0)
6448 d_append_char (dpi, '*');
6449 return;
6450 case DEMANGLE_COMPONENT_REFERENCE_THIS:
6451 /* For the ref-qualifier, put a space before the &. */
6452 d_append_char (dpi, ' ');
6453 /* FALLTHRU */
6454 case DEMANGLE_COMPONENT_REFERENCE:
6455 d_append_char (dpi, '&');
6456 return;
6457 case DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS:
6458 d_append_char (dpi, ' ');
6459 /* FALLTHRU */
6460 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
6461 d_append_string (dpi, "&&");
6462 return;
6463 case DEMANGLE_COMPONENT_COMPLEX:
6464 d_append_string (dpi, " _Complex");
6465 return;
6466 case DEMANGLE_COMPONENT_IMAGINARY:
6467 d_append_string (dpi, " _Imaginary");
6468 return;
6469 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
6470 if (d_last_char (dpi) != '(')
6471 d_append_char (dpi, ' ');
6472 d_print_comp (dpi, options, d_left (mod));
6473 d_append_string (dpi, "::*");
6474 return;
6475 case DEMANGLE_COMPONENT_TYPED_NAME:
6476 d_print_comp (dpi, options, d_left (mod));
6477 return;
6478 case DEMANGLE_COMPONENT_VECTOR_TYPE:
6479 d_append_string (dpi, " __vector(");
6480 d_print_comp (dpi, options, d_left (mod));
6481 d_append_char (dpi, ')');
6482 return;
6483
6484 default:
6485 /* Otherwise, we have something that won't go back on the
6486 modifier stack, so we can just print it. */
6487 d_print_comp (dpi, options, mod);
6488 return;
6489 }
6490 }
6491
6492 /* Print a function type, except for the return type. */
6493
6494 static void
6495 d_print_function_type (struct d_print_info *dpi, int options,
6496 struct demangle_component *dc,
6497 struct d_print_mod *mods)
6498 {
6499 int need_paren;
6500 int need_space;
6501 struct d_print_mod *p;
6502 struct d_print_mod *hold_modifiers;
6503
6504 need_paren = 0;
6505 need_space = 0;
6506 for (p = mods; p != NULL; p = p->next)
6507 {
6508 if (p->printed)
6509 break;
6510
6511 switch (p->mod->type)
6512 {
6513 case DEMANGLE_COMPONENT_POINTER:
6514 case DEMANGLE_COMPONENT_REFERENCE:
6515 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
6516 need_paren = 1;
6517 break;
6518 case DEMANGLE_COMPONENT_RESTRICT:
6519 case DEMANGLE_COMPONENT_VOLATILE:
6520 case DEMANGLE_COMPONENT_CONST:
6521 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
6522 case DEMANGLE_COMPONENT_COMPLEX:
6523 case DEMANGLE_COMPONENT_IMAGINARY:
6524 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
6525 need_space = 1;
6526 need_paren = 1;
6527 break;
6528 FNQUAL_COMPONENT_CASE:
6529 break;
6530 default:
6531 break;
6532 }
6533 if (need_paren)
6534 break;
6535 }
6536
6537 if (need_paren)
6538 {
6539 if (! need_space)
6540 {
6541 if (d_last_char (dpi) != '('
6542 && d_last_char (dpi) != '*')
6543 need_space = 1;
6544 }
6545 if (need_space && d_last_char (dpi) != ' ')
6546 d_append_char (dpi, ' ');
6547 d_append_char (dpi, '(');
6548 }
6549
6550 hold_modifiers = dpi->modifiers;
6551 dpi->modifiers = NULL;
6552
6553 d_print_mod_list (dpi, options, mods, 0);
6554
6555 if (need_paren)
6556 d_append_char (dpi, ')');
6557
6558 d_append_char (dpi, '(');
6559
6560 if (d_right (dc) != NULL)
6561 d_print_comp (dpi, options, d_right (dc));
6562
6563 d_append_char (dpi, ')');
6564
6565 d_print_mod_list (dpi, options, mods, 1);
6566
6567 dpi->modifiers = hold_modifiers;
6568 }
6569
6570 /* Print an array type, except for the element type. */
6571
6572 static void
6573 d_print_array_type (struct d_print_info *dpi, int options,
6574 struct demangle_component *dc,
6575 struct d_print_mod *mods)
6576 {
6577 int need_space;
6578
6579 need_space = 1;
6580 if (mods != NULL)
6581 {
6582 int need_paren;
6583 struct d_print_mod *p;
6584
6585 need_paren = 0;
6586 for (p = mods; p != NULL; p = p->next)
6587 {
6588 if (! p->printed)
6589 {
6590 if (p->mod->type == DEMANGLE_COMPONENT_ARRAY_TYPE)
6591 {
6592 need_space = 0;
6593 break;
6594 }
6595 else
6596 {
6597 need_paren = 1;
6598 need_space = 1;
6599 break;
6600 }
6601 }
6602 }
6603
6604 if (need_paren)
6605 d_append_string (dpi, " (");
6606
6607 d_print_mod_list (dpi, options, mods, 0);
6608
6609 if (need_paren)
6610 d_append_char (dpi, ')');
6611 }
6612
6613 if (need_space)
6614 d_append_char (dpi, ' ');
6615
6616 d_append_char (dpi, '[');
6617
6618 if (d_left (dc) != NULL)
6619 d_print_comp (dpi, options, d_left (dc));
6620
6621 d_append_char (dpi, ']');
6622 }
6623
6624 /* Print an operator in an expression. */
6625
6626 static void
6627 d_print_expr_op (struct d_print_info *dpi, int options,
6628 struct demangle_component *dc)
6629 {
6630 if (dc->type == DEMANGLE_COMPONENT_OPERATOR)
6631 d_append_buffer (dpi, dc->u.s_operator.op->name,
6632 dc->u.s_operator.op->len);
6633 else
6634 d_print_comp (dpi, options, dc);
6635 }
6636
6637 /* Print a cast. */
6638
6639 static void
6640 d_print_cast (struct d_print_info *dpi, int options,
6641 struct demangle_component *dc)
6642 {
6643 d_print_comp (dpi, options, d_left (dc));
6644 }
6645
6646 /* Print a conversion operator. */
6647
6648 static void
6649 d_print_conversion (struct d_print_info *dpi, int options,
6650 struct demangle_component *dc)
6651 {
6652 struct d_print_template dpt;
6653
6654 /* For a conversion operator, we need the template parameters from
6655 the enclosing template in scope for processing the type. */
6656 if (dpi->current_template != NULL)
6657 {
6658 dpt.next = dpi->templates;
6659 dpi->templates = &dpt;
6660 dpt.template_decl = dpi->current_template;
6661 }
6662
6663 d_print_comp (dpi, options, d_left (dc));
6664
6665 if (dpi->current_template != NULL)
6666 dpi->templates = dpt.next;
6667 }
6668
6669 /* Initialize the information structure we use to pass around
6670 information. */
6671
6672 CP_STATIC_IF_GLIBCPP_V3
6673 void
6674 cplus_demangle_init_info (const char *mangled, int options, size_t len,
6675 struct d_info *di)
6676 {
6677 di->s = mangled;
6678 di->send = mangled + len;
6679 di->options = options;
6680
6681 di->n = mangled;
6682
6683 /* We cannot need more components than twice the number of chars in
6684 the mangled string. Most components correspond directly to
6685 chars, but the ARGLIST types are exceptions. */
6686 di->num_comps = 2 * len;
6687 di->next_comp = 0;
6688
6689 /* Similarly, we cannot need more substitutions than there are
6690 chars in the mangled string. */
6691 di->num_subs = len;
6692 di->next_sub = 0;
6693
6694 di->last_name = NULL;
6695
6696 di->expansion = 0;
6697 di->is_expression = 0;
6698 di->is_conversion = 0;
6699 di->recursion_level = 0;
6700 }
6701
6702 /* Internal implementation for the demangler. If MANGLED is a g++ v3 ABI
6703 mangled name, return strings in repeated callback giving the demangled
6704 name. OPTIONS is the usual libiberty demangler options. On success,
6705 this returns 1. On failure, returns 0. */
6706
6707 static int
6708 d_demangle_callback (const char *mangled, int options,
6709 demangle_callbackref callback, void *opaque)
6710 {
6711 enum
6712 {
6713 DCT_TYPE,
6714 DCT_MANGLED,
6715 DCT_GLOBAL_CTORS,
6716 DCT_GLOBAL_DTORS
6717 }
6718 type;
6719 struct d_info di;
6720 struct demangle_component *dc;
6721 int status;
6722
6723 if (mangled[0] == '_' && mangled[1] == 'Z')
6724 type = DCT_MANGLED;
6725 else if (strncmp (mangled, "_GLOBAL_", 8) == 0
6726 && (mangled[8] == '.' || mangled[8] == '_' || mangled[8] == '$')
6727 && (mangled[9] == 'D' || mangled[9] == 'I')
6728 && mangled[10] == '_')
6729 type = mangled[9] == 'I' ? DCT_GLOBAL_CTORS : DCT_GLOBAL_DTORS;
6730 else
6731 {
6732 if ((options & DMGL_TYPES) == 0)
6733 return 0;
6734 type = DCT_TYPE;
6735 }
6736
6737 di.unresolved_name_state = 1;
6738
6739 again:
6740 cplus_demangle_init_info (mangled, options, strlen (mangled), &di);
6741
6742 /* PR 87675 - Check for a mangled string that is so long
6743 that we do not have enough stack space to demangle it. */
6744 if (((options & DMGL_NO_RECURSE_LIMIT) == 0)
6745 /* This check is a bit arbitrary, since what we really want to do is to
6746 compare the sizes of the di.comps and di.subs arrays against the
6747 amount of stack space remaining. But there is no portable way to do
6748 this, so instead we use the recursion limit as a guide to the maximum
6749 size of the arrays. */
6750 && (unsigned long) di.num_comps > DEMANGLE_RECURSION_LIMIT)
6751 {
6752 /* FIXME: We need a way to indicate that a stack limit has been reached. */
6753 return 0;
6754 }
6755
6756 {
6757 #ifdef CP_DYNAMIC_ARRAYS
6758 __extension__ struct demangle_component comps[di.num_comps];
6759 __extension__ struct demangle_component *subs[di.num_subs];
6760
6761 di.comps = comps;
6762 di.subs = subs;
6763 #else
6764 di.comps = alloca (di.num_comps * sizeof (*di.comps));
6765 di.subs = alloca (di.num_subs * sizeof (*di.subs));
6766 #endif
6767
6768 switch (type)
6769 {
6770 case DCT_TYPE:
6771 dc = cplus_demangle_type (&di);
6772 break;
6773 case DCT_MANGLED:
6774 dc = cplus_demangle_mangled_name (&di, 1);
6775 break;
6776 case DCT_GLOBAL_CTORS:
6777 case DCT_GLOBAL_DTORS:
6778 d_advance (&di, 11);
6779 dc = d_make_comp (&di,
6780 (type == DCT_GLOBAL_CTORS
6781 ? DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS
6782 : DEMANGLE_COMPONENT_GLOBAL_DESTRUCTORS),
6783 d_make_demangle_mangled_name (&di, d_str (&di)),
6784 NULL);
6785 d_advance (&di, strlen (d_str (&di)));
6786 break;
6787 default:
6788 abort (); /* We have listed all the cases. */
6789 }
6790
6791 /* If DMGL_PARAMS is set, then if we didn't consume the entire
6792 mangled string, then we didn't successfully demangle it. If
6793 DMGL_PARAMS is not set, we didn't look at the trailing
6794 parameters. */
6795 if (((options & DMGL_PARAMS) != 0) && d_peek_char (&di) != '\0')
6796 dc = NULL;
6797
6798 /* See discussion in d_unresolved_name. */
6799 if (dc == NULL && di.unresolved_name_state == -1)
6800 {
6801 di.unresolved_name_state = 0;
6802 goto again;
6803 }
6804
6805 #ifdef CP_DEMANGLE_DEBUG
6806 d_dump (dc, 0);
6807 #endif
6808
6809 status = (dc != NULL)
6810 ? cplus_demangle_print_callback (options, dc, callback, opaque)
6811 : 0;
6812 }
6813
6814 return status;
6815 }
6816
6817 /* Entry point for the demangler. If MANGLED is a g++ v3 ABI mangled
6818 name, return a buffer allocated with malloc holding the demangled
6819 name. OPTIONS is the usual libiberty demangler options. On
6820 success, this sets *PALC to the allocated size of the returned
6821 buffer. On failure, this sets *PALC to 0 for a bad name, or 1 for
6822 a memory allocation failure, and returns NULL. */
6823
6824 static char *
6825 d_demangle (const char *mangled, int options, size_t *palc)
6826 {
6827 struct d_growable_string dgs;
6828 int status;
6829
6830 d_growable_string_init (&dgs, 0);
6831
6832 status = d_demangle_callback (mangled, options,
6833 d_growable_string_callback_adapter, &dgs);
6834 if (status == 0)
6835 {
6836 free (dgs.buf);
6837 *palc = 0;
6838 return NULL;
6839 }
6840
6841 *palc = dgs.allocation_failure ? 1 : dgs.alc;
6842 return dgs.buf;
6843 }
6844
6845 #if defined(IN_LIBGCC2) || defined(IN_GLIBCPP_V3)
6846
6847 extern char *__cxa_demangle (const char *, char *, size_t *, int *);
6848
6849 /* ia64 ABI-mandated entry point in the C++ runtime library for
6850 performing demangling. MANGLED_NAME is a NUL-terminated character
6851 string containing the name to be demangled.
6852
6853 OUTPUT_BUFFER is a region of memory, allocated with malloc, of
6854 *LENGTH bytes, into which the demangled name is stored. If
6855 OUTPUT_BUFFER is not long enough, it is expanded using realloc.
6856 OUTPUT_BUFFER may instead be NULL; in that case, the demangled name
6857 is placed in a region of memory allocated with malloc.
6858
6859 If LENGTH is non-NULL, the length of the buffer containing the
6860 demangled name, is placed in *LENGTH.
6861
6862 The return value is a pointer to the start of the NUL-terminated
6863 demangled name, or NULL if the demangling fails. The caller is
6864 responsible for deallocating this memory using free.
6865
6866 *STATUS is set to one of the following values:
6867 0: The demangling operation succeeded.
6868 -1: A memory allocation failure occurred.
6869 -2: MANGLED_NAME is not a valid name under the C++ ABI mangling rules.
6870 -3: One of the arguments is invalid.
6871
6872 The demangling is performed using the C++ ABI mangling rules, with
6873 GNU extensions. */
6874
6875 char *
6876 __cxa_demangle (const char *mangled_name, char *output_buffer,
6877 size_t *length, int *status)
6878 {
6879 char *demangled;
6880 size_t alc;
6881
6882 if (mangled_name == NULL)
6883 {
6884 if (status != NULL)
6885 *status = -3;
6886 return NULL;
6887 }
6888
6889 if (output_buffer != NULL && length == NULL)
6890 {
6891 if (status != NULL)
6892 *status = -3;
6893 return NULL;
6894 }
6895
6896 demangled = d_demangle (mangled_name, DMGL_PARAMS | DMGL_TYPES, &alc);
6897
6898 if (demangled == NULL)
6899 {
6900 if (status != NULL)
6901 {
6902 if (alc == 1)
6903 *status = -1;
6904 else
6905 *status = -2;
6906 }
6907 return NULL;
6908 }
6909
6910 if (output_buffer == NULL)
6911 {
6912 if (length != NULL)
6913 *length = alc;
6914 }
6915 else
6916 {
6917 if (strlen (demangled) < *length)
6918 {
6919 strcpy (output_buffer, demangled);
6920 free (demangled);
6921 demangled = output_buffer;
6922 }
6923 else
6924 {
6925 free (output_buffer);
6926 *length = alc;
6927 }
6928 }
6929
6930 if (status != NULL)
6931 *status = 0;
6932
6933 return demangled;
6934 }
6935
6936 extern int __gcclibcxx_demangle_callback (const char *,
6937 void (*)
6938 (const char *, size_t, void *),
6939 void *);
6940
6941 /* Alternative, allocationless entry point in the C++ runtime library
6942 for performing demangling. MANGLED_NAME is a NUL-terminated character
6943 string containing the name to be demangled.
6944
6945 CALLBACK is a callback function, called with demangled string
6946 segments as demangling progresses; it is called at least once,
6947 but may be called more than once. OPAQUE is a generalized pointer
6948 used as a callback argument.
6949
6950 The return code is one of the following values, equivalent to
6951 the STATUS values of __cxa_demangle() (excluding -1, since this
6952 function performs no memory allocations):
6953 0: The demangling operation succeeded.
6954 -2: MANGLED_NAME is not a valid name under the C++ ABI mangling rules.
6955 -3: One of the arguments is invalid.
6956
6957 The demangling is performed using the C++ ABI mangling rules, with
6958 GNU extensions. */
6959
6960 int
6961 __gcclibcxx_demangle_callback (const char *mangled_name,
6962 void (*callback) (const char *, size_t, void *),
6963 void *opaque)
6964 {
6965 int status;
6966
6967 if (mangled_name == NULL || callback == NULL)
6968 return -3;
6969
6970 status = d_demangle_callback (mangled_name, DMGL_PARAMS | DMGL_TYPES,
6971 callback, opaque);
6972 if (status == 0)
6973 return -2;
6974
6975 return 0;
6976 }
6977
6978 #else /* ! (IN_LIBGCC2 || IN_GLIBCPP_V3) */
6979
6980 /* Entry point for libiberty demangler. If MANGLED is a g++ v3 ABI
6981 mangled name, return a buffer allocated with malloc holding the
6982 demangled name. Otherwise, return NULL. */
6983
6984 char *
6985 cplus_demangle_v3 (const char *mangled, int options)
6986 {
6987 size_t alc;
6988
6989 return d_demangle (mangled, options, &alc);
6990 }
6991
6992 int
6993 cplus_demangle_v3_callback (const char *mangled, int options,
6994 demangle_callbackref callback, void *opaque)
6995 {
6996 return d_demangle_callback (mangled, options, callback, opaque);
6997 }
6998
6999 /* Demangle a Java symbol. Java uses a subset of the V3 ABI C++ mangling
7000 conventions, but the output formatting is a little different.
7001 This instructs the C++ demangler not to emit pointer characters ("*"), to
7002 use Java's namespace separator symbol ("." instead of "::"), and to output
7003 JArray<TYPE> as TYPE[]. */
7004
7005 char *
7006 java_demangle_v3 (const char *mangled)
7007 {
7008 size_t alc;
7009
7010 return d_demangle (mangled, DMGL_JAVA | DMGL_PARAMS | DMGL_RET_POSTFIX, &alc);
7011 }
7012
7013 int
7014 java_demangle_v3_callback (const char *mangled,
7015 demangle_callbackref callback, void *opaque)
7016 {
7017 return d_demangle_callback (mangled,
7018 DMGL_JAVA | DMGL_PARAMS | DMGL_RET_POSTFIX,
7019 callback, opaque);
7020 }
7021
7022 #endif /* IN_LIBGCC2 || IN_GLIBCPP_V3 */
7023
7024 #ifndef IN_GLIBCPP_V3
7025
7026 /* Demangle a string in order to find out whether it is a constructor
7027 or destructor. Return non-zero on success. Set *CTOR_KIND and
7028 *DTOR_KIND appropriately. */
7029
7030 static int
7031 is_ctor_or_dtor (const char *mangled,
7032 enum gnu_v3_ctor_kinds *ctor_kind,
7033 enum gnu_v3_dtor_kinds *dtor_kind)
7034 {
7035 struct d_info di;
7036 struct demangle_component *dc;
7037 int ret;
7038
7039 *ctor_kind = (enum gnu_v3_ctor_kinds) 0;
7040 *dtor_kind = (enum gnu_v3_dtor_kinds) 0;
7041
7042 cplus_demangle_init_info (mangled, DMGL_GNU_V3, strlen (mangled), &di);
7043
7044 {
7045 #ifdef CP_DYNAMIC_ARRAYS
7046 __extension__ struct demangle_component comps[di.num_comps];
7047 __extension__ struct demangle_component *subs[di.num_subs];
7048
7049 di.comps = comps;
7050 di.subs = subs;
7051 #else
7052 di.comps = alloca (di.num_comps * sizeof (*di.comps));
7053 di.subs = alloca (di.num_subs * sizeof (*di.subs));
7054 #endif
7055
7056 dc = cplus_demangle_mangled_name (&di, 1);
7057
7058 /* Note that because we did not pass DMGL_PARAMS, we don't expect
7059 to demangle the entire string. */
7060
7061 ret = 0;
7062 while (dc != NULL)
7063 {
7064 switch (dc->type)
7065 {
7066 /* These cannot appear on a constructor or destructor. */
7067 case DEMANGLE_COMPONENT_RESTRICT_THIS:
7068 case DEMANGLE_COMPONENT_VOLATILE_THIS:
7069 case DEMANGLE_COMPONENT_CONST_THIS:
7070 case DEMANGLE_COMPONENT_REFERENCE_THIS:
7071 case DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS:
7072 default:
7073 dc = NULL;
7074 break;
7075 case DEMANGLE_COMPONENT_TYPED_NAME:
7076 case DEMANGLE_COMPONENT_TEMPLATE:
7077 dc = d_left (dc);
7078 break;
7079 case DEMANGLE_COMPONENT_QUAL_NAME:
7080 case DEMANGLE_COMPONENT_LOCAL_NAME:
7081 dc = d_right (dc);
7082 break;
7083 case DEMANGLE_COMPONENT_CTOR:
7084 *ctor_kind = dc->u.s_ctor.kind;
7085 ret = 1;
7086 dc = NULL;
7087 break;
7088 case DEMANGLE_COMPONENT_DTOR:
7089 *dtor_kind = dc->u.s_dtor.kind;
7090 ret = 1;
7091 dc = NULL;
7092 break;
7093 }
7094 }
7095 }
7096
7097 return ret;
7098 }
7099
7100 /* Return whether NAME is the mangled form of a g++ V3 ABI constructor
7101 name. A non-zero return indicates the type of constructor. */
7102
7103 enum gnu_v3_ctor_kinds
7104 is_gnu_v3_mangled_ctor (const char *name)
7105 {
7106 enum gnu_v3_ctor_kinds ctor_kind;
7107 enum gnu_v3_dtor_kinds dtor_kind;
7108
7109 if (! is_ctor_or_dtor (name, &ctor_kind, &dtor_kind))
7110 return (enum gnu_v3_ctor_kinds) 0;
7111 return ctor_kind;
7112 }
7113
7114
7115 /* Return whether NAME is the mangled form of a g++ V3 ABI destructor
7116 name. A non-zero return indicates the type of destructor. */
7117
7118 enum gnu_v3_dtor_kinds
7119 is_gnu_v3_mangled_dtor (const char *name)
7120 {
7121 enum gnu_v3_ctor_kinds ctor_kind;
7122 enum gnu_v3_dtor_kinds dtor_kind;
7123
7124 if (! is_ctor_or_dtor (name, &ctor_kind, &dtor_kind))
7125 return (enum gnu_v3_dtor_kinds) 0;
7126 return dtor_kind;
7127 }
7128
7129 #endif /* IN_GLIBCPP_V3 */
7130
7131 #ifdef STANDALONE_DEMANGLER
7132
7133 #include "getopt.h"
7134 #include "dyn-string.h"
7135
7136 static void print_usage (FILE* fp, int exit_value);
7137
7138 #define IS_ALPHA(CHAR) \
7139 (((CHAR) >= 'a' && (CHAR) <= 'z') \
7140 || ((CHAR) >= 'A' && (CHAR) <= 'Z'))
7141
7142 /* Non-zero if CHAR is a character than can occur in a mangled name. */
7143 #define is_mangled_char(CHAR) \
7144 (IS_ALPHA (CHAR) || IS_DIGIT (CHAR) \
7145 || (CHAR) == '_' || (CHAR) == '.' || (CHAR) == '$')
7146
7147 /* The name of this program, as invoked. */
7148 const char* program_name;
7149
7150 /* Prints usage summary to FP and then exits with EXIT_VALUE. */
7151
7152 static void
7153 print_usage (FILE* fp, int exit_value)
7154 {
7155 fprintf (fp, "Usage: %s [options] [names ...]\n", program_name);
7156 fprintf (fp, "Options:\n");
7157 fprintf (fp, " -h,--help Display this message.\n");
7158 fprintf (fp, " -p,--no-params Don't display function parameters\n");
7159 fprintf (fp, " -v,--verbose Produce verbose demanglings.\n");
7160 fprintf (fp, "If names are provided, they are demangled. Otherwise filters standard input.\n");
7161
7162 exit (exit_value);
7163 }
7164
7165 /* Option specification for getopt_long. */
7166 static const struct option long_options[] =
7167 {
7168 { "help", no_argument, NULL, 'h' },
7169 { "no-params", no_argument, NULL, 'p' },
7170 { "verbose", no_argument, NULL, 'v' },
7171 { NULL, no_argument, NULL, 0 },
7172 };
7173
7174 /* Main entry for a demangling filter executable. It will demangle
7175 its command line arguments, if any. If none are provided, it will
7176 filter stdin to stdout, replacing any recognized mangled C++ names
7177 with their demangled equivalents. */
7178
7179 int
7180 main (int argc, char *argv[])
7181 {
7182 int i;
7183 int opt_char;
7184 int options = DMGL_PARAMS | DMGL_ANSI | DMGL_TYPES;
7185
7186 /* Use the program name of this program, as invoked. */
7187 program_name = argv[0];
7188
7189 /* Parse options. */
7190 do
7191 {
7192 opt_char = getopt_long (argc, argv, "hpv", long_options, NULL);
7193 switch (opt_char)
7194 {
7195 case '?': /* Unrecognized option. */
7196 print_usage (stderr, 1);
7197 break;
7198
7199 case 'h':
7200 print_usage (stdout, 0);
7201 break;
7202
7203 case 'p':
7204 options &= ~ DMGL_PARAMS;
7205 break;
7206
7207 case 'v':
7208 options |= DMGL_VERBOSE;
7209 break;
7210 }
7211 }
7212 while (opt_char != -1);
7213
7214 if (optind == argc)
7215 /* No command line arguments were provided. Filter stdin. */
7216 {
7217 dyn_string_t mangled = dyn_string_new (3);
7218 char *s;
7219
7220 /* Read all of input. */
7221 while (!feof (stdin))
7222 {
7223 char c;
7224
7225 /* Pile characters into mangled until we hit one that can't
7226 occur in a mangled name. */
7227 c = getchar ();
7228 while (!feof (stdin) && is_mangled_char (c))
7229 {
7230 dyn_string_append_char (mangled, c);
7231 if (feof (stdin))
7232 break;
7233 c = getchar ();
7234 }
7235
7236 if (dyn_string_length (mangled) > 0)
7237 {
7238 #ifdef IN_GLIBCPP_V3
7239 s = __cxa_demangle (dyn_string_buf (mangled), NULL, NULL, NULL);
7240 #else
7241 s = cplus_demangle_v3 (dyn_string_buf (mangled), options);
7242 #endif
7243
7244 if (s != NULL)
7245 {
7246 fputs (s, stdout);
7247 free (s);
7248 }
7249 else
7250 {
7251 /* It might not have been a mangled name. Print the
7252 original text. */
7253 fputs (dyn_string_buf (mangled), stdout);
7254 }
7255
7256 dyn_string_clear (mangled);
7257 }
7258
7259 /* If we haven't hit EOF yet, we've read one character that
7260 can't occur in a mangled name, so print it out. */
7261 if (!feof (stdin))
7262 putchar (c);
7263 }
7264
7265 dyn_string_delete (mangled);
7266 }
7267 else
7268 /* Demangle command line arguments. */
7269 {
7270 /* Loop over command line arguments. */
7271 for (i = optind; i < argc; ++i)
7272 {
7273 char *s;
7274 #ifdef IN_GLIBCPP_V3
7275 int status;
7276 #endif
7277
7278 /* Attempt to demangle. */
7279 #ifdef IN_GLIBCPP_V3
7280 s = __cxa_demangle (argv[i], NULL, NULL, &status);
7281 #else
7282 s = cplus_demangle_v3 (argv[i], options);
7283 #endif
7284
7285 /* If it worked, print the demangled name. */
7286 if (s != NULL)
7287 {
7288 printf ("%s\n", s);
7289 free (s);
7290 }
7291 else
7292 {
7293 #ifdef IN_GLIBCPP_V3
7294 fprintf (stderr, "Failed: %s (status %d)\n", argv[i], status);
7295 #else
7296 fprintf (stderr, "Failed: %s\n", argv[i]);
7297 #endif
7298 }
7299 }
7300 }
7301
7302 return 0;
7303 }
7304
7305 #endif /* STANDALONE_DEMANGLER */