OpenCores
URL https://opencores.org/ocsvn/open8_urisc/open8_urisc/trunk

Subversion Repositories open8_urisc

[/] [open8_urisc/] [trunk/] [gnu/] [binutils/] [libiberty/] [cp-demangle.c] - Blame information for rev 253

Go to most recent revision | Details | Compare with Previous | View Log

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

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.