re PR target/86753 (gcc.target/aarch64/sve/vcond_[45].c fail after recent combine...
[official-gcc.git] / libiberty / cp-demangle.c
blobaa78c86dd443c5078c5f440ebeaafd01ae3cd8ec
1 /* Demangler for g++ V3 ABI.
2 Copyright (C) 2003-2019 Free Software Foundation, Inc.
3 Written by Ian Lance Taylor <ian@wasabisystems.com>.
5 This file is part of the libiberty library, which is part of GCC.
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.
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.)
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.
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.
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
35 This code was written while looking at the demangler written by
36 Alex Samuel <samuel@codesourcery.com>.
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.
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)
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.
67 This file also defines some other functions and variables which are
68 only to be used by the file cp-demint.c.
70 Preprocessor macros you can define while compiling this file:
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]().
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.
88 STANDALONE_DEMANGLER
89 If defined, this file defines a main() function which demangles
90 any arguments, or, if none, demangles stdin.
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.
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. */
101 #if defined (_AIX) && !defined (__GNUC__)
102 #pragma alloca
103 #endif
105 #ifdef HAVE_CONFIG_H
106 #include "config.h"
107 #endif
109 #include <stdio.h>
111 #ifdef HAVE_STDLIB_H
112 #include <stdlib.h>
113 #endif
114 #ifdef HAVE_STRING_H
115 #include <string.h>
116 #endif
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 */
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
137 #include "ansidecl.h"
138 #include "libiberty.h"
139 #include "demangle.h"
140 #include "cp-demangle.h"
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
148 #define CP_STATIC_IF_GLIBCPP_V3 static
150 #define cplus_demangle_fill_name d_fill_name
151 static int d_fill_name (struct demangle_component *, const char *, int);
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 *);
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 *);
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 *);
168 #define cplus_demangle_mangled_name d_mangled_name
169 static struct demangle_component *d_mangled_name (struct d_info *, int);
171 #define cplus_demangle_type d_type
172 static struct demangle_component *d_type (struct d_info *);
174 #define cplus_demangle_print d_print
175 static char *d_print (int, struct demangle_component *, int, size_t *);
177 #define cplus_demangle_print_callback d_print_callback
178 static int d_print_callback (int, struct demangle_component *,
179 demangle_callbackref, void *);
181 #define cplus_demangle_init_info d_init_info
182 static void d_init_info (const char *, int, size_t, struct d_info *);
184 #else /* ! defined(IN_GLIBCPP_V3) */
185 #define CP_STATIC_IF_GLIBCPP_V3
186 #endif /* ! defined(IN_GLIBCPP_V3) */
188 /* See if the compiler supports dynamic arrays. */
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__) */
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.
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. */
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')
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)
221 /* Information we keep for the standard substitutions. */
223 struct d_standard_sub_info
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;
244 /* Accessors for subtrees of struct demangle_component. */
246 #define d_left(dc) ((dc)->u.s_binary.left)
247 #define d_right(dc) ((dc)->u.s_binary.right)
249 /* A list of templates. This is used while printing. */
251 struct d_print_template
253 /* Next template on the list. */
254 struct d_print_template *next;
255 /* This template. */
256 const struct demangle_component *template_decl;
259 /* A list of type modifiers. This is used while printing. */
261 struct d_print_mod
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;
274 /* We use these structures to hold information during printing. */
276 struct d_growable_string
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;
288 /* Stack of components, innermost first, used to avoid loops. */
290 struct d_component_stack
292 /* This component. */
293 const struct demangle_component *dc;
294 /* This component's parent. */
295 const struct d_component_stack *parent;
298 /* A demangle component and some scope captured when it was first
299 traversed. */
301 struct d_saved_scope
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;
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. */
314 struct d_info_checkpoint
316 const char *n;
317 int next_comp;
318 int next_sub;
319 int expansion;
322 /* Maximum number of times d_print_comp may be called recursively. */
323 #define MAX_RECURSION_COUNT 1024
325 enum { D_PRINT_BUFFER_LENGTH = 256 };
326 struct d_print_info
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 /* Non-zero if we're printing a lambda argument. A template
351 parameter reference actually means 'auto'. */
352 int is_lambda_arg;
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;
376 #ifdef CP_DEMANGLE_DEBUG
377 static void d_dump (struct demangle_component *, int);
378 #endif
380 static struct demangle_component *
381 d_make_empty (struct d_info *);
383 static struct demangle_component *
384 d_make_comp (struct d_info *, enum demangle_component_type,
385 struct demangle_component *,
386 struct demangle_component *);
388 static struct demangle_component *
389 d_make_name (struct d_info *, const char *, int);
391 static struct demangle_component *
392 d_make_demangle_mangled_name (struct d_info *, const char *);
394 static struct demangle_component *
395 d_make_builtin_type (struct d_info *,
396 const struct demangle_builtin_type_info *);
398 static struct demangle_component *
399 d_make_operator (struct d_info *,
400 const struct demangle_operator_info *);
402 static struct demangle_component *
403 d_make_extended_operator (struct d_info *, int,
404 struct demangle_component *);
406 static struct demangle_component *
407 d_make_ctor (struct d_info *, enum gnu_v3_ctor_kinds,
408 struct demangle_component *);
410 static struct demangle_component *
411 d_make_dtor (struct d_info *, enum gnu_v3_dtor_kinds,
412 struct demangle_component *);
414 static struct demangle_component *
415 d_make_template_param (struct d_info *, int);
417 static struct demangle_component *
418 d_make_sub (struct d_info *, const char *, int);
420 static int
421 has_return_type (struct demangle_component *);
423 static int
424 is_ctor_dtor_or_conversion (struct demangle_component *);
426 static struct demangle_component *d_encoding (struct d_info *, int);
428 static struct demangle_component *d_name (struct d_info *);
430 static struct demangle_component *d_nested_name (struct d_info *);
432 static struct demangle_component *d_prefix (struct d_info *);
434 static struct demangle_component *d_unqualified_name (struct d_info *);
436 static struct demangle_component *d_source_name (struct d_info *);
438 static int d_number (struct d_info *);
440 static struct demangle_component *d_identifier (struct d_info *, int);
442 static struct demangle_component *d_operator_name (struct d_info *);
444 static struct demangle_component *d_special_name (struct d_info *);
446 static struct demangle_component *d_parmlist (struct d_info *);
448 static int d_call_offset (struct d_info *, int);
450 static struct demangle_component *d_ctor_dtor_name (struct d_info *);
452 static struct demangle_component **
453 d_cv_qualifiers (struct d_info *, struct demangle_component **, int);
455 static struct demangle_component *
456 d_ref_qualifier (struct d_info *, struct demangle_component *);
458 static struct demangle_component *
459 d_function_type (struct d_info *);
461 static struct demangle_component *
462 d_bare_function_type (struct d_info *, int);
464 static struct demangle_component *
465 d_class_enum_type (struct d_info *);
467 static struct demangle_component *d_array_type (struct d_info *);
469 static struct demangle_component *d_vector_type (struct d_info *);
471 static struct demangle_component *
472 d_pointer_to_member_type (struct d_info *);
474 static struct demangle_component *
475 d_template_param (struct d_info *);
477 static struct demangle_component *d_template_args (struct d_info *);
478 static struct demangle_component *d_template_args_1 (struct d_info *);
480 static struct demangle_component *
481 d_template_arg (struct d_info *);
483 static struct demangle_component *d_expression (struct d_info *);
485 static struct demangle_component *d_expr_primary (struct d_info *);
487 static struct demangle_component *d_local_name (struct d_info *);
489 static int d_discriminator (struct d_info *);
491 static struct demangle_component *d_lambda (struct d_info *);
493 static struct demangle_component *d_unnamed_type (struct d_info *);
495 static struct demangle_component *
496 d_clone_suffix (struct d_info *, struct demangle_component *);
498 static int
499 d_add_substitution (struct d_info *, struct demangle_component *);
501 static struct demangle_component *d_substitution (struct d_info *, int);
503 static void d_checkpoint (struct d_info *, struct d_info_checkpoint *);
505 static void d_backtrack (struct d_info *, struct d_info_checkpoint *);
507 static void d_growable_string_init (struct d_growable_string *, size_t);
509 static inline void
510 d_growable_string_resize (struct d_growable_string *, size_t);
512 static inline void
513 d_growable_string_append_buffer (struct d_growable_string *,
514 const char *, size_t);
515 static void
516 d_growable_string_callback_adapter (const char *, size_t, void *);
518 static void
519 d_print_init (struct d_print_info *, demangle_callbackref, void *,
520 const struct demangle_component *);
522 static inline void d_print_error (struct d_print_info *);
524 static inline int d_print_saw_error (struct d_print_info *);
526 static inline void d_print_flush (struct d_print_info *);
528 static inline void d_append_char (struct d_print_info *, char);
530 static inline void d_append_buffer (struct d_print_info *,
531 const char *, size_t);
533 static inline void d_append_string (struct d_print_info *, const char *);
535 static inline char d_last_char (struct d_print_info *);
537 static void
538 d_print_comp (struct d_print_info *, int, struct demangle_component *);
540 static void
541 d_print_java_identifier (struct d_print_info *, const char *, int);
543 static void
544 d_print_mod_list (struct d_print_info *, int, struct d_print_mod *, int);
546 static void
547 d_print_mod (struct d_print_info *, int, struct demangle_component *);
549 static void
550 d_print_function_type (struct d_print_info *, int,
551 struct demangle_component *,
552 struct d_print_mod *);
554 static void
555 d_print_array_type (struct d_print_info *, int,
556 struct demangle_component *,
557 struct d_print_mod *);
559 static void
560 d_print_expr_op (struct d_print_info *, int, struct demangle_component *);
562 static void d_print_cast (struct d_print_info *, int,
563 struct demangle_component *);
564 static void d_print_conversion (struct d_print_info *, int,
565 struct demangle_component *);
567 static int d_demangle_callback (const char *, int,
568 demangle_callbackref, void *);
569 static char *d_demangle (const char *, int, size_t *);
571 #define FNQUAL_COMPONENT_CASE \
572 case DEMANGLE_COMPONENT_RESTRICT_THIS: \
573 case DEMANGLE_COMPONENT_VOLATILE_THIS: \
574 case DEMANGLE_COMPONENT_CONST_THIS: \
575 case DEMANGLE_COMPONENT_REFERENCE_THIS: \
576 case DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS: \
577 case DEMANGLE_COMPONENT_TRANSACTION_SAFE: \
578 case DEMANGLE_COMPONENT_NOEXCEPT: \
579 case DEMANGLE_COMPONENT_THROW_SPEC
581 /* True iff TYPE is a demangling component representing a
582 function-type-qualifier. */
584 static int
585 is_fnqual_component_type (enum demangle_component_type type)
587 switch (type)
589 FNQUAL_COMPONENT_CASE:
590 return 1;
591 default:
592 break;
594 return 0;
598 #ifdef CP_DEMANGLE_DEBUG
600 static void
601 d_dump (struct demangle_component *dc, int indent)
603 int i;
605 if (dc == NULL)
607 if (indent == 0)
608 printf ("failed demangling\n");
609 return;
612 for (i = 0; i < indent; ++i)
613 putchar (' ');
615 switch (dc->type)
617 case DEMANGLE_COMPONENT_NAME:
618 printf ("name '%.*s'\n", dc->u.s_name.len, dc->u.s_name.s);
619 return;
620 case DEMANGLE_COMPONENT_TAGGED_NAME:
621 printf ("tagged name\n");
622 d_dump (dc->u.s_binary.left, indent + 2);
623 d_dump (dc->u.s_binary.right, indent + 2);
624 return;
625 case DEMANGLE_COMPONENT_TEMPLATE_PARAM:
626 printf ("template parameter %ld\n", dc->u.s_number.number);
627 return;
628 case DEMANGLE_COMPONENT_TPARM_OBJ:
629 printf ("template parameter object\n");
630 break;
631 case DEMANGLE_COMPONENT_FUNCTION_PARAM:
632 printf ("function parameter %ld\n", dc->u.s_number.number);
633 return;
634 case DEMANGLE_COMPONENT_CTOR:
635 printf ("constructor %d\n", (int) dc->u.s_ctor.kind);
636 d_dump (dc->u.s_ctor.name, indent + 2);
637 return;
638 case DEMANGLE_COMPONENT_DTOR:
639 printf ("destructor %d\n", (int) dc->u.s_dtor.kind);
640 d_dump (dc->u.s_dtor.name, indent + 2);
641 return;
642 case DEMANGLE_COMPONENT_SUB_STD:
643 printf ("standard substitution %s\n", dc->u.s_string.string);
644 return;
645 case DEMANGLE_COMPONENT_BUILTIN_TYPE:
646 printf ("builtin type %s\n", dc->u.s_builtin.type->name);
647 return;
648 case DEMANGLE_COMPONENT_OPERATOR:
649 printf ("operator %s\n", dc->u.s_operator.op->name);
650 return;
651 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
652 printf ("extended operator with %d args\n",
653 dc->u.s_extended_operator.args);
654 d_dump (dc->u.s_extended_operator.name, indent + 2);
655 return;
657 case DEMANGLE_COMPONENT_QUAL_NAME:
658 printf ("qualified name\n");
659 break;
660 case DEMANGLE_COMPONENT_LOCAL_NAME:
661 printf ("local name\n");
662 break;
663 case DEMANGLE_COMPONENT_TYPED_NAME:
664 printf ("typed name\n");
665 break;
666 case DEMANGLE_COMPONENT_TEMPLATE:
667 printf ("template\n");
668 break;
669 case DEMANGLE_COMPONENT_VTABLE:
670 printf ("vtable\n");
671 break;
672 case DEMANGLE_COMPONENT_VTT:
673 printf ("VTT\n");
674 break;
675 case DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE:
676 printf ("construction vtable\n");
677 break;
678 case DEMANGLE_COMPONENT_TYPEINFO:
679 printf ("typeinfo\n");
680 break;
681 case DEMANGLE_COMPONENT_TYPEINFO_NAME:
682 printf ("typeinfo name\n");
683 break;
684 case DEMANGLE_COMPONENT_TYPEINFO_FN:
685 printf ("typeinfo function\n");
686 break;
687 case DEMANGLE_COMPONENT_THUNK:
688 printf ("thunk\n");
689 break;
690 case DEMANGLE_COMPONENT_VIRTUAL_THUNK:
691 printf ("virtual thunk\n");
692 break;
693 case DEMANGLE_COMPONENT_COVARIANT_THUNK:
694 printf ("covariant thunk\n");
695 break;
696 case DEMANGLE_COMPONENT_JAVA_CLASS:
697 printf ("java class\n");
698 break;
699 case DEMANGLE_COMPONENT_GUARD:
700 printf ("guard\n");
701 break;
702 case DEMANGLE_COMPONENT_REFTEMP:
703 printf ("reference temporary\n");
704 break;
705 case DEMANGLE_COMPONENT_HIDDEN_ALIAS:
706 printf ("hidden alias\n");
707 break;
708 case DEMANGLE_COMPONENT_TRANSACTION_CLONE:
709 printf ("transaction clone\n");
710 break;
711 case DEMANGLE_COMPONENT_NONTRANSACTION_CLONE:
712 printf ("non-transaction clone\n");
713 break;
714 case DEMANGLE_COMPONENT_RESTRICT:
715 printf ("restrict\n");
716 break;
717 case DEMANGLE_COMPONENT_VOLATILE:
718 printf ("volatile\n");
719 break;
720 case DEMANGLE_COMPONENT_CONST:
721 printf ("const\n");
722 break;
723 case DEMANGLE_COMPONENT_RESTRICT_THIS:
724 printf ("restrict this\n");
725 break;
726 case DEMANGLE_COMPONENT_VOLATILE_THIS:
727 printf ("volatile this\n");
728 break;
729 case DEMANGLE_COMPONENT_CONST_THIS:
730 printf ("const this\n");
731 break;
732 case DEMANGLE_COMPONENT_REFERENCE_THIS:
733 printf ("reference this\n");
734 break;
735 case DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS:
736 printf ("rvalue reference this\n");
737 break;
738 case DEMANGLE_COMPONENT_TRANSACTION_SAFE:
739 printf ("transaction_safe this\n");
740 break;
741 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
742 printf ("vendor type qualifier\n");
743 break;
744 case DEMANGLE_COMPONENT_POINTER:
745 printf ("pointer\n");
746 break;
747 case DEMANGLE_COMPONENT_REFERENCE:
748 printf ("reference\n");
749 break;
750 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
751 printf ("rvalue reference\n");
752 break;
753 case DEMANGLE_COMPONENT_COMPLEX:
754 printf ("complex\n");
755 break;
756 case DEMANGLE_COMPONENT_IMAGINARY:
757 printf ("imaginary\n");
758 break;
759 case DEMANGLE_COMPONENT_VENDOR_TYPE:
760 printf ("vendor type\n");
761 break;
762 case DEMANGLE_COMPONENT_FUNCTION_TYPE:
763 printf ("function type\n");
764 break;
765 case DEMANGLE_COMPONENT_ARRAY_TYPE:
766 printf ("array type\n");
767 break;
768 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
769 printf ("pointer to member type\n");
770 break;
771 case DEMANGLE_COMPONENT_FIXED_TYPE:
772 printf ("fixed-point type, accum? %d, sat? %d\n",
773 dc->u.s_fixed.accum, dc->u.s_fixed.sat);
774 d_dump (dc->u.s_fixed.length, indent + 2);
775 break;
776 case DEMANGLE_COMPONENT_ARGLIST:
777 printf ("argument list\n");
778 break;
779 case DEMANGLE_COMPONENT_TEMPLATE_ARGLIST:
780 printf ("template argument list\n");
781 break;
782 case DEMANGLE_COMPONENT_INITIALIZER_LIST:
783 printf ("initializer list\n");
784 break;
785 case DEMANGLE_COMPONENT_CAST:
786 printf ("cast\n");
787 break;
788 case DEMANGLE_COMPONENT_CONVERSION:
789 printf ("conversion operator\n");
790 break;
791 case DEMANGLE_COMPONENT_NULLARY:
792 printf ("nullary operator\n");
793 break;
794 case DEMANGLE_COMPONENT_UNARY:
795 printf ("unary operator\n");
796 break;
797 case DEMANGLE_COMPONENT_BINARY:
798 printf ("binary operator\n");
799 break;
800 case DEMANGLE_COMPONENT_BINARY_ARGS:
801 printf ("binary operator arguments\n");
802 break;
803 case DEMANGLE_COMPONENT_TRINARY:
804 printf ("trinary operator\n");
805 break;
806 case DEMANGLE_COMPONENT_TRINARY_ARG1:
807 printf ("trinary operator arguments 1\n");
808 break;
809 case DEMANGLE_COMPONENT_TRINARY_ARG2:
810 printf ("trinary operator arguments 1\n");
811 break;
812 case DEMANGLE_COMPONENT_LITERAL:
813 printf ("literal\n");
814 break;
815 case DEMANGLE_COMPONENT_LITERAL_NEG:
816 printf ("negative literal\n");
817 break;
818 case DEMANGLE_COMPONENT_JAVA_RESOURCE:
819 printf ("java resource\n");
820 break;
821 case DEMANGLE_COMPONENT_COMPOUND_NAME:
822 printf ("compound name\n");
823 break;
824 case DEMANGLE_COMPONENT_CHARACTER:
825 printf ("character '%c'\n", dc->u.s_character.character);
826 return;
827 case DEMANGLE_COMPONENT_NUMBER:
828 printf ("number %ld\n", dc->u.s_number.number);
829 return;
830 case DEMANGLE_COMPONENT_DECLTYPE:
831 printf ("decltype\n");
832 break;
833 case DEMANGLE_COMPONENT_PACK_EXPANSION:
834 printf ("pack expansion\n");
835 break;
836 case DEMANGLE_COMPONENT_TLS_INIT:
837 printf ("tls init function\n");
838 break;
839 case DEMANGLE_COMPONENT_TLS_WRAPPER:
840 printf ("tls wrapper function\n");
841 break;
842 case DEMANGLE_COMPONENT_DEFAULT_ARG:
843 printf ("default argument %d\n", dc->u.s_unary_num.num);
844 d_dump (dc->u.s_unary_num.sub, indent+2);
845 return;
846 case DEMANGLE_COMPONENT_LAMBDA:
847 printf ("lambda %d\n", dc->u.s_unary_num.num);
848 d_dump (dc->u.s_unary_num.sub, indent+2);
849 return;
852 d_dump (d_left (dc), indent + 2);
853 d_dump (d_right (dc), indent + 2);
856 #endif /* CP_DEMANGLE_DEBUG */
858 /* Fill in a DEMANGLE_COMPONENT_NAME. */
860 CP_STATIC_IF_GLIBCPP_V3
862 cplus_demangle_fill_name (struct demangle_component *p, const char *s, int len)
864 if (p == NULL || s == NULL || len <= 0)
865 return 0;
866 p->d_printing = 0;
867 p->type = DEMANGLE_COMPONENT_NAME;
868 p->u.s_name.s = s;
869 p->u.s_name.len = len;
870 return 1;
873 /* Fill in a DEMANGLE_COMPONENT_EXTENDED_OPERATOR. */
875 CP_STATIC_IF_GLIBCPP_V3
877 cplus_demangle_fill_extended_operator (struct demangle_component *p, int args,
878 struct demangle_component *name)
880 if (p == NULL || args < 0 || name == NULL)
881 return 0;
882 p->d_printing = 0;
883 p->type = DEMANGLE_COMPONENT_EXTENDED_OPERATOR;
884 p->u.s_extended_operator.args = args;
885 p->u.s_extended_operator.name = name;
886 return 1;
889 /* Fill in a DEMANGLE_COMPONENT_CTOR. */
891 CP_STATIC_IF_GLIBCPP_V3
893 cplus_demangle_fill_ctor (struct demangle_component *p,
894 enum gnu_v3_ctor_kinds kind,
895 struct demangle_component *name)
897 if (p == NULL
898 || name == NULL
899 || (int) kind < gnu_v3_complete_object_ctor
900 || (int) kind > gnu_v3_object_ctor_group)
901 return 0;
902 p->d_printing = 0;
903 p->type = DEMANGLE_COMPONENT_CTOR;
904 p->u.s_ctor.kind = kind;
905 p->u.s_ctor.name = name;
906 return 1;
909 /* Fill in a DEMANGLE_COMPONENT_DTOR. */
911 CP_STATIC_IF_GLIBCPP_V3
913 cplus_demangle_fill_dtor (struct demangle_component *p,
914 enum gnu_v3_dtor_kinds kind,
915 struct demangle_component *name)
917 if (p == NULL
918 || name == NULL
919 || (int) kind < gnu_v3_deleting_dtor
920 || (int) kind > gnu_v3_object_dtor_group)
921 return 0;
922 p->d_printing = 0;
923 p->type = DEMANGLE_COMPONENT_DTOR;
924 p->u.s_dtor.kind = kind;
925 p->u.s_dtor.name = name;
926 return 1;
929 /* Add a new component. */
931 static struct demangle_component *
932 d_make_empty (struct d_info *di)
934 struct demangle_component *p;
936 if (di->next_comp >= di->num_comps)
937 return NULL;
938 p = &di->comps[di->next_comp];
939 p->d_printing = 0;
940 ++di->next_comp;
941 return p;
944 /* Add a new generic component. */
946 static struct demangle_component *
947 d_make_comp (struct d_info *di, enum demangle_component_type type,
948 struct demangle_component *left,
949 struct demangle_component *right)
951 struct demangle_component *p;
953 /* We check for errors here. A typical error would be a NULL return
954 from a subroutine. We catch those here, and return NULL
955 upward. */
956 switch (type)
958 /* These types require two parameters. */
959 case DEMANGLE_COMPONENT_QUAL_NAME:
960 case DEMANGLE_COMPONENT_LOCAL_NAME:
961 case DEMANGLE_COMPONENT_TYPED_NAME:
962 case DEMANGLE_COMPONENT_TAGGED_NAME:
963 case DEMANGLE_COMPONENT_TEMPLATE:
964 case DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE:
965 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
966 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
967 case DEMANGLE_COMPONENT_UNARY:
968 case DEMANGLE_COMPONENT_BINARY:
969 case DEMANGLE_COMPONENT_BINARY_ARGS:
970 case DEMANGLE_COMPONENT_TRINARY:
971 case DEMANGLE_COMPONENT_TRINARY_ARG1:
972 case DEMANGLE_COMPONENT_LITERAL:
973 case DEMANGLE_COMPONENT_LITERAL_NEG:
974 case DEMANGLE_COMPONENT_COMPOUND_NAME:
975 case DEMANGLE_COMPONENT_VECTOR_TYPE:
976 case DEMANGLE_COMPONENT_CLONE:
977 if (left == NULL || right == NULL)
978 return NULL;
979 break;
981 /* These types only require one parameter. */
982 case DEMANGLE_COMPONENT_VTABLE:
983 case DEMANGLE_COMPONENT_VTT:
984 case DEMANGLE_COMPONENT_TYPEINFO:
985 case DEMANGLE_COMPONENT_TYPEINFO_NAME:
986 case DEMANGLE_COMPONENT_TYPEINFO_FN:
987 case DEMANGLE_COMPONENT_THUNK:
988 case DEMANGLE_COMPONENT_VIRTUAL_THUNK:
989 case DEMANGLE_COMPONENT_COVARIANT_THUNK:
990 case DEMANGLE_COMPONENT_JAVA_CLASS:
991 case DEMANGLE_COMPONENT_GUARD:
992 case DEMANGLE_COMPONENT_TLS_INIT:
993 case DEMANGLE_COMPONENT_TLS_WRAPPER:
994 case DEMANGLE_COMPONENT_REFTEMP:
995 case DEMANGLE_COMPONENT_HIDDEN_ALIAS:
996 case DEMANGLE_COMPONENT_TRANSACTION_CLONE:
997 case DEMANGLE_COMPONENT_NONTRANSACTION_CLONE:
998 case DEMANGLE_COMPONENT_POINTER:
999 case DEMANGLE_COMPONENT_REFERENCE:
1000 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
1001 case DEMANGLE_COMPONENT_COMPLEX:
1002 case DEMANGLE_COMPONENT_IMAGINARY:
1003 case DEMANGLE_COMPONENT_VENDOR_TYPE:
1004 case DEMANGLE_COMPONENT_CAST:
1005 case DEMANGLE_COMPONENT_CONVERSION:
1006 case DEMANGLE_COMPONENT_JAVA_RESOURCE:
1007 case DEMANGLE_COMPONENT_DECLTYPE:
1008 case DEMANGLE_COMPONENT_PACK_EXPANSION:
1009 case DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS:
1010 case DEMANGLE_COMPONENT_GLOBAL_DESTRUCTORS:
1011 case DEMANGLE_COMPONENT_NULLARY:
1012 case DEMANGLE_COMPONENT_TRINARY_ARG2:
1013 case DEMANGLE_COMPONENT_TPARM_OBJ:
1014 if (left == NULL)
1015 return NULL;
1016 break;
1018 /* This needs a right parameter, but the left parameter can be
1019 empty. */
1020 case DEMANGLE_COMPONENT_ARRAY_TYPE:
1021 case DEMANGLE_COMPONENT_INITIALIZER_LIST:
1022 if (right == NULL)
1023 return NULL;
1024 break;
1026 /* These are allowed to have no parameters--in some cases they
1027 will be filled in later. */
1028 case DEMANGLE_COMPONENT_FUNCTION_TYPE:
1029 case DEMANGLE_COMPONENT_RESTRICT:
1030 case DEMANGLE_COMPONENT_VOLATILE:
1031 case DEMANGLE_COMPONENT_CONST:
1032 case DEMANGLE_COMPONENT_ARGLIST:
1033 case DEMANGLE_COMPONENT_TEMPLATE_ARGLIST:
1034 FNQUAL_COMPONENT_CASE:
1035 break;
1037 /* Other types should not be seen here. */
1038 default:
1039 return NULL;
1042 p = d_make_empty (di);
1043 if (p != NULL)
1045 p->type = type;
1046 p->u.s_binary.left = left;
1047 p->u.s_binary.right = right;
1049 return p;
1052 /* Add a new demangle mangled name component. */
1054 static struct demangle_component *
1055 d_make_demangle_mangled_name (struct d_info *di, const char *s)
1057 if (d_peek_char (di) != '_' || d_peek_next_char (di) != 'Z')
1058 return d_make_name (di, s, strlen (s));
1059 d_advance (di, 2);
1060 return d_encoding (di, 0);
1063 /* Add a new name component. */
1065 static struct demangle_component *
1066 d_make_name (struct d_info *di, const char *s, int len)
1068 struct demangle_component *p;
1070 p = d_make_empty (di);
1071 if (! cplus_demangle_fill_name (p, s, len))
1072 return NULL;
1073 return p;
1076 /* Add a new builtin type component. */
1078 static struct demangle_component *
1079 d_make_builtin_type (struct d_info *di,
1080 const struct demangle_builtin_type_info *type)
1082 struct demangle_component *p;
1084 if (type == NULL)
1085 return NULL;
1086 p = d_make_empty (di);
1087 if (p != NULL)
1089 p->type = DEMANGLE_COMPONENT_BUILTIN_TYPE;
1090 p->u.s_builtin.type = type;
1092 return p;
1095 /* Add a new operator component. */
1097 static struct demangle_component *
1098 d_make_operator (struct d_info *di, const struct demangle_operator_info *op)
1100 struct demangle_component *p;
1102 p = d_make_empty (di);
1103 if (p != NULL)
1105 p->type = DEMANGLE_COMPONENT_OPERATOR;
1106 p->u.s_operator.op = op;
1108 return p;
1111 /* Add a new extended operator component. */
1113 static struct demangle_component *
1114 d_make_extended_operator (struct d_info *di, int args,
1115 struct demangle_component *name)
1117 struct demangle_component *p;
1119 p = d_make_empty (di);
1120 if (! cplus_demangle_fill_extended_operator (p, args, name))
1121 return NULL;
1122 return p;
1125 static struct demangle_component *
1126 d_make_default_arg (struct d_info *di, int num,
1127 struct demangle_component *sub)
1129 struct demangle_component *p = d_make_empty (di);
1130 if (p)
1132 p->type = DEMANGLE_COMPONENT_DEFAULT_ARG;
1133 p->u.s_unary_num.num = num;
1134 p->u.s_unary_num.sub = sub;
1136 return p;
1139 /* Add a new constructor component. */
1141 static struct demangle_component *
1142 d_make_ctor (struct d_info *di, enum gnu_v3_ctor_kinds kind,
1143 struct demangle_component *name)
1145 struct demangle_component *p;
1147 p = d_make_empty (di);
1148 if (! cplus_demangle_fill_ctor (p, kind, name))
1149 return NULL;
1150 return p;
1153 /* Add a new destructor component. */
1155 static struct demangle_component *
1156 d_make_dtor (struct d_info *di, enum gnu_v3_dtor_kinds kind,
1157 struct demangle_component *name)
1159 struct demangle_component *p;
1161 p = d_make_empty (di);
1162 if (! cplus_demangle_fill_dtor (p, kind, name))
1163 return NULL;
1164 return p;
1167 /* Add a new template parameter. */
1169 static struct demangle_component *
1170 d_make_template_param (struct d_info *di, int i)
1172 struct demangle_component *p;
1174 p = d_make_empty (di);
1175 if (p != NULL)
1177 p->type = DEMANGLE_COMPONENT_TEMPLATE_PARAM;
1178 p->u.s_number.number = i;
1180 return p;
1183 /* Add a new function parameter. */
1185 static struct demangle_component *
1186 d_make_function_param (struct d_info *di, int i)
1188 struct demangle_component *p;
1190 p = d_make_empty (di);
1191 if (p != NULL)
1193 p->type = DEMANGLE_COMPONENT_FUNCTION_PARAM;
1194 p->u.s_number.number = i;
1196 return p;
1199 /* Add a new standard substitution component. */
1201 static struct demangle_component *
1202 d_make_sub (struct d_info *di, const char *name, int len)
1204 struct demangle_component *p;
1206 p = d_make_empty (di);
1207 if (p != NULL)
1209 p->type = DEMANGLE_COMPONENT_SUB_STD;
1210 p->u.s_string.string = name;
1211 p->u.s_string.len = len;
1213 return p;
1216 /* <mangled-name> ::= _Z <encoding> [<clone-suffix>]*
1218 TOP_LEVEL is non-zero when called at the top level. */
1220 CP_STATIC_IF_GLIBCPP_V3
1221 struct demangle_component *
1222 cplus_demangle_mangled_name (struct d_info *di, int top_level)
1224 struct demangle_component *p;
1226 if (! d_check_char (di, '_')
1227 /* Allow missing _ if not at toplevel to work around a
1228 bug in G++ abi-version=2 mangling; see the comment in
1229 write_template_arg. */
1230 && top_level)
1231 return NULL;
1232 if (! d_check_char (di, 'Z'))
1233 return NULL;
1234 p = d_encoding (di, top_level);
1236 /* If at top level and parsing parameters, check for a clone
1237 suffix. */
1238 if (top_level && (di->options & DMGL_PARAMS) != 0)
1239 while (d_peek_char (di) == '.'
1240 && (IS_LOWER (d_peek_next_char (di))
1241 || d_peek_next_char (di) == '_'
1242 || IS_DIGIT (d_peek_next_char (di))))
1243 p = d_clone_suffix (di, p);
1245 return p;
1248 /* Return whether a function should have a return type. The argument
1249 is the function name, which may be qualified in various ways. The
1250 rules are that template functions have return types with some
1251 exceptions, function types which are not part of a function name
1252 mangling have return types with some exceptions, and non-template
1253 function names do not have return types. The exceptions are that
1254 constructors, destructors, and conversion operators do not have
1255 return types. */
1257 static int
1258 has_return_type (struct demangle_component *dc)
1260 if (dc == NULL)
1261 return 0;
1262 switch (dc->type)
1264 default:
1265 return 0;
1266 case DEMANGLE_COMPONENT_LOCAL_NAME:
1267 return has_return_type (d_right (dc));
1268 case DEMANGLE_COMPONENT_TEMPLATE:
1269 return ! is_ctor_dtor_or_conversion (d_left (dc));
1270 FNQUAL_COMPONENT_CASE:
1271 return has_return_type (d_left (dc));
1275 /* Return whether a name is a constructor, a destructor, or a
1276 conversion operator. */
1278 static int
1279 is_ctor_dtor_or_conversion (struct demangle_component *dc)
1281 if (dc == NULL)
1282 return 0;
1283 switch (dc->type)
1285 default:
1286 return 0;
1287 case DEMANGLE_COMPONENT_QUAL_NAME:
1288 case DEMANGLE_COMPONENT_LOCAL_NAME:
1289 return is_ctor_dtor_or_conversion (d_right (dc));
1290 case DEMANGLE_COMPONENT_CTOR:
1291 case DEMANGLE_COMPONENT_DTOR:
1292 case DEMANGLE_COMPONENT_CONVERSION:
1293 return 1;
1297 /* <encoding> ::= <(function) name> <bare-function-type>
1298 ::= <(data) name>
1299 ::= <special-name>
1301 TOP_LEVEL is non-zero when called at the top level, in which case
1302 if DMGL_PARAMS is not set we do not demangle the function
1303 parameters. We only set this at the top level, because otherwise
1304 we would not correctly demangle names in local scopes. */
1306 static struct demangle_component *
1307 d_encoding (struct d_info *di, int top_level)
1309 char peek = d_peek_char (di);
1310 struct demangle_component *dc;
1312 if (peek == 'G' || peek == 'T')
1313 dc = d_special_name (di);
1314 else
1316 dc = d_name (di);
1318 if (!dc)
1319 /* Failed already. */;
1320 else if (top_level && (di->options & DMGL_PARAMS) == 0)
1322 /* Strip off any initial CV-qualifiers, as they really apply
1323 to the `this' parameter, and they were not output by the
1324 v2 demangler without DMGL_PARAMS. */
1325 while (is_fnqual_component_type (dc->type))
1326 dc = d_left (dc);
1328 /* If the top level is a DEMANGLE_COMPONENT_LOCAL_NAME, then
1329 there may be function-qualifiers on its right argument which
1330 really apply here; this happens when parsing a class
1331 which is local to a function. */
1332 if (dc->type == DEMANGLE_COMPONENT_LOCAL_NAME)
1334 while (d_right (dc) != NULL
1335 && is_fnqual_component_type (d_right (dc)->type))
1336 d_right (dc) = d_left (d_right (dc));
1338 if (d_right (dc) == NULL)
1339 dc = NULL;
1342 else
1344 peek = d_peek_char (di);
1345 if (peek != '\0' && peek != 'E')
1347 struct demangle_component *ftype;
1349 ftype = d_bare_function_type (di, has_return_type (dc));
1350 if (ftype)
1352 /* If this is a non-top-level local-name, clear the
1353 return type, so it doesn't confuse the user by
1354 being confused with the return type of whaever
1355 this is nested within. */
1356 if (!top_level && dc->type == DEMANGLE_COMPONENT_LOCAL_NAME
1357 && ftype->type == DEMANGLE_COMPONENT_FUNCTION_TYPE)
1358 d_left (ftype) = NULL;
1360 dc = d_make_comp (di, DEMANGLE_COMPONENT_TYPED_NAME,
1361 dc, ftype);
1363 else
1364 dc = NULL;
1369 return dc;
1372 /* <tagged-name> ::= <name> B <source-name> */
1374 static struct demangle_component *
1375 d_abi_tags (struct d_info *di, struct demangle_component *dc)
1377 struct demangle_component *hold_last_name;
1378 char peek;
1380 /* Preserve the last name, so the ABI tag doesn't clobber it. */
1381 hold_last_name = di->last_name;
1383 while (peek = d_peek_char (di),
1384 peek == 'B')
1386 struct demangle_component *tag;
1387 d_advance (di, 1);
1388 tag = d_source_name (di);
1389 dc = d_make_comp (di, DEMANGLE_COMPONENT_TAGGED_NAME, dc, tag);
1392 di->last_name = hold_last_name;
1394 return dc;
1397 /* <name> ::= <nested-name>
1398 ::= <unscoped-name>
1399 ::= <unscoped-template-name> <template-args>
1400 ::= <local-name>
1402 <unscoped-name> ::= <unqualified-name>
1403 ::= St <unqualified-name>
1405 <unscoped-template-name> ::= <unscoped-name>
1406 ::= <substitution>
1409 static struct demangle_component *
1410 d_name (struct d_info *di)
1412 char peek = d_peek_char (di);
1413 struct demangle_component *dc;
1415 switch (peek)
1417 case 'N':
1418 return d_nested_name (di);
1420 case 'Z':
1421 return d_local_name (di);
1423 case 'U':
1424 return d_unqualified_name (di);
1426 case 'S':
1428 int subst;
1430 if (d_peek_next_char (di) != 't')
1432 dc = d_substitution (di, 0);
1433 subst = 1;
1435 else
1437 d_advance (di, 2);
1438 dc = d_make_comp (di, DEMANGLE_COMPONENT_QUAL_NAME,
1439 d_make_name (di, "std", 3),
1440 d_unqualified_name (di));
1441 di->expansion += 3;
1442 subst = 0;
1445 if (d_peek_char (di) != 'I')
1447 /* The grammar does not permit this case to occur if we
1448 called d_substitution() above (i.e., subst == 1). We
1449 don't bother to check. */
1451 else
1453 /* This is <template-args>, which means that we just saw
1454 <unscoped-template-name>, which is a substitution
1455 candidate if we didn't just get it from a
1456 substitution. */
1457 if (! subst)
1459 if (! d_add_substitution (di, dc))
1460 return NULL;
1462 dc = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, dc,
1463 d_template_args (di));
1466 return dc;
1469 case 'L':
1470 default:
1471 dc = d_unqualified_name (di);
1472 if (d_peek_char (di) == 'I')
1474 /* This is <template-args>, which means that we just saw
1475 <unscoped-template-name>, which is a substitution
1476 candidate. */
1477 if (! d_add_substitution (di, dc))
1478 return NULL;
1479 dc = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, dc,
1480 d_template_args (di));
1482 return dc;
1486 /* <nested-name> ::= N [<CV-qualifiers>] [<ref-qualifier>] <prefix> <unqualified-name> E
1487 ::= N [<CV-qualifiers>] [<ref-qualifier>] <template-prefix> <template-args> E
1490 static struct demangle_component *
1491 d_nested_name (struct d_info *di)
1493 struct demangle_component *ret;
1494 struct demangle_component **pret;
1495 struct demangle_component *rqual;
1497 if (! d_check_char (di, 'N'))
1498 return NULL;
1500 pret = d_cv_qualifiers (di, &ret, 1);
1501 if (pret == NULL)
1502 return NULL;
1504 /* Parse the ref-qualifier now and then attach it
1505 once we have something to attach it to. */
1506 rqual = d_ref_qualifier (di, NULL);
1508 *pret = d_prefix (di);
1509 if (*pret == NULL)
1510 return NULL;
1512 if (rqual)
1514 d_left (rqual) = ret;
1515 ret = rqual;
1518 if (! d_check_char (di, 'E'))
1519 return NULL;
1521 return ret;
1524 /* <prefix> ::= <prefix> <unqualified-name>
1525 ::= <template-prefix> <template-args>
1526 ::= <template-param>
1527 ::= <decltype>
1529 ::= <substitution>
1531 <template-prefix> ::= <prefix> <(template) unqualified-name>
1532 ::= <template-param>
1533 ::= <substitution>
1536 static struct demangle_component *
1537 d_prefix (struct d_info *di)
1539 struct demangle_component *ret = NULL;
1541 while (1)
1543 char peek;
1544 enum demangle_component_type comb_type;
1545 struct demangle_component *dc;
1547 peek = d_peek_char (di);
1548 if (peek == '\0')
1549 return NULL;
1551 /* The older code accepts a <local-name> here, but I don't see
1552 that in the grammar. The older code does not accept a
1553 <template-param> here. */
1555 comb_type = DEMANGLE_COMPONENT_QUAL_NAME;
1556 if (peek == 'D')
1558 char peek2 = d_peek_next_char (di);
1559 if (peek2 == 'T' || peek2 == 't')
1560 /* Decltype. */
1561 dc = cplus_demangle_type (di);
1562 else
1563 /* Destructor name. */
1564 dc = d_unqualified_name (di);
1566 else if (IS_DIGIT (peek)
1567 || IS_LOWER (peek)
1568 || peek == 'C'
1569 || peek == 'U'
1570 || peek == 'L')
1571 dc = d_unqualified_name (di);
1572 else if (peek == 'S')
1573 dc = d_substitution (di, 1);
1574 else if (peek == 'I')
1576 if (ret == NULL)
1577 return NULL;
1578 comb_type = DEMANGLE_COMPONENT_TEMPLATE;
1579 dc = d_template_args (di);
1581 else if (peek == 'T')
1582 dc = d_template_param (di);
1583 else if (peek == 'E')
1584 return ret;
1585 else if (peek == 'M')
1587 /* Initializer scope for a lambda. We don't need to represent
1588 this; the normal code will just treat the variable as a type
1589 scope, which gives appropriate output. */
1590 if (ret == NULL)
1591 return NULL;
1592 d_advance (di, 1);
1593 continue;
1595 else
1596 return NULL;
1598 if (ret == NULL)
1599 ret = dc;
1600 else
1601 ret = d_make_comp (di, comb_type, ret, dc);
1603 if (peek != 'S' && d_peek_char (di) != 'E')
1605 if (! d_add_substitution (di, ret))
1606 return NULL;
1611 /* <unqualified-name> ::= <operator-name>
1612 ::= <ctor-dtor-name>
1613 ::= <source-name>
1614 ::= <local-source-name>
1616 <local-source-name> ::= L <source-name> <discriminator>
1619 static struct demangle_component *
1620 d_unqualified_name (struct d_info *di)
1622 struct demangle_component *ret;
1623 char peek;
1625 peek = d_peek_char (di);
1626 if (IS_DIGIT (peek))
1627 ret = d_source_name (di);
1628 else if (IS_LOWER (peek))
1630 if (peek == 'o' && d_peek_next_char (di) == 'n')
1631 d_advance (di, 2);
1632 ret = d_operator_name (di);
1633 if (ret != NULL && ret->type == DEMANGLE_COMPONENT_OPERATOR)
1635 di->expansion += sizeof "operator" + ret->u.s_operator.op->len - 2;
1636 if (!strcmp (ret->u.s_operator.op->code, "li"))
1637 ret = d_make_comp (di, DEMANGLE_COMPONENT_UNARY, ret,
1638 d_source_name (di));
1641 else if (peek == 'C' || peek == 'D')
1642 ret = d_ctor_dtor_name (di);
1643 else if (peek == 'L')
1645 d_advance (di, 1);
1647 ret = d_source_name (di);
1648 if (ret == NULL)
1649 return NULL;
1650 if (! d_discriminator (di))
1651 return NULL;
1653 else if (peek == 'U')
1655 switch (d_peek_next_char (di))
1657 case 'l':
1658 ret = d_lambda (di);
1659 break;
1660 case 't':
1661 ret = d_unnamed_type (di);
1662 break;
1663 default:
1664 return NULL;
1667 else
1668 return NULL;
1670 if (d_peek_char (di) == 'B')
1671 ret = d_abi_tags (di, ret);
1672 return ret;
1675 /* <source-name> ::= <(positive length) number> <identifier> */
1677 static struct demangle_component *
1678 d_source_name (struct d_info *di)
1680 int len;
1681 struct demangle_component *ret;
1683 len = d_number (di);
1684 if (len <= 0)
1685 return NULL;
1686 ret = d_identifier (di, len);
1687 di->last_name = ret;
1688 return ret;
1691 /* number ::= [n] <(non-negative decimal integer)> */
1693 static int
1694 d_number (struct d_info *di)
1696 int negative;
1697 char peek;
1698 int ret;
1700 negative = 0;
1701 peek = d_peek_char (di);
1702 if (peek == 'n')
1704 negative = 1;
1705 d_advance (di, 1);
1706 peek = d_peek_char (di);
1709 ret = 0;
1710 while (1)
1712 if (! IS_DIGIT (peek))
1714 if (negative)
1715 ret = - ret;
1716 return ret;
1718 if (ret > ((INT_MAX - (peek - '0')) / 10))
1719 return -1;
1720 ret = ret * 10 + peek - '0';
1721 d_advance (di, 1);
1722 peek = d_peek_char (di);
1726 /* Like d_number, but returns a demangle_component. */
1728 static struct demangle_component *
1729 d_number_component (struct d_info *di)
1731 struct demangle_component *ret = d_make_empty (di);
1732 if (ret)
1734 ret->type = DEMANGLE_COMPONENT_NUMBER;
1735 ret->u.s_number.number = d_number (di);
1737 return ret;
1740 /* identifier ::= <(unqualified source code identifier)> */
1742 static struct demangle_component *
1743 d_identifier (struct d_info *di, int len)
1745 const char *name;
1747 name = d_str (di);
1749 if (di->send - name < len)
1750 return NULL;
1752 d_advance (di, len);
1754 /* A Java mangled name may have a trailing '$' if it is a C++
1755 keyword. This '$' is not included in the length count. We just
1756 ignore the '$'. */
1757 if ((di->options & DMGL_JAVA) != 0
1758 && d_peek_char (di) == '$')
1759 d_advance (di, 1);
1761 /* Look for something which looks like a gcc encoding of an
1762 anonymous namespace, and replace it with a more user friendly
1763 name. */
1764 if (len >= (int) ANONYMOUS_NAMESPACE_PREFIX_LEN + 2
1765 && memcmp (name, ANONYMOUS_NAMESPACE_PREFIX,
1766 ANONYMOUS_NAMESPACE_PREFIX_LEN) == 0)
1768 const char *s;
1770 s = name + ANONYMOUS_NAMESPACE_PREFIX_LEN;
1771 if ((*s == '.' || *s == '_' || *s == '$')
1772 && s[1] == 'N')
1774 di->expansion -= len - sizeof "(anonymous namespace)";
1775 return d_make_name (di, "(anonymous namespace)",
1776 sizeof "(anonymous namespace)" - 1);
1780 return d_make_name (di, name, len);
1783 /* operator_name ::= many different two character encodings.
1784 ::= cv <type>
1785 ::= v <digit> <source-name>
1787 This list is sorted for binary search. */
1789 #define NL(s) s, (sizeof s) - 1
1791 CP_STATIC_IF_GLIBCPP_V3
1792 const struct demangle_operator_info cplus_demangle_operators[] =
1794 { "aN", NL ("&="), 2 },
1795 { "aS", NL ("="), 2 },
1796 { "aa", NL ("&&"), 2 },
1797 { "ad", NL ("&"), 1 },
1798 { "an", NL ("&"), 2 },
1799 { "at", NL ("alignof "), 1 },
1800 { "az", NL ("alignof "), 1 },
1801 { "cc", NL ("const_cast"), 2 },
1802 { "cl", NL ("()"), 2 },
1803 { "cm", NL (","), 2 },
1804 { "co", NL ("~"), 1 },
1805 { "dV", NL ("/="), 2 },
1806 { "da", NL ("delete[] "), 1 },
1807 { "dc", NL ("dynamic_cast"), 2 },
1808 { "de", NL ("*"), 1 },
1809 { "dl", NL ("delete "), 1 },
1810 { "ds", NL (".*"), 2 },
1811 { "dt", NL ("."), 2 },
1812 { "dv", NL ("/"), 2 },
1813 { "eO", NL ("^="), 2 },
1814 { "eo", NL ("^"), 2 },
1815 { "eq", NL ("=="), 2 },
1816 { "fL", NL ("..."), 3 },
1817 { "fR", NL ("..."), 3 },
1818 { "fl", NL ("..."), 2 },
1819 { "fr", NL ("..."), 2 },
1820 { "ge", NL (">="), 2 },
1821 { "gs", NL ("::"), 1 },
1822 { "gt", NL (">"), 2 },
1823 { "ix", NL ("[]"), 2 },
1824 { "lS", NL ("<<="), 2 },
1825 { "le", NL ("<="), 2 },
1826 { "li", NL ("operator\"\" "), 1 },
1827 { "ls", NL ("<<"), 2 },
1828 { "lt", NL ("<"), 2 },
1829 { "mI", NL ("-="), 2 },
1830 { "mL", NL ("*="), 2 },
1831 { "mi", NL ("-"), 2 },
1832 { "ml", NL ("*"), 2 },
1833 { "mm", NL ("--"), 1 },
1834 { "na", NL ("new[]"), 3 },
1835 { "ne", NL ("!="), 2 },
1836 { "ng", NL ("-"), 1 },
1837 { "nt", NL ("!"), 1 },
1838 { "nw", NL ("new"), 3 },
1839 { "oR", NL ("|="), 2 },
1840 { "oo", NL ("||"), 2 },
1841 { "or", NL ("|"), 2 },
1842 { "pL", NL ("+="), 2 },
1843 { "pl", NL ("+"), 2 },
1844 { "pm", NL ("->*"), 2 },
1845 { "pp", NL ("++"), 1 },
1846 { "ps", NL ("+"), 1 },
1847 { "pt", NL ("->"), 2 },
1848 { "qu", NL ("?"), 3 },
1849 { "rM", NL ("%="), 2 },
1850 { "rS", NL (">>="), 2 },
1851 { "rc", NL ("reinterpret_cast"), 2 },
1852 { "rm", NL ("%"), 2 },
1853 { "rs", NL (">>"), 2 },
1854 { "sP", NL ("sizeof..."), 1 },
1855 { "sZ", NL ("sizeof..."), 1 },
1856 { "sc", NL ("static_cast"), 2 },
1857 { "st", NL ("sizeof "), 1 },
1858 { "sz", NL ("sizeof "), 1 },
1859 { "tr", NL ("throw"), 0 },
1860 { "tw", NL ("throw "), 1 },
1861 { NULL, NULL, 0, 0 }
1864 static struct demangle_component *
1865 d_operator_name (struct d_info *di)
1867 char c1;
1868 char c2;
1870 c1 = d_next_char (di);
1871 c2 = d_next_char (di);
1872 if (c1 == 'v' && IS_DIGIT (c2))
1873 return d_make_extended_operator (di, c2 - '0', d_source_name (di));
1874 else if (c1 == 'c' && c2 == 'v')
1876 struct demangle_component *type;
1877 int was_conversion = di->is_conversion;
1878 struct demangle_component *res;
1880 di->is_conversion = ! di->is_expression;
1881 type = cplus_demangle_type (di);
1882 if (di->is_conversion)
1883 res = d_make_comp (di, DEMANGLE_COMPONENT_CONVERSION, type, NULL);
1884 else
1885 res = d_make_comp (di, DEMANGLE_COMPONENT_CAST, type, NULL);
1886 di->is_conversion = was_conversion;
1887 return res;
1889 else
1891 /* LOW is the inclusive lower bound. */
1892 int low = 0;
1893 /* HIGH is the exclusive upper bound. We subtract one to ignore
1894 the sentinel at the end of the array. */
1895 int high = ((sizeof (cplus_demangle_operators)
1896 / sizeof (cplus_demangle_operators[0]))
1897 - 1);
1899 while (1)
1901 int i;
1902 const struct demangle_operator_info *p;
1904 i = low + (high - low) / 2;
1905 p = cplus_demangle_operators + i;
1907 if (c1 == p->code[0] && c2 == p->code[1])
1908 return d_make_operator (di, p);
1910 if (c1 < p->code[0] || (c1 == p->code[0] && c2 < p->code[1]))
1911 high = i;
1912 else
1913 low = i + 1;
1914 if (low == high)
1915 return NULL;
1920 static struct demangle_component *
1921 d_make_character (struct d_info *di, int c)
1923 struct demangle_component *p;
1924 p = d_make_empty (di);
1925 if (p != NULL)
1927 p->type = DEMANGLE_COMPONENT_CHARACTER;
1928 p->u.s_character.character = c;
1930 return p;
1933 static struct demangle_component *
1934 d_java_resource (struct d_info *di)
1936 struct demangle_component *p = NULL;
1937 struct demangle_component *next = NULL;
1938 int len, i;
1939 char c;
1940 const char *str;
1942 len = d_number (di);
1943 if (len <= 1)
1944 return NULL;
1946 /* Eat the leading '_'. */
1947 if (d_next_char (di) != '_')
1948 return NULL;
1949 len--;
1951 str = d_str (di);
1952 i = 0;
1954 while (len > 0)
1956 c = str[i];
1957 if (!c)
1958 return NULL;
1960 /* Each chunk is either a '$' escape... */
1961 if (c == '$')
1963 i++;
1964 switch (str[i++])
1966 case 'S':
1967 c = '/';
1968 break;
1969 case '_':
1970 c = '.';
1971 break;
1972 case '$':
1973 c = '$';
1974 break;
1975 default:
1976 return NULL;
1978 next = d_make_character (di, c);
1979 d_advance (di, i);
1980 str = d_str (di);
1981 len -= i;
1982 i = 0;
1983 if (next == NULL)
1984 return NULL;
1986 /* ... or a sequence of characters. */
1987 else
1989 while (i < len && str[i] && str[i] != '$')
1990 i++;
1992 next = d_make_name (di, str, i);
1993 d_advance (di, i);
1994 str = d_str (di);
1995 len -= i;
1996 i = 0;
1997 if (next == NULL)
1998 return NULL;
2001 if (p == NULL)
2002 p = next;
2003 else
2005 p = d_make_comp (di, DEMANGLE_COMPONENT_COMPOUND_NAME, p, next);
2006 if (p == NULL)
2007 return NULL;
2011 p = d_make_comp (di, DEMANGLE_COMPONENT_JAVA_RESOURCE, p, NULL);
2013 return p;
2016 /* <special-name> ::= TV <type>
2017 ::= TT <type>
2018 ::= TI <type>
2019 ::= TS <type>
2020 ::= TA <template-arg>
2021 ::= GV <(object) name>
2022 ::= T <call-offset> <(base) encoding>
2023 ::= Tc <call-offset> <call-offset> <(base) encoding>
2024 Also g++ extensions:
2025 ::= TC <type> <(offset) number> _ <(base) type>
2026 ::= TF <type>
2027 ::= TJ <type>
2028 ::= GR <name>
2029 ::= GA <encoding>
2030 ::= Gr <resource name>
2031 ::= GTt <encoding>
2032 ::= GTn <encoding>
2035 static struct demangle_component *
2036 d_special_name (struct d_info *di)
2038 di->expansion += 20;
2039 if (d_check_char (di, 'T'))
2041 switch (d_next_char (di))
2043 case 'V':
2044 di->expansion -= 5;
2045 return d_make_comp (di, DEMANGLE_COMPONENT_VTABLE,
2046 cplus_demangle_type (di), NULL);
2047 case 'T':
2048 di->expansion -= 10;
2049 return d_make_comp (di, DEMANGLE_COMPONENT_VTT,
2050 cplus_demangle_type (di), NULL);
2051 case 'I':
2052 return d_make_comp (di, DEMANGLE_COMPONENT_TYPEINFO,
2053 cplus_demangle_type (di), NULL);
2054 case 'S':
2055 return d_make_comp (di, DEMANGLE_COMPONENT_TYPEINFO_NAME,
2056 cplus_demangle_type (di), NULL);
2058 case 'h':
2059 if (! d_call_offset (di, 'h'))
2060 return NULL;
2061 return d_make_comp (di, DEMANGLE_COMPONENT_THUNK,
2062 d_encoding (di, 0), NULL);
2064 case 'v':
2065 if (! d_call_offset (di, 'v'))
2066 return NULL;
2067 return d_make_comp (di, DEMANGLE_COMPONENT_VIRTUAL_THUNK,
2068 d_encoding (di, 0), NULL);
2070 case 'c':
2071 if (! d_call_offset (di, '\0'))
2072 return NULL;
2073 if (! d_call_offset (di, '\0'))
2074 return NULL;
2075 return d_make_comp (di, DEMANGLE_COMPONENT_COVARIANT_THUNK,
2076 d_encoding (di, 0), NULL);
2078 case 'C':
2080 struct demangle_component *derived_type;
2081 int offset;
2082 struct demangle_component *base_type;
2084 derived_type = cplus_demangle_type (di);
2085 offset = d_number (di);
2086 if (offset < 0)
2087 return NULL;
2088 if (! d_check_char (di, '_'))
2089 return NULL;
2090 base_type = cplus_demangle_type (di);
2091 /* We don't display the offset. FIXME: We should display
2092 it in verbose mode. */
2093 di->expansion += 5;
2094 return d_make_comp (di, DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE,
2095 base_type, derived_type);
2098 case 'F':
2099 return d_make_comp (di, DEMANGLE_COMPONENT_TYPEINFO_FN,
2100 cplus_demangle_type (di), NULL);
2101 case 'J':
2102 return d_make_comp (di, DEMANGLE_COMPONENT_JAVA_CLASS,
2103 cplus_demangle_type (di), NULL);
2105 case 'H':
2106 return d_make_comp (di, DEMANGLE_COMPONENT_TLS_INIT,
2107 d_name (di), NULL);
2109 case 'W':
2110 return d_make_comp (di, DEMANGLE_COMPONENT_TLS_WRAPPER,
2111 d_name (di), NULL);
2113 case 'A':
2114 return d_make_comp (di, DEMANGLE_COMPONENT_TPARM_OBJ,
2115 d_template_arg (di), NULL);
2117 default:
2118 return NULL;
2121 else if (d_check_char (di, 'G'))
2123 switch (d_next_char (di))
2125 case 'V':
2126 return d_make_comp (di, DEMANGLE_COMPONENT_GUARD,
2127 d_name (di), NULL);
2129 case 'R':
2131 struct demangle_component *name = d_name (di);
2132 return d_make_comp (di, DEMANGLE_COMPONENT_REFTEMP, name,
2133 d_number_component (di));
2136 case 'A':
2137 return d_make_comp (di, DEMANGLE_COMPONENT_HIDDEN_ALIAS,
2138 d_encoding (di, 0), NULL);
2140 case 'T':
2141 switch (d_next_char (di))
2143 case 'n':
2144 return d_make_comp (di, DEMANGLE_COMPONENT_NONTRANSACTION_CLONE,
2145 d_encoding (di, 0), NULL);
2146 default:
2147 /* ??? The proposal is that other letters (such as 'h') stand
2148 for different variants of transaction cloning, such as
2149 compiling directly for hardware transaction support. But
2150 they still should all be transactional clones of some sort
2151 so go ahead and call them that. */
2152 case 't':
2153 return d_make_comp (di, DEMANGLE_COMPONENT_TRANSACTION_CLONE,
2154 d_encoding (di, 0), NULL);
2157 case 'r':
2158 return d_java_resource (di);
2160 default:
2161 return NULL;
2164 else
2165 return NULL;
2168 /* <call-offset> ::= h <nv-offset> _
2169 ::= v <v-offset> _
2171 <nv-offset> ::= <(offset) number>
2173 <v-offset> ::= <(offset) number> _ <(virtual offset) number>
2175 The C parameter, if not '\0', is a character we just read which is
2176 the start of the <call-offset>.
2178 We don't display the offset information anywhere. FIXME: We should
2179 display it in verbose mode. */
2181 static int
2182 d_call_offset (struct d_info *di, int c)
2184 if (c == '\0')
2185 c = d_next_char (di);
2187 if (c == 'h')
2188 d_number (di);
2189 else if (c == 'v')
2191 d_number (di);
2192 if (! d_check_char (di, '_'))
2193 return 0;
2194 d_number (di);
2196 else
2197 return 0;
2199 if (! d_check_char (di, '_'))
2200 return 0;
2202 return 1;
2205 /* <ctor-dtor-name> ::= C1
2206 ::= C2
2207 ::= C3
2208 ::= D0
2209 ::= D1
2210 ::= D2
2213 static struct demangle_component *
2214 d_ctor_dtor_name (struct d_info *di)
2216 if (di->last_name != NULL)
2218 if (di->last_name->type == DEMANGLE_COMPONENT_NAME)
2219 di->expansion += di->last_name->u.s_name.len;
2220 else if (di->last_name->type == DEMANGLE_COMPONENT_SUB_STD)
2221 di->expansion += di->last_name->u.s_string.len;
2223 switch (d_peek_char (di))
2225 case 'C':
2227 enum gnu_v3_ctor_kinds kind;
2228 int inheriting = 0;
2230 if (d_peek_next_char (di) == 'I')
2232 inheriting = 1;
2233 d_advance (di, 1);
2236 switch (d_peek_next_char (di))
2238 case '1':
2239 kind = gnu_v3_complete_object_ctor;
2240 break;
2241 case '2':
2242 kind = gnu_v3_base_object_ctor;
2243 break;
2244 case '3':
2245 kind = gnu_v3_complete_object_allocating_ctor;
2246 break;
2247 case '4':
2248 kind = gnu_v3_unified_ctor;
2249 break;
2250 case '5':
2251 kind = gnu_v3_object_ctor_group;
2252 break;
2253 default:
2254 return NULL;
2257 d_advance (di, 2);
2259 if (inheriting)
2260 cplus_demangle_type (di);
2262 return d_make_ctor (di, kind, di->last_name);
2265 case 'D':
2267 enum gnu_v3_dtor_kinds kind;
2269 switch (d_peek_next_char (di))
2271 case '0':
2272 kind = gnu_v3_deleting_dtor;
2273 break;
2274 case '1':
2275 kind = gnu_v3_complete_object_dtor;
2276 break;
2277 case '2':
2278 kind = gnu_v3_base_object_dtor;
2279 break;
2280 /* digit '3' is not used */
2281 case '4':
2282 kind = gnu_v3_unified_dtor;
2283 break;
2284 case '5':
2285 kind = gnu_v3_object_dtor_group;
2286 break;
2287 default:
2288 return NULL;
2290 d_advance (di, 2);
2291 return d_make_dtor (di, kind, di->last_name);
2294 default:
2295 return NULL;
2299 /* True iff we're looking at an order-insensitive type-qualifier, including
2300 function-type-qualifiers. */
2302 static int
2303 next_is_type_qual (struct d_info *di)
2305 char peek = d_peek_char (di);
2306 if (peek == 'r' || peek == 'V' || peek == 'K')
2307 return 1;
2308 if (peek == 'D')
2310 peek = d_peek_next_char (di);
2311 if (peek == 'x' || peek == 'o' || peek == 'O' || peek == 'w')
2312 return 1;
2314 return 0;
2317 /* <type> ::= <builtin-type>
2318 ::= <function-type>
2319 ::= <class-enum-type>
2320 ::= <array-type>
2321 ::= <pointer-to-member-type>
2322 ::= <template-param>
2323 ::= <template-template-param> <template-args>
2324 ::= <substitution>
2325 ::= <CV-qualifiers> <type>
2326 ::= P <type>
2327 ::= R <type>
2328 ::= O <type> (C++0x)
2329 ::= C <type>
2330 ::= G <type>
2331 ::= U <source-name> <type>
2333 <builtin-type> ::= various one letter codes
2334 ::= u <source-name>
2337 CP_STATIC_IF_GLIBCPP_V3
2338 const struct demangle_builtin_type_info
2339 cplus_demangle_builtin_types[D_BUILTIN_TYPE_COUNT] =
2341 /* a */ { NL ("signed char"), NL ("signed char"), D_PRINT_DEFAULT },
2342 /* b */ { NL ("bool"), NL ("boolean"), D_PRINT_BOOL },
2343 /* c */ { NL ("char"), NL ("byte"), D_PRINT_DEFAULT },
2344 /* d */ { NL ("double"), NL ("double"), D_PRINT_FLOAT },
2345 /* e */ { NL ("long double"), NL ("long double"), D_PRINT_FLOAT },
2346 /* f */ { NL ("float"), NL ("float"), D_PRINT_FLOAT },
2347 /* g */ { NL ("__float128"), NL ("__float128"), D_PRINT_FLOAT },
2348 /* h */ { NL ("unsigned char"), NL ("unsigned char"), D_PRINT_DEFAULT },
2349 /* i */ { NL ("int"), NL ("int"), D_PRINT_INT },
2350 /* j */ { NL ("unsigned int"), NL ("unsigned"), D_PRINT_UNSIGNED },
2351 /* k */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
2352 /* l */ { NL ("long"), NL ("long"), D_PRINT_LONG },
2353 /* m */ { NL ("unsigned long"), NL ("unsigned long"), D_PRINT_UNSIGNED_LONG },
2354 /* n */ { NL ("__int128"), NL ("__int128"), D_PRINT_DEFAULT },
2355 /* o */ { NL ("unsigned __int128"), NL ("unsigned __int128"),
2356 D_PRINT_DEFAULT },
2357 /* p */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
2358 /* q */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
2359 /* r */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
2360 /* s */ { NL ("short"), NL ("short"), D_PRINT_DEFAULT },
2361 /* t */ { NL ("unsigned short"), NL ("unsigned short"), D_PRINT_DEFAULT },
2362 /* u */ { NULL, 0, NULL, 0, D_PRINT_DEFAULT },
2363 /* v */ { NL ("void"), NL ("void"), D_PRINT_VOID },
2364 /* w */ { NL ("wchar_t"), NL ("char"), D_PRINT_DEFAULT },
2365 /* x */ { NL ("long long"), NL ("long"), D_PRINT_LONG_LONG },
2366 /* y */ { NL ("unsigned long long"), NL ("unsigned long long"),
2367 D_PRINT_UNSIGNED_LONG_LONG },
2368 /* z */ { NL ("..."), NL ("..."), D_PRINT_DEFAULT },
2369 /* 26 */ { NL ("decimal32"), NL ("decimal32"), D_PRINT_DEFAULT },
2370 /* 27 */ { NL ("decimal64"), NL ("decimal64"), D_PRINT_DEFAULT },
2371 /* 28 */ { NL ("decimal128"), NL ("decimal128"), D_PRINT_DEFAULT },
2372 /* 29 */ { NL ("half"), NL ("half"), D_PRINT_FLOAT },
2373 /* 30 */ { NL ("char8_t"), NL ("char8_t"), D_PRINT_DEFAULT },
2374 /* 31 */ { NL ("char16_t"), NL ("char16_t"), D_PRINT_DEFAULT },
2375 /* 32 */ { NL ("char32_t"), NL ("char32_t"), D_PRINT_DEFAULT },
2376 /* 33 */ { NL ("decltype(nullptr)"), NL ("decltype(nullptr)"),
2377 D_PRINT_DEFAULT },
2380 CP_STATIC_IF_GLIBCPP_V3
2381 struct demangle_component *
2382 cplus_demangle_type (struct d_info *di)
2384 char peek;
2385 struct demangle_component *ret;
2386 int can_subst;
2388 /* The ABI specifies that when CV-qualifiers are used, the base type
2389 is substitutable, and the fully qualified type is substitutable,
2390 but the base type with a strict subset of the CV-qualifiers is
2391 not substitutable. The natural recursive implementation of the
2392 CV-qualifiers would cause subsets to be substitutable, so instead
2393 we pull them all off now.
2395 FIXME: The ABI says that order-insensitive vendor qualifiers
2396 should be handled in the same way, but we have no way to tell
2397 which vendor qualifiers are order-insensitive and which are
2398 order-sensitive. So we just assume that they are all
2399 order-sensitive. g++ 3.4 supports only one vendor qualifier,
2400 __vector, and it treats it as order-sensitive when mangling
2401 names. */
2403 if (next_is_type_qual (di))
2405 struct demangle_component **pret;
2407 pret = d_cv_qualifiers (di, &ret, 0);
2408 if (pret == NULL)
2409 return NULL;
2410 if (d_peek_char (di) == 'F')
2412 /* cv-qualifiers before a function type apply to 'this',
2413 so avoid adding the unqualified function type to
2414 the substitution list. */
2415 *pret = d_function_type (di);
2417 else
2418 *pret = cplus_demangle_type (di);
2419 if (!*pret)
2420 return NULL;
2421 if ((*pret)->type == DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS
2422 || (*pret)->type == DEMANGLE_COMPONENT_REFERENCE_THIS)
2424 /* Move the ref-qualifier outside the cv-qualifiers so that
2425 they are printed in the right order. */
2426 struct demangle_component *fn = d_left (*pret);
2427 d_left (*pret) = ret;
2428 ret = *pret;
2429 *pret = fn;
2431 if (! d_add_substitution (di, ret))
2432 return NULL;
2433 return ret;
2436 can_subst = 1;
2438 peek = d_peek_char (di);
2439 switch (peek)
2441 case 'a': case 'b': case 'c': case 'd': case 'e': case 'f': case 'g':
2442 case 'h': case 'i': case 'j': case 'l': case 'm': case 'n':
2443 case 'o': case 's': case 't':
2444 case 'v': case 'w': case 'x': case 'y': case 'z':
2445 ret = d_make_builtin_type (di,
2446 &cplus_demangle_builtin_types[peek - 'a']);
2447 di->expansion += ret->u.s_builtin.type->len;
2448 can_subst = 0;
2449 d_advance (di, 1);
2450 break;
2452 case 'u':
2453 d_advance (di, 1);
2454 ret = d_make_comp (di, DEMANGLE_COMPONENT_VENDOR_TYPE,
2455 d_source_name (di), NULL);
2456 break;
2458 case 'F':
2459 ret = d_function_type (di);
2460 break;
2462 case '0': case '1': case '2': case '3': case '4':
2463 case '5': case '6': case '7': case '8': case '9':
2464 case 'N':
2465 case 'Z':
2466 ret = d_class_enum_type (di);
2467 break;
2469 case 'A':
2470 ret = d_array_type (di);
2471 break;
2473 case 'M':
2474 ret = d_pointer_to_member_type (di);
2475 break;
2477 case 'T':
2478 ret = d_template_param (di);
2479 if (d_peek_char (di) == 'I')
2481 /* This may be <template-template-param> <template-args>.
2482 If this is the type for a conversion operator, we can
2483 have a <template-template-param> here only by following
2484 a derivation like this:
2486 <nested-name>
2487 -> <template-prefix> <template-args>
2488 -> <prefix> <template-unqualified-name> <template-args>
2489 -> <unqualified-name> <template-unqualified-name> <template-args>
2490 -> <source-name> <template-unqualified-name> <template-args>
2491 -> <source-name> <operator-name> <template-args>
2492 -> <source-name> cv <type> <template-args>
2493 -> <source-name> cv <template-template-param> <template-args> <template-args>
2495 where the <template-args> is followed by another.
2496 Otherwise, we must have a derivation like this:
2498 <nested-name>
2499 -> <template-prefix> <template-args>
2500 -> <prefix> <template-unqualified-name> <template-args>
2501 -> <unqualified-name> <template-unqualified-name> <template-args>
2502 -> <source-name> <template-unqualified-name> <template-args>
2503 -> <source-name> <operator-name> <template-args>
2504 -> <source-name> cv <type> <template-args>
2505 -> <source-name> cv <template-param> <template-args>
2507 where we need to leave the <template-args> to be processed
2508 by d_prefix (following the <template-prefix>).
2510 The <template-template-param> part is a substitution
2511 candidate. */
2512 if (! di->is_conversion)
2514 if (! d_add_substitution (di, ret))
2515 return NULL;
2516 ret = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, ret,
2517 d_template_args (di));
2519 else
2521 struct demangle_component *args;
2522 struct d_info_checkpoint checkpoint;
2524 d_checkpoint (di, &checkpoint);
2525 args = d_template_args (di);
2526 if (d_peek_char (di) == 'I')
2528 if (! d_add_substitution (di, ret))
2529 return NULL;
2530 ret = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, ret,
2531 args);
2533 else
2534 d_backtrack (di, &checkpoint);
2537 break;
2539 case 'S':
2540 /* If this is a special substitution, then it is the start of
2541 <class-enum-type>. */
2543 char peek_next;
2545 peek_next = d_peek_next_char (di);
2546 if (IS_DIGIT (peek_next)
2547 || peek_next == '_'
2548 || IS_UPPER (peek_next))
2550 ret = d_substitution (di, 0);
2551 /* The substituted name may have been a template name and
2552 may be followed by tepmlate args. */
2553 if (d_peek_char (di) == 'I')
2554 ret = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, ret,
2555 d_template_args (di));
2556 else
2557 can_subst = 0;
2559 else
2561 ret = d_class_enum_type (di);
2562 /* If the substitution was a complete type, then it is not
2563 a new substitution candidate. However, if the
2564 substitution was followed by template arguments, then
2565 the whole thing is a substitution candidate. */
2566 if (ret != NULL && ret->type == DEMANGLE_COMPONENT_SUB_STD)
2567 can_subst = 0;
2570 break;
2572 case 'O':
2573 d_advance (di, 1);
2574 ret = d_make_comp (di, DEMANGLE_COMPONENT_RVALUE_REFERENCE,
2575 cplus_demangle_type (di), NULL);
2576 break;
2578 case 'P':
2579 d_advance (di, 1);
2580 ret = d_make_comp (di, DEMANGLE_COMPONENT_POINTER,
2581 cplus_demangle_type (di), NULL);
2582 break;
2584 case 'R':
2585 d_advance (di, 1);
2586 ret = d_make_comp (di, DEMANGLE_COMPONENT_REFERENCE,
2587 cplus_demangle_type (di), NULL);
2588 break;
2590 case 'C':
2591 d_advance (di, 1);
2592 ret = d_make_comp (di, DEMANGLE_COMPONENT_COMPLEX,
2593 cplus_demangle_type (di), NULL);
2594 break;
2596 case 'G':
2597 d_advance (di, 1);
2598 ret = d_make_comp (di, DEMANGLE_COMPONENT_IMAGINARY,
2599 cplus_demangle_type (di), NULL);
2600 break;
2602 case 'U':
2603 d_advance (di, 1);
2604 ret = d_source_name (di);
2605 if (d_peek_char (di) == 'I')
2606 ret = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, ret,
2607 d_template_args (di));
2608 ret = d_make_comp (di, DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL,
2609 cplus_demangle_type (di), ret);
2610 break;
2612 case 'D':
2613 can_subst = 0;
2614 d_advance (di, 1);
2615 peek = d_next_char (di);
2616 switch (peek)
2618 case 'T':
2619 case 't':
2620 /* decltype (expression) */
2621 ret = d_make_comp (di, DEMANGLE_COMPONENT_DECLTYPE,
2622 d_expression (di), NULL);
2623 if (ret && d_next_char (di) != 'E')
2624 ret = NULL;
2625 can_subst = 1;
2626 break;
2628 case 'p':
2629 /* Pack expansion. */
2630 ret = d_make_comp (di, DEMANGLE_COMPONENT_PACK_EXPANSION,
2631 cplus_demangle_type (di), NULL);
2632 can_subst = 1;
2633 break;
2635 case 'a':
2636 /* auto */
2637 ret = d_make_name (di, "auto", 4);
2638 break;
2639 case 'c':
2640 /* decltype(auto) */
2641 ret = d_make_name (di, "decltype(auto)", 14);
2642 break;
2644 case 'f':
2645 /* 32-bit decimal floating point */
2646 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[26]);
2647 di->expansion += ret->u.s_builtin.type->len;
2648 break;
2649 case 'd':
2650 /* 64-bit DFP */
2651 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[27]);
2652 di->expansion += ret->u.s_builtin.type->len;
2653 break;
2654 case 'e':
2655 /* 128-bit DFP */
2656 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[28]);
2657 di->expansion += ret->u.s_builtin.type->len;
2658 break;
2659 case 'h':
2660 /* 16-bit half-precision FP */
2661 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[29]);
2662 di->expansion += ret->u.s_builtin.type->len;
2663 break;
2664 case 'u':
2665 /* char8_t */
2666 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[30]);
2667 di->expansion += ret->u.s_builtin.type->len;
2668 break;
2669 case 's':
2670 /* char16_t */
2671 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[31]);
2672 di->expansion += ret->u.s_builtin.type->len;
2673 break;
2674 case 'i':
2675 /* char32_t */
2676 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[32]);
2677 di->expansion += ret->u.s_builtin.type->len;
2678 break;
2680 case 'F':
2681 /* Fixed point types. DF<int bits><length><fract bits><sat> */
2682 ret = d_make_empty (di);
2683 ret->type = DEMANGLE_COMPONENT_FIXED_TYPE;
2684 if ((ret->u.s_fixed.accum = IS_DIGIT (d_peek_char (di))))
2685 /* For demangling we don't care about the bits. */
2686 d_number (di);
2687 ret->u.s_fixed.length = cplus_demangle_type (di);
2688 if (ret->u.s_fixed.length == NULL)
2689 return NULL;
2690 d_number (di);
2691 peek = d_next_char (di);
2692 ret->u.s_fixed.sat = (peek == 's');
2693 break;
2695 case 'v':
2696 ret = d_vector_type (di);
2697 can_subst = 1;
2698 break;
2700 case 'n':
2701 /* decltype(nullptr) */
2702 ret = d_make_builtin_type (di, &cplus_demangle_builtin_types[33]);
2703 di->expansion += ret->u.s_builtin.type->len;
2704 break;
2706 default:
2707 return NULL;
2709 break;
2711 default:
2712 return NULL;
2715 if (can_subst)
2717 if (! d_add_substitution (di, ret))
2718 return NULL;
2721 return ret;
2724 /* <CV-qualifiers> ::= [r] [V] [K] [Dx] */
2726 static struct demangle_component **
2727 d_cv_qualifiers (struct d_info *di,
2728 struct demangle_component **pret, int member_fn)
2730 struct demangle_component **pstart;
2731 char peek;
2733 pstart = pret;
2734 peek = d_peek_char (di);
2735 while (next_is_type_qual (di))
2737 enum demangle_component_type t;
2738 struct demangle_component *right = NULL;
2740 d_advance (di, 1);
2741 if (peek == 'r')
2743 t = (member_fn
2744 ? DEMANGLE_COMPONENT_RESTRICT_THIS
2745 : DEMANGLE_COMPONENT_RESTRICT);
2746 di->expansion += sizeof "restrict";
2748 else if (peek == 'V')
2750 t = (member_fn
2751 ? DEMANGLE_COMPONENT_VOLATILE_THIS
2752 : DEMANGLE_COMPONENT_VOLATILE);
2753 di->expansion += sizeof "volatile";
2755 else if (peek == 'K')
2757 t = (member_fn
2758 ? DEMANGLE_COMPONENT_CONST_THIS
2759 : DEMANGLE_COMPONENT_CONST);
2760 di->expansion += sizeof "const";
2762 else
2764 peek = d_next_char (di);
2765 if (peek == 'x')
2767 t = DEMANGLE_COMPONENT_TRANSACTION_SAFE;
2768 di->expansion += sizeof "transaction_safe";
2770 else if (peek == 'o'
2771 || peek == 'O')
2773 t = DEMANGLE_COMPONENT_NOEXCEPT;
2774 di->expansion += sizeof "noexcept";
2775 if (peek == 'O')
2777 right = d_expression (di);
2778 if (right == NULL)
2779 return NULL;
2780 if (! d_check_char (di, 'E'))
2781 return NULL;
2784 else if (peek == 'w')
2786 t = DEMANGLE_COMPONENT_THROW_SPEC;
2787 di->expansion += sizeof "throw";
2788 right = d_parmlist (di);
2789 if (right == NULL)
2790 return NULL;
2791 if (! d_check_char (di, 'E'))
2792 return NULL;
2794 else
2795 return NULL;
2798 *pret = d_make_comp (di, t, NULL, right);
2799 if (*pret == NULL)
2800 return NULL;
2801 pret = &d_left (*pret);
2803 peek = d_peek_char (di);
2806 if (!member_fn && peek == 'F')
2808 while (pstart != pret)
2810 switch ((*pstart)->type)
2812 case DEMANGLE_COMPONENT_RESTRICT:
2813 (*pstart)->type = DEMANGLE_COMPONENT_RESTRICT_THIS;
2814 break;
2815 case DEMANGLE_COMPONENT_VOLATILE:
2816 (*pstart)->type = DEMANGLE_COMPONENT_VOLATILE_THIS;
2817 break;
2818 case DEMANGLE_COMPONENT_CONST:
2819 (*pstart)->type = DEMANGLE_COMPONENT_CONST_THIS;
2820 break;
2821 default:
2822 break;
2824 pstart = &d_left (*pstart);
2828 return pret;
2831 /* <ref-qualifier> ::= R
2832 ::= O */
2834 static struct demangle_component *
2835 d_ref_qualifier (struct d_info *di, struct demangle_component *sub)
2837 struct demangle_component *ret = sub;
2838 char peek;
2840 peek = d_peek_char (di);
2841 if (peek == 'R' || peek == 'O')
2843 enum demangle_component_type t;
2844 if (peek == 'R')
2846 t = DEMANGLE_COMPONENT_REFERENCE_THIS;
2847 di->expansion += sizeof "&";
2849 else
2851 t = DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS;
2852 di->expansion += sizeof "&&";
2854 d_advance (di, 1);
2856 ret = d_make_comp (di, t, ret, NULL);
2859 return ret;
2862 /* <function-type> ::= F [Y] <bare-function-type> [<ref-qualifier>] [T] E */
2864 static struct demangle_component *
2865 d_function_type (struct d_info *di)
2867 struct demangle_component *ret = NULL;
2869 if ((di->options & DMGL_NO_RECURSE_LIMIT) == 0)
2871 if (di->recursion_level > DEMANGLE_RECURSION_LIMIT)
2872 /* FIXME: There ought to be a way to report
2873 that the recursion limit has been reached. */
2874 return NULL;
2876 di->recursion_level ++;
2879 if (d_check_char (di, 'F'))
2881 if (d_peek_char (di) == 'Y')
2883 /* Function has C linkage. We don't print this information.
2884 FIXME: We should print it in verbose mode. */
2885 d_advance (di, 1);
2887 ret = d_bare_function_type (di, 1);
2888 ret = d_ref_qualifier (di, ret);
2890 if (! d_check_char (di, 'E'))
2891 ret = NULL;
2894 if ((di->options & DMGL_NO_RECURSE_LIMIT) == 0)
2895 di->recursion_level --;
2896 return ret;
2899 /* <type>+ */
2901 static struct demangle_component *
2902 d_parmlist (struct d_info *di)
2904 struct demangle_component *tl;
2905 struct demangle_component **ptl;
2907 tl = NULL;
2908 ptl = &tl;
2909 while (1)
2911 struct demangle_component *type;
2913 char peek = d_peek_char (di);
2914 if (peek == '\0' || peek == 'E' || peek == '.')
2915 break;
2916 if ((peek == 'R' || peek == 'O')
2917 && d_peek_next_char (di) == 'E')
2918 /* Function ref-qualifier, not a ref prefix for a parameter type. */
2919 break;
2920 type = cplus_demangle_type (di);
2921 if (type == NULL)
2922 return NULL;
2923 *ptl = d_make_comp (di, DEMANGLE_COMPONENT_ARGLIST, type, NULL);
2924 if (*ptl == NULL)
2925 return NULL;
2926 ptl = &d_right (*ptl);
2929 /* There should be at least one parameter type besides the optional
2930 return type. A function which takes no arguments will have a
2931 single parameter type void. */
2932 if (tl == NULL)
2933 return NULL;
2935 /* If we have a single parameter type void, omit it. */
2936 if (d_right (tl) == NULL
2937 && d_left (tl)->type == DEMANGLE_COMPONENT_BUILTIN_TYPE
2938 && d_left (tl)->u.s_builtin.type->print == D_PRINT_VOID)
2940 di->expansion -= d_left (tl)->u.s_builtin.type->len;
2941 d_left (tl) = NULL;
2944 return tl;
2947 /* <bare-function-type> ::= [J]<type>+ */
2949 static struct demangle_component *
2950 d_bare_function_type (struct d_info *di, int has_return_type)
2952 struct demangle_component *return_type;
2953 struct demangle_component *tl;
2954 char peek;
2956 /* Detect special qualifier indicating that the first argument
2957 is the return type. */
2958 peek = d_peek_char (di);
2959 if (peek == 'J')
2961 d_advance (di, 1);
2962 has_return_type = 1;
2965 if (has_return_type)
2967 return_type = cplus_demangle_type (di);
2968 if (return_type == NULL)
2969 return NULL;
2971 else
2972 return_type = NULL;
2974 tl = d_parmlist (di);
2975 if (tl == NULL)
2976 return NULL;
2978 return d_make_comp (di, DEMANGLE_COMPONENT_FUNCTION_TYPE,
2979 return_type, tl);
2982 /* <class-enum-type> ::= <name> */
2984 static struct demangle_component *
2985 d_class_enum_type (struct d_info *di)
2987 return d_name (di);
2990 /* <array-type> ::= A <(positive dimension) number> _ <(element) type>
2991 ::= A [<(dimension) expression>] _ <(element) type>
2994 static struct demangle_component *
2995 d_array_type (struct d_info *di)
2997 char peek;
2998 struct demangle_component *dim;
3000 if (! d_check_char (di, 'A'))
3001 return NULL;
3003 peek = d_peek_char (di);
3004 if (peek == '_')
3005 dim = NULL;
3006 else if (IS_DIGIT (peek))
3008 const char *s;
3010 s = d_str (di);
3013 d_advance (di, 1);
3014 peek = d_peek_char (di);
3016 while (IS_DIGIT (peek));
3017 dim = d_make_name (di, s, d_str (di) - s);
3018 if (dim == NULL)
3019 return NULL;
3021 else
3023 dim = d_expression (di);
3024 if (dim == NULL)
3025 return NULL;
3028 if (! d_check_char (di, '_'))
3029 return NULL;
3031 return d_make_comp (di, DEMANGLE_COMPONENT_ARRAY_TYPE, dim,
3032 cplus_demangle_type (di));
3035 /* <vector-type> ::= Dv <number> _ <type>
3036 ::= Dv _ <expression> _ <type> */
3038 static struct demangle_component *
3039 d_vector_type (struct d_info *di)
3041 char peek;
3042 struct demangle_component *dim;
3044 peek = d_peek_char (di);
3045 if (peek == '_')
3047 d_advance (di, 1);
3048 dim = d_expression (di);
3050 else
3051 dim = d_number_component (di);
3053 if (dim == NULL)
3054 return NULL;
3056 if (! d_check_char (di, '_'))
3057 return NULL;
3059 return d_make_comp (di, DEMANGLE_COMPONENT_VECTOR_TYPE, dim,
3060 cplus_demangle_type (di));
3063 /* <pointer-to-member-type> ::= M <(class) type> <(member) type> */
3065 static struct demangle_component *
3066 d_pointer_to_member_type (struct d_info *di)
3068 struct demangle_component *cl;
3069 struct demangle_component *mem;
3071 if (! d_check_char (di, 'M'))
3072 return NULL;
3074 cl = cplus_demangle_type (di);
3075 if (cl == NULL)
3076 return NULL;
3078 /* The ABI says, "The type of a non-static member function is considered
3079 to be different, for the purposes of substitution, from the type of a
3080 namespace-scope or static member function whose type appears
3081 similar. The types of two non-static member functions are considered
3082 to be different, for the purposes of substitution, if the functions
3083 are members of different classes. In other words, for the purposes of
3084 substitution, the class of which the function is a member is
3085 considered part of the type of function."
3087 For a pointer to member function, this call to cplus_demangle_type
3088 will end up adding a (possibly qualified) non-member function type to
3089 the substitution table, which is not correct; however, the member
3090 function type will never be used in a substitution, so putting the
3091 wrong type in the substitution table is harmless. */
3093 mem = cplus_demangle_type (di);
3094 if (mem == NULL)
3095 return NULL;
3097 return d_make_comp (di, DEMANGLE_COMPONENT_PTRMEM_TYPE, cl, mem);
3100 /* <non-negative number> _ */
3102 static int
3103 d_compact_number (struct d_info *di)
3105 int num;
3106 if (d_peek_char (di) == '_')
3107 num = 0;
3108 else if (d_peek_char (di) == 'n')
3109 return -1;
3110 else
3111 num = d_number (di) + 1;
3113 if (num < 0 || ! d_check_char (di, '_'))
3114 return -1;
3115 return num;
3118 /* <template-param> ::= T_
3119 ::= T <(parameter-2 non-negative) number> _
3122 static struct demangle_component *
3123 d_template_param (struct d_info *di)
3125 int param;
3127 if (! d_check_char (di, 'T'))
3128 return NULL;
3130 param = d_compact_number (di);
3131 if (param < 0)
3132 return NULL;
3134 return d_make_template_param (di, param);
3137 /* <template-args> ::= I <template-arg>+ E */
3139 static struct demangle_component *
3140 d_template_args (struct d_info *di)
3142 if (d_peek_char (di) != 'I'
3143 && d_peek_char (di) != 'J')
3144 return NULL;
3145 d_advance (di, 1);
3147 return d_template_args_1 (di);
3150 /* <template-arg>* E */
3152 static struct demangle_component *
3153 d_template_args_1 (struct d_info *di)
3155 struct demangle_component *hold_last_name;
3156 struct demangle_component *al;
3157 struct demangle_component **pal;
3159 /* Preserve the last name we saw--don't let the template arguments
3160 clobber it, as that would give us the wrong name for a subsequent
3161 constructor or destructor. */
3162 hold_last_name = di->last_name;
3164 if (d_peek_char (di) == 'E')
3166 /* An argument pack can be empty. */
3167 d_advance (di, 1);
3168 return d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE_ARGLIST, NULL, NULL);
3171 al = NULL;
3172 pal = &al;
3173 while (1)
3175 struct demangle_component *a;
3177 a = d_template_arg (di);
3178 if (a == NULL)
3179 return NULL;
3181 *pal = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE_ARGLIST, a, NULL);
3182 if (*pal == NULL)
3183 return NULL;
3184 pal = &d_right (*pal);
3186 if (d_peek_char (di) == 'E')
3188 d_advance (di, 1);
3189 break;
3193 di->last_name = hold_last_name;
3195 return al;
3198 /* <template-arg> ::= <type>
3199 ::= X <expression> E
3200 ::= <expr-primary>
3203 static struct demangle_component *
3204 d_template_arg (struct d_info *di)
3206 struct demangle_component *ret;
3208 switch (d_peek_char (di))
3210 case 'X':
3211 d_advance (di, 1);
3212 ret = d_expression (di);
3213 if (! d_check_char (di, 'E'))
3214 return NULL;
3215 return ret;
3217 case 'L':
3218 return d_expr_primary (di);
3220 case 'I':
3221 case 'J':
3222 /* An argument pack. */
3223 return d_template_args (di);
3225 default:
3226 return cplus_demangle_type (di);
3230 /* Parse a sequence of expressions until we hit the terminator
3231 character. */
3233 static struct demangle_component *
3234 d_exprlist (struct d_info *di, char terminator)
3236 struct demangle_component *list = NULL;
3237 struct demangle_component **p = &list;
3239 if (d_peek_char (di) == terminator)
3241 d_advance (di, 1);
3242 return d_make_comp (di, DEMANGLE_COMPONENT_ARGLIST, NULL, NULL);
3245 while (1)
3247 struct demangle_component *arg = d_expression (di);
3248 if (arg == NULL)
3249 return NULL;
3251 *p = d_make_comp (di, DEMANGLE_COMPONENT_ARGLIST, arg, NULL);
3252 if (*p == NULL)
3253 return NULL;
3254 p = &d_right (*p);
3256 if (d_peek_char (di) == terminator)
3258 d_advance (di, 1);
3259 break;
3263 return list;
3266 /* Returns nonzero iff OP is an operator for a C++ cast: const_cast,
3267 dynamic_cast, static_cast or reinterpret_cast. */
3269 static int
3270 op_is_new_cast (struct demangle_component *op)
3272 const char *code = op->u.s_operator.op->code;
3273 return (code[1] == 'c'
3274 && (code[0] == 's' || code[0] == 'd'
3275 || code[0] == 'c' || code[0] == 'r'));
3278 /* <expression> ::= <(unary) operator-name> <expression>
3279 ::= <(binary) operator-name> <expression> <expression>
3280 ::= <(trinary) operator-name> <expression> <expression> <expression>
3281 ::= cl <expression>+ E
3282 ::= st <type>
3283 ::= <template-param>
3284 ::= sr <type> <unqualified-name>
3285 ::= sr <type> <unqualified-name> <template-args>
3286 ::= <expr-primary>
3289 static inline struct demangle_component *
3290 d_expression_1 (struct d_info *di)
3292 char peek;
3294 peek = d_peek_char (di);
3295 if (peek == 'L')
3296 return d_expr_primary (di);
3297 else if (peek == 'T')
3298 return d_template_param (di);
3299 else if (peek == 's' && d_peek_next_char (di) == 'r')
3301 struct demangle_component *type;
3302 struct demangle_component *name;
3304 d_advance (di, 2);
3305 type = cplus_demangle_type (di);
3306 name = d_unqualified_name (di);
3307 if (d_peek_char (di) != 'I')
3308 return d_make_comp (di, DEMANGLE_COMPONENT_QUAL_NAME, type, name);
3309 else
3310 return d_make_comp (di, DEMANGLE_COMPONENT_QUAL_NAME, type,
3311 d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, name,
3312 d_template_args (di)));
3314 else if (peek == 's' && d_peek_next_char (di) == 'p')
3316 d_advance (di, 2);
3317 return d_make_comp (di, DEMANGLE_COMPONENT_PACK_EXPANSION,
3318 d_expression_1 (di), NULL);
3320 else if (peek == 'f' && d_peek_next_char (di) == 'p')
3322 /* Function parameter used in a late-specified return type. */
3323 int index;
3324 d_advance (di, 2);
3325 if (d_peek_char (di) == 'T')
3327 /* 'this' parameter. */
3328 d_advance (di, 1);
3329 index = 0;
3331 else
3333 index = d_compact_number (di);
3334 if (index == INT_MAX || index == -1)
3335 return NULL;
3336 index++;
3338 return d_make_function_param (di, index);
3340 else if (IS_DIGIT (peek)
3341 || (peek == 'o' && d_peek_next_char (di) == 'n'))
3343 /* We can get an unqualified name as an expression in the case of
3344 a dependent function call, i.e. decltype(f(t)). */
3345 struct demangle_component *name;
3347 if (peek == 'o')
3348 /* operator-function-id, i.e. operator+(t). */
3349 d_advance (di, 2);
3351 name = d_unqualified_name (di);
3352 if (name == NULL)
3353 return NULL;
3354 if (d_peek_char (di) == 'I')
3355 return d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE, name,
3356 d_template_args (di));
3357 else
3358 return name;
3360 else if ((peek == 'i' || peek == 't')
3361 && d_peek_next_char (di) == 'l')
3363 /* Brace-enclosed initializer list, untyped or typed. */
3364 struct demangle_component *type = NULL;
3365 d_advance (di, 2);
3366 if (peek == 't')
3367 type = cplus_demangle_type (di);
3368 if (!d_peek_char (di) || !d_peek_next_char (di))
3369 return NULL;
3370 return d_make_comp (di, DEMANGLE_COMPONENT_INITIALIZER_LIST,
3371 type, d_exprlist (di, 'E'));
3373 else
3375 struct demangle_component *op;
3376 const char *code = NULL;
3377 int args;
3379 op = d_operator_name (di);
3380 if (op == NULL)
3381 return NULL;
3383 if (op->type == DEMANGLE_COMPONENT_OPERATOR)
3385 code = op->u.s_operator.op->code;
3386 di->expansion += op->u.s_operator.op->len - 2;
3387 if (strcmp (code, "st") == 0)
3388 return d_make_comp (di, DEMANGLE_COMPONENT_UNARY, op,
3389 cplus_demangle_type (di));
3392 switch (op->type)
3394 default:
3395 return NULL;
3396 case DEMANGLE_COMPONENT_OPERATOR:
3397 args = op->u.s_operator.op->args;
3398 break;
3399 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
3400 args = op->u.s_extended_operator.args;
3401 break;
3402 case DEMANGLE_COMPONENT_CAST:
3403 args = 1;
3404 break;
3407 switch (args)
3409 case 0:
3410 return d_make_comp (di, DEMANGLE_COMPONENT_NULLARY, op, NULL);
3412 case 1:
3414 struct demangle_component *operand;
3415 int suffix = 0;
3417 if (code && (code[0] == 'p' || code[0] == 'm')
3418 && code[1] == code[0])
3419 /* pp_ and mm_ are the prefix variants. */
3420 suffix = !d_check_char (di, '_');
3422 if (op->type == DEMANGLE_COMPONENT_CAST
3423 && d_check_char (di, '_'))
3424 operand = d_exprlist (di, 'E');
3425 else if (code && !strcmp (code, "sP"))
3426 operand = d_template_args_1 (di);
3427 else
3428 operand = d_expression_1 (di);
3430 if (suffix)
3431 /* Indicate the suffix variant for d_print_comp. */
3432 operand = d_make_comp (di, DEMANGLE_COMPONENT_BINARY_ARGS,
3433 operand, operand);
3435 return d_make_comp (di, DEMANGLE_COMPONENT_UNARY, op, operand);
3437 case 2:
3439 struct demangle_component *left;
3440 struct demangle_component *right;
3442 if (code == NULL)
3443 return NULL;
3444 if (op_is_new_cast (op))
3445 left = cplus_demangle_type (di);
3446 else if (code[0] == 'f')
3447 /* fold-expression. */
3448 left = d_operator_name (di);
3449 else
3450 left = d_expression_1 (di);
3451 if (!strcmp (code, "cl"))
3452 right = d_exprlist (di, 'E');
3453 else if (!strcmp (code, "dt") || !strcmp (code, "pt"))
3455 right = d_unqualified_name (di);
3456 if (d_peek_char (di) == 'I')
3457 right = d_make_comp (di, DEMANGLE_COMPONENT_TEMPLATE,
3458 right, d_template_args (di));
3460 else
3461 right = d_expression_1 (di);
3463 return d_make_comp (di, DEMANGLE_COMPONENT_BINARY, op,
3464 d_make_comp (di,
3465 DEMANGLE_COMPONENT_BINARY_ARGS,
3466 left, right));
3468 case 3:
3470 struct demangle_component *first;
3471 struct demangle_component *second;
3472 struct demangle_component *third;
3474 if (code == NULL)
3475 return NULL;
3476 else if (!strcmp (code, "qu"))
3478 /* ?: expression. */
3479 first = d_expression_1 (di);
3480 second = d_expression_1 (di);
3481 third = d_expression_1 (di);
3482 if (third == NULL)
3483 return NULL;
3485 else if (code[0] == 'f')
3487 /* fold-expression. */
3488 first = d_operator_name (di);
3489 second = d_expression_1 (di);
3490 third = d_expression_1 (di);
3491 if (third == NULL)
3492 return NULL;
3494 else if (code[0] == 'n')
3496 /* new-expression. */
3497 if (code[1] != 'w' && code[1] != 'a')
3498 return NULL;
3499 first = d_exprlist (di, '_');
3500 second = cplus_demangle_type (di);
3501 if (d_peek_char (di) == 'E')
3503 d_advance (di, 1);
3504 third = NULL;
3506 else if (d_peek_char (di) == 'p'
3507 && d_peek_next_char (di) == 'i')
3509 /* Parenthesized initializer. */
3510 d_advance (di, 2);
3511 third = d_exprlist (di, 'E');
3513 else if (d_peek_char (di) == 'i'
3514 && d_peek_next_char (di) == 'l')
3515 /* initializer-list. */
3516 third = d_expression_1 (di);
3517 else
3518 return NULL;
3520 else
3521 return NULL;
3522 return d_make_comp (di, DEMANGLE_COMPONENT_TRINARY, op,
3523 d_make_comp (di,
3524 DEMANGLE_COMPONENT_TRINARY_ARG1,
3525 first,
3526 d_make_comp (di,
3527 DEMANGLE_COMPONENT_TRINARY_ARG2,
3528 second, third)));
3530 default:
3531 return NULL;
3536 static struct demangle_component *
3537 d_expression (struct d_info *di)
3539 struct demangle_component *ret;
3540 int was_expression = di->is_expression;
3542 di->is_expression = 1;
3543 ret = d_expression_1 (di);
3544 di->is_expression = was_expression;
3545 return ret;
3548 /* <expr-primary> ::= L <type> <(value) number> E
3549 ::= L <type> <(value) float> E
3550 ::= L <mangled-name> E
3553 static struct demangle_component *
3554 d_expr_primary (struct d_info *di)
3556 struct demangle_component *ret;
3558 if (! d_check_char (di, 'L'))
3559 return NULL;
3560 if (d_peek_char (di) == '_'
3561 /* Workaround for G++ bug; see comment in write_template_arg. */
3562 || d_peek_char (di) == 'Z')
3563 ret = cplus_demangle_mangled_name (di, 0);
3564 else
3566 struct demangle_component *type;
3567 enum demangle_component_type t;
3568 const char *s;
3570 type = cplus_demangle_type (di);
3571 if (type == NULL)
3572 return NULL;
3574 /* If we have a type we know how to print, we aren't going to
3575 print the type name itself. */
3576 if (type->type == DEMANGLE_COMPONENT_BUILTIN_TYPE
3577 && type->u.s_builtin.type->print != D_PRINT_DEFAULT)
3578 di->expansion -= type->u.s_builtin.type->len;
3580 /* Rather than try to interpret the literal value, we just
3581 collect it as a string. Note that it's possible to have a
3582 floating point literal here. The ABI specifies that the
3583 format of such literals is machine independent. That's fine,
3584 but what's not fine is that versions of g++ up to 3.2 with
3585 -fabi-version=1 used upper case letters in the hex constant,
3586 and dumped out gcc's internal representation. That makes it
3587 hard to tell where the constant ends, and hard to dump the
3588 constant in any readable form anyhow. We don't attempt to
3589 handle these cases. */
3591 t = DEMANGLE_COMPONENT_LITERAL;
3592 if (d_peek_char (di) == 'n')
3594 t = DEMANGLE_COMPONENT_LITERAL_NEG;
3595 d_advance (di, 1);
3597 s = d_str (di);
3598 while (d_peek_char (di) != 'E')
3600 if (d_peek_char (di) == '\0')
3601 return NULL;
3602 d_advance (di, 1);
3604 ret = d_make_comp (di, t, type, d_make_name (di, s, d_str (di) - s));
3606 if (! d_check_char (di, 'E'))
3607 return NULL;
3608 return ret;
3611 /* <local-name> ::= Z <(function) encoding> E <(entity) name> [<discriminator>]
3612 ::= Z <(function) encoding> E s [<discriminator>]
3613 ::= Z <(function) encoding> E d [<parameter> number>] _ <entity name>
3616 static struct demangle_component *
3617 d_local_name (struct d_info *di)
3619 struct demangle_component *function;
3620 struct demangle_component *name;
3622 if (! d_check_char (di, 'Z'))
3623 return NULL;
3625 function = d_encoding (di, 0);
3626 if (!function)
3627 return NULL;
3629 if (! d_check_char (di, 'E'))
3630 return NULL;
3632 if (d_peek_char (di) == 's')
3634 d_advance (di, 1);
3635 if (! d_discriminator (di))
3636 return NULL;
3637 name = d_make_name (di, "string literal", sizeof "string literal" - 1);
3639 else
3641 int num = -1;
3643 if (d_peek_char (di) == 'd')
3645 /* Default argument scope: d <number> _. */
3646 d_advance (di, 1);
3647 num = d_compact_number (di);
3648 if (num < 0)
3649 return NULL;
3652 name = d_name (di);
3654 if (name
3655 /* Lambdas and unnamed types have internal discriminators
3656 and are not functions. */
3657 && name->type != DEMANGLE_COMPONENT_LAMBDA
3658 && name->type != DEMANGLE_COMPONENT_UNNAMED_TYPE)
3660 /* Read and ignore an optional discriminator. */
3661 if (! d_discriminator (di))
3662 return NULL;
3665 if (num >= 0)
3666 name = d_make_default_arg (di, num, name);
3669 /* Elide the return type of the containing function so as to not
3670 confuse the user thinking it is the return type of whatever local
3671 function we might be containing. */
3672 if (function->type == DEMANGLE_COMPONENT_TYPED_NAME
3673 && d_right (function)->type == DEMANGLE_COMPONENT_FUNCTION_TYPE)
3674 d_left (d_right (function)) = NULL;
3676 return d_make_comp (di, DEMANGLE_COMPONENT_LOCAL_NAME, function, name);
3679 /* <discriminator> ::= _ <number> # when number < 10
3680 ::= __ <number> _ # when number >= 10
3682 <discriminator> ::= _ <number> # when number >=10
3683 is also accepted to support gcc versions that wrongly mangled that way.
3685 We demangle the discriminator, but we don't print it out. FIXME:
3686 We should print it out in verbose mode. */
3688 static int
3689 d_discriminator (struct d_info *di)
3691 int discrim, num_underscores = 1;
3693 if (d_peek_char (di) != '_')
3694 return 1;
3695 d_advance (di, 1);
3696 if (d_peek_char (di) == '_')
3698 ++num_underscores;
3699 d_advance (di, 1);
3702 discrim = d_number (di);
3703 if (discrim < 0)
3704 return 0;
3705 if (num_underscores > 1 && discrim >= 10)
3707 if (d_peek_char (di) == '_')
3708 d_advance (di, 1);
3709 else
3710 return 0;
3713 return 1;
3716 /* <closure-type-name> ::= Ul <lambda-sig> E [ <nonnegative number> ] _ */
3718 static struct demangle_component *
3719 d_lambda (struct d_info *di)
3721 struct demangle_component *tl;
3722 struct demangle_component *ret;
3723 int num;
3725 if (! d_check_char (di, 'U'))
3726 return NULL;
3727 if (! d_check_char (di, 'l'))
3728 return NULL;
3730 tl = d_parmlist (di);
3731 if (tl == NULL)
3732 return NULL;
3734 if (! d_check_char (di, 'E'))
3735 return NULL;
3737 num = d_compact_number (di);
3738 if (num < 0)
3739 return NULL;
3741 ret = d_make_empty (di);
3742 if (ret)
3744 ret->type = DEMANGLE_COMPONENT_LAMBDA;
3745 ret->u.s_unary_num.sub = tl;
3746 ret->u.s_unary_num.num = num;
3749 if (! d_add_substitution (di, ret))
3750 return NULL;
3752 return ret;
3755 /* <unnamed-type-name> ::= Ut [ <nonnegative number> ] _ */
3757 static struct demangle_component *
3758 d_unnamed_type (struct d_info *di)
3760 struct demangle_component *ret;
3761 int num;
3763 if (! d_check_char (di, 'U'))
3764 return NULL;
3765 if (! d_check_char (di, 't'))
3766 return NULL;
3768 num = d_compact_number (di);
3769 if (num < 0)
3770 return NULL;
3772 ret = d_make_empty (di);
3773 if (ret)
3775 ret->type = DEMANGLE_COMPONENT_UNNAMED_TYPE;
3776 ret->u.s_number.number = num;
3779 if (! d_add_substitution (di, ret))
3780 return NULL;
3782 return ret;
3785 /* <clone-suffix> ::= [ . <clone-type-identifier> ] [ . <nonnegative number> ]*
3788 static struct demangle_component *
3789 d_clone_suffix (struct d_info *di, struct demangle_component *encoding)
3791 const char *suffix = d_str (di);
3792 const char *pend = suffix;
3793 struct demangle_component *n;
3795 if (*pend == '.' && (IS_LOWER (pend[1]) || pend[1] == '_'))
3797 pend += 2;
3798 while (IS_LOWER (*pend) || *pend == '_')
3799 ++pend;
3801 while (*pend == '.' && IS_DIGIT (pend[1]))
3803 pend += 2;
3804 while (IS_DIGIT (*pend))
3805 ++pend;
3807 d_advance (di, pend - suffix);
3808 n = d_make_name (di, suffix, pend - suffix);
3809 return d_make_comp (di, DEMANGLE_COMPONENT_CLONE, encoding, n);
3812 /* Add a new substitution. */
3814 static int
3815 d_add_substitution (struct d_info *di, struct demangle_component *dc)
3817 if (dc == NULL)
3818 return 0;
3819 if (di->next_sub >= di->num_subs)
3820 return 0;
3821 di->subs[di->next_sub] = dc;
3822 ++di->next_sub;
3823 return 1;
3826 /* <substitution> ::= S <seq-id> _
3827 ::= S_
3828 ::= St
3829 ::= Sa
3830 ::= Sb
3831 ::= Ss
3832 ::= Si
3833 ::= So
3834 ::= Sd
3836 If PREFIX is non-zero, then this type is being used as a prefix in
3837 a qualified name. In this case, for the standard substitutions, we
3838 need to check whether we are being used as a prefix for a
3839 constructor or destructor, and return a full template name.
3840 Otherwise we will get something like std::iostream::~iostream()
3841 which does not correspond particularly well to any function which
3842 actually appears in the source.
3845 static const struct d_standard_sub_info standard_subs[] =
3847 { 't', NL ("std"),
3848 NL ("std"),
3849 NULL, 0 },
3850 { 'a', NL ("std::allocator"),
3851 NL ("std::allocator"),
3852 NL ("allocator") },
3853 { 'b', NL ("std::basic_string"),
3854 NL ("std::basic_string"),
3855 NL ("basic_string") },
3856 { 's', NL ("std::string"),
3857 NL ("std::basic_string<char, std::char_traits<char>, std::allocator<char> >"),
3858 NL ("basic_string") },
3859 { 'i', NL ("std::istream"),
3860 NL ("std::basic_istream<char, std::char_traits<char> >"),
3861 NL ("basic_istream") },
3862 { 'o', NL ("std::ostream"),
3863 NL ("std::basic_ostream<char, std::char_traits<char> >"),
3864 NL ("basic_ostream") },
3865 { 'd', NL ("std::iostream"),
3866 NL ("std::basic_iostream<char, std::char_traits<char> >"),
3867 NL ("basic_iostream") }
3870 static struct demangle_component *
3871 d_substitution (struct d_info *di, int prefix)
3873 char c;
3875 if (! d_check_char (di, 'S'))
3876 return NULL;
3878 c = d_next_char (di);
3879 if (c == '_' || IS_DIGIT (c) || IS_UPPER (c))
3881 unsigned int id;
3883 id = 0;
3884 if (c != '_')
3888 unsigned int new_id;
3890 if (IS_DIGIT (c))
3891 new_id = id * 36 + c - '0';
3892 else if (IS_UPPER (c))
3893 new_id = id * 36 + c - 'A' + 10;
3894 else
3895 return NULL;
3896 if (new_id < id)
3897 return NULL;
3898 id = new_id;
3899 c = d_next_char (di);
3901 while (c != '_');
3903 ++id;
3906 if (id >= (unsigned int) di->next_sub)
3907 return NULL;
3909 return di->subs[id];
3911 else
3913 int verbose;
3914 const struct d_standard_sub_info *p;
3915 const struct d_standard_sub_info *pend;
3917 verbose = (di->options & DMGL_VERBOSE) != 0;
3918 if (! verbose && prefix)
3920 char peek;
3922 peek = d_peek_char (di);
3923 if (peek == 'C' || peek == 'D')
3924 verbose = 1;
3927 pend = (&standard_subs[0]
3928 + sizeof standard_subs / sizeof standard_subs[0]);
3929 for (p = &standard_subs[0]; p < pend; ++p)
3931 if (c == p->code)
3933 const char *s;
3934 int len;
3935 struct demangle_component *dc;
3937 if (p->set_last_name != NULL)
3938 di->last_name = d_make_sub (di, p->set_last_name,
3939 p->set_last_name_len);
3940 if (verbose)
3942 s = p->full_expansion;
3943 len = p->full_len;
3945 else
3947 s = p->simple_expansion;
3948 len = p->simple_len;
3950 di->expansion += len;
3951 dc = d_make_sub (di, s, len);
3952 if (d_peek_char (di) == 'B')
3954 /* If there are ABI tags on the abbreviation, it becomes
3955 a substitution candidate. */
3956 dc = d_abi_tags (di, dc);
3957 if (! d_add_substitution (di, dc))
3958 return NULL;
3960 return dc;
3964 return NULL;
3968 static void
3969 d_checkpoint (struct d_info *di, struct d_info_checkpoint *checkpoint)
3971 checkpoint->n = di->n;
3972 checkpoint->next_comp = di->next_comp;
3973 checkpoint->next_sub = di->next_sub;
3974 checkpoint->expansion = di->expansion;
3977 static void
3978 d_backtrack (struct d_info *di, struct d_info_checkpoint *checkpoint)
3980 di->n = checkpoint->n;
3981 di->next_comp = checkpoint->next_comp;
3982 di->next_sub = checkpoint->next_sub;
3983 di->expansion = checkpoint->expansion;
3986 /* Initialize a growable string. */
3988 static void
3989 d_growable_string_init (struct d_growable_string *dgs, size_t estimate)
3991 dgs->buf = NULL;
3992 dgs->len = 0;
3993 dgs->alc = 0;
3994 dgs->allocation_failure = 0;
3996 if (estimate > 0)
3997 d_growable_string_resize (dgs, estimate);
4000 /* Grow a growable string to a given size. */
4002 static inline void
4003 d_growable_string_resize (struct d_growable_string *dgs, size_t need)
4005 size_t newalc;
4006 char *newbuf;
4008 if (dgs->allocation_failure)
4009 return;
4011 /* Start allocation at two bytes to avoid any possibility of confusion
4012 with the special value of 1 used as a return in *palc to indicate
4013 allocation failures. */
4014 newalc = dgs->alc > 0 ? dgs->alc : 2;
4015 while (newalc < need)
4016 newalc <<= 1;
4018 newbuf = (char *) realloc (dgs->buf, newalc);
4019 if (newbuf == NULL)
4021 free (dgs->buf);
4022 dgs->buf = NULL;
4023 dgs->len = 0;
4024 dgs->alc = 0;
4025 dgs->allocation_failure = 1;
4026 return;
4028 dgs->buf = newbuf;
4029 dgs->alc = newalc;
4032 /* Append a buffer to a growable string. */
4034 static inline void
4035 d_growable_string_append_buffer (struct d_growable_string *dgs,
4036 const char *s, size_t l)
4038 size_t need;
4040 need = dgs->len + l + 1;
4041 if (need > dgs->alc)
4042 d_growable_string_resize (dgs, need);
4044 if (dgs->allocation_failure)
4045 return;
4047 memcpy (dgs->buf + dgs->len, s, l);
4048 dgs->buf[dgs->len + l] = '\0';
4049 dgs->len += l;
4052 /* Bridge growable strings to the callback mechanism. */
4054 static void
4055 d_growable_string_callback_adapter (const char *s, size_t l, void *opaque)
4057 struct d_growable_string *dgs = (struct d_growable_string*) opaque;
4059 d_growable_string_append_buffer (dgs, s, l);
4062 /* Walk the tree, counting the number of templates encountered, and
4063 the number of times a scope might be saved. These counts will be
4064 used to allocate data structures for d_print_comp, so the logic
4065 here must mirror the logic d_print_comp will use. It is not
4066 important that the resulting numbers are exact, so long as they
4067 are larger than the actual numbers encountered. */
4069 static void
4070 d_count_templates_scopes (struct d_print_info *dpi,
4071 const struct demangle_component *dc)
4073 if (dc == NULL)
4074 return;
4076 switch (dc->type)
4078 case DEMANGLE_COMPONENT_NAME:
4079 case DEMANGLE_COMPONENT_TEMPLATE_PARAM:
4080 case DEMANGLE_COMPONENT_FUNCTION_PARAM:
4081 case DEMANGLE_COMPONENT_SUB_STD:
4082 case DEMANGLE_COMPONENT_BUILTIN_TYPE:
4083 case DEMANGLE_COMPONENT_OPERATOR:
4084 case DEMANGLE_COMPONENT_CHARACTER:
4085 case DEMANGLE_COMPONENT_NUMBER:
4086 case DEMANGLE_COMPONENT_UNNAMED_TYPE:
4087 break;
4089 case DEMANGLE_COMPONENT_TEMPLATE:
4090 dpi->num_copy_templates++;
4091 goto recurse_left_right;
4093 case DEMANGLE_COMPONENT_REFERENCE:
4094 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
4095 if (d_left (dc)->type == DEMANGLE_COMPONENT_TEMPLATE_PARAM)
4096 dpi->num_saved_scopes++;
4097 goto recurse_left_right;
4099 case DEMANGLE_COMPONENT_QUAL_NAME:
4100 case DEMANGLE_COMPONENT_LOCAL_NAME:
4101 case DEMANGLE_COMPONENT_TYPED_NAME:
4102 case DEMANGLE_COMPONENT_VTABLE:
4103 case DEMANGLE_COMPONENT_VTT:
4104 case DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE:
4105 case DEMANGLE_COMPONENT_TYPEINFO:
4106 case DEMANGLE_COMPONENT_TYPEINFO_NAME:
4107 case DEMANGLE_COMPONENT_TYPEINFO_FN:
4108 case DEMANGLE_COMPONENT_THUNK:
4109 case DEMANGLE_COMPONENT_VIRTUAL_THUNK:
4110 case DEMANGLE_COMPONENT_COVARIANT_THUNK:
4111 case DEMANGLE_COMPONENT_JAVA_CLASS:
4112 case DEMANGLE_COMPONENT_GUARD:
4113 case DEMANGLE_COMPONENT_TLS_INIT:
4114 case DEMANGLE_COMPONENT_TLS_WRAPPER:
4115 case DEMANGLE_COMPONENT_REFTEMP:
4116 case DEMANGLE_COMPONENT_HIDDEN_ALIAS:
4117 case DEMANGLE_COMPONENT_RESTRICT:
4118 case DEMANGLE_COMPONENT_VOLATILE:
4119 case DEMANGLE_COMPONENT_CONST:
4120 case DEMANGLE_COMPONENT_RESTRICT_THIS:
4121 case DEMANGLE_COMPONENT_VOLATILE_THIS:
4122 case DEMANGLE_COMPONENT_CONST_THIS:
4123 case DEMANGLE_COMPONENT_REFERENCE_THIS:
4124 case DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS:
4125 case DEMANGLE_COMPONENT_TRANSACTION_SAFE:
4126 case DEMANGLE_COMPONENT_NOEXCEPT:
4127 case DEMANGLE_COMPONENT_THROW_SPEC:
4128 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
4129 case DEMANGLE_COMPONENT_POINTER:
4130 case DEMANGLE_COMPONENT_COMPLEX:
4131 case DEMANGLE_COMPONENT_IMAGINARY:
4132 case DEMANGLE_COMPONENT_VENDOR_TYPE:
4133 case DEMANGLE_COMPONENT_FUNCTION_TYPE:
4134 case DEMANGLE_COMPONENT_ARRAY_TYPE:
4135 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
4136 case DEMANGLE_COMPONENT_VECTOR_TYPE:
4137 case DEMANGLE_COMPONENT_ARGLIST:
4138 case DEMANGLE_COMPONENT_TEMPLATE_ARGLIST:
4139 case DEMANGLE_COMPONENT_TPARM_OBJ:
4140 case DEMANGLE_COMPONENT_INITIALIZER_LIST:
4141 case DEMANGLE_COMPONENT_CAST:
4142 case DEMANGLE_COMPONENT_CONVERSION:
4143 case DEMANGLE_COMPONENT_NULLARY:
4144 case DEMANGLE_COMPONENT_UNARY:
4145 case DEMANGLE_COMPONENT_BINARY:
4146 case DEMANGLE_COMPONENT_BINARY_ARGS:
4147 case DEMANGLE_COMPONENT_TRINARY:
4148 case DEMANGLE_COMPONENT_TRINARY_ARG1:
4149 case DEMANGLE_COMPONENT_TRINARY_ARG2:
4150 case DEMANGLE_COMPONENT_LITERAL:
4151 case DEMANGLE_COMPONENT_LITERAL_NEG:
4152 case DEMANGLE_COMPONENT_JAVA_RESOURCE:
4153 case DEMANGLE_COMPONENT_COMPOUND_NAME:
4154 case DEMANGLE_COMPONENT_DECLTYPE:
4155 case DEMANGLE_COMPONENT_TRANSACTION_CLONE:
4156 case DEMANGLE_COMPONENT_NONTRANSACTION_CLONE:
4157 case DEMANGLE_COMPONENT_PACK_EXPANSION:
4158 case DEMANGLE_COMPONENT_TAGGED_NAME:
4159 case DEMANGLE_COMPONENT_CLONE:
4160 recurse_left_right:
4161 /* PR 89394 - Check for too much recursion. */
4162 if (dpi->recursion > DEMANGLE_RECURSION_LIMIT)
4163 /* FIXME: There ought to be a way to report to the
4164 user that the recursion limit has been reached. */
4165 return;
4167 ++ dpi->recursion;
4168 d_count_templates_scopes (dpi, d_left (dc));
4169 d_count_templates_scopes (dpi, d_right (dc));
4170 -- dpi->recursion;
4171 break;
4173 case DEMANGLE_COMPONENT_CTOR:
4174 d_count_templates_scopes (dpi, dc->u.s_ctor.name);
4175 break;
4177 case DEMANGLE_COMPONENT_DTOR:
4178 d_count_templates_scopes (dpi, dc->u.s_dtor.name);
4179 break;
4181 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
4182 d_count_templates_scopes (dpi, dc->u.s_extended_operator.name);
4183 break;
4185 case DEMANGLE_COMPONENT_FIXED_TYPE:
4186 d_count_templates_scopes (dpi, dc->u.s_fixed.length);
4187 break;
4189 case DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS:
4190 case DEMANGLE_COMPONENT_GLOBAL_DESTRUCTORS:
4191 d_count_templates_scopes (dpi, d_left (dc));
4192 break;
4194 case DEMANGLE_COMPONENT_LAMBDA:
4195 case DEMANGLE_COMPONENT_DEFAULT_ARG:
4196 d_count_templates_scopes (dpi, dc->u.s_unary_num.sub);
4197 break;
4201 /* Initialize a print information structure. */
4203 static void
4204 d_print_init (struct d_print_info *dpi, demangle_callbackref callback,
4205 void *opaque, const struct demangle_component *dc)
4207 dpi->len = 0;
4208 dpi->last_char = '\0';
4209 dpi->templates = NULL;
4210 dpi->modifiers = NULL;
4211 dpi->pack_index = 0;
4212 dpi->flush_count = 0;
4214 dpi->callback = callback;
4215 dpi->opaque = opaque;
4217 dpi->demangle_failure = 0;
4218 dpi->recursion = 0;
4219 dpi->is_lambda_arg = 0;
4221 dpi->component_stack = NULL;
4223 dpi->saved_scopes = NULL;
4224 dpi->next_saved_scope = 0;
4225 dpi->num_saved_scopes = 0;
4227 dpi->copy_templates = NULL;
4228 dpi->next_copy_template = 0;
4229 dpi->num_copy_templates = 0;
4231 d_count_templates_scopes (dpi, dc);
4232 /* If we did not reach the recursion limit, then reset the
4233 current recursion value back to 0, so that we can print
4234 the templates. */
4235 if (dpi->recursion < DEMANGLE_RECURSION_LIMIT)
4236 dpi->recursion = 0;
4237 dpi->num_copy_templates *= dpi->num_saved_scopes;
4239 dpi->current_template = NULL;
4242 /* Indicate that an error occurred during printing, and test for error. */
4244 static inline void
4245 d_print_error (struct d_print_info *dpi)
4247 dpi->demangle_failure = 1;
4250 static inline int
4251 d_print_saw_error (struct d_print_info *dpi)
4253 return dpi->demangle_failure != 0;
4256 /* Flush buffered characters to the callback. */
4258 static inline void
4259 d_print_flush (struct d_print_info *dpi)
4261 dpi->buf[dpi->len] = '\0';
4262 dpi->callback (dpi->buf, dpi->len, dpi->opaque);
4263 dpi->len = 0;
4264 dpi->flush_count++;
4267 /* Append characters and buffers for printing. */
4269 static inline void
4270 d_append_char (struct d_print_info *dpi, char c)
4272 if (dpi->len == sizeof (dpi->buf) - 1)
4273 d_print_flush (dpi);
4275 dpi->buf[dpi->len++] = c;
4276 dpi->last_char = c;
4279 static inline void
4280 d_append_buffer (struct d_print_info *dpi, const char *s, size_t l)
4282 size_t i;
4284 for (i = 0; i < l; i++)
4285 d_append_char (dpi, s[i]);
4288 static inline void
4289 d_append_string (struct d_print_info *dpi, const char *s)
4291 d_append_buffer (dpi, s, strlen (s));
4294 static inline void
4295 d_append_num (struct d_print_info *dpi, int l)
4297 char buf[25];
4298 sprintf (buf,"%d", l);
4299 d_append_string (dpi, buf);
4302 static inline char
4303 d_last_char (struct d_print_info *dpi)
4305 return dpi->last_char;
4308 /* Turn components into a human readable string. OPTIONS is the
4309 options bits passed to the demangler. DC is the tree to print.
4310 CALLBACK is a function to call to flush demangled string segments
4311 as they fill the intermediate buffer, and OPAQUE is a generalized
4312 callback argument. On success, this returns 1. On failure,
4313 it returns 0, indicating a bad parse. It does not use heap
4314 memory to build an output string, so cannot encounter memory
4315 allocation failure. */
4317 CP_STATIC_IF_GLIBCPP_V3
4319 cplus_demangle_print_callback (int options,
4320 struct demangle_component *dc,
4321 demangle_callbackref callback, void *opaque)
4323 struct d_print_info dpi;
4325 d_print_init (&dpi, callback, opaque, dc);
4328 #ifdef CP_DYNAMIC_ARRAYS
4329 /* Avoid zero-length VLAs, which are prohibited by the C99 standard
4330 and flagged as errors by Address Sanitizer. */
4331 __extension__ struct d_saved_scope scopes[(dpi.num_saved_scopes > 0)
4332 ? dpi.num_saved_scopes : 1];
4333 __extension__ struct d_print_template temps[(dpi.num_copy_templates > 0)
4334 ? dpi.num_copy_templates : 1];
4336 dpi.saved_scopes = scopes;
4337 dpi.copy_templates = temps;
4338 #else
4339 dpi.saved_scopes = alloca (dpi.num_saved_scopes
4340 * sizeof (*dpi.saved_scopes));
4341 dpi.copy_templates = alloca (dpi.num_copy_templates
4342 * sizeof (*dpi.copy_templates));
4343 #endif
4345 d_print_comp (&dpi, options, dc);
4348 d_print_flush (&dpi);
4350 return ! d_print_saw_error (&dpi);
4353 /* Turn components into a human readable string. OPTIONS is the
4354 options bits passed to the demangler. DC is the tree to print.
4355 ESTIMATE is a guess at the length of the result. This returns a
4356 string allocated by malloc, or NULL on error. On success, this
4357 sets *PALC to the size of the allocated buffer. On failure, this
4358 sets *PALC to 0 for a bad parse, or to 1 for a memory allocation
4359 failure. */
4361 CP_STATIC_IF_GLIBCPP_V3
4362 char *
4363 cplus_demangle_print (int options, struct demangle_component *dc,
4364 int estimate, size_t *palc)
4366 struct d_growable_string dgs;
4368 d_growable_string_init (&dgs, estimate);
4370 if (! cplus_demangle_print_callback (options, dc,
4371 d_growable_string_callback_adapter,
4372 &dgs))
4374 free (dgs.buf);
4375 *palc = 0;
4376 return NULL;
4379 *palc = dgs.allocation_failure ? 1 : dgs.alc;
4380 return dgs.buf;
4383 /* Returns the I'th element of the template arglist ARGS, or NULL on
4384 failure. If I is negative, return the entire arglist. */
4386 static struct demangle_component *
4387 d_index_template_argument (struct demangle_component *args, int i)
4389 struct demangle_component *a;
4391 if (i < 0)
4392 /* Print the whole argument pack. */
4393 return args;
4395 for (a = args;
4396 a != NULL;
4397 a = d_right (a))
4399 if (a->type != DEMANGLE_COMPONENT_TEMPLATE_ARGLIST)
4400 return NULL;
4401 if (i <= 0)
4402 break;
4403 --i;
4405 if (i != 0 || a == NULL)
4406 return NULL;
4408 return d_left (a);
4411 /* Returns the template argument from the current context indicated by DC,
4412 which is a DEMANGLE_COMPONENT_TEMPLATE_PARAM, or NULL. */
4414 static struct demangle_component *
4415 d_lookup_template_argument (struct d_print_info *dpi,
4416 const struct demangle_component *dc)
4418 if (dpi->templates == NULL)
4420 d_print_error (dpi);
4421 return NULL;
4424 return d_index_template_argument
4425 (d_right (dpi->templates->template_decl),
4426 dc->u.s_number.number);
4429 /* Returns a template argument pack used in DC (any will do), or NULL. */
4431 static struct demangle_component *
4432 d_find_pack (struct d_print_info *dpi,
4433 const struct demangle_component *dc)
4435 struct demangle_component *a;
4436 if (dc == NULL)
4437 return NULL;
4439 switch (dc->type)
4441 case DEMANGLE_COMPONENT_TEMPLATE_PARAM:
4442 a = d_lookup_template_argument (dpi, dc);
4443 if (a && a->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST)
4444 return a;
4445 return NULL;
4447 case DEMANGLE_COMPONENT_PACK_EXPANSION:
4448 return NULL;
4450 case DEMANGLE_COMPONENT_LAMBDA:
4451 case DEMANGLE_COMPONENT_NAME:
4452 case DEMANGLE_COMPONENT_TAGGED_NAME:
4453 case DEMANGLE_COMPONENT_OPERATOR:
4454 case DEMANGLE_COMPONENT_BUILTIN_TYPE:
4455 case DEMANGLE_COMPONENT_SUB_STD:
4456 case DEMANGLE_COMPONENT_CHARACTER:
4457 case DEMANGLE_COMPONENT_FUNCTION_PARAM:
4458 case DEMANGLE_COMPONENT_UNNAMED_TYPE:
4459 case DEMANGLE_COMPONENT_FIXED_TYPE:
4460 case DEMANGLE_COMPONENT_DEFAULT_ARG:
4461 case DEMANGLE_COMPONENT_NUMBER:
4462 return NULL;
4464 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
4465 return d_find_pack (dpi, dc->u.s_extended_operator.name);
4466 case DEMANGLE_COMPONENT_CTOR:
4467 return d_find_pack (dpi, dc->u.s_ctor.name);
4468 case DEMANGLE_COMPONENT_DTOR:
4469 return d_find_pack (dpi, dc->u.s_dtor.name);
4471 default:
4472 a = d_find_pack (dpi, d_left (dc));
4473 if (a)
4474 return a;
4475 return d_find_pack (dpi, d_right (dc));
4479 /* Returns the length of the template argument pack DC. */
4481 static int
4482 d_pack_length (const struct demangle_component *dc)
4484 int count = 0;
4485 while (dc && dc->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST
4486 && d_left (dc) != NULL)
4488 ++count;
4489 dc = d_right (dc);
4491 return count;
4494 /* Returns the number of template args in DC, expanding any pack expansions
4495 found there. */
4497 static int
4498 d_args_length (struct d_print_info *dpi, const struct demangle_component *dc)
4500 int count = 0;
4501 for (; dc && dc->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST;
4502 dc = d_right (dc))
4504 struct demangle_component *elt = d_left (dc);
4505 if (elt == NULL)
4506 break;
4507 if (elt->type == DEMANGLE_COMPONENT_PACK_EXPANSION)
4509 struct demangle_component *a = d_find_pack (dpi, d_left (elt));
4510 count += d_pack_length (a);
4512 else
4513 ++count;
4515 return count;
4518 /* DC is a component of a mangled expression. Print it, wrapped in parens
4519 if needed. */
4521 static void
4522 d_print_subexpr (struct d_print_info *dpi, int options,
4523 struct demangle_component *dc)
4525 int simple = 0;
4526 if (dc->type == DEMANGLE_COMPONENT_NAME
4527 || dc->type == DEMANGLE_COMPONENT_QUAL_NAME
4528 || dc->type == DEMANGLE_COMPONENT_INITIALIZER_LIST
4529 || dc->type == DEMANGLE_COMPONENT_FUNCTION_PARAM)
4530 simple = 1;
4531 if (!simple)
4532 d_append_char (dpi, '(');
4533 d_print_comp (dpi, options, dc);
4534 if (!simple)
4535 d_append_char (dpi, ')');
4538 /* Save the current scope. */
4540 static void
4541 d_save_scope (struct d_print_info *dpi,
4542 const struct demangle_component *container)
4544 struct d_saved_scope *scope;
4545 struct d_print_template *src, **link;
4547 if (dpi->next_saved_scope >= dpi->num_saved_scopes)
4549 d_print_error (dpi);
4550 return;
4552 scope = &dpi->saved_scopes[dpi->next_saved_scope];
4553 dpi->next_saved_scope++;
4555 scope->container = container;
4556 link = &scope->templates;
4558 for (src = dpi->templates; src != NULL; src = src->next)
4560 struct d_print_template *dst;
4562 if (dpi->next_copy_template >= dpi->num_copy_templates)
4564 d_print_error (dpi);
4565 return;
4567 dst = &dpi->copy_templates[dpi->next_copy_template];
4568 dpi->next_copy_template++;
4570 dst->template_decl = src->template_decl;
4571 *link = dst;
4572 link = &dst->next;
4575 *link = NULL;
4578 /* Attempt to locate a previously saved scope. Returns NULL if no
4579 corresponding saved scope was found. */
4581 static struct d_saved_scope *
4582 d_get_saved_scope (struct d_print_info *dpi,
4583 const struct demangle_component *container)
4585 int i;
4587 for (i = 0; i < dpi->next_saved_scope; i++)
4588 if (dpi->saved_scopes[i].container == container)
4589 return &dpi->saved_scopes[i];
4591 return NULL;
4594 /* If DC is a C++17 fold-expression, print it and return true; otherwise
4595 return false. */
4597 static int
4598 d_maybe_print_fold_expression (struct d_print_info *dpi, int options,
4599 struct demangle_component *dc)
4601 struct demangle_component *ops, *operator_, *op1, *op2;
4602 int save_idx;
4604 const char *fold_code = d_left (dc)->u.s_operator.op->code;
4605 if (fold_code[0] != 'f')
4606 return 0;
4608 ops = d_right (dc);
4609 operator_ = d_left (ops);
4610 op1 = d_right (ops);
4611 op2 = 0;
4612 if (op1->type == DEMANGLE_COMPONENT_TRINARY_ARG2)
4614 op2 = d_right (op1);
4615 op1 = d_left (op1);
4618 /* Print the whole pack. */
4619 save_idx = dpi->pack_index;
4620 dpi->pack_index = -1;
4622 switch (fold_code[1])
4624 /* Unary left fold, (... + X). */
4625 case 'l':
4626 d_append_string (dpi, "(...");
4627 d_print_expr_op (dpi, options, operator_);
4628 d_print_subexpr (dpi, options, op1);
4629 d_append_char (dpi, ')');
4630 break;
4632 /* Unary right fold, (X + ...). */
4633 case 'r':
4634 d_append_char (dpi, '(');
4635 d_print_subexpr (dpi, options, op1);
4636 d_print_expr_op (dpi, options, operator_);
4637 d_append_string (dpi, "...)");
4638 break;
4640 /* Binary left fold, (42 + ... + X). */
4641 case 'L':
4642 /* Binary right fold, (X + ... + 42). */
4643 case 'R':
4644 d_append_char (dpi, '(');
4645 d_print_subexpr (dpi, options, op1);
4646 d_print_expr_op (dpi, options, operator_);
4647 d_append_string (dpi, "...");
4648 d_print_expr_op (dpi, options, operator_);
4649 d_print_subexpr (dpi, options, op2);
4650 d_append_char (dpi, ')');
4651 break;
4654 dpi->pack_index = save_idx;
4655 return 1;
4658 /* Subroutine to handle components. */
4660 static void
4661 d_print_comp_inner (struct d_print_info *dpi, int options,
4662 struct demangle_component *dc)
4664 /* Magic variable to let reference smashing skip over the next modifier
4665 without needing to modify *dc. */
4666 struct demangle_component *mod_inner = NULL;
4668 /* Variable used to store the current templates while a previously
4669 captured scope is used. */
4670 struct d_print_template *saved_templates;
4672 /* Nonzero if templates have been stored in the above variable. */
4673 int need_template_restore = 0;
4675 if (dc == NULL)
4677 d_print_error (dpi);
4678 return;
4680 if (d_print_saw_error (dpi))
4681 return;
4683 switch (dc->type)
4685 case DEMANGLE_COMPONENT_NAME:
4686 if ((options & DMGL_JAVA) == 0)
4687 d_append_buffer (dpi, dc->u.s_name.s, dc->u.s_name.len);
4688 else
4689 d_print_java_identifier (dpi, dc->u.s_name.s, dc->u.s_name.len);
4690 return;
4692 case DEMANGLE_COMPONENT_TAGGED_NAME:
4693 d_print_comp (dpi, options, d_left (dc));
4694 d_append_string (dpi, "[abi:");
4695 d_print_comp (dpi, options, d_right (dc));
4696 d_append_char (dpi, ']');
4697 return;
4699 case DEMANGLE_COMPONENT_QUAL_NAME:
4700 case DEMANGLE_COMPONENT_LOCAL_NAME:
4701 d_print_comp (dpi, options, d_left (dc));
4702 if ((options & DMGL_JAVA) == 0)
4703 d_append_string (dpi, "::");
4704 else
4705 d_append_char (dpi, '.');
4707 struct demangle_component *local_name = d_right (dc);
4708 if (local_name->type == DEMANGLE_COMPONENT_DEFAULT_ARG)
4710 d_append_string (dpi, "{default arg#");
4711 d_append_num (dpi, local_name->u.s_unary_num.num + 1);
4712 d_append_string (dpi, "}::");
4713 local_name = local_name->u.s_unary_num.sub;
4715 d_print_comp (dpi, options, local_name);
4717 return;
4719 case DEMANGLE_COMPONENT_TYPED_NAME:
4721 struct d_print_mod *hold_modifiers;
4722 struct demangle_component *typed_name;
4723 struct d_print_mod adpm[4];
4724 unsigned int i;
4725 struct d_print_template dpt;
4727 /* Pass the name down to the type so that it can be printed in
4728 the right place for the type. We also have to pass down
4729 any CV-qualifiers, which apply to the this parameter. */
4730 hold_modifiers = dpi->modifiers;
4731 dpi->modifiers = 0;
4732 i = 0;
4733 typed_name = d_left (dc);
4734 while (typed_name != NULL)
4736 if (i >= sizeof adpm / sizeof adpm[0])
4738 d_print_error (dpi);
4739 return;
4742 adpm[i].next = dpi->modifiers;
4743 dpi->modifiers = &adpm[i];
4744 adpm[i].mod = typed_name;
4745 adpm[i].printed = 0;
4746 adpm[i].templates = dpi->templates;
4747 ++i;
4749 if (!is_fnqual_component_type (typed_name->type))
4750 break;
4752 typed_name = d_left (typed_name);
4755 if (typed_name == NULL)
4757 d_print_error (dpi);
4758 return;
4761 /* If typed_name is a DEMANGLE_COMPONENT_LOCAL_NAME, then
4762 there may be CV-qualifiers on its right argument which
4763 really apply here; this happens when parsing a class that
4764 is local to a function. */
4765 if (typed_name->type == DEMANGLE_COMPONENT_LOCAL_NAME)
4767 typed_name = d_right (typed_name);
4768 if (typed_name->type == DEMANGLE_COMPONENT_DEFAULT_ARG)
4769 typed_name = typed_name->u.s_unary_num.sub;
4770 while (typed_name != NULL
4771 && is_fnqual_component_type (typed_name->type))
4773 if (i >= sizeof adpm / sizeof adpm[0])
4775 d_print_error (dpi);
4776 return;
4779 adpm[i] = adpm[i - 1];
4780 adpm[i].next = &adpm[i - 1];
4781 dpi->modifiers = &adpm[i];
4783 adpm[i - 1].mod = typed_name;
4784 adpm[i - 1].printed = 0;
4785 adpm[i - 1].templates = dpi->templates;
4786 ++i;
4788 typed_name = d_left (typed_name);
4790 if (typed_name == NULL)
4792 d_print_error (dpi);
4793 return;
4797 /* If typed_name is a template, then it applies to the
4798 function type as well. */
4799 if (typed_name->type == DEMANGLE_COMPONENT_TEMPLATE)
4801 dpt.next = dpi->templates;
4802 dpi->templates = &dpt;
4803 dpt.template_decl = typed_name;
4806 d_print_comp (dpi, options, d_right (dc));
4808 if (typed_name->type == DEMANGLE_COMPONENT_TEMPLATE)
4809 dpi->templates = dpt.next;
4811 /* If the modifiers didn't get printed by the type, print them
4812 now. */
4813 while (i > 0)
4815 --i;
4816 if (! adpm[i].printed)
4818 d_append_char (dpi, ' ');
4819 d_print_mod (dpi, options, adpm[i].mod);
4823 dpi->modifiers = hold_modifiers;
4825 return;
4828 case DEMANGLE_COMPONENT_TEMPLATE:
4830 struct d_print_mod *hold_dpm;
4831 struct demangle_component *dcl;
4832 const struct demangle_component *hold_current;
4834 /* This template may need to be referenced by a cast operator
4835 contained in its subtree. */
4836 hold_current = dpi->current_template;
4837 dpi->current_template = dc;
4839 /* Don't push modifiers into a template definition. Doing so
4840 could give the wrong definition for a template argument.
4841 Instead, treat the template essentially as a name. */
4843 hold_dpm = dpi->modifiers;
4844 dpi->modifiers = NULL;
4846 dcl = d_left (dc);
4848 if ((options & DMGL_JAVA) != 0
4849 && dcl->type == DEMANGLE_COMPONENT_NAME
4850 && dcl->u.s_name.len == 6
4851 && strncmp (dcl->u.s_name.s, "JArray", 6) == 0)
4853 /* Special-case Java arrays, so that JArray<TYPE> appears
4854 instead as TYPE[]. */
4856 d_print_comp (dpi, options, d_right (dc));
4857 d_append_string (dpi, "[]");
4859 else
4861 d_print_comp (dpi, options, dcl);
4862 if (d_last_char (dpi) == '<')
4863 d_append_char (dpi, ' ');
4864 d_append_char (dpi, '<');
4865 d_print_comp (dpi, options, d_right (dc));
4866 /* Avoid generating two consecutive '>' characters, to avoid
4867 the C++ syntactic ambiguity. */
4868 if (d_last_char (dpi) == '>')
4869 d_append_char (dpi, ' ');
4870 d_append_char (dpi, '>');
4873 dpi->modifiers = hold_dpm;
4874 dpi->current_template = hold_current;
4876 return;
4879 case DEMANGLE_COMPONENT_TEMPLATE_PARAM:
4880 if (dpi->is_lambda_arg)
4882 /* Show the template parm index, as that's how g++ displays
4883 these, and future proofs us against potential
4884 '[]<typename T> (T *a, T *b) {...}'. */
4885 d_append_buffer (dpi, "auto:", 5);
4886 d_append_num (dpi, dc->u.s_number.number + 1);
4888 else
4890 struct d_print_template *hold_dpt;
4891 struct demangle_component *a = d_lookup_template_argument (dpi, dc);
4893 if (a && a->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST)
4894 a = d_index_template_argument (a, dpi->pack_index);
4896 if (a == NULL)
4898 d_print_error (dpi);
4899 return;
4902 /* While processing this parameter, we need to pop the list
4903 of templates. This is because the template parameter may
4904 itself be a reference to a parameter of an outer
4905 template. */
4907 hold_dpt = dpi->templates;
4908 dpi->templates = hold_dpt->next;
4910 d_print_comp (dpi, options, a);
4912 dpi->templates = hold_dpt;
4914 return;
4916 case DEMANGLE_COMPONENT_TPARM_OBJ:
4917 d_append_string (dpi, "template parameter object for ");
4918 d_print_comp (dpi, options, d_left (dc));
4919 return;
4921 case DEMANGLE_COMPONENT_CTOR:
4922 d_print_comp (dpi, options, dc->u.s_ctor.name);
4923 return;
4925 case DEMANGLE_COMPONENT_DTOR:
4926 d_append_char (dpi, '~');
4927 d_print_comp (dpi, options, dc->u.s_dtor.name);
4928 return;
4930 case DEMANGLE_COMPONENT_VTABLE:
4931 d_append_string (dpi, "vtable for ");
4932 d_print_comp (dpi, options, d_left (dc));
4933 return;
4935 case DEMANGLE_COMPONENT_VTT:
4936 d_append_string (dpi, "VTT for ");
4937 d_print_comp (dpi, options, d_left (dc));
4938 return;
4940 case DEMANGLE_COMPONENT_CONSTRUCTION_VTABLE:
4941 d_append_string (dpi, "construction vtable for ");
4942 d_print_comp (dpi, options, d_left (dc));
4943 d_append_string (dpi, "-in-");
4944 d_print_comp (dpi, options, d_right (dc));
4945 return;
4947 case DEMANGLE_COMPONENT_TYPEINFO:
4948 d_append_string (dpi, "typeinfo for ");
4949 d_print_comp (dpi, options, d_left (dc));
4950 return;
4952 case DEMANGLE_COMPONENT_TYPEINFO_NAME:
4953 d_append_string (dpi, "typeinfo name for ");
4954 d_print_comp (dpi, options, d_left (dc));
4955 return;
4957 case DEMANGLE_COMPONENT_TYPEINFO_FN:
4958 d_append_string (dpi, "typeinfo fn for ");
4959 d_print_comp (dpi, options, d_left (dc));
4960 return;
4962 case DEMANGLE_COMPONENT_THUNK:
4963 d_append_string (dpi, "non-virtual thunk to ");
4964 d_print_comp (dpi, options, d_left (dc));
4965 return;
4967 case DEMANGLE_COMPONENT_VIRTUAL_THUNK:
4968 d_append_string (dpi, "virtual thunk to ");
4969 d_print_comp (dpi, options, d_left (dc));
4970 return;
4972 case DEMANGLE_COMPONENT_COVARIANT_THUNK:
4973 d_append_string (dpi, "covariant return thunk to ");
4974 d_print_comp (dpi, options, d_left (dc));
4975 return;
4977 case DEMANGLE_COMPONENT_JAVA_CLASS:
4978 d_append_string (dpi, "java Class for ");
4979 d_print_comp (dpi, options, d_left (dc));
4980 return;
4982 case DEMANGLE_COMPONENT_GUARD:
4983 d_append_string (dpi, "guard variable for ");
4984 d_print_comp (dpi, options, d_left (dc));
4985 return;
4987 case DEMANGLE_COMPONENT_TLS_INIT:
4988 d_append_string (dpi, "TLS init function for ");
4989 d_print_comp (dpi, options, d_left (dc));
4990 return;
4992 case DEMANGLE_COMPONENT_TLS_WRAPPER:
4993 d_append_string (dpi, "TLS wrapper function for ");
4994 d_print_comp (dpi, options, d_left (dc));
4995 return;
4997 case DEMANGLE_COMPONENT_REFTEMP:
4998 d_append_string (dpi, "reference temporary #");
4999 d_print_comp (dpi, options, d_right (dc));
5000 d_append_string (dpi, " for ");
5001 d_print_comp (dpi, options, d_left (dc));
5002 return;
5004 case DEMANGLE_COMPONENT_HIDDEN_ALIAS:
5005 d_append_string (dpi, "hidden alias for ");
5006 d_print_comp (dpi, options, d_left (dc));
5007 return;
5009 case DEMANGLE_COMPONENT_TRANSACTION_CLONE:
5010 d_append_string (dpi, "transaction clone for ");
5011 d_print_comp (dpi, options, d_left (dc));
5012 return;
5014 case DEMANGLE_COMPONENT_NONTRANSACTION_CLONE:
5015 d_append_string (dpi, "non-transaction clone for ");
5016 d_print_comp (dpi, options, d_left (dc));
5017 return;
5019 case DEMANGLE_COMPONENT_SUB_STD:
5020 d_append_buffer (dpi, dc->u.s_string.string, dc->u.s_string.len);
5021 return;
5023 case DEMANGLE_COMPONENT_RESTRICT:
5024 case DEMANGLE_COMPONENT_VOLATILE:
5025 case DEMANGLE_COMPONENT_CONST:
5027 struct d_print_mod *pdpm;
5029 /* When printing arrays, it's possible to have cases where the
5030 same CV-qualifier gets pushed on the stack multiple times.
5031 We only need to print it once. */
5033 for (pdpm = dpi->modifiers; pdpm != NULL; pdpm = pdpm->next)
5035 if (! pdpm->printed)
5037 if (pdpm->mod->type != DEMANGLE_COMPONENT_RESTRICT
5038 && pdpm->mod->type != DEMANGLE_COMPONENT_VOLATILE
5039 && pdpm->mod->type != DEMANGLE_COMPONENT_CONST)
5040 break;
5041 if (pdpm->mod->type == dc->type)
5043 d_print_comp (dpi, options, d_left (dc));
5044 return;
5049 goto modifier;
5051 case DEMANGLE_COMPONENT_REFERENCE:
5052 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
5054 /* Handle reference smashing: & + && = &. */
5055 struct demangle_component *sub = d_left (dc);
5056 if (!dpi->is_lambda_arg
5057 && sub->type == DEMANGLE_COMPONENT_TEMPLATE_PARAM)
5059 struct d_saved_scope *scope = d_get_saved_scope (dpi, sub);
5060 struct demangle_component *a;
5062 if (scope == NULL)
5064 /* This is the first time SUB has been traversed.
5065 We need to capture the current templates so
5066 they can be restored if SUB is reentered as a
5067 substitution. */
5068 d_save_scope (dpi, sub);
5069 if (d_print_saw_error (dpi))
5070 return;
5072 else
5074 const struct d_component_stack *dcse;
5075 int found_self_or_parent = 0;
5077 /* This traversal is reentering SUB as a substition.
5078 If we are not beneath SUB or DC in the tree then we
5079 need to restore SUB's template stack temporarily. */
5080 for (dcse = dpi->component_stack; dcse != NULL;
5081 dcse = dcse->parent)
5083 if (dcse->dc == sub
5084 || (dcse->dc == dc
5085 && dcse != dpi->component_stack))
5087 found_self_or_parent = 1;
5088 break;
5092 if (!found_self_or_parent)
5094 saved_templates = dpi->templates;
5095 dpi->templates = scope->templates;
5096 need_template_restore = 1;
5100 a = d_lookup_template_argument (dpi, sub);
5101 if (a && a->type == DEMANGLE_COMPONENT_TEMPLATE_ARGLIST)
5102 a = d_index_template_argument (a, dpi->pack_index);
5104 if (a == NULL)
5106 if (need_template_restore)
5107 dpi->templates = saved_templates;
5109 d_print_error (dpi);
5110 return;
5113 sub = a;
5116 if (sub->type == DEMANGLE_COMPONENT_REFERENCE
5117 || sub->type == dc->type)
5118 dc = sub;
5119 else if (sub->type == DEMANGLE_COMPONENT_RVALUE_REFERENCE)
5120 mod_inner = d_left (sub);
5122 /* Fall through. */
5124 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
5125 case DEMANGLE_COMPONENT_POINTER:
5126 case DEMANGLE_COMPONENT_COMPLEX:
5127 case DEMANGLE_COMPONENT_IMAGINARY:
5128 FNQUAL_COMPONENT_CASE:
5129 modifier:
5131 /* We keep a list of modifiers on the stack. */
5132 struct d_print_mod dpm;
5134 dpm.next = dpi->modifiers;
5135 dpi->modifiers = &dpm;
5136 dpm.mod = dc;
5137 dpm.printed = 0;
5138 dpm.templates = dpi->templates;
5140 if (!mod_inner)
5141 mod_inner = d_left (dc);
5143 d_print_comp (dpi, options, mod_inner);
5145 /* If the modifier didn't get printed by the type, print it
5146 now. */
5147 if (! dpm.printed)
5148 d_print_mod (dpi, options, dc);
5150 dpi->modifiers = dpm.next;
5152 if (need_template_restore)
5153 dpi->templates = saved_templates;
5155 return;
5158 case DEMANGLE_COMPONENT_BUILTIN_TYPE:
5159 if ((options & DMGL_JAVA) == 0)
5160 d_append_buffer (dpi, dc->u.s_builtin.type->name,
5161 dc->u.s_builtin.type->len);
5162 else
5163 d_append_buffer (dpi, dc->u.s_builtin.type->java_name,
5164 dc->u.s_builtin.type->java_len);
5165 return;
5167 case DEMANGLE_COMPONENT_VENDOR_TYPE:
5168 d_print_comp (dpi, options, d_left (dc));
5169 return;
5171 case DEMANGLE_COMPONENT_FUNCTION_TYPE:
5173 if ((options & DMGL_RET_POSTFIX) != 0)
5174 d_print_function_type (dpi,
5175 options & ~(DMGL_RET_POSTFIX | DMGL_RET_DROP),
5176 dc, dpi->modifiers);
5178 /* Print return type if present */
5179 if (d_left (dc) != NULL && (options & DMGL_RET_POSTFIX) != 0)
5180 d_print_comp (dpi, options & ~(DMGL_RET_POSTFIX | DMGL_RET_DROP),
5181 d_left (dc));
5182 else if (d_left (dc) != NULL && (options & DMGL_RET_DROP) == 0)
5184 struct d_print_mod dpm;
5186 /* We must pass this type down as a modifier in order to
5187 print it in the right location. */
5188 dpm.next = dpi->modifiers;
5189 dpi->modifiers = &dpm;
5190 dpm.mod = dc;
5191 dpm.printed = 0;
5192 dpm.templates = dpi->templates;
5194 d_print_comp (dpi, options & ~(DMGL_RET_POSTFIX | DMGL_RET_DROP),
5195 d_left (dc));
5197 dpi->modifiers = dpm.next;
5199 if (dpm.printed)
5200 return;
5202 /* In standard prefix notation, there is a space between the
5203 return type and the function signature. */
5204 if ((options & DMGL_RET_POSTFIX) == 0)
5205 d_append_char (dpi, ' ');
5208 if ((options & DMGL_RET_POSTFIX) == 0)
5209 d_print_function_type (dpi,
5210 options & ~(DMGL_RET_POSTFIX | DMGL_RET_DROP),
5211 dc, dpi->modifiers);
5213 return;
5216 case DEMANGLE_COMPONENT_ARRAY_TYPE:
5218 struct d_print_mod *hold_modifiers;
5219 struct d_print_mod adpm[4];
5220 unsigned int i;
5221 struct d_print_mod *pdpm;
5223 /* We must pass this type down as a modifier in order to print
5224 multi-dimensional arrays correctly. If the array itself is
5225 CV-qualified, we act as though the element type were
5226 CV-qualified. We do this by copying the modifiers down
5227 rather than fiddling pointers, so that we don't wind up
5228 with a d_print_mod higher on the stack pointing into our
5229 stack frame after we return. */
5231 hold_modifiers = dpi->modifiers;
5233 adpm[0].next = hold_modifiers;
5234 dpi->modifiers = &adpm[0];
5235 adpm[0].mod = dc;
5236 adpm[0].printed = 0;
5237 adpm[0].templates = dpi->templates;
5239 i = 1;
5240 pdpm = hold_modifiers;
5241 while (pdpm != NULL
5242 && (pdpm->mod->type == DEMANGLE_COMPONENT_RESTRICT
5243 || pdpm->mod->type == DEMANGLE_COMPONENT_VOLATILE
5244 || pdpm->mod->type == DEMANGLE_COMPONENT_CONST))
5246 if (! pdpm->printed)
5248 if (i >= sizeof adpm / sizeof adpm[0])
5250 d_print_error (dpi);
5251 return;
5254 adpm[i] = *pdpm;
5255 adpm[i].next = dpi->modifiers;
5256 dpi->modifiers = &adpm[i];
5257 pdpm->printed = 1;
5258 ++i;
5261 pdpm = pdpm->next;
5264 d_print_comp (dpi, options, d_right (dc));
5266 dpi->modifiers = hold_modifiers;
5268 if (adpm[0].printed)
5269 return;
5271 while (i > 1)
5273 --i;
5274 d_print_mod (dpi, options, adpm[i].mod);
5277 d_print_array_type (dpi, options, dc, dpi->modifiers);
5279 return;
5282 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
5283 case DEMANGLE_COMPONENT_VECTOR_TYPE:
5285 struct d_print_mod dpm;
5287 dpm.next = dpi->modifiers;
5288 dpi->modifiers = &dpm;
5289 dpm.mod = dc;
5290 dpm.printed = 0;
5291 dpm.templates = dpi->templates;
5293 d_print_comp (dpi, options, d_right (dc));
5295 /* If the modifier didn't get printed by the type, print it
5296 now. */
5297 if (! dpm.printed)
5298 d_print_mod (dpi, options, dc);
5300 dpi->modifiers = dpm.next;
5302 return;
5305 case DEMANGLE_COMPONENT_FIXED_TYPE:
5306 if (dc->u.s_fixed.sat)
5307 d_append_string (dpi, "_Sat ");
5308 /* Don't print "int _Accum". */
5309 if (dc->u.s_fixed.length->u.s_builtin.type
5310 != &cplus_demangle_builtin_types['i'-'a'])
5312 d_print_comp (dpi, options, dc->u.s_fixed.length);
5313 d_append_char (dpi, ' ');
5315 if (dc->u.s_fixed.accum)
5316 d_append_string (dpi, "_Accum");
5317 else
5318 d_append_string (dpi, "_Fract");
5319 return;
5321 case DEMANGLE_COMPONENT_ARGLIST:
5322 case DEMANGLE_COMPONENT_TEMPLATE_ARGLIST:
5323 if (d_left (dc) != NULL)
5324 d_print_comp (dpi, options, d_left (dc));
5325 if (d_right (dc) != NULL)
5327 size_t len;
5328 unsigned long int flush_count;
5329 /* Make sure ", " isn't flushed by d_append_string, otherwise
5330 dpi->len -= 2 wouldn't work. */
5331 if (dpi->len >= sizeof (dpi->buf) - 2)
5332 d_print_flush (dpi);
5333 d_append_string (dpi, ", ");
5334 len = dpi->len;
5335 flush_count = dpi->flush_count;
5336 d_print_comp (dpi, options, d_right (dc));
5337 /* If that didn't print anything (which can happen with empty
5338 template argument packs), remove the comma and space. */
5339 if (dpi->flush_count == flush_count && dpi->len == len)
5340 dpi->len -= 2;
5342 return;
5344 case DEMANGLE_COMPONENT_INITIALIZER_LIST:
5346 struct demangle_component *type = d_left (dc);
5347 struct demangle_component *list = d_right (dc);
5349 if (type)
5350 d_print_comp (dpi, options, type);
5351 d_append_char (dpi, '{');
5352 d_print_comp (dpi, options, list);
5353 d_append_char (dpi, '}');
5355 return;
5357 case DEMANGLE_COMPONENT_OPERATOR:
5359 const struct demangle_operator_info *op = dc->u.s_operator.op;
5360 int len = op->len;
5362 d_append_string (dpi, "operator");
5363 /* Add a space before new/delete. */
5364 if (IS_LOWER (op->name[0]))
5365 d_append_char (dpi, ' ');
5366 /* Omit a trailing space. */
5367 if (op->name[len-1] == ' ')
5368 --len;
5369 d_append_buffer (dpi, op->name, len);
5370 return;
5373 case DEMANGLE_COMPONENT_EXTENDED_OPERATOR:
5374 d_append_string (dpi, "operator ");
5375 d_print_comp (dpi, options, dc->u.s_extended_operator.name);
5376 return;
5378 case DEMANGLE_COMPONENT_CONVERSION:
5379 d_append_string (dpi, "operator ");
5380 d_print_conversion (dpi, options, dc);
5381 return;
5383 case DEMANGLE_COMPONENT_NULLARY:
5384 d_print_expr_op (dpi, options, d_left (dc));
5385 return;
5387 case DEMANGLE_COMPONENT_UNARY:
5389 struct demangle_component *op = d_left (dc);
5390 struct demangle_component *operand = d_right (dc);
5391 const char *code = NULL;
5393 if (op->type == DEMANGLE_COMPONENT_OPERATOR)
5395 code = op->u.s_operator.op->code;
5396 if (!strcmp (code, "ad"))
5398 /* Don't print the argument list for the address of a
5399 function. */
5400 if (operand->type == DEMANGLE_COMPONENT_TYPED_NAME
5401 && d_left (operand)->type == DEMANGLE_COMPONENT_QUAL_NAME
5402 && d_right (operand)->type == DEMANGLE_COMPONENT_FUNCTION_TYPE)
5403 operand = d_left (operand);
5405 if (operand->type == DEMANGLE_COMPONENT_BINARY_ARGS)
5407 /* This indicates a suffix operator. */
5408 operand = d_left (operand);
5409 d_print_subexpr (dpi, options, operand);
5410 d_print_expr_op (dpi, options, op);
5411 return;
5415 /* For sizeof..., just print the pack length. */
5416 if (code && !strcmp (code, "sZ"))
5418 struct demangle_component *a = d_find_pack (dpi, operand);
5419 int len = d_pack_length (a);
5420 d_append_num (dpi, len);
5421 return;
5423 else if (code && !strcmp (code, "sP"))
5425 int len = d_args_length (dpi, operand);
5426 d_append_num (dpi, len);
5427 return;
5430 if (op->type != DEMANGLE_COMPONENT_CAST)
5431 d_print_expr_op (dpi, options, op);
5432 else
5434 d_append_char (dpi, '(');
5435 d_print_cast (dpi, options, op);
5436 d_append_char (dpi, ')');
5438 if (code && !strcmp (code, "gs"))
5439 /* Avoid parens after '::'. */
5440 d_print_comp (dpi, options, operand);
5441 else if (code && !strcmp (code, "st"))
5442 /* Always print parens for sizeof (type). */
5444 d_append_char (dpi, '(');
5445 d_print_comp (dpi, options, operand);
5446 d_append_char (dpi, ')');
5448 else
5449 d_print_subexpr (dpi, options, operand);
5451 return;
5453 case DEMANGLE_COMPONENT_BINARY:
5454 if (d_right (dc)->type != DEMANGLE_COMPONENT_BINARY_ARGS)
5456 d_print_error (dpi);
5457 return;
5460 if (op_is_new_cast (d_left (dc)))
5462 d_print_expr_op (dpi, options, d_left (dc));
5463 d_append_char (dpi, '<');
5464 d_print_comp (dpi, options, d_left (d_right (dc)));
5465 d_append_string (dpi, ">(");
5466 d_print_comp (dpi, options, d_right (d_right (dc)));
5467 d_append_char (dpi, ')');
5468 return;
5471 if (d_maybe_print_fold_expression (dpi, options, dc))
5472 return;
5474 /* We wrap an expression which uses the greater-than operator in
5475 an extra layer of parens so that it does not get confused
5476 with the '>' which ends the template parameters. */
5477 if (d_left (dc)->type == DEMANGLE_COMPONENT_OPERATOR
5478 && d_left (dc)->u.s_operator.op->len == 1
5479 && d_left (dc)->u.s_operator.op->name[0] == '>')
5480 d_append_char (dpi, '(');
5482 if (strcmp (d_left (dc)->u.s_operator.op->code, "cl") == 0
5483 && d_left (d_right (dc))->type == DEMANGLE_COMPONENT_TYPED_NAME)
5485 /* Function call used in an expression should not have printed types
5486 of the function arguments. Values of the function arguments still
5487 get printed below. */
5489 const struct demangle_component *func = d_left (d_right (dc));
5491 if (d_right (func)->type != DEMANGLE_COMPONENT_FUNCTION_TYPE)
5492 d_print_error (dpi);
5493 d_print_subexpr (dpi, options, d_left (func));
5495 else
5496 d_print_subexpr (dpi, options, d_left (d_right (dc)));
5497 if (strcmp (d_left (dc)->u.s_operator.op->code, "ix") == 0)
5499 d_append_char (dpi, '[');
5500 d_print_comp (dpi, options, d_right (d_right (dc)));
5501 d_append_char (dpi, ']');
5503 else
5505 if (strcmp (d_left (dc)->u.s_operator.op->code, "cl") != 0)
5506 d_print_expr_op (dpi, options, d_left (dc));
5507 d_print_subexpr (dpi, options, d_right (d_right (dc)));
5510 if (d_left (dc)->type == DEMANGLE_COMPONENT_OPERATOR
5511 && d_left (dc)->u.s_operator.op->len == 1
5512 && d_left (dc)->u.s_operator.op->name[0] == '>')
5513 d_append_char (dpi, ')');
5515 return;
5517 case DEMANGLE_COMPONENT_BINARY_ARGS:
5518 /* We should only see this as part of DEMANGLE_COMPONENT_BINARY. */
5519 d_print_error (dpi);
5520 return;
5522 case DEMANGLE_COMPONENT_TRINARY:
5523 if (d_right (dc)->type != DEMANGLE_COMPONENT_TRINARY_ARG1
5524 || d_right (d_right (dc))->type != DEMANGLE_COMPONENT_TRINARY_ARG2)
5526 d_print_error (dpi);
5527 return;
5529 if (d_maybe_print_fold_expression (dpi, options, dc))
5530 return;
5532 struct demangle_component *op = d_left (dc);
5533 struct demangle_component *first = d_left (d_right (dc));
5534 struct demangle_component *second = d_left (d_right (d_right (dc)));
5535 struct demangle_component *third = d_right (d_right (d_right (dc)));
5537 if (!strcmp (op->u.s_operator.op->code, "qu"))
5539 d_print_subexpr (dpi, options, first);
5540 d_print_expr_op (dpi, options, op);
5541 d_print_subexpr (dpi, options, second);
5542 d_append_string (dpi, " : ");
5543 d_print_subexpr (dpi, options, third);
5545 else
5547 d_append_string (dpi, "new ");
5548 if (d_left (first) != NULL)
5550 d_print_subexpr (dpi, options, first);
5551 d_append_char (dpi, ' ');
5553 d_print_comp (dpi, options, second);
5554 if (third)
5555 d_print_subexpr (dpi, options, third);
5558 return;
5560 case DEMANGLE_COMPONENT_TRINARY_ARG1:
5561 case DEMANGLE_COMPONENT_TRINARY_ARG2:
5562 /* We should only see these are part of DEMANGLE_COMPONENT_TRINARY. */
5563 d_print_error (dpi);
5564 return;
5566 case DEMANGLE_COMPONENT_LITERAL:
5567 case DEMANGLE_COMPONENT_LITERAL_NEG:
5569 enum d_builtin_type_print tp;
5571 /* For some builtin types, produce simpler output. */
5572 tp = D_PRINT_DEFAULT;
5573 if (d_left (dc)->type == DEMANGLE_COMPONENT_BUILTIN_TYPE)
5575 tp = d_left (dc)->u.s_builtin.type->print;
5576 switch (tp)
5578 case D_PRINT_INT:
5579 case D_PRINT_UNSIGNED:
5580 case D_PRINT_LONG:
5581 case D_PRINT_UNSIGNED_LONG:
5582 case D_PRINT_LONG_LONG:
5583 case D_PRINT_UNSIGNED_LONG_LONG:
5584 if (d_right (dc)->type == DEMANGLE_COMPONENT_NAME)
5586 if (dc->type == DEMANGLE_COMPONENT_LITERAL_NEG)
5587 d_append_char (dpi, '-');
5588 d_print_comp (dpi, options, d_right (dc));
5589 switch (tp)
5591 default:
5592 break;
5593 case D_PRINT_UNSIGNED:
5594 d_append_char (dpi, 'u');
5595 break;
5596 case D_PRINT_LONG:
5597 d_append_char (dpi, 'l');
5598 break;
5599 case D_PRINT_UNSIGNED_LONG:
5600 d_append_string (dpi, "ul");
5601 break;
5602 case D_PRINT_LONG_LONG:
5603 d_append_string (dpi, "ll");
5604 break;
5605 case D_PRINT_UNSIGNED_LONG_LONG:
5606 d_append_string (dpi, "ull");
5607 break;
5609 return;
5611 break;
5613 case D_PRINT_BOOL:
5614 if (d_right (dc)->type == DEMANGLE_COMPONENT_NAME
5615 && d_right (dc)->u.s_name.len == 1
5616 && dc->type == DEMANGLE_COMPONENT_LITERAL)
5618 switch (d_right (dc)->u.s_name.s[0])
5620 case '0':
5621 d_append_string (dpi, "false");
5622 return;
5623 case '1':
5624 d_append_string (dpi, "true");
5625 return;
5626 default:
5627 break;
5630 break;
5632 default:
5633 break;
5637 d_append_char (dpi, '(');
5638 d_print_comp (dpi, options, d_left (dc));
5639 d_append_char (dpi, ')');
5640 if (dc->type == DEMANGLE_COMPONENT_LITERAL_NEG)
5641 d_append_char (dpi, '-');
5642 if (tp == D_PRINT_FLOAT)
5643 d_append_char (dpi, '[');
5644 d_print_comp (dpi, options, d_right (dc));
5645 if (tp == D_PRINT_FLOAT)
5646 d_append_char (dpi, ']');
5648 return;
5650 case DEMANGLE_COMPONENT_NUMBER:
5651 d_append_num (dpi, dc->u.s_number.number);
5652 return;
5654 case DEMANGLE_COMPONENT_JAVA_RESOURCE:
5655 d_append_string (dpi, "java resource ");
5656 d_print_comp (dpi, options, d_left (dc));
5657 return;
5659 case DEMANGLE_COMPONENT_COMPOUND_NAME:
5660 d_print_comp (dpi, options, d_left (dc));
5661 d_print_comp (dpi, options, d_right (dc));
5662 return;
5664 case DEMANGLE_COMPONENT_CHARACTER:
5665 d_append_char (dpi, dc->u.s_character.character);
5666 return;
5668 case DEMANGLE_COMPONENT_DECLTYPE:
5669 d_append_string (dpi, "decltype (");
5670 d_print_comp (dpi, options, d_left (dc));
5671 d_append_char (dpi, ')');
5672 return;
5674 case DEMANGLE_COMPONENT_PACK_EXPANSION:
5676 int len;
5677 int i;
5678 struct demangle_component *a = d_find_pack (dpi, d_left (dc));
5679 if (a == NULL)
5681 /* d_find_pack won't find anything if the only packs involved
5682 in this expansion are function parameter packs; in that
5683 case, just print the pattern and "...". */
5684 d_print_subexpr (dpi, options, d_left (dc));
5685 d_append_string (dpi, "...");
5686 return;
5689 len = d_pack_length (a);
5690 dc = d_left (dc);
5691 for (i = 0; i < len; ++i)
5693 dpi->pack_index = i;
5694 d_print_comp (dpi, options, dc);
5695 if (i < len-1)
5696 d_append_string (dpi, ", ");
5699 return;
5701 case DEMANGLE_COMPONENT_FUNCTION_PARAM:
5703 long num = dc->u.s_number.number;
5704 if (num == 0)
5705 d_append_string (dpi, "this");
5706 else
5708 d_append_string (dpi, "{parm#");
5709 d_append_num (dpi, num);
5710 d_append_char (dpi, '}');
5713 return;
5715 case DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS:
5716 d_append_string (dpi, "global constructors keyed to ");
5717 d_print_comp (dpi, options, dc->u.s_binary.left);
5718 return;
5720 case DEMANGLE_COMPONENT_GLOBAL_DESTRUCTORS:
5721 d_append_string (dpi, "global destructors keyed to ");
5722 d_print_comp (dpi, options, dc->u.s_binary.left);
5723 return;
5725 case DEMANGLE_COMPONENT_LAMBDA:
5726 d_append_string (dpi, "{lambda(");
5727 /* Generic lambda auto parms are mangled as the template type
5728 parm they are. */
5729 dpi->is_lambda_arg++;
5730 d_print_comp (dpi, options, dc->u.s_unary_num.sub);
5731 dpi->is_lambda_arg--;
5732 d_append_string (dpi, ")#");
5733 d_append_num (dpi, dc->u.s_unary_num.num + 1);
5734 d_append_char (dpi, '}');
5735 return;
5737 case DEMANGLE_COMPONENT_UNNAMED_TYPE:
5738 d_append_string (dpi, "{unnamed type#");
5739 d_append_num (dpi, dc->u.s_number.number + 1);
5740 d_append_char (dpi, '}');
5741 return;
5743 case DEMANGLE_COMPONENT_CLONE:
5744 d_print_comp (dpi, options, d_left (dc));
5745 d_append_string (dpi, " [clone ");
5746 d_print_comp (dpi, options, d_right (dc));
5747 d_append_char (dpi, ']');
5748 return;
5750 default:
5751 d_print_error (dpi);
5752 return;
5756 static void
5757 d_print_comp (struct d_print_info *dpi, int options,
5758 struct demangle_component *dc)
5760 struct d_component_stack self;
5761 if (dc == NULL || dc->d_printing > 1 || dpi->recursion > MAX_RECURSION_COUNT)
5763 d_print_error (dpi);
5764 return;
5767 dc->d_printing++;
5768 dpi->recursion++;
5770 self.dc = dc;
5771 self.parent = dpi->component_stack;
5772 dpi->component_stack = &self;
5774 d_print_comp_inner (dpi, options, dc);
5776 dpi->component_stack = self.parent;
5777 dc->d_printing--;
5778 dpi->recursion--;
5781 /* Print a Java dentifier. For Java we try to handle encoded extended
5782 Unicode characters. The C++ ABI doesn't mention Unicode encoding,
5783 so we don't it for C++. Characters are encoded as
5784 __U<hex-char>+_. */
5786 static void
5787 d_print_java_identifier (struct d_print_info *dpi, const char *name, int len)
5789 const char *p;
5790 const char *end;
5792 end = name + len;
5793 for (p = name; p < end; ++p)
5795 if (end - p > 3
5796 && p[0] == '_'
5797 && p[1] == '_'
5798 && p[2] == 'U')
5800 unsigned long c;
5801 const char *q;
5803 c = 0;
5804 for (q = p + 3; q < end; ++q)
5806 int dig;
5808 if (IS_DIGIT (*q))
5809 dig = *q - '0';
5810 else if (*q >= 'A' && *q <= 'F')
5811 dig = *q - 'A' + 10;
5812 else if (*q >= 'a' && *q <= 'f')
5813 dig = *q - 'a' + 10;
5814 else
5815 break;
5817 c = c * 16 + dig;
5819 /* If the Unicode character is larger than 256, we don't try
5820 to deal with it here. FIXME. */
5821 if (q < end && *q == '_' && c < 256)
5823 d_append_char (dpi, c);
5824 p = q;
5825 continue;
5829 d_append_char (dpi, *p);
5833 /* Print a list of modifiers. SUFFIX is 1 if we are printing
5834 qualifiers on this after printing a function. */
5836 static void
5837 d_print_mod_list (struct d_print_info *dpi, int options,
5838 struct d_print_mod *mods, int suffix)
5840 struct d_print_template *hold_dpt;
5842 if (mods == NULL || d_print_saw_error (dpi))
5843 return;
5845 if (mods->printed
5846 || (! suffix
5847 && (is_fnqual_component_type (mods->mod->type))))
5849 d_print_mod_list (dpi, options, mods->next, suffix);
5850 return;
5853 mods->printed = 1;
5855 hold_dpt = dpi->templates;
5856 dpi->templates = mods->templates;
5858 if (mods->mod->type == DEMANGLE_COMPONENT_FUNCTION_TYPE)
5860 d_print_function_type (dpi, options, mods->mod, mods->next);
5861 dpi->templates = hold_dpt;
5862 return;
5864 else if (mods->mod->type == DEMANGLE_COMPONENT_ARRAY_TYPE)
5866 d_print_array_type (dpi, options, mods->mod, mods->next);
5867 dpi->templates = hold_dpt;
5868 return;
5870 else if (mods->mod->type == DEMANGLE_COMPONENT_LOCAL_NAME)
5872 struct d_print_mod *hold_modifiers;
5873 struct demangle_component *dc;
5875 /* When this is on the modifier stack, we have pulled any
5876 qualifiers off the right argument already. Otherwise, we
5877 print it as usual, but don't let the left argument see any
5878 modifiers. */
5880 hold_modifiers = dpi->modifiers;
5881 dpi->modifiers = NULL;
5882 d_print_comp (dpi, options, d_left (mods->mod));
5883 dpi->modifiers = hold_modifiers;
5885 if ((options & DMGL_JAVA) == 0)
5886 d_append_string (dpi, "::");
5887 else
5888 d_append_char (dpi, '.');
5890 dc = d_right (mods->mod);
5892 if (dc->type == DEMANGLE_COMPONENT_DEFAULT_ARG)
5894 d_append_string (dpi, "{default arg#");
5895 d_append_num (dpi, dc->u.s_unary_num.num + 1);
5896 d_append_string (dpi, "}::");
5897 dc = dc->u.s_unary_num.sub;
5900 while (is_fnqual_component_type (dc->type))
5901 dc = d_left (dc);
5903 d_print_comp (dpi, options, dc);
5905 dpi->templates = hold_dpt;
5906 return;
5909 d_print_mod (dpi, options, mods->mod);
5911 dpi->templates = hold_dpt;
5913 d_print_mod_list (dpi, options, mods->next, suffix);
5916 /* Print a modifier. */
5918 static void
5919 d_print_mod (struct d_print_info *dpi, int options,
5920 struct demangle_component *mod)
5922 switch (mod->type)
5924 case DEMANGLE_COMPONENT_RESTRICT:
5925 case DEMANGLE_COMPONENT_RESTRICT_THIS:
5926 d_append_string (dpi, " restrict");
5927 return;
5928 case DEMANGLE_COMPONENT_VOLATILE:
5929 case DEMANGLE_COMPONENT_VOLATILE_THIS:
5930 d_append_string (dpi, " volatile");
5931 return;
5932 case DEMANGLE_COMPONENT_CONST:
5933 case DEMANGLE_COMPONENT_CONST_THIS:
5934 d_append_string (dpi, " const");
5935 return;
5936 case DEMANGLE_COMPONENT_TRANSACTION_SAFE:
5937 d_append_string (dpi, " transaction_safe");
5938 return;
5939 case DEMANGLE_COMPONENT_NOEXCEPT:
5940 d_append_string (dpi, " noexcept");
5941 if (d_right (mod))
5943 d_append_char (dpi, '(');
5944 d_print_comp (dpi, options, d_right (mod));
5945 d_append_char (dpi, ')');
5947 return;
5948 case DEMANGLE_COMPONENT_THROW_SPEC:
5949 d_append_string (dpi, " throw");
5950 if (d_right (mod))
5952 d_append_char (dpi, '(');
5953 d_print_comp (dpi, options, d_right (mod));
5954 d_append_char (dpi, ')');
5956 return;
5957 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
5958 d_append_char (dpi, ' ');
5959 d_print_comp (dpi, options, d_right (mod));
5960 return;
5961 case DEMANGLE_COMPONENT_POINTER:
5962 /* There is no pointer symbol in Java. */
5963 if ((options & DMGL_JAVA) == 0)
5964 d_append_char (dpi, '*');
5965 return;
5966 case DEMANGLE_COMPONENT_REFERENCE_THIS:
5967 /* For the ref-qualifier, put a space before the &. */
5968 d_append_char (dpi, ' ');
5969 /* FALLTHRU */
5970 case DEMANGLE_COMPONENT_REFERENCE:
5971 d_append_char (dpi, '&');
5972 return;
5973 case DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS:
5974 d_append_char (dpi, ' ');
5975 /* FALLTHRU */
5976 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
5977 d_append_string (dpi, "&&");
5978 return;
5979 case DEMANGLE_COMPONENT_COMPLEX:
5980 d_append_string (dpi, "complex ");
5981 return;
5982 case DEMANGLE_COMPONENT_IMAGINARY:
5983 d_append_string (dpi, "imaginary ");
5984 return;
5985 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
5986 if (d_last_char (dpi) != '(')
5987 d_append_char (dpi, ' ');
5988 d_print_comp (dpi, options, d_left (mod));
5989 d_append_string (dpi, "::*");
5990 return;
5991 case DEMANGLE_COMPONENT_TYPED_NAME:
5992 d_print_comp (dpi, options, d_left (mod));
5993 return;
5994 case DEMANGLE_COMPONENT_VECTOR_TYPE:
5995 d_append_string (dpi, " __vector(");
5996 d_print_comp (dpi, options, d_left (mod));
5997 d_append_char (dpi, ')');
5998 return;
6000 default:
6001 /* Otherwise, we have something that won't go back on the
6002 modifier stack, so we can just print it. */
6003 d_print_comp (dpi, options, mod);
6004 return;
6008 /* Print a function type, except for the return type. */
6010 static void
6011 d_print_function_type (struct d_print_info *dpi, int options,
6012 struct demangle_component *dc,
6013 struct d_print_mod *mods)
6015 int need_paren;
6016 int need_space;
6017 struct d_print_mod *p;
6018 struct d_print_mod *hold_modifiers;
6020 need_paren = 0;
6021 need_space = 0;
6022 for (p = mods; p != NULL; p = p->next)
6024 if (p->printed)
6025 break;
6027 switch (p->mod->type)
6029 case DEMANGLE_COMPONENT_POINTER:
6030 case DEMANGLE_COMPONENT_REFERENCE:
6031 case DEMANGLE_COMPONENT_RVALUE_REFERENCE:
6032 need_paren = 1;
6033 break;
6034 case DEMANGLE_COMPONENT_RESTRICT:
6035 case DEMANGLE_COMPONENT_VOLATILE:
6036 case DEMANGLE_COMPONENT_CONST:
6037 case DEMANGLE_COMPONENT_VENDOR_TYPE_QUAL:
6038 case DEMANGLE_COMPONENT_COMPLEX:
6039 case DEMANGLE_COMPONENT_IMAGINARY:
6040 case DEMANGLE_COMPONENT_PTRMEM_TYPE:
6041 need_space = 1;
6042 need_paren = 1;
6043 break;
6044 FNQUAL_COMPONENT_CASE:
6045 break;
6046 default:
6047 break;
6049 if (need_paren)
6050 break;
6053 if (need_paren)
6055 if (! need_space)
6057 if (d_last_char (dpi) != '('
6058 && d_last_char (dpi) != '*')
6059 need_space = 1;
6061 if (need_space && d_last_char (dpi) != ' ')
6062 d_append_char (dpi, ' ');
6063 d_append_char (dpi, '(');
6066 hold_modifiers = dpi->modifiers;
6067 dpi->modifiers = NULL;
6069 d_print_mod_list (dpi, options, mods, 0);
6071 if (need_paren)
6072 d_append_char (dpi, ')');
6074 d_append_char (dpi, '(');
6076 if (d_right (dc) != NULL)
6077 d_print_comp (dpi, options, d_right (dc));
6079 d_append_char (dpi, ')');
6081 d_print_mod_list (dpi, options, mods, 1);
6083 dpi->modifiers = hold_modifiers;
6086 /* Print an array type, except for the element type. */
6088 static void
6089 d_print_array_type (struct d_print_info *dpi, int options,
6090 struct demangle_component *dc,
6091 struct d_print_mod *mods)
6093 int need_space;
6095 need_space = 1;
6096 if (mods != NULL)
6098 int need_paren;
6099 struct d_print_mod *p;
6101 need_paren = 0;
6102 for (p = mods; p != NULL; p = p->next)
6104 if (! p->printed)
6106 if (p->mod->type == DEMANGLE_COMPONENT_ARRAY_TYPE)
6108 need_space = 0;
6109 break;
6111 else
6113 need_paren = 1;
6114 need_space = 1;
6115 break;
6120 if (need_paren)
6121 d_append_string (dpi, " (");
6123 d_print_mod_list (dpi, options, mods, 0);
6125 if (need_paren)
6126 d_append_char (dpi, ')');
6129 if (need_space)
6130 d_append_char (dpi, ' ');
6132 d_append_char (dpi, '[');
6134 if (d_left (dc) != NULL)
6135 d_print_comp (dpi, options, d_left (dc));
6137 d_append_char (dpi, ']');
6140 /* Print an operator in an expression. */
6142 static void
6143 d_print_expr_op (struct d_print_info *dpi, int options,
6144 struct demangle_component *dc)
6146 if (dc->type == DEMANGLE_COMPONENT_OPERATOR)
6147 d_append_buffer (dpi, dc->u.s_operator.op->name,
6148 dc->u.s_operator.op->len);
6149 else
6150 d_print_comp (dpi, options, dc);
6153 /* Print a cast. */
6155 static void
6156 d_print_cast (struct d_print_info *dpi, int options,
6157 struct demangle_component *dc)
6159 d_print_comp (dpi, options, d_left (dc));
6162 /* Print a conversion operator. */
6164 static void
6165 d_print_conversion (struct d_print_info *dpi, int options,
6166 struct demangle_component *dc)
6168 struct d_print_template dpt;
6170 /* For a conversion operator, we need the template parameters from
6171 the enclosing template in scope for processing the type. */
6172 if (dpi->current_template != NULL)
6174 dpt.next = dpi->templates;
6175 dpi->templates = &dpt;
6176 dpt.template_decl = dpi->current_template;
6179 if (d_left (dc)->type != DEMANGLE_COMPONENT_TEMPLATE)
6181 d_print_comp (dpi, options, d_left (dc));
6182 if (dpi->current_template != NULL)
6183 dpi->templates = dpt.next;
6185 else
6187 d_print_comp (dpi, options, d_left (d_left (dc)));
6189 /* For a templated cast operator, we need to remove the template
6190 parameters from scope after printing the operator name,
6191 so we need to handle the template printing here. */
6192 if (dpi->current_template != NULL)
6193 dpi->templates = dpt.next;
6195 if (d_last_char (dpi) == '<')
6196 d_append_char (dpi, ' ');
6197 d_append_char (dpi, '<');
6198 d_print_comp (dpi, options, d_right (d_left (dc)));
6199 /* Avoid generating two consecutive '>' characters, to avoid
6200 the C++ syntactic ambiguity. */
6201 if (d_last_char (dpi) == '>')
6202 d_append_char (dpi, ' ');
6203 d_append_char (dpi, '>');
6207 /* Initialize the information structure we use to pass around
6208 information. */
6210 CP_STATIC_IF_GLIBCPP_V3
6211 void
6212 cplus_demangle_init_info (const char *mangled, int options, size_t len,
6213 struct d_info *di)
6215 di->s = mangled;
6216 di->send = mangled + len;
6217 di->options = options;
6219 di->n = mangled;
6221 /* We cannot need more components than twice the number of chars in
6222 the mangled string. Most components correspond directly to
6223 chars, but the ARGLIST types are exceptions. */
6224 di->num_comps = 2 * len;
6225 di->next_comp = 0;
6227 /* Similarly, we cannot need more substitutions than there are
6228 chars in the mangled string. */
6229 di->num_subs = len;
6230 di->next_sub = 0;
6232 di->last_name = NULL;
6234 di->expansion = 0;
6235 di->is_expression = 0;
6236 di->is_conversion = 0;
6237 di->recursion_level = 0;
6240 /* Internal implementation for the demangler. If MANGLED is a g++ v3 ABI
6241 mangled name, return strings in repeated callback giving the demangled
6242 name. OPTIONS is the usual libiberty demangler options. On success,
6243 this returns 1. On failure, returns 0. */
6245 static int
6246 d_demangle_callback (const char *mangled, int options,
6247 demangle_callbackref callback, void *opaque)
6249 enum
6251 DCT_TYPE,
6252 DCT_MANGLED,
6253 DCT_GLOBAL_CTORS,
6254 DCT_GLOBAL_DTORS
6256 type;
6257 struct d_info di;
6258 struct demangle_component *dc;
6259 int status;
6261 if (mangled[0] == '_' && mangled[1] == 'Z')
6262 type = DCT_MANGLED;
6263 else if (strncmp (mangled, "_GLOBAL_", 8) == 0
6264 && (mangled[8] == '.' || mangled[8] == '_' || mangled[8] == '$')
6265 && (mangled[9] == 'D' || mangled[9] == 'I')
6266 && mangled[10] == '_')
6267 type = mangled[9] == 'I' ? DCT_GLOBAL_CTORS : DCT_GLOBAL_DTORS;
6268 else
6270 if ((options & DMGL_TYPES) == 0)
6271 return 0;
6272 type = DCT_TYPE;
6275 cplus_demangle_init_info (mangled, options, strlen (mangled), &di);
6277 /* PR 87675 - Check for a mangled string that is so long
6278 that we do not have enough stack space to demangle it. */
6279 if (((options & DMGL_NO_RECURSE_LIMIT) == 0)
6280 /* This check is a bit arbitrary, since what we really want to do is to
6281 compare the sizes of the di.comps and di.subs arrays against the
6282 amount of stack space remaining. But there is no portable way to do
6283 this, so instead we use the recursion limit as a guide to the maximum
6284 size of the arrays. */
6285 && (unsigned long) di.num_comps > DEMANGLE_RECURSION_LIMIT)
6287 /* FIXME: We need a way to indicate that a stack limit has been reached. */
6288 return 0;
6292 #ifdef CP_DYNAMIC_ARRAYS
6293 __extension__ struct demangle_component comps[di.num_comps];
6294 __extension__ struct demangle_component *subs[di.num_subs];
6296 di.comps = comps;
6297 di.subs = subs;
6298 #else
6299 di.comps = alloca (di.num_comps * sizeof (*di.comps));
6300 di.subs = alloca (di.num_subs * sizeof (*di.subs));
6301 #endif
6303 switch (type)
6305 case DCT_TYPE:
6306 dc = cplus_demangle_type (&di);
6307 break;
6308 case DCT_MANGLED:
6309 dc = cplus_demangle_mangled_name (&di, 1);
6310 break;
6311 case DCT_GLOBAL_CTORS:
6312 case DCT_GLOBAL_DTORS:
6313 d_advance (&di, 11);
6314 dc = d_make_comp (&di,
6315 (type == DCT_GLOBAL_CTORS
6316 ? DEMANGLE_COMPONENT_GLOBAL_CONSTRUCTORS
6317 : DEMANGLE_COMPONENT_GLOBAL_DESTRUCTORS),
6318 d_make_demangle_mangled_name (&di, d_str (&di)),
6319 NULL);
6320 d_advance (&di, strlen (d_str (&di)));
6321 break;
6322 default:
6323 abort (); /* We have listed all the cases. */
6326 /* If DMGL_PARAMS is set, then if we didn't consume the entire
6327 mangled string, then we didn't successfully demangle it. If
6328 DMGL_PARAMS is not set, we didn't look at the trailing
6329 parameters. */
6330 if (((options & DMGL_PARAMS) != 0) && d_peek_char (&di) != '\0')
6331 dc = NULL;
6333 #ifdef CP_DEMANGLE_DEBUG
6334 d_dump (dc, 0);
6335 #endif
6337 status = (dc != NULL)
6338 ? cplus_demangle_print_callback (options, dc, callback, opaque)
6339 : 0;
6342 return status;
6345 /* Entry point for the demangler. If MANGLED is a g++ v3 ABI mangled
6346 name, return a buffer allocated with malloc holding the demangled
6347 name. OPTIONS is the usual libiberty demangler options. On
6348 success, this sets *PALC to the allocated size of the returned
6349 buffer. On failure, this sets *PALC to 0 for a bad name, or 1 for
6350 a memory allocation failure, and returns NULL. */
6352 static char *
6353 d_demangle (const char *mangled, int options, size_t *palc)
6355 struct d_growable_string dgs;
6356 int status;
6358 d_growable_string_init (&dgs, 0);
6360 status = d_demangle_callback (mangled, options,
6361 d_growable_string_callback_adapter, &dgs);
6362 if (status == 0)
6364 free (dgs.buf);
6365 *palc = 0;
6366 return NULL;
6369 *palc = dgs.allocation_failure ? 1 : dgs.alc;
6370 return dgs.buf;
6373 #if defined(IN_LIBGCC2) || defined(IN_GLIBCPP_V3)
6375 extern char *__cxa_demangle (const char *, char *, size_t *, int *);
6377 /* ia64 ABI-mandated entry point in the C++ runtime library for
6378 performing demangling. MANGLED_NAME is a NUL-terminated character
6379 string containing the name to be demangled.
6381 OUTPUT_BUFFER is a region of memory, allocated with malloc, of
6382 *LENGTH bytes, into which the demangled name is stored. If
6383 OUTPUT_BUFFER is not long enough, it is expanded using realloc.
6384 OUTPUT_BUFFER may instead be NULL; in that case, the demangled name
6385 is placed in a region of memory allocated with malloc.
6387 If LENGTH is non-NULL, the length of the buffer containing the
6388 demangled name, is placed in *LENGTH.
6390 The return value is a pointer to the start of the NUL-terminated
6391 demangled name, or NULL if the demangling fails. The caller is
6392 responsible for deallocating this memory using free.
6394 *STATUS is set to one of the following values:
6395 0: The demangling operation succeeded.
6396 -1: A memory allocation failure occurred.
6397 -2: MANGLED_NAME is not a valid name under the C++ ABI mangling rules.
6398 -3: One of the arguments is invalid.
6400 The demangling is performed using the C++ ABI mangling rules, with
6401 GNU extensions. */
6403 char *
6404 __cxa_demangle (const char *mangled_name, char *output_buffer,
6405 size_t *length, int *status)
6407 char *demangled;
6408 size_t alc;
6410 if (mangled_name == NULL)
6412 if (status != NULL)
6413 *status = -3;
6414 return NULL;
6417 if (output_buffer != NULL && length == NULL)
6419 if (status != NULL)
6420 *status = -3;
6421 return NULL;
6424 demangled = d_demangle (mangled_name, DMGL_PARAMS | DMGL_TYPES, &alc);
6426 if (demangled == NULL)
6428 if (status != NULL)
6430 if (alc == 1)
6431 *status = -1;
6432 else
6433 *status = -2;
6435 return NULL;
6438 if (output_buffer == NULL)
6440 if (length != NULL)
6441 *length = alc;
6443 else
6445 if (strlen (demangled) < *length)
6447 strcpy (output_buffer, demangled);
6448 free (demangled);
6449 demangled = output_buffer;
6451 else
6453 free (output_buffer);
6454 *length = alc;
6458 if (status != NULL)
6459 *status = 0;
6461 return demangled;
6464 extern int __gcclibcxx_demangle_callback (const char *,
6465 void (*)
6466 (const char *, size_t, void *),
6467 void *);
6469 /* Alternative, allocationless entry point in the C++ runtime library
6470 for performing demangling. MANGLED_NAME is a NUL-terminated character
6471 string containing the name to be demangled.
6473 CALLBACK is a callback function, called with demangled string
6474 segments as demangling progresses; it is called at least once,
6475 but may be called more than once. OPAQUE is a generalized pointer
6476 used as a callback argument.
6478 The return code is one of the following values, equivalent to
6479 the STATUS values of __cxa_demangle() (excluding -1, since this
6480 function performs no memory allocations):
6481 0: The demangling operation succeeded.
6482 -2: MANGLED_NAME is not a valid name under the C++ ABI mangling rules.
6483 -3: One of the arguments is invalid.
6485 The demangling is performed using the C++ ABI mangling rules, with
6486 GNU extensions. */
6489 __gcclibcxx_demangle_callback (const char *mangled_name,
6490 void (*callback) (const char *, size_t, void *),
6491 void *opaque)
6493 int status;
6495 if (mangled_name == NULL || callback == NULL)
6496 return -3;
6498 status = d_demangle_callback (mangled_name, DMGL_PARAMS | DMGL_TYPES,
6499 callback, opaque);
6500 if (status == 0)
6501 return -2;
6503 return 0;
6506 #else /* ! (IN_LIBGCC2 || IN_GLIBCPP_V3) */
6508 /* Entry point for libiberty demangler. If MANGLED is a g++ v3 ABI
6509 mangled name, return a buffer allocated with malloc holding the
6510 demangled name. Otherwise, return NULL. */
6512 char *
6513 cplus_demangle_v3 (const char *mangled, int options)
6515 size_t alc;
6517 return d_demangle (mangled, options, &alc);
6521 cplus_demangle_v3_callback (const char *mangled, int options,
6522 demangle_callbackref callback, void *opaque)
6524 return d_demangle_callback (mangled, options, callback, opaque);
6527 /* Demangle a Java symbol. Java uses a subset of the V3 ABI C++ mangling
6528 conventions, but the output formatting is a little different.
6529 This instructs the C++ demangler not to emit pointer characters ("*"), to
6530 use Java's namespace separator symbol ("." instead of "::"), and to output
6531 JArray<TYPE> as TYPE[]. */
6533 char *
6534 java_demangle_v3 (const char *mangled)
6536 size_t alc;
6538 return d_demangle (mangled, DMGL_JAVA | DMGL_PARAMS | DMGL_RET_POSTFIX, &alc);
6542 java_demangle_v3_callback (const char *mangled,
6543 demangle_callbackref callback, void *opaque)
6545 return d_demangle_callback (mangled,
6546 DMGL_JAVA | DMGL_PARAMS | DMGL_RET_POSTFIX,
6547 callback, opaque);
6550 #endif /* IN_LIBGCC2 || IN_GLIBCPP_V3 */
6552 #ifndef IN_GLIBCPP_V3
6554 /* Demangle a string in order to find out whether it is a constructor
6555 or destructor. Return non-zero on success. Set *CTOR_KIND and
6556 *DTOR_KIND appropriately. */
6558 static int
6559 is_ctor_or_dtor (const char *mangled,
6560 enum gnu_v3_ctor_kinds *ctor_kind,
6561 enum gnu_v3_dtor_kinds *dtor_kind)
6563 struct d_info di;
6564 struct demangle_component *dc;
6565 int ret;
6567 *ctor_kind = (enum gnu_v3_ctor_kinds) 0;
6568 *dtor_kind = (enum gnu_v3_dtor_kinds) 0;
6570 cplus_demangle_init_info (mangled, DMGL_GNU_V3, strlen (mangled), &di);
6573 #ifdef CP_DYNAMIC_ARRAYS
6574 __extension__ struct demangle_component comps[di.num_comps];
6575 __extension__ struct demangle_component *subs[di.num_subs];
6577 di.comps = comps;
6578 di.subs = subs;
6579 #else
6580 di.comps = alloca (di.num_comps * sizeof (*di.comps));
6581 di.subs = alloca (di.num_subs * sizeof (*di.subs));
6582 #endif
6584 dc = cplus_demangle_mangled_name (&di, 1);
6586 /* Note that because we did not pass DMGL_PARAMS, we don't expect
6587 to demangle the entire string. */
6589 ret = 0;
6590 while (dc != NULL)
6592 switch (dc->type)
6594 /* These cannot appear on a constructor or destructor. */
6595 case DEMANGLE_COMPONENT_RESTRICT_THIS:
6596 case DEMANGLE_COMPONENT_VOLATILE_THIS:
6597 case DEMANGLE_COMPONENT_CONST_THIS:
6598 case DEMANGLE_COMPONENT_REFERENCE_THIS:
6599 case DEMANGLE_COMPONENT_RVALUE_REFERENCE_THIS:
6600 default:
6601 dc = NULL;
6602 break;
6603 case DEMANGLE_COMPONENT_TYPED_NAME:
6604 case DEMANGLE_COMPONENT_TEMPLATE:
6605 dc = d_left (dc);
6606 break;
6607 case DEMANGLE_COMPONENT_QUAL_NAME:
6608 case DEMANGLE_COMPONENT_LOCAL_NAME:
6609 dc = d_right (dc);
6610 break;
6611 case DEMANGLE_COMPONENT_CTOR:
6612 *ctor_kind = dc->u.s_ctor.kind;
6613 ret = 1;
6614 dc = NULL;
6615 break;
6616 case DEMANGLE_COMPONENT_DTOR:
6617 *dtor_kind = dc->u.s_dtor.kind;
6618 ret = 1;
6619 dc = NULL;
6620 break;
6625 return ret;
6628 /* Return whether NAME is the mangled form of a g++ V3 ABI constructor
6629 name. A non-zero return indicates the type of constructor. */
6631 enum gnu_v3_ctor_kinds
6632 is_gnu_v3_mangled_ctor (const char *name)
6634 enum gnu_v3_ctor_kinds ctor_kind;
6635 enum gnu_v3_dtor_kinds dtor_kind;
6637 if (! is_ctor_or_dtor (name, &ctor_kind, &dtor_kind))
6638 return (enum gnu_v3_ctor_kinds) 0;
6639 return ctor_kind;
6643 /* Return whether NAME is the mangled form of a g++ V3 ABI destructor
6644 name. A non-zero return indicates the type of destructor. */
6646 enum gnu_v3_dtor_kinds
6647 is_gnu_v3_mangled_dtor (const char *name)
6649 enum gnu_v3_ctor_kinds ctor_kind;
6650 enum gnu_v3_dtor_kinds dtor_kind;
6652 if (! is_ctor_or_dtor (name, &ctor_kind, &dtor_kind))
6653 return (enum gnu_v3_dtor_kinds) 0;
6654 return dtor_kind;
6657 #endif /* IN_GLIBCPP_V3 */
6659 #ifdef STANDALONE_DEMANGLER
6661 #include "getopt.h"
6662 #include "dyn-string.h"
6664 static void print_usage (FILE* fp, int exit_value);
6666 #define IS_ALPHA(CHAR) \
6667 (((CHAR) >= 'a' && (CHAR) <= 'z') \
6668 || ((CHAR) >= 'A' && (CHAR) <= 'Z'))
6670 /* Non-zero if CHAR is a character than can occur in a mangled name. */
6671 #define is_mangled_char(CHAR) \
6672 (IS_ALPHA (CHAR) || IS_DIGIT (CHAR) \
6673 || (CHAR) == '_' || (CHAR) == '.' || (CHAR) == '$')
6675 /* The name of this program, as invoked. */
6676 const char* program_name;
6678 /* Prints usage summary to FP and then exits with EXIT_VALUE. */
6680 static void
6681 print_usage (FILE* fp, int exit_value)
6683 fprintf (fp, "Usage: %s [options] [names ...]\n", program_name);
6684 fprintf (fp, "Options:\n");
6685 fprintf (fp, " -h,--help Display this message.\n");
6686 fprintf (fp, " -p,--no-params Don't display function parameters\n");
6687 fprintf (fp, " -v,--verbose Produce verbose demanglings.\n");
6688 fprintf (fp, "If names are provided, they are demangled. Otherwise filters standard input.\n");
6690 exit (exit_value);
6693 /* Option specification for getopt_long. */
6694 static const struct option long_options[] =
6696 { "help", no_argument, NULL, 'h' },
6697 { "no-params", no_argument, NULL, 'p' },
6698 { "verbose", no_argument, NULL, 'v' },
6699 { NULL, no_argument, NULL, 0 },
6702 /* Main entry for a demangling filter executable. It will demangle
6703 its command line arguments, if any. If none are provided, it will
6704 filter stdin to stdout, replacing any recognized mangled C++ names
6705 with their demangled equivalents. */
6708 main (int argc, char *argv[])
6710 int i;
6711 int opt_char;
6712 int options = DMGL_PARAMS | DMGL_ANSI | DMGL_TYPES;
6714 /* Use the program name of this program, as invoked. */
6715 program_name = argv[0];
6717 /* Parse options. */
6720 opt_char = getopt_long (argc, argv, "hpv", long_options, NULL);
6721 switch (opt_char)
6723 case '?': /* Unrecognized option. */
6724 print_usage (stderr, 1);
6725 break;
6727 case 'h':
6728 print_usage (stdout, 0);
6729 break;
6731 case 'p':
6732 options &= ~ DMGL_PARAMS;
6733 break;
6735 case 'v':
6736 options |= DMGL_VERBOSE;
6737 break;
6740 while (opt_char != -1);
6742 if (optind == argc)
6743 /* No command line arguments were provided. Filter stdin. */
6745 dyn_string_t mangled = dyn_string_new (3);
6746 char *s;
6748 /* Read all of input. */
6749 while (!feof (stdin))
6751 char c;
6753 /* Pile characters into mangled until we hit one that can't
6754 occur in a mangled name. */
6755 c = getchar ();
6756 while (!feof (stdin) && is_mangled_char (c))
6758 dyn_string_append_char (mangled, c);
6759 if (feof (stdin))
6760 break;
6761 c = getchar ();
6764 if (dyn_string_length (mangled) > 0)
6766 #ifdef IN_GLIBCPP_V3
6767 s = __cxa_demangle (dyn_string_buf (mangled), NULL, NULL, NULL);
6768 #else
6769 s = cplus_demangle_v3 (dyn_string_buf (mangled), options);
6770 #endif
6772 if (s != NULL)
6774 fputs (s, stdout);
6775 free (s);
6777 else
6779 /* It might not have been a mangled name. Print the
6780 original text. */
6781 fputs (dyn_string_buf (mangled), stdout);
6784 dyn_string_clear (mangled);
6787 /* If we haven't hit EOF yet, we've read one character that
6788 can't occur in a mangled name, so print it out. */
6789 if (!feof (stdin))
6790 putchar (c);
6793 dyn_string_delete (mangled);
6795 else
6796 /* Demangle command line arguments. */
6798 /* Loop over command line arguments. */
6799 for (i = optind; i < argc; ++i)
6801 char *s;
6802 #ifdef IN_GLIBCPP_V3
6803 int status;
6804 #endif
6806 /* Attempt to demangle. */
6807 #ifdef IN_GLIBCPP_V3
6808 s = __cxa_demangle (argv[i], NULL, NULL, &status);
6809 #else
6810 s = cplus_demangle_v3 (argv[i], options);
6811 #endif
6813 /* If it worked, print the demangled name. */
6814 if (s != NULL)
6816 printf ("%s\n", s);
6817 free (s);
6819 else
6821 #ifdef IN_GLIBCPP_V3
6822 fprintf (stderr, "Failed: %s (status %d)\n", argv[i], status);
6823 #else
6824 fprintf (stderr, "Failed: %s\n", argv[i]);
6825 #endif
6830 return 0;
6833 #endif /* STANDALONE_DEMANGLER */