call.c (add_list_candidates): Use OVL_FIRST.
[gcc.git] / gcc / cp / error.c
1 /* Call-backs for C++ error reporting.
2 This code is non-reentrant.
3 Copyright (C) 1993-2017 Free Software Foundation, Inc.
4 This file is part of GCC.
5
6 GCC is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3, or (at your option)
9 any later version.
10
11 GCC is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
19
20 #include "config.h"
21 #include "system.h"
22 #include "coretypes.h"
23 #include "cp-tree.h"
24 #include "stringpool.h"
25 #include "tree-diagnostic.h"
26 #include "langhooks-def.h"
27 #include "intl.h"
28 #include "cxx-pretty-print.h"
29 #include "tree-pretty-print.h"
30 #include "c-family/c-objc.h"
31 #include "ubsan.h"
32 #include "internal-fn.h"
33
34 #define pp_separate_with_comma(PP) pp_cxx_separate_with (PP, ',')
35 #define pp_separate_with_semicolon(PP) pp_cxx_separate_with (PP, ';')
36
37 /* cxx_pp is a C++ front-end-specific pretty printer: this is where we
38 dump C++ ASTs as strings. It is mostly used only by the various
39 tree -> string functions that are occasionally called from the
40 debugger or by the front-end for things like
41 __PRETTY_FUNCTION__. */
42 static cxx_pretty_printer actual_pretty_printer;
43 static cxx_pretty_printer * const cxx_pp = &actual_pretty_printer;
44
45 /* Translate if being used for diagnostics, but not for dump files or
46 __PRETTY_FUNCTION. */
47 #define M_(msgid) (pp_translate_identifiers (cxx_pp) ? _(msgid) : (msgid))
48
49 # define NEXT_CODE(T) (TREE_CODE (TREE_TYPE (T)))
50
51 static const char *args_to_string (tree, int);
52 static const char *assop_to_string (enum tree_code);
53 static const char *code_to_string (enum tree_code);
54 static const char *cv_to_string (tree, int);
55 static const char *decl_to_string (tree, int);
56 static const char *expr_to_string (tree);
57 static const char *fndecl_to_string (tree, int);
58 static const char *op_to_string (enum tree_code);
59 static const char *parm_to_string (int);
60 static const char *type_to_string (tree, int);
61
62 static void dump_alias_template_specialization (cxx_pretty_printer *, tree, int);
63 static void dump_type (cxx_pretty_printer *, tree, int);
64 static void dump_typename (cxx_pretty_printer *, tree, int);
65 static void dump_simple_decl (cxx_pretty_printer *, tree, tree, int);
66 static void dump_decl (cxx_pretty_printer *, tree, int);
67 static void dump_template_decl (cxx_pretty_printer *, tree, int);
68 static void dump_function_decl (cxx_pretty_printer *, tree, int);
69 static void dump_expr (cxx_pretty_printer *, tree, int);
70 static void dump_unary_op (cxx_pretty_printer *, const char *, tree, int);
71 static void dump_binary_op (cxx_pretty_printer *, const char *, tree, int);
72 static void dump_aggr_type (cxx_pretty_printer *, tree, int);
73 static void dump_type_prefix (cxx_pretty_printer *, tree, int);
74 static void dump_type_suffix (cxx_pretty_printer *, tree, int);
75 static void dump_function_name (cxx_pretty_printer *, tree, int);
76 static void dump_call_expr_args (cxx_pretty_printer *, tree, int, bool);
77 static void dump_aggr_init_expr_args (cxx_pretty_printer *, tree, int, bool);
78 static void dump_expr_list (cxx_pretty_printer *, tree, int);
79 static void dump_global_iord (cxx_pretty_printer *, tree);
80 static void dump_parameters (cxx_pretty_printer *, tree, int);
81 static void dump_ref_qualifier (cxx_pretty_printer *, tree, int);
82 static void dump_exception_spec (cxx_pretty_printer *, tree, int);
83 static void dump_template_argument (cxx_pretty_printer *, tree, int);
84 static void dump_template_argument_list (cxx_pretty_printer *, tree, int);
85 static void dump_template_parameter (cxx_pretty_printer *, tree, int);
86 static void dump_template_bindings (cxx_pretty_printer *, tree, tree,
87 vec<tree, va_gc> *);
88 static void dump_scope (cxx_pretty_printer *, tree, int);
89 static void dump_template_parms (cxx_pretty_printer *, tree, int, int);
90 static int get_non_default_template_args_count (tree, int);
91 static const char *function_category (tree);
92 static void maybe_print_constexpr_context (diagnostic_context *);
93 static void maybe_print_instantiation_context (diagnostic_context *);
94 static void print_instantiation_full_context (diagnostic_context *);
95 static void print_instantiation_partial_context (diagnostic_context *,
96 struct tinst_level *,
97 location_t);
98 static void cp_diagnostic_starter (diagnostic_context *, diagnostic_info *);
99 static void cp_print_error_function (diagnostic_context *, diagnostic_info *);
100
101 static bool cp_printer (pretty_printer *, text_info *, const char *,
102 int, bool, bool, bool);
103
104 /* CONTEXT->printer is a basic pretty printer that was constructed
105 presumably by diagnostic_initialize(), called early in the
106 compiler's initialization process (in general_init) Before the FE
107 is initialized. This (C++) FE-specific diagnostic initializer is
108 thus replacing the basic pretty printer with one that has C++-aware
109 capacities. */
110
111 void
112 cxx_initialize_diagnostics (diagnostic_context *context)
113 {
114 pretty_printer *base = context->printer;
115 cxx_pretty_printer *pp = XNEW (cxx_pretty_printer);
116 context->printer = new (pp) cxx_pretty_printer ();
117
118 /* It is safe to free this object because it was previously XNEW()'d. */
119 base->~pretty_printer ();
120 XDELETE (base);
121
122 c_common_diagnostics_set_defaults (context);
123 diagnostic_starter (context) = cp_diagnostic_starter;
124 /* diagnostic_finalizer is already c_diagnostic_finalizer. */
125 diagnostic_format_decoder (context) = cp_printer;
126 }
127
128 /* Dump a scope, if deemed necessary. */
129
130 static void
131 dump_scope (cxx_pretty_printer *pp, tree scope, int flags)
132 {
133 int f = flags & (TFF_SCOPE | TFF_CHASE_TYPEDEF);
134
135 if (scope == NULL_TREE)
136 return;
137
138 if (TREE_CODE (scope) == NAMESPACE_DECL)
139 {
140 if (scope != global_namespace)
141 {
142 dump_decl (pp, scope, f);
143 pp_cxx_colon_colon (pp);
144 }
145 }
146 else if (AGGREGATE_TYPE_P (scope))
147 {
148 dump_type (pp, scope, f);
149 pp_cxx_colon_colon (pp);
150 }
151 else if ((flags & TFF_SCOPE) && TREE_CODE (scope) == FUNCTION_DECL)
152 {
153 dump_function_decl (pp, scope, f);
154 pp_cxx_colon_colon (pp);
155 }
156 }
157
158 /* Dump the template ARGument under control of FLAGS. */
159
160 static void
161 dump_template_argument (cxx_pretty_printer *pp, tree arg, int flags)
162 {
163 if (ARGUMENT_PACK_P (arg))
164 dump_template_argument_list (pp, ARGUMENT_PACK_ARGS (arg),
165 /* No default args in argument packs. */
166 flags|TFF_NO_OMIT_DEFAULT_TEMPLATE_ARGUMENTS);
167 else if (TYPE_P (arg) || TREE_CODE (arg) == TEMPLATE_DECL)
168 dump_type (pp, arg, flags & ~TFF_CLASS_KEY_OR_ENUM);
169 else
170 {
171 if (TREE_CODE (arg) == TREE_LIST)
172 arg = TREE_VALUE (arg);
173
174 /* Strip implicit conversions. */
175 while (CONVERT_EXPR_P (arg))
176 arg = TREE_OPERAND (arg, 0);
177
178 dump_expr (pp, arg, (flags | TFF_EXPR_IN_PARENS) & ~TFF_CLASS_KEY_OR_ENUM);
179 }
180 }
181
182 /* Count the number of template arguments ARGS whose value does not
183 match the (optional) default template parameter in PARAMS */
184
185 static int
186 get_non_default_template_args_count (tree args, int flags)
187 {
188 int n = TREE_VEC_LENGTH (INNERMOST_TEMPLATE_ARGS (args));
189
190 if (/* We use this flag when generating debug information. We don't
191 want to expand templates at this point, for this may generate
192 new decls, which gets decl counts out of sync, which may in
193 turn cause codegen differences between compilations with and
194 without -g. */
195 (flags & TFF_NO_OMIT_DEFAULT_TEMPLATE_ARGUMENTS) != 0
196 || !flag_pretty_templates)
197 return n;
198
199 return GET_NON_DEFAULT_TEMPLATE_ARGS_COUNT (INNERMOST_TEMPLATE_ARGS (args));
200 }
201
202 /* Dump a template-argument-list ARGS (always a TREE_VEC) under control
203 of FLAGS. */
204
205 static void
206 dump_template_argument_list (cxx_pretty_printer *pp, tree args, int flags)
207 {
208 int n = get_non_default_template_args_count (args, flags);
209 int need_comma = 0;
210 int i;
211
212 for (i = 0; i < n; ++i)
213 {
214 tree arg = TREE_VEC_ELT (args, i);
215
216 /* Only print a comma if we know there is an argument coming. In
217 the case of an empty template argument pack, no actual
218 argument will be printed. */
219 if (need_comma
220 && (!ARGUMENT_PACK_P (arg)
221 || TREE_VEC_LENGTH (ARGUMENT_PACK_ARGS (arg)) > 0))
222 pp_separate_with_comma (pp);
223
224 dump_template_argument (pp, arg, flags);
225 need_comma = 1;
226 }
227 }
228
229 /* Dump a template parameter PARM (a TREE_LIST) under control of FLAGS. */
230
231 static void
232 dump_template_parameter (cxx_pretty_printer *pp, tree parm, int flags)
233 {
234 tree p;
235 tree a;
236
237 if (parm == error_mark_node)
238 return;
239
240 p = TREE_VALUE (parm);
241 a = TREE_PURPOSE (parm);
242
243 if (TREE_CODE (p) == TYPE_DECL)
244 {
245 if (flags & TFF_DECL_SPECIFIERS)
246 {
247 pp_cxx_ws_string (pp, "class");
248 if (TEMPLATE_TYPE_PARAMETER_PACK (TREE_TYPE (p)))
249 pp_cxx_ws_string (pp, "...");
250 if (DECL_NAME (p))
251 pp_cxx_tree_identifier (pp, DECL_NAME (p));
252 }
253 else if (DECL_NAME (p))
254 pp_cxx_tree_identifier (pp, DECL_NAME (p));
255 else
256 pp_cxx_canonical_template_parameter (pp, TREE_TYPE (p));
257 }
258 else
259 dump_decl (pp, p, flags | TFF_DECL_SPECIFIERS);
260
261 if ((flags & TFF_FUNCTION_DEFAULT_ARGUMENTS) && a != NULL_TREE)
262 {
263 pp_cxx_whitespace (pp);
264 pp_equal (pp);
265 pp_cxx_whitespace (pp);
266 if (TREE_CODE (p) == TYPE_DECL || TREE_CODE (p) == TEMPLATE_DECL)
267 dump_type (pp, a, flags & ~TFF_CHASE_TYPEDEF);
268 else
269 dump_expr (pp, a, flags | TFF_EXPR_IN_PARENS);
270 }
271 }
272
273 /* Dump, under control of FLAGS, a template-parameter-list binding.
274 PARMS is a TREE_LIST of TREE_VEC of TREE_LIST and ARGS is a
275 TREE_VEC. */
276
277 static void
278 dump_template_bindings (cxx_pretty_printer *pp, tree parms, tree args,
279 vec<tree, va_gc> *typenames)
280 {
281 bool need_semicolon = false;
282 int i;
283 tree t;
284
285 while (parms)
286 {
287 tree p = TREE_VALUE (parms);
288 int lvl = TMPL_PARMS_DEPTH (parms);
289 int arg_idx = 0;
290 int i;
291 tree lvl_args = NULL_TREE;
292
293 /* Don't crash if we had an invalid argument list. */
294 if (TMPL_ARGS_DEPTH (args) >= lvl)
295 lvl_args = TMPL_ARGS_LEVEL (args, lvl);
296
297 for (i = 0; i < TREE_VEC_LENGTH (p); ++i)
298 {
299 tree arg = NULL_TREE;
300
301 /* Don't crash if we had an invalid argument list. */
302 if (lvl_args && NUM_TMPL_ARGS (lvl_args) > arg_idx)
303 arg = TREE_VEC_ELT (lvl_args, arg_idx);
304
305 if (need_semicolon)
306 pp_separate_with_semicolon (pp);
307 dump_template_parameter (pp, TREE_VEC_ELT (p, i),
308 TFF_PLAIN_IDENTIFIER);
309 pp_cxx_whitespace (pp);
310 pp_equal (pp);
311 pp_cxx_whitespace (pp);
312 if (arg)
313 {
314 if (ARGUMENT_PACK_P (arg))
315 pp_cxx_left_brace (pp);
316 dump_template_argument (pp, arg, TFF_PLAIN_IDENTIFIER);
317 if (ARGUMENT_PACK_P (arg))
318 pp_cxx_right_brace (pp);
319 }
320 else
321 pp_string (pp, M_("<missing>"));
322
323 ++arg_idx;
324 need_semicolon = true;
325 }
326
327 parms = TREE_CHAIN (parms);
328 }
329
330 /* Don't bother with typenames for a partial instantiation. */
331 if (vec_safe_is_empty (typenames) || uses_template_parms (args))
332 return;
333
334 /* Don't try to print typenames when we're processing a clone. */
335 if (current_function_decl
336 && !DECL_LANG_SPECIFIC (current_function_decl))
337 return;
338
339 /* Don't try to do this once cgraph starts throwing away front-end
340 information. */
341 if (at_eof >= 2)
342 return;
343
344 FOR_EACH_VEC_SAFE_ELT (typenames, i, t)
345 {
346 if (need_semicolon)
347 pp_separate_with_semicolon (pp);
348 dump_type (pp, t, TFF_PLAIN_IDENTIFIER);
349 pp_cxx_whitespace (pp);
350 pp_equal (pp);
351 pp_cxx_whitespace (pp);
352 push_deferring_access_checks (dk_no_check);
353 t = tsubst (t, args, tf_none, NULL_TREE);
354 pop_deferring_access_checks ();
355 /* Strip typedefs. We can't just use TFF_CHASE_TYPEDEF because
356 pp_simple_type_specifier doesn't know about it. */
357 t = strip_typedefs (t);
358 dump_type (pp, t, TFF_PLAIN_IDENTIFIER);
359 }
360 }
361
362 /* Dump a human-readable equivalent of the alias template
363 specialization of T. */
364
365 static void
366 dump_alias_template_specialization (cxx_pretty_printer *pp, tree t, int flags)
367 {
368 gcc_assert (alias_template_specialization_p (t));
369
370 tree decl = TYPE_NAME (t);
371 if (!(flags & TFF_UNQUALIFIED_NAME))
372 dump_scope (pp, CP_DECL_CONTEXT (decl), flags);
373 pp_cxx_tree_identifier (pp, DECL_NAME (decl));
374 dump_template_parms (pp, DECL_TEMPLATE_INFO (decl),
375 /*primary=*/false,
376 flags & ~TFF_TEMPLATE_HEADER);
377 }
378
379 /* Dump a human-readable equivalent of TYPE. FLAGS controls the
380 format. */
381
382 static void
383 dump_type (cxx_pretty_printer *pp, tree t, int flags)
384 {
385 if (t == NULL_TREE)
386 return;
387
388 /* Don't print e.g. "struct mytypedef". */
389 if (TYPE_P (t) && typedef_variant_p (t))
390 {
391 tree decl = TYPE_NAME (t);
392 if ((flags & TFF_CHASE_TYPEDEF)
393 || DECL_SELF_REFERENCE_P (decl)
394 || (!flag_pretty_templates
395 && DECL_LANG_SPECIFIC (decl) && DECL_TEMPLATE_INFO (decl)))
396 t = strip_typedefs (t);
397 else if (alias_template_specialization_p (t))
398 {
399 dump_alias_template_specialization (pp, t, flags);
400 return;
401 }
402 else if (same_type_p (t, TREE_TYPE (decl)))
403 t = decl;
404 else
405 {
406 pp_cxx_cv_qualifier_seq (pp, t);
407 pp_cxx_tree_identifier (pp, TYPE_IDENTIFIER (t));
408 return;
409 }
410 }
411
412 if (TYPE_PTRMEMFUNC_P (t))
413 goto offset_type;
414
415 switch (TREE_CODE (t))
416 {
417 case LANG_TYPE:
418 if (t == init_list_type_node)
419 pp_string (pp, M_("<brace-enclosed initializer list>"));
420 else if (t == unknown_type_node)
421 pp_string (pp, M_("<unresolved overloaded function type>"));
422 else
423 {
424 pp_cxx_cv_qualifier_seq (pp, t);
425 pp_cxx_tree_identifier (pp, TYPE_IDENTIFIER (t));
426 }
427 break;
428
429 case TREE_LIST:
430 /* A list of function parms. */
431 dump_parameters (pp, t, flags);
432 break;
433
434 case IDENTIFIER_NODE:
435 pp_cxx_tree_identifier (pp, t);
436 break;
437
438 case TREE_BINFO:
439 dump_type (pp, BINFO_TYPE (t), flags);
440 break;
441
442 case RECORD_TYPE:
443 case UNION_TYPE:
444 case ENUMERAL_TYPE:
445 dump_aggr_type (pp, t, flags);
446 break;
447
448 case TYPE_DECL:
449 if (flags & TFF_CHASE_TYPEDEF)
450 {
451 dump_type (pp, DECL_ORIGINAL_TYPE (t)
452 ? DECL_ORIGINAL_TYPE (t) : TREE_TYPE (t), flags);
453 break;
454 }
455 /* Fall through. */
456
457 case TEMPLATE_DECL:
458 case NAMESPACE_DECL:
459 dump_decl (pp, t, flags & ~TFF_DECL_SPECIFIERS);
460 break;
461
462 case INTEGER_TYPE:
463 case REAL_TYPE:
464 case VOID_TYPE:
465 case BOOLEAN_TYPE:
466 case COMPLEX_TYPE:
467 case VECTOR_TYPE:
468 case FIXED_POINT_TYPE:
469 pp_type_specifier_seq (pp, t);
470 break;
471
472 case TEMPLATE_TEMPLATE_PARM:
473 /* For parameters inside template signature. */
474 if (TYPE_IDENTIFIER (t))
475 pp_cxx_tree_identifier (pp, TYPE_IDENTIFIER (t));
476 else
477 pp_cxx_canonical_template_parameter (pp, t);
478 break;
479
480 case BOUND_TEMPLATE_TEMPLATE_PARM:
481 {
482 tree args = TYPE_TI_ARGS (t);
483 pp_cxx_cv_qualifier_seq (pp, t);
484 pp_cxx_tree_identifier (pp, TYPE_IDENTIFIER (t));
485 pp_cxx_begin_template_argument_list (pp);
486 dump_template_argument_list (pp, args, flags);
487 pp_cxx_end_template_argument_list (pp);
488 }
489 break;
490
491 case TEMPLATE_TYPE_PARM:
492 pp_cxx_cv_qualifier_seq (pp, t);
493 if (tree c = PLACEHOLDER_TYPE_CONSTRAINTS (t))
494 pp_cxx_constrained_type_spec (pp, c);
495 else if (TYPE_IDENTIFIER (t))
496 pp_cxx_tree_identifier (pp, TYPE_IDENTIFIER (t));
497 else
498 pp_cxx_canonical_template_parameter
499 (pp, TEMPLATE_TYPE_PARM_INDEX (t));
500 break;
501
502 /* This is not always necessary for pointers and such, but doing this
503 reduces code size. */
504 case ARRAY_TYPE:
505 case POINTER_TYPE:
506 case REFERENCE_TYPE:
507 case OFFSET_TYPE:
508 offset_type:
509 case FUNCTION_TYPE:
510 case METHOD_TYPE:
511 {
512 dump_type_prefix (pp, t, flags);
513 dump_type_suffix (pp, t, flags);
514 break;
515 }
516 case TYPENAME_TYPE:
517 if (! (flags & TFF_CHASE_TYPEDEF)
518 && DECL_ORIGINAL_TYPE (TYPE_NAME (t)))
519 {
520 dump_decl (pp, TYPE_NAME (t), TFF_PLAIN_IDENTIFIER);
521 break;
522 }
523 pp_cxx_cv_qualifier_seq (pp, t);
524 pp_cxx_ws_string (pp,
525 TYPENAME_IS_ENUM_P (t) ? "enum"
526 : TYPENAME_IS_CLASS_P (t) ? "class"
527 : "typename");
528 dump_typename (pp, t, flags);
529 break;
530
531 case UNBOUND_CLASS_TEMPLATE:
532 if (! (flags & TFF_UNQUALIFIED_NAME))
533 {
534 dump_type (pp, TYPE_CONTEXT (t), flags);
535 pp_cxx_colon_colon (pp);
536 }
537 pp_cxx_ws_string (pp, "template");
538 dump_type (pp, TYPE_IDENTIFIER (t), flags);
539 break;
540
541 case TYPEOF_TYPE:
542 pp_cxx_ws_string (pp, "__typeof__");
543 pp_cxx_whitespace (pp);
544 pp_cxx_left_paren (pp);
545 dump_expr (pp, TYPEOF_TYPE_EXPR (t), flags & ~TFF_EXPR_IN_PARENS);
546 pp_cxx_right_paren (pp);
547 break;
548
549 case UNDERLYING_TYPE:
550 pp_cxx_ws_string (pp, "__underlying_type");
551 pp_cxx_whitespace (pp);
552 pp_cxx_left_paren (pp);
553 dump_expr (pp, UNDERLYING_TYPE_TYPE (t), flags & ~TFF_EXPR_IN_PARENS);
554 pp_cxx_right_paren (pp);
555 break;
556
557 case TYPE_PACK_EXPANSION:
558 dump_type (pp, PACK_EXPANSION_PATTERN (t), flags);
559 pp_cxx_ws_string (pp, "...");
560 break;
561
562 case TYPE_ARGUMENT_PACK:
563 dump_template_argument (pp, t, flags);
564 break;
565
566 case DECLTYPE_TYPE:
567 pp_cxx_ws_string (pp, "decltype");
568 pp_cxx_whitespace (pp);
569 pp_cxx_left_paren (pp);
570 dump_expr (pp, DECLTYPE_TYPE_EXPR (t), flags & ~TFF_EXPR_IN_PARENS);
571 pp_cxx_right_paren (pp);
572 break;
573
574 case NULLPTR_TYPE:
575 pp_string (pp, "std::nullptr_t");
576 break;
577
578 default:
579 pp_unsupported_tree (pp, t);
580 /* Fall through. */
581
582 case ERROR_MARK:
583 pp_string (pp, M_("<type error>"));
584 break;
585 }
586 }
587
588 /* Dump a TYPENAME_TYPE. We need to notice when the context is itself
589 a TYPENAME_TYPE. */
590
591 static void
592 dump_typename (cxx_pretty_printer *pp, tree t, int flags)
593 {
594 tree ctx = TYPE_CONTEXT (t);
595
596 if (TREE_CODE (ctx) == TYPENAME_TYPE)
597 dump_typename (pp, ctx, flags);
598 else
599 dump_type (pp, ctx, flags & ~TFF_CLASS_KEY_OR_ENUM);
600 pp_cxx_colon_colon (pp);
601 dump_decl (pp, TYPENAME_TYPE_FULLNAME (t), flags);
602 }
603
604 /* Return the name of the supplied aggregate, or enumeral type. */
605
606 const char *
607 class_key_or_enum_as_string (tree t)
608 {
609 if (TREE_CODE (t) == ENUMERAL_TYPE)
610 {
611 if (SCOPED_ENUM_P (t))
612 return "enum class";
613 else
614 return "enum";
615 }
616 else if (TREE_CODE (t) == UNION_TYPE)
617 return "union";
618 else if (TYPE_LANG_SPECIFIC (t) && CLASSTYPE_DECLARED_CLASS (t))
619 return "class";
620 else
621 return "struct";
622 }
623
624 /* Print out a class declaration T under the control of FLAGS,
625 in the form `class foo'. */
626
627 static void
628 dump_aggr_type (cxx_pretty_printer *pp, tree t, int flags)
629 {
630 tree name;
631 const char *variety = class_key_or_enum_as_string (t);
632 int typdef = 0;
633 int tmplate = 0;
634
635 pp_cxx_cv_qualifier_seq (pp, t);
636
637 if (flags & TFF_CLASS_KEY_OR_ENUM)
638 pp_cxx_ws_string (pp, variety);
639
640 name = TYPE_NAME (t);
641
642 if (name)
643 {
644 typdef = (!DECL_ARTIFICIAL (name)
645 /* An alias specialization is not considered to be a
646 typedef. */
647 && !alias_template_specialization_p (t));
648
649 if ((typdef
650 && ((flags & TFF_CHASE_TYPEDEF)
651 || (!flag_pretty_templates && DECL_LANG_SPECIFIC (name)
652 && DECL_TEMPLATE_INFO (name))))
653 || DECL_SELF_REFERENCE_P (name))
654 {
655 t = TYPE_MAIN_VARIANT (t);
656 name = TYPE_NAME (t);
657 typdef = 0;
658 }
659
660 tmplate = !typdef && TREE_CODE (t) != ENUMERAL_TYPE
661 && TYPE_LANG_SPECIFIC (t) && CLASSTYPE_TEMPLATE_INFO (t)
662 && (TREE_CODE (CLASSTYPE_TI_TEMPLATE (t)) != TEMPLATE_DECL
663 || PRIMARY_TEMPLATE_P (CLASSTYPE_TI_TEMPLATE (t)));
664
665 if (! (flags & TFF_UNQUALIFIED_NAME))
666 dump_scope (pp, CP_DECL_CONTEXT (name), flags | TFF_SCOPE);
667 flags &= ~TFF_UNQUALIFIED_NAME;
668 if (tmplate)
669 {
670 /* Because the template names are mangled, we have to locate
671 the most general template, and use that name. */
672 tree tpl = TYPE_TI_TEMPLATE (t);
673
674 while (DECL_TEMPLATE_INFO (tpl))
675 tpl = DECL_TI_TEMPLATE (tpl);
676 name = tpl;
677 }
678 name = DECL_NAME (name);
679 }
680
681 if (name == 0 || anon_aggrname_p (name))
682 {
683 if (flags & TFF_CLASS_KEY_OR_ENUM)
684 pp_string (pp, M_("<unnamed>"));
685 else
686 pp_printf (pp, M_("<unnamed %s>"), variety);
687 }
688 else if (LAMBDA_TYPE_P (t))
689 {
690 /* A lambda's "type" is essentially its signature. */
691 pp_string (pp, M_("<lambda"));
692 if (lambda_function (t))
693 dump_parameters (pp,
694 FUNCTION_FIRST_USER_PARMTYPE (lambda_function (t)),
695 flags);
696 pp_greater (pp);
697 }
698 else
699 pp_cxx_tree_identifier (pp, name);
700 if (tmplate)
701 dump_template_parms (pp, TYPE_TEMPLATE_INFO (t),
702 !CLASSTYPE_USE_TEMPLATE (t),
703 flags & ~TFF_TEMPLATE_HEADER);
704 }
705
706 /* Dump into the obstack the initial part of the output for a given type.
707 This is necessary when dealing with things like functions returning
708 functions. Examples:
709
710 return type of `int (* fee ())()': pointer -> function -> int. Both
711 pointer (and reference and offset) and function (and member) types must
712 deal with prefix and suffix.
713
714 Arrays must also do this for DECL nodes, like int a[], and for things like
715 int *[]&. */
716
717 static void
718 dump_type_prefix (cxx_pretty_printer *pp, tree t, int flags)
719 {
720 if (TYPE_PTRMEMFUNC_P (t))
721 {
722 t = TYPE_PTRMEMFUNC_FN_TYPE (t);
723 goto offset_type;
724 }
725
726 switch (TREE_CODE (t))
727 {
728 case POINTER_TYPE:
729 case REFERENCE_TYPE:
730 {
731 tree sub = TREE_TYPE (t);
732
733 dump_type_prefix (pp, sub, flags);
734 if (TREE_CODE (sub) == ARRAY_TYPE
735 || TREE_CODE (sub) == FUNCTION_TYPE)
736 {
737 pp_cxx_whitespace (pp);
738 pp_cxx_left_paren (pp);
739 pp_c_attributes_display (pp, TYPE_ATTRIBUTES (sub));
740 }
741 if (TYPE_PTR_P (t))
742 pp_star (pp);
743 else if (TREE_CODE (t) == REFERENCE_TYPE)
744 {
745 if (TYPE_REF_IS_RVALUE (t))
746 pp_ampersand_ampersand (pp);
747 else
748 pp_ampersand (pp);
749 }
750 pp->padding = pp_before;
751 pp_cxx_cv_qualifier_seq (pp, t);
752 }
753 break;
754
755 case OFFSET_TYPE:
756 offset_type:
757 dump_type_prefix (pp, TREE_TYPE (t), flags);
758 if (TREE_CODE (t) == OFFSET_TYPE) /* pmfs deal with this in d_t_p */
759 {
760 pp_maybe_space (pp);
761 if (TREE_CODE (TREE_TYPE (t)) == ARRAY_TYPE)
762 pp_cxx_left_paren (pp);
763 dump_type (pp, TYPE_OFFSET_BASETYPE (t), flags);
764 pp_cxx_colon_colon (pp);
765 }
766 pp_cxx_star (pp);
767 pp_cxx_cv_qualifier_seq (pp, t);
768 pp->padding = pp_before;
769 break;
770
771 /* This can be reached without a pointer when dealing with
772 templates, e.g. std::is_function. */
773 case FUNCTION_TYPE:
774 dump_type_prefix (pp, TREE_TYPE (t), flags);
775 break;
776
777 case METHOD_TYPE:
778 dump_type_prefix (pp, TREE_TYPE (t), flags);
779 pp_maybe_space (pp);
780 pp_cxx_left_paren (pp);
781 dump_aggr_type (pp, TYPE_METHOD_BASETYPE (t), flags);
782 pp_cxx_colon_colon (pp);
783 break;
784
785 case ARRAY_TYPE:
786 dump_type_prefix (pp, TREE_TYPE (t), flags);
787 break;
788
789 case ENUMERAL_TYPE:
790 case IDENTIFIER_NODE:
791 case INTEGER_TYPE:
792 case BOOLEAN_TYPE:
793 case REAL_TYPE:
794 case RECORD_TYPE:
795 case TEMPLATE_TYPE_PARM:
796 case TEMPLATE_TEMPLATE_PARM:
797 case BOUND_TEMPLATE_TEMPLATE_PARM:
798 case TREE_LIST:
799 case TYPE_DECL:
800 case TREE_VEC:
801 case UNION_TYPE:
802 case LANG_TYPE:
803 case VOID_TYPE:
804 case TYPENAME_TYPE:
805 case COMPLEX_TYPE:
806 case VECTOR_TYPE:
807 case TYPEOF_TYPE:
808 case UNDERLYING_TYPE:
809 case DECLTYPE_TYPE:
810 case TYPE_PACK_EXPANSION:
811 case FIXED_POINT_TYPE:
812 case NULLPTR_TYPE:
813 dump_type (pp, t, flags);
814 pp->padding = pp_before;
815 break;
816
817 default:
818 pp_unsupported_tree (pp, t);
819 /* fall through. */
820 case ERROR_MARK:
821 pp_string (pp, M_("<typeprefixerror>"));
822 break;
823 }
824 }
825
826 /* Dump the suffix of type T, under control of FLAGS. This is the part
827 which appears after the identifier (or function parms). */
828
829 static void
830 dump_type_suffix (cxx_pretty_printer *pp, tree t, int flags)
831 {
832 if (TYPE_PTRMEMFUNC_P (t))
833 t = TYPE_PTRMEMFUNC_FN_TYPE (t);
834
835 switch (TREE_CODE (t))
836 {
837 case POINTER_TYPE:
838 case REFERENCE_TYPE:
839 case OFFSET_TYPE:
840 if (TREE_CODE (TREE_TYPE (t)) == ARRAY_TYPE
841 || TREE_CODE (TREE_TYPE (t)) == FUNCTION_TYPE)
842 pp_cxx_right_paren (pp);
843 if (TREE_CODE (t) == POINTER_TYPE)
844 flags |= TFF_POINTER;
845 dump_type_suffix (pp, TREE_TYPE (t), flags);
846 break;
847
848 case FUNCTION_TYPE:
849 case METHOD_TYPE:
850 {
851 tree arg;
852 if (TREE_CODE (t) == METHOD_TYPE)
853 /* Can only be reached through a pointer. */
854 pp_cxx_right_paren (pp);
855 arg = TYPE_ARG_TYPES (t);
856 if (TREE_CODE (t) == METHOD_TYPE)
857 arg = TREE_CHAIN (arg);
858
859 /* Function pointers don't have default args. Not in standard C++,
860 anyway; they may in g++, but we'll just pretend otherwise. */
861 dump_parameters (pp, arg, flags & ~TFF_FUNCTION_DEFAULT_ARGUMENTS);
862
863 pp->padding = pp_before;
864 pp_cxx_cv_qualifiers (pp, type_memfn_quals (t),
865 TREE_CODE (t) == FUNCTION_TYPE
866 && (flags & TFF_POINTER));
867 dump_ref_qualifier (pp, t, flags);
868 if (tx_safe_fn_type_p (t))
869 pp_cxx_ws_string (pp, "transaction_safe");
870 dump_exception_spec (pp, TYPE_RAISES_EXCEPTIONS (t), flags);
871 dump_type_suffix (pp, TREE_TYPE (t), flags);
872 break;
873 }
874
875 case ARRAY_TYPE:
876 pp_maybe_space (pp);
877 pp_cxx_left_bracket (pp);
878 if (tree dtype = TYPE_DOMAIN (t))
879 {
880 tree max = TYPE_MAX_VALUE (dtype);
881 /* Zero-length arrays have an upper bound of SIZE_MAX. */
882 if (integer_all_onesp (max))
883 pp_character (pp, '0');
884 else if (tree_fits_shwi_p (max))
885 pp_wide_integer (pp, tree_to_shwi (max) + 1);
886 else
887 {
888 STRIP_NOPS (max);
889 if (TREE_CODE (max) == SAVE_EXPR)
890 max = TREE_OPERAND (max, 0);
891 if (TREE_CODE (max) == MINUS_EXPR
892 || TREE_CODE (max) == PLUS_EXPR)
893 {
894 max = TREE_OPERAND (max, 0);
895 while (CONVERT_EXPR_P (max))
896 max = TREE_OPERAND (max, 0);
897 }
898 else
899 max = fold_build2_loc (input_location,
900 PLUS_EXPR, dtype, max,
901 build_int_cst (dtype, 1));
902 dump_expr (pp, max, flags & ~TFF_EXPR_IN_PARENS);
903 }
904 }
905 pp_cxx_right_bracket (pp);
906 dump_type_suffix (pp, TREE_TYPE (t), flags);
907 break;
908
909 case ENUMERAL_TYPE:
910 case IDENTIFIER_NODE:
911 case INTEGER_TYPE:
912 case BOOLEAN_TYPE:
913 case REAL_TYPE:
914 case RECORD_TYPE:
915 case TEMPLATE_TYPE_PARM:
916 case TEMPLATE_TEMPLATE_PARM:
917 case BOUND_TEMPLATE_TEMPLATE_PARM:
918 case TREE_LIST:
919 case TYPE_DECL:
920 case TREE_VEC:
921 case UNION_TYPE:
922 case LANG_TYPE:
923 case VOID_TYPE:
924 case TYPENAME_TYPE:
925 case COMPLEX_TYPE:
926 case VECTOR_TYPE:
927 case TYPEOF_TYPE:
928 case UNDERLYING_TYPE:
929 case DECLTYPE_TYPE:
930 case TYPE_PACK_EXPANSION:
931 case FIXED_POINT_TYPE:
932 case NULLPTR_TYPE:
933 break;
934
935 default:
936 pp_unsupported_tree (pp, t);
937 case ERROR_MARK:
938 /* Don't mark it here, we should have already done in
939 dump_type_prefix. */
940 break;
941 }
942 }
943
944 static void
945 dump_global_iord (cxx_pretty_printer *pp, tree t)
946 {
947 const char *p = NULL;
948
949 if (DECL_GLOBAL_CTOR_P (t))
950 p = M_("(static initializers for %s)");
951 else if (DECL_GLOBAL_DTOR_P (t))
952 p = M_("(static destructors for %s)");
953 else
954 gcc_unreachable ();
955
956 pp_printf (pp, p, DECL_SOURCE_FILE (t));
957 }
958
959 static void
960 dump_simple_decl (cxx_pretty_printer *pp, tree t, tree type, int flags)
961 {
962 if (flags & TFF_DECL_SPECIFIERS)
963 {
964 if (VAR_P (t) && DECL_DECLARED_CONSTEXPR_P (t))
965 {
966 if (DECL_LANG_SPECIFIC (t) && DECL_DECLARED_CONCEPT_P (t))
967 pp_cxx_ws_string (pp, "concept");
968 else
969 pp_cxx_ws_string (pp, "constexpr");
970 }
971 dump_type_prefix (pp, type, flags & ~TFF_UNQUALIFIED_NAME);
972 pp_maybe_space (pp);
973 }
974 if (! (flags & TFF_UNQUALIFIED_NAME)
975 && TREE_CODE (t) != PARM_DECL
976 && (!DECL_INITIAL (t)
977 || TREE_CODE (DECL_INITIAL (t)) != TEMPLATE_PARM_INDEX))
978 dump_scope (pp, CP_DECL_CONTEXT (t), flags);
979 flags &= ~TFF_UNQUALIFIED_NAME;
980 if ((flags & TFF_DECL_SPECIFIERS)
981 && DECL_TEMPLATE_PARM_P (t)
982 && TEMPLATE_PARM_PARAMETER_PACK (DECL_INITIAL (t)))
983 pp_string (pp, "...");
984 if (DECL_NAME (t))
985 {
986 if (TREE_CODE (t) == FIELD_DECL && DECL_NORMAL_CAPTURE_P (t))
987 {
988 pp_less (pp);
989 pp_string (pp, IDENTIFIER_POINTER (DECL_NAME (t)) + 2);
990 pp_string (pp, " capture>");
991 }
992 else
993 dump_decl (pp, DECL_NAME (t), flags);
994 }
995 else
996 pp_string (pp, M_("<anonymous>"));
997 if (flags & TFF_DECL_SPECIFIERS)
998 dump_type_suffix (pp, type, flags);
999 }
1000
1001 /* Print an IDENTIFIER_NODE that is the name of a declaration. */
1002
1003 static void
1004 dump_decl_name (cxx_pretty_printer *pp, tree t, int flags)
1005 {
1006 /* These special cases are duplicated here so that other functions
1007 can feed identifiers to error and get them demangled properly. */
1008 if (IDENTIFIER_TYPENAME_P (t))
1009 {
1010 pp_cxx_ws_string (pp, "operator");
1011 /* Not exactly IDENTIFIER_TYPE_VALUE. */
1012 dump_type (pp, TREE_TYPE (t), flags);
1013 return;
1014 }
1015 if (dguide_name_p (t))
1016 {
1017 dump_decl (pp, CLASSTYPE_TI_TEMPLATE (TREE_TYPE (t)),
1018 TFF_UNQUALIFIED_NAME);
1019 return;
1020 }
1021
1022 const char *str = IDENTIFIER_POINTER (t);
1023 if (!strncmp (str, "_ZGR", 3))
1024 {
1025 pp_cxx_ws_string (pp, "<temporary>");
1026 return;
1027 }
1028
1029 pp_cxx_tree_identifier (pp, t);
1030 }
1031
1032 /* Dump a human readable string for the decl T under control of FLAGS. */
1033
1034 static void
1035 dump_decl (cxx_pretty_printer *pp, tree t, int flags)
1036 {
1037 if (t == NULL_TREE)
1038 return;
1039
1040 /* If doing Objective-C++, give Objective-C a chance to demangle
1041 Objective-C method names. */
1042 if (c_dialect_objc ())
1043 {
1044 const char *demangled = objc_maybe_printable_name (t, flags);
1045 if (demangled)
1046 {
1047 pp_string (pp, demangled);
1048 return;
1049 }
1050 }
1051
1052 switch (TREE_CODE (t))
1053 {
1054 case TYPE_DECL:
1055 /* Don't say 'typedef class A' */
1056 if (DECL_ARTIFICIAL (t) && !DECL_SELF_REFERENCE_P (t))
1057 {
1058 if ((flags & TFF_DECL_SPECIFIERS)
1059 && TREE_CODE (TREE_TYPE (t)) == TEMPLATE_TYPE_PARM)
1060 {
1061 /* Say `class T' not just `T'. */
1062 pp_cxx_ws_string (pp, "class");
1063
1064 /* Emit the `...' for a parameter pack. */
1065 if (TEMPLATE_TYPE_PARAMETER_PACK (TREE_TYPE (t)))
1066 pp_cxx_ws_string (pp, "...");
1067 }
1068
1069 dump_type (pp, TREE_TYPE (t), flags);
1070 break;
1071 }
1072 if (TYPE_DECL_ALIAS_P (t)
1073 && (flags & TFF_DECL_SPECIFIERS
1074 || flags & TFF_CLASS_KEY_OR_ENUM))
1075 {
1076 pp_cxx_ws_string (pp, "using");
1077 dump_decl (pp, DECL_NAME (t), flags);
1078 pp_cxx_whitespace (pp);
1079 pp_cxx_ws_string (pp, "=");
1080 pp_cxx_whitespace (pp);
1081 dump_type (pp, (DECL_ORIGINAL_TYPE (t)
1082 ? DECL_ORIGINAL_TYPE (t) : TREE_TYPE (t)),
1083 flags);
1084 break;
1085 }
1086 if ((flags & TFF_DECL_SPECIFIERS)
1087 && !DECL_SELF_REFERENCE_P (t))
1088 pp_cxx_ws_string (pp, "typedef");
1089 dump_simple_decl (pp, t, DECL_ORIGINAL_TYPE (t)
1090 ? DECL_ORIGINAL_TYPE (t) : TREE_TYPE (t),
1091 flags);
1092 break;
1093
1094 case VAR_DECL:
1095 if (DECL_NAME (t) && VTABLE_NAME_P (DECL_NAME (t)))
1096 {
1097 pp_string (pp, M_("vtable for "));
1098 gcc_assert (TYPE_P (DECL_CONTEXT (t)));
1099 dump_type (pp, DECL_CONTEXT (t), flags);
1100 break;
1101 }
1102 /* Fall through. */
1103 case FIELD_DECL:
1104 case PARM_DECL:
1105 dump_simple_decl (pp, t, TREE_TYPE (t), flags);
1106
1107 /* Handle variable template specializations. */
1108 if (VAR_P (t)
1109 && DECL_LANG_SPECIFIC (t)
1110 && DECL_TEMPLATE_INFO (t)
1111 && PRIMARY_TEMPLATE_P (DECL_TI_TEMPLATE (t)))
1112 {
1113 pp_cxx_begin_template_argument_list (pp);
1114 tree args = INNERMOST_TEMPLATE_ARGS (DECL_TI_ARGS (t));
1115 dump_template_argument_list (pp, args, flags);
1116 pp_cxx_end_template_argument_list (pp);
1117 }
1118 break;
1119
1120 case RESULT_DECL:
1121 pp_string (pp, M_("<return value> "));
1122 dump_simple_decl (pp, t, TREE_TYPE (t), flags);
1123 break;
1124
1125 case NAMESPACE_DECL:
1126 if (flags & TFF_DECL_SPECIFIERS)
1127 pp->declaration (t);
1128 else
1129 {
1130 if (! (flags & TFF_UNQUALIFIED_NAME))
1131 dump_scope (pp, CP_DECL_CONTEXT (t), flags);
1132 flags &= ~TFF_UNQUALIFIED_NAME;
1133 if (DECL_NAME (t) == NULL_TREE)
1134 {
1135 if (!(pp->flags & pp_c_flag_gnu_v3))
1136 pp_cxx_ws_string (pp, M_("{anonymous}"));
1137 else
1138 pp_cxx_ws_string (pp, M_("(anonymous namespace)"));
1139 }
1140 else
1141 pp_cxx_tree_identifier (pp, DECL_NAME (t));
1142 }
1143 break;
1144
1145 case SCOPE_REF:
1146 dump_type (pp, TREE_OPERAND (t, 0), flags);
1147 pp_colon_colon (pp);
1148 dump_decl (pp, TREE_OPERAND (t, 1), TFF_UNQUALIFIED_NAME);
1149 break;
1150
1151 case ARRAY_REF:
1152 dump_decl (pp, TREE_OPERAND (t, 0), flags);
1153 pp_cxx_left_bracket (pp);
1154 dump_decl (pp, TREE_OPERAND (t, 1), flags);
1155 pp_cxx_right_bracket (pp);
1156 break;
1157
1158 case ARRAY_NOTATION_REF:
1159 dump_decl (pp, ARRAY_NOTATION_ARRAY (t), flags | TFF_EXPR_IN_PARENS);
1160 pp_cxx_left_bracket (pp);
1161 dump_decl (pp, ARRAY_NOTATION_START (t), flags | TFF_EXPR_IN_PARENS);
1162 pp_colon (pp);
1163 dump_decl (pp, ARRAY_NOTATION_LENGTH (t), flags | TFF_EXPR_IN_PARENS);
1164 pp_colon (pp);
1165 dump_decl (pp, ARRAY_NOTATION_STRIDE (t), flags | TFF_EXPR_IN_PARENS);
1166 pp_cxx_right_bracket (pp);
1167 break;
1168
1169 /* So that we can do dump_decl on an aggr type. */
1170 case RECORD_TYPE:
1171 case UNION_TYPE:
1172 case ENUMERAL_TYPE:
1173 dump_type (pp, t, flags);
1174 break;
1175
1176 case BIT_NOT_EXPR:
1177 /* This is a pseudo destructor call which has not been folded into
1178 a PSEUDO_DTOR_EXPR yet. */
1179 pp_cxx_complement (pp);
1180 dump_type (pp, TREE_OPERAND (t, 0), flags);
1181 break;
1182
1183 case TYPE_EXPR:
1184 gcc_unreachable ();
1185 break;
1186
1187 case IDENTIFIER_NODE:
1188 dump_decl_name (pp, t, flags);
1189 break;
1190
1191 case OVERLOAD:
1192 if (!OVL_SINGLE_P (t))
1193 {
1194 t = OVL_FIRST (t);
1195 tree ctx = CP_DECL_CONTEXT (t);
1196 if (ctx != global_namespace)
1197 {
1198 if (TYPE_P (ctx))
1199 dump_type (pp, ctx, flags);
1200 else
1201 dump_decl (pp, ctx, flags);
1202 pp_cxx_colon_colon (pp);
1203 }
1204 dump_decl (pp, DECL_NAME (t), flags);
1205 break;
1206 }
1207
1208 /* If there's only one function, just treat it like an ordinary
1209 FUNCTION_DECL. */
1210 t = OVL_FIRST (t);
1211 /* Fall through. */
1212
1213 case FUNCTION_DECL:
1214 if (! DECL_LANG_SPECIFIC (t))
1215 {
1216 if (DECL_ABSTRACT_ORIGIN (t)
1217 && DECL_ABSTRACT_ORIGIN (t) != t)
1218 dump_decl (pp, DECL_ABSTRACT_ORIGIN (t), flags);
1219 else
1220 dump_function_name (pp, t, flags);
1221 }
1222 else if (DECL_GLOBAL_CTOR_P (t) || DECL_GLOBAL_DTOR_P (t))
1223 dump_global_iord (pp, t);
1224 else
1225 dump_function_decl (pp, t, flags);
1226 break;
1227
1228 case TEMPLATE_DECL:
1229 dump_template_decl (pp, t, flags);
1230 break;
1231
1232 case TEMPLATE_ID_EXPR:
1233 {
1234 tree name = TREE_OPERAND (t, 0);
1235 tree args = TREE_OPERAND (t, 1);
1236
1237 if (!identifier_p (name))
1238 name = OVL_NAME (name);
1239 dump_decl (pp, name, flags);
1240 pp_cxx_begin_template_argument_list (pp);
1241 if (args == error_mark_node)
1242 pp_string (pp, M_("<template arguments error>"));
1243 else if (args)
1244 dump_template_argument_list
1245 (pp, args, flags|TFF_NO_OMIT_DEFAULT_TEMPLATE_ARGUMENTS);
1246 pp_cxx_end_template_argument_list (pp);
1247 }
1248 break;
1249
1250 case LABEL_DECL:
1251 pp_cxx_tree_identifier (pp, DECL_NAME (t));
1252 break;
1253
1254 case CONST_DECL:
1255 if ((TREE_TYPE (t) != NULL_TREE && NEXT_CODE (t) == ENUMERAL_TYPE)
1256 || (DECL_INITIAL (t) &&
1257 TREE_CODE (DECL_INITIAL (t)) == TEMPLATE_PARM_INDEX))
1258 dump_simple_decl (pp, t, TREE_TYPE (t), flags);
1259 else if (DECL_NAME (t))
1260 dump_decl (pp, DECL_NAME (t), flags);
1261 else if (DECL_INITIAL (t))
1262 dump_expr (pp, DECL_INITIAL (t), flags | TFF_EXPR_IN_PARENS);
1263 else
1264 pp_string (pp, M_("<enumerator>"));
1265 break;
1266
1267 case USING_DECL:
1268 {
1269 pp_cxx_ws_string (pp, "using");
1270 tree scope = USING_DECL_SCOPE (t);
1271 bool variadic = false;
1272 if (PACK_EXPANSION_P (scope))
1273 {
1274 scope = PACK_EXPANSION_PATTERN (scope);
1275 variadic = true;
1276 }
1277 dump_type (pp, scope, flags);
1278 pp_cxx_colon_colon (pp);
1279 dump_decl (pp, DECL_NAME (t), flags);
1280 if (variadic)
1281 pp_cxx_ws_string (pp, "...");
1282 }
1283 break;
1284
1285 case STATIC_ASSERT:
1286 pp->declaration (t);
1287 break;
1288
1289 case BASELINK:
1290 dump_decl (pp, BASELINK_FUNCTIONS (t), flags);
1291 break;
1292
1293 case NON_DEPENDENT_EXPR:
1294 dump_expr (pp, t, flags);
1295 break;
1296
1297 case TEMPLATE_TYPE_PARM:
1298 if (flags & TFF_DECL_SPECIFIERS)
1299 pp->declaration (t);
1300 else
1301 pp->type_id (t);
1302 break;
1303
1304 case UNBOUND_CLASS_TEMPLATE:
1305 case TYPE_PACK_EXPANSION:
1306 case TREE_BINFO:
1307 dump_type (pp, t, flags);
1308 break;
1309
1310 default:
1311 pp_unsupported_tree (pp, t);
1312 /* Fall through. */
1313
1314 case ERROR_MARK:
1315 pp_string (pp, M_("<declaration error>"));
1316 break;
1317 }
1318 }
1319
1320 /* Dump a template declaration T under control of FLAGS. This means the
1321 'template <...> leaders plus the 'class X' or 'void fn(...)' part. */
1322
1323 static void
1324 dump_template_decl (cxx_pretty_printer *pp, tree t, int flags)
1325 {
1326 tree orig_parms = DECL_TEMPLATE_PARMS (t);
1327 tree parms;
1328 int i;
1329
1330 if (flags & TFF_TEMPLATE_HEADER)
1331 {
1332 for (parms = orig_parms = nreverse (orig_parms);
1333 parms;
1334 parms = TREE_CHAIN (parms))
1335 {
1336 tree inner_parms = INNERMOST_TEMPLATE_PARMS (parms);
1337 int len = TREE_VEC_LENGTH (inner_parms);
1338
1339 if (len == 0)
1340 {
1341 /* Skip over the dummy template levels of a template template
1342 parm. */
1343 gcc_assert (TREE_CODE (TREE_TYPE (t)) == TEMPLATE_TEMPLATE_PARM);
1344 continue;
1345 }
1346
1347 pp_cxx_ws_string (pp, "template");
1348 pp_cxx_begin_template_argument_list (pp);
1349
1350 /* If we've shown the template prefix, we'd better show the
1351 parameters' and decl's type too. */
1352 flags |= TFF_DECL_SPECIFIERS;
1353
1354 for (i = 0; i < len; i++)
1355 {
1356 if (i)
1357 pp_separate_with_comma (pp);
1358 dump_template_parameter (pp, TREE_VEC_ELT (inner_parms, i),
1359 flags);
1360 }
1361 pp_cxx_end_template_argument_list (pp);
1362 pp_cxx_whitespace (pp);
1363 }
1364 nreverse(orig_parms);
1365
1366 if (DECL_TEMPLATE_TEMPLATE_PARM_P (t))
1367 {
1368 /* Say `template<arg> class TT' not just `template<arg> TT'. */
1369 pp_cxx_ws_string (pp, "class");
1370
1371 /* If this is a parameter pack, print the ellipsis. */
1372 if (TEMPLATE_TYPE_PARAMETER_PACK (TREE_TYPE (t)))
1373 pp_cxx_ws_string (pp, "...");
1374 }
1375
1376 /* Only print the requirements if we're also printing
1377 the template header. */
1378 if (flag_concepts)
1379 if (tree ci = get_constraints (t))
1380 if (check_constraint_info (ci))
1381 if (tree reqs = CI_TEMPLATE_REQS (ci))
1382 {
1383 pp_cxx_requires_clause (pp, reqs);
1384 pp_cxx_whitespace (pp);
1385 }
1386 }
1387
1388
1389 if (DECL_CLASS_TEMPLATE_P (t))
1390 dump_type (pp, TREE_TYPE (t),
1391 ((flags & ~TFF_CLASS_KEY_OR_ENUM) | TFF_TEMPLATE_NAME
1392 | (flags & TFF_DECL_SPECIFIERS ? TFF_CLASS_KEY_OR_ENUM : 0)));
1393 else if (DECL_TEMPLATE_RESULT (t)
1394 && (VAR_P (DECL_TEMPLATE_RESULT (t))
1395 /* Alias template. */
1396 || DECL_TYPE_TEMPLATE_P (t)))
1397 dump_decl (pp, DECL_TEMPLATE_RESULT (t), flags | TFF_TEMPLATE_NAME);
1398 else
1399 {
1400 gcc_assert (TREE_TYPE (t));
1401 switch (NEXT_CODE (t))
1402 {
1403 case METHOD_TYPE:
1404 case FUNCTION_TYPE:
1405 dump_function_decl (pp, t, flags | TFF_TEMPLATE_NAME);
1406 break;
1407 default:
1408 /* This case can occur with some invalid code. */
1409 dump_type (pp, TREE_TYPE (t),
1410 (flags & ~TFF_CLASS_KEY_OR_ENUM) | TFF_TEMPLATE_NAME
1411 | (flags & TFF_DECL_SPECIFIERS
1412 ? TFF_CLASS_KEY_OR_ENUM : 0));
1413 }
1414 }
1415 }
1416
1417 /* find_typenames looks through the type of the function template T
1418 and returns a vec containing any typedefs, decltypes or TYPENAME_TYPEs
1419 it finds. */
1420
1421 struct find_typenames_t
1422 {
1423 hash_set<tree> *p_set;
1424 vec<tree, va_gc> *typenames;
1425 };
1426
1427 static tree
1428 find_typenames_r (tree *tp, int *walk_subtrees, void *data)
1429 {
1430 struct find_typenames_t *d = (struct find_typenames_t *)data;
1431 tree mv = NULL_TREE;
1432
1433 if (TYPE_P (*tp) && is_typedef_decl (TYPE_NAME (*tp)))
1434 /* Add the type of the typedef without any additional cv-quals. */
1435 mv = TREE_TYPE (TYPE_NAME (*tp));
1436 else if (TREE_CODE (*tp) == TYPENAME_TYPE
1437 || TREE_CODE (*tp) == DECLTYPE_TYPE)
1438 /* Add the typename without any cv-qualifiers. */
1439 mv = TYPE_MAIN_VARIANT (*tp);
1440
1441 if (TREE_CODE (*tp) == TYPE_PACK_EXPANSION)
1442 {
1443 /* Don't mess with parameter packs since we don't remember
1444 the pack expansion context for a particular typename. */
1445 *walk_subtrees = false;
1446 return NULL_TREE;
1447 }
1448
1449 if (mv && (mv == *tp || !d->p_set->add (mv)))
1450 vec_safe_push (d->typenames, mv);
1451
1452 /* Search into class template arguments, which cp_walk_subtrees
1453 doesn't do. */
1454 if (CLASS_TYPE_P (*tp) && CLASSTYPE_TEMPLATE_INFO (*tp))
1455 cp_walk_tree (&CLASSTYPE_TI_ARGS (*tp), find_typenames_r,
1456 data, d->p_set);
1457
1458 return NULL_TREE;
1459 }
1460
1461 static vec<tree, va_gc> *
1462 find_typenames (tree t)
1463 {
1464 struct find_typenames_t ft;
1465 ft.p_set = new hash_set<tree>;
1466 ft.typenames = NULL;
1467 cp_walk_tree (&TREE_TYPE (DECL_TEMPLATE_RESULT (t)),
1468 find_typenames_r, &ft, ft.p_set);
1469 delete ft.p_set;
1470 return ft.typenames;
1471 }
1472
1473 /* Output the "[with ...]" clause for a template instantiation T iff
1474 TEMPLATE_PARMS, TEMPLATE_ARGS and FLAGS are suitable. T may be NULL if
1475 formatting a deduction/substitution diagnostic rather than an
1476 instantiation. */
1477
1478 static void
1479 dump_substitution (cxx_pretty_printer *pp,
1480 tree t, tree template_parms, tree template_args,
1481 int flags)
1482 {
1483 if (template_parms != NULL_TREE && template_args != NULL_TREE
1484 && !(flags & TFF_NO_TEMPLATE_BINDINGS))
1485 {
1486 vec<tree, va_gc> *typenames = t ? find_typenames (t) : NULL;
1487 pp_cxx_whitespace (pp);
1488 pp_cxx_left_bracket (pp);
1489 pp->translate_string ("with");
1490 pp_cxx_whitespace (pp);
1491 dump_template_bindings (pp, template_parms, template_args, typenames);
1492 pp_cxx_right_bracket (pp);
1493 }
1494 }
1495
1496 /* Dump the lambda function FN including its 'mutable' qualifier and any
1497 template bindings. */
1498
1499 static void
1500 dump_lambda_function (cxx_pretty_printer *pp,
1501 tree fn, tree template_parms, tree template_args,
1502 int flags)
1503 {
1504 /* A lambda's signature is essentially its "type". */
1505 dump_type (pp, DECL_CONTEXT (fn), flags);
1506 if (!(TYPE_QUALS (class_of_this_parm (TREE_TYPE (fn))) & TYPE_QUAL_CONST))
1507 {
1508 pp->padding = pp_before;
1509 pp_c_ws_string (pp, "mutable");
1510 }
1511 dump_substitution (pp, fn, template_parms, template_args, flags);
1512 }
1513
1514 /* Pretty print a function decl. There are several ways we want to print a
1515 function declaration. The TFF_ bits in FLAGS tells us how to behave.
1516 As error can only apply the '#' flag once to give 0 and 1 for V, there
1517 is %D which doesn't print the throw specs, and %F which does. */
1518
1519 static void
1520 dump_function_decl (cxx_pretty_printer *pp, tree t, int flags)
1521 {
1522 tree fntype;
1523 tree parmtypes;
1524 tree cname = NULL_TREE;
1525 tree template_args = NULL_TREE;
1526 tree template_parms = NULL_TREE;
1527 int show_return = flags & TFF_RETURN_TYPE || flags & TFF_DECL_SPECIFIERS;
1528 int do_outer_scope = ! (flags & TFF_UNQUALIFIED_NAME);
1529 tree exceptions;
1530 bool constexpr_p;
1531
1532 flags &= ~(TFF_UNQUALIFIED_NAME | TFF_TEMPLATE_NAME);
1533 if (TREE_CODE (t) == TEMPLATE_DECL)
1534 t = DECL_TEMPLATE_RESULT (t);
1535
1536 /* Save the exceptions, in case t is a specialization and we are
1537 emitting an error about incompatible specifications. */
1538 exceptions = TYPE_RAISES_EXCEPTIONS (TREE_TYPE (t));
1539
1540 /* Likewise for the constexpr specifier, in case t is a specialization. */
1541 constexpr_p = DECL_DECLARED_CONSTEXPR_P (t);
1542
1543 /* Pretty print template instantiations only. */
1544 if (DECL_USE_TEMPLATE (t) && DECL_TEMPLATE_INFO (t)
1545 && !(flags & TFF_NO_TEMPLATE_BINDINGS)
1546 && flag_pretty_templates)
1547 {
1548 tree tmpl;
1549
1550 template_args = DECL_TI_ARGS (t);
1551 tmpl = most_general_template (t);
1552 if (tmpl && TREE_CODE (tmpl) == TEMPLATE_DECL)
1553 {
1554 template_parms = DECL_TEMPLATE_PARMS (tmpl);
1555 t = tmpl;
1556 }
1557 }
1558
1559 if (DECL_NAME (t) && LAMBDA_FUNCTION_P (t))
1560 return dump_lambda_function (pp, t, template_parms, template_args, flags);
1561
1562 fntype = TREE_TYPE (t);
1563 parmtypes = FUNCTION_FIRST_USER_PARMTYPE (t);
1564
1565 if (DECL_CLASS_SCOPE_P (t))
1566 cname = DECL_CONTEXT (t);
1567 /* This is for partially instantiated template methods. */
1568 else if (TREE_CODE (fntype) == METHOD_TYPE)
1569 cname = TREE_TYPE (TREE_VALUE (parmtypes));
1570
1571 if (flags & TFF_DECL_SPECIFIERS)
1572 {
1573 if (DECL_STATIC_FUNCTION_P (t))
1574 pp_cxx_ws_string (pp, "static");
1575 else if (DECL_VIRTUAL_P (t))
1576 pp_cxx_ws_string (pp, "virtual");
1577
1578 if (constexpr_p)
1579 {
1580 if (DECL_DECLARED_CONCEPT_P (t))
1581 pp_cxx_ws_string (pp, "concept");
1582 else
1583 pp_cxx_ws_string (pp, "constexpr");
1584 }
1585 }
1586
1587 /* Print the return type? */
1588 if (show_return)
1589 show_return = (!DECL_CONV_FN_P (t) && !DECL_CONSTRUCTOR_P (t)
1590 && !DECL_DESTRUCTOR_P (t) && !deduction_guide_p (t));
1591 if (show_return)
1592 {
1593 tree ret = fndecl_declared_return_type (t);
1594 dump_type_prefix (pp, ret, flags);
1595 }
1596
1597 /* Print the function name. */
1598 if (!do_outer_scope)
1599 /* Nothing. */;
1600 else if (cname)
1601 {
1602 dump_type (pp, cname, flags);
1603 pp_cxx_colon_colon (pp);
1604 }
1605 else
1606 dump_scope (pp, CP_DECL_CONTEXT (t), flags);
1607
1608 dump_function_name (pp, t, flags);
1609
1610 if (!(flags & TFF_NO_FUNCTION_ARGUMENTS))
1611 {
1612 dump_parameters (pp, parmtypes, flags);
1613
1614 if (TREE_CODE (fntype) == METHOD_TYPE)
1615 {
1616 pp->padding = pp_before;
1617 pp_cxx_cv_qualifier_seq (pp, class_of_this_parm (fntype));
1618 dump_ref_qualifier (pp, fntype, flags);
1619 }
1620
1621 if (tx_safe_fn_type_p (fntype))
1622 {
1623 pp->padding = pp_before;
1624 pp_cxx_ws_string (pp, "transaction_safe");
1625 }
1626
1627 if (flags & TFF_EXCEPTION_SPECIFICATION)
1628 {
1629 pp->padding = pp_before;
1630 dump_exception_spec (pp, exceptions, flags);
1631 }
1632
1633 if (show_return)
1634 dump_type_suffix (pp, TREE_TYPE (fntype), flags);
1635 else if (deduction_guide_p (t))
1636 {
1637 pp_cxx_ws_string (pp, "->");
1638 dump_type (pp, TREE_TYPE (TREE_TYPE (t)), flags);
1639 }
1640
1641 if (flag_concepts)
1642 if (tree ci = get_constraints (t))
1643 if (tree reqs = CI_DECLARATOR_REQS (ci))
1644 pp_cxx_requires_clause (pp, reqs);
1645
1646 dump_substitution (pp, t, template_parms, template_args, flags);
1647
1648 if (tree base = DECL_INHERITED_CTOR_BASE (t))
1649 {
1650 pp_cxx_ws_string (pp, "[inherited from");
1651 dump_type (pp, base, TFF_PLAIN_IDENTIFIER);
1652 pp_character (pp, ']');
1653 }
1654 }
1655 else if (template_args)
1656 {
1657 bool need_comma = false;
1658 int i;
1659 pp_cxx_begin_template_argument_list (pp);
1660 template_args = INNERMOST_TEMPLATE_ARGS (template_args);
1661 for (i = 0; i < TREE_VEC_LENGTH (template_args); ++i)
1662 {
1663 tree arg = TREE_VEC_ELT (template_args, i);
1664 if (need_comma)
1665 pp_separate_with_comma (pp);
1666 if (ARGUMENT_PACK_P (arg))
1667 pp_cxx_left_brace (pp);
1668 dump_template_argument (pp, arg, TFF_PLAIN_IDENTIFIER);
1669 if (ARGUMENT_PACK_P (arg))
1670 pp_cxx_right_brace (pp);
1671 need_comma = true;
1672 }
1673 pp_cxx_end_template_argument_list (pp);
1674 }
1675 }
1676
1677 /* Print a parameter list. If this is for a member function, the
1678 member object ptr (and any other hidden args) should have
1679 already been removed. */
1680
1681 static void
1682 dump_parameters (cxx_pretty_printer *pp, tree parmtypes, int flags)
1683 {
1684 int first = 1;
1685 flags &= ~TFF_SCOPE;
1686 pp_cxx_left_paren (pp);
1687
1688 for (first = 1; parmtypes != void_list_node;
1689 parmtypes = TREE_CHAIN (parmtypes))
1690 {
1691 if (!first)
1692 pp_separate_with_comma (pp);
1693 first = 0;
1694 if (!parmtypes)
1695 {
1696 pp_cxx_ws_string (pp, "...");
1697 break;
1698 }
1699
1700 dump_type (pp, TREE_VALUE (parmtypes), flags);
1701
1702 if ((flags & TFF_FUNCTION_DEFAULT_ARGUMENTS) && TREE_PURPOSE (parmtypes))
1703 {
1704 pp_cxx_whitespace (pp);
1705 pp_equal (pp);
1706 pp_cxx_whitespace (pp);
1707 dump_expr (pp, TREE_PURPOSE (parmtypes), flags | TFF_EXPR_IN_PARENS);
1708 }
1709 }
1710
1711 pp_cxx_right_paren (pp);
1712 }
1713
1714 /* Print ref-qualifier of a FUNCTION_TYPE or METHOD_TYPE. FLAGS are ignored. */
1715
1716 static void
1717 dump_ref_qualifier (cxx_pretty_printer *pp, tree t, int flags ATTRIBUTE_UNUSED)
1718 {
1719 if (FUNCTION_REF_QUALIFIED (t))
1720 {
1721 pp->padding = pp_before;
1722 if (FUNCTION_RVALUE_QUALIFIED (t))
1723 pp_cxx_ws_string (pp, "&&");
1724 else
1725 pp_cxx_ws_string (pp, "&");
1726 }
1727 }
1728
1729 /* Print an exception specification. T is the exception specification. */
1730
1731 static void
1732 dump_exception_spec (cxx_pretty_printer *pp, tree t, int flags)
1733 {
1734 if (t && TREE_PURPOSE (t))
1735 {
1736 pp_cxx_ws_string (pp, "noexcept");
1737 if (!integer_onep (TREE_PURPOSE (t)))
1738 {
1739 pp_cxx_whitespace (pp);
1740 pp_cxx_left_paren (pp);
1741 if (DEFERRED_NOEXCEPT_SPEC_P (t))
1742 pp_cxx_ws_string (pp, "<uninstantiated>");
1743 else
1744 dump_expr (pp, TREE_PURPOSE (t), flags);
1745 pp_cxx_right_paren (pp);
1746 }
1747 }
1748 else if (t)
1749 {
1750 pp_cxx_ws_string (pp, "throw");
1751 pp_cxx_whitespace (pp);
1752 pp_cxx_left_paren (pp);
1753 if (TREE_VALUE (t) != NULL_TREE)
1754 while (1)
1755 {
1756 dump_type (pp, TREE_VALUE (t), flags);
1757 t = TREE_CHAIN (t);
1758 if (!t)
1759 break;
1760 pp_separate_with_comma (pp);
1761 }
1762 pp_cxx_right_paren (pp);
1763 }
1764 }
1765
1766 /* Handle the function name for a FUNCTION_DECL node, grokking operators
1767 and destructors properly. */
1768
1769 static void
1770 dump_function_name (cxx_pretty_printer *pp, tree t, int flags)
1771 {
1772 tree name = DECL_NAME (t);
1773
1774 /* We can get here with a decl that was synthesized by language-
1775 independent machinery (e.g. coverage.c) in which case it won't
1776 have a lang_specific structure attached and DECL_CONSTRUCTOR_P
1777 will crash. In this case it is safe just to print out the
1778 literal name. */
1779 if (!DECL_LANG_SPECIFIC (t))
1780 {
1781 pp_cxx_tree_identifier (pp, name);
1782 return;
1783 }
1784
1785 if (TREE_CODE (t) == TEMPLATE_DECL)
1786 t = DECL_TEMPLATE_RESULT (t);
1787
1788 /* Don't let the user see __comp_ctor et al. */
1789 if (DECL_CONSTRUCTOR_P (t)
1790 || DECL_DESTRUCTOR_P (t))
1791 {
1792 if (LAMBDA_TYPE_P (DECL_CONTEXT (t)))
1793 name = get_identifier ("<lambda>");
1794 else if (TYPE_UNNAMED_P (DECL_CONTEXT (t)))
1795 name = get_identifier ("<constructor>");
1796 else
1797 name = constructor_name (DECL_CONTEXT (t));
1798 }
1799
1800 if (DECL_DESTRUCTOR_P (t))
1801 {
1802 pp_cxx_complement (pp);
1803 dump_decl (pp, name, TFF_PLAIN_IDENTIFIER);
1804 }
1805 else if (DECL_CONV_FN_P (t))
1806 {
1807 /* This cannot use the hack that the operator's return
1808 type is stashed off of its name because it may be
1809 used for error reporting. In the case of conflicting
1810 declarations, both will have the same name, yet
1811 the types will be different, hence the TREE_TYPE field
1812 of the first name will be clobbered by the second. */
1813 pp_cxx_ws_string (pp, "operator");
1814 dump_type (pp, TREE_TYPE (TREE_TYPE (t)), flags);
1815 }
1816 else
1817 dump_decl (pp, name, flags);
1818
1819 if (DECL_TEMPLATE_INFO (t)
1820 && !DECL_FRIEND_PSEUDO_TEMPLATE_INSTANTIATION (t)
1821 && (TREE_CODE (DECL_TI_TEMPLATE (t)) != TEMPLATE_DECL
1822 || PRIMARY_TEMPLATE_P (DECL_TI_TEMPLATE (t))))
1823 dump_template_parms (pp, DECL_TEMPLATE_INFO (t), !DECL_USE_TEMPLATE (t),
1824 flags);
1825 }
1826
1827 /* Dump the template parameters from the template info INFO under control of
1828 FLAGS. PRIMARY indicates whether this is a primary template decl, or
1829 specialization (partial or complete). For partial specializations we show
1830 the specialized parameter values. For a primary template we show no
1831 decoration. */
1832
1833 static void
1834 dump_template_parms (cxx_pretty_printer *pp, tree info,
1835 int primary, int flags)
1836 {
1837 tree args = info ? TI_ARGS (info) : NULL_TREE;
1838
1839 if (primary && flags & TFF_TEMPLATE_NAME)
1840 return;
1841 flags &= ~(TFF_CLASS_KEY_OR_ENUM | TFF_TEMPLATE_NAME);
1842 pp_cxx_begin_template_argument_list (pp);
1843
1844 /* Be careful only to print things when we have them, so as not
1845 to crash producing error messages. */
1846 if (args && !primary)
1847 {
1848 int len, ix;
1849 len = get_non_default_template_args_count (args, flags);
1850
1851 args = INNERMOST_TEMPLATE_ARGS (args);
1852 for (ix = 0; ix != len; ix++)
1853 {
1854 tree arg = TREE_VEC_ELT (args, ix);
1855
1856 /* Only print a comma if we know there is an argument coming. In
1857 the case of an empty template argument pack, no actual
1858 argument will be printed. */
1859 if (ix
1860 && (!ARGUMENT_PACK_P (arg)
1861 || TREE_VEC_LENGTH (ARGUMENT_PACK_ARGS (arg)) > 0))
1862 pp_separate_with_comma (pp);
1863
1864 if (!arg)
1865 pp_string (pp, M_("<template parameter error>"));
1866 else
1867 dump_template_argument (pp, arg, flags);
1868 }
1869 }
1870 else if (primary)
1871 {
1872 tree tpl = TI_TEMPLATE (info);
1873 tree parms = DECL_TEMPLATE_PARMS (tpl);
1874 int len, ix;
1875
1876 parms = TREE_CODE (parms) == TREE_LIST ? TREE_VALUE (parms) : NULL_TREE;
1877 len = parms ? TREE_VEC_LENGTH (parms) : 0;
1878
1879 for (ix = 0; ix != len; ix++)
1880 {
1881 tree parm;
1882
1883 if (TREE_VEC_ELT (parms, ix) == error_mark_node)
1884 {
1885 pp_string (pp, M_("<template parameter error>"));
1886 continue;
1887 }
1888
1889 parm = TREE_VALUE (TREE_VEC_ELT (parms, ix));
1890
1891 if (ix)
1892 pp_separate_with_comma (pp);
1893
1894 dump_decl (pp, parm, flags & ~TFF_DECL_SPECIFIERS);
1895 }
1896 }
1897 pp_cxx_end_template_argument_list (pp);
1898 }
1899
1900 /* Print out the arguments of CALL_EXPR T as a parenthesized list using
1901 flags FLAGS. Skip over the first argument if SKIPFIRST is true. */
1902
1903 static void
1904 dump_call_expr_args (cxx_pretty_printer *pp, tree t, int flags, bool skipfirst)
1905 {
1906 tree arg;
1907 call_expr_arg_iterator iter;
1908
1909 pp_cxx_left_paren (pp);
1910 FOR_EACH_CALL_EXPR_ARG (arg, iter, t)
1911 {
1912 if (skipfirst)
1913 skipfirst = false;
1914 else
1915 {
1916 dump_expr (pp, arg, flags | TFF_EXPR_IN_PARENS);
1917 if (more_call_expr_args_p (&iter))
1918 pp_separate_with_comma (pp);
1919 }
1920 }
1921 pp_cxx_right_paren (pp);
1922 }
1923
1924 /* Print out the arguments of AGGR_INIT_EXPR T as a parenthesized list
1925 using flags FLAGS. Skip over the first argument if SKIPFIRST is
1926 true. */
1927
1928 static void
1929 dump_aggr_init_expr_args (cxx_pretty_printer *pp, tree t, int flags,
1930 bool skipfirst)
1931 {
1932 tree arg;
1933 aggr_init_expr_arg_iterator iter;
1934
1935 pp_cxx_left_paren (pp);
1936 FOR_EACH_AGGR_INIT_EXPR_ARG (arg, iter, t)
1937 {
1938 if (skipfirst)
1939 skipfirst = false;
1940 else
1941 {
1942 dump_expr (pp, arg, flags | TFF_EXPR_IN_PARENS);
1943 if (more_aggr_init_expr_args_p (&iter))
1944 pp_separate_with_comma (pp);
1945 }
1946 }
1947 pp_cxx_right_paren (pp);
1948 }
1949
1950 /* Print out a list of initializers (subr of dump_expr). */
1951
1952 static void
1953 dump_expr_list (cxx_pretty_printer *pp, tree l, int flags)
1954 {
1955 while (l)
1956 {
1957 dump_expr (pp, TREE_VALUE (l), flags | TFF_EXPR_IN_PARENS);
1958 l = TREE_CHAIN (l);
1959 if (l)
1960 pp_separate_with_comma (pp);
1961 }
1962 }
1963
1964 /* Print out a vector of initializers (subr of dump_expr). */
1965
1966 static void
1967 dump_expr_init_vec (cxx_pretty_printer *pp, vec<constructor_elt, va_gc> *v,
1968 int flags)
1969 {
1970 unsigned HOST_WIDE_INT idx;
1971 tree value;
1972
1973 FOR_EACH_CONSTRUCTOR_VALUE (v, idx, value)
1974 {
1975 dump_expr (pp, value, flags | TFF_EXPR_IN_PARENS);
1976 if (idx != v->length () - 1)
1977 pp_separate_with_comma (pp);
1978 }
1979 }
1980
1981
1982 /* We've gotten an indirect REFERENCE (an OBJ_TYPE_REF) to a virtual
1983 function. Resolve it to a close relative -- in the sense of static
1984 type -- variant being overridden. That is close to what was written in
1985 the source code. Subroutine of dump_expr. */
1986
1987 static tree
1988 resolve_virtual_fun_from_obj_type_ref (tree ref)
1989 {
1990 tree obj_type = TREE_TYPE (OBJ_TYPE_REF_OBJECT (ref));
1991 HOST_WIDE_INT index = tree_to_uhwi (OBJ_TYPE_REF_TOKEN (ref));
1992 tree fun = BINFO_VIRTUALS (TYPE_BINFO (TREE_TYPE (obj_type)));
1993 while (index)
1994 {
1995 fun = TREE_CHAIN (fun);
1996 index -= (TARGET_VTABLE_USES_DESCRIPTORS
1997 ? TARGET_VTABLE_USES_DESCRIPTORS : 1);
1998 }
1999
2000 return BV_FN (fun);
2001 }
2002
2003 /* Print out an expression E under control of FLAGS. */
2004
2005 static void
2006 dump_expr (cxx_pretty_printer *pp, tree t, int flags)
2007 {
2008 tree op;
2009
2010 if (t == 0)
2011 return;
2012
2013 if (STATEMENT_CLASS_P (t))
2014 {
2015 pp_cxx_ws_string (pp, M_("<statement>"));
2016 return;
2017 }
2018
2019 switch (TREE_CODE (t))
2020 {
2021 case VAR_DECL:
2022 case PARM_DECL:
2023 case FIELD_DECL:
2024 case CONST_DECL:
2025 case FUNCTION_DECL:
2026 case TEMPLATE_DECL:
2027 case NAMESPACE_DECL:
2028 case LABEL_DECL:
2029 case OVERLOAD:
2030 case TYPE_DECL:
2031 case IDENTIFIER_NODE:
2032 dump_decl (pp, t, ((flags & ~(TFF_DECL_SPECIFIERS|TFF_RETURN_TYPE
2033 |TFF_TEMPLATE_HEADER))
2034 | TFF_NO_TEMPLATE_BINDINGS
2035 | TFF_NO_FUNCTION_ARGUMENTS));
2036 break;
2037
2038 case SSA_NAME:
2039 if (SSA_NAME_VAR (t)
2040 && !DECL_ARTIFICIAL (SSA_NAME_VAR (t)))
2041 dump_expr (pp, SSA_NAME_VAR (t), flags);
2042 else
2043 pp_cxx_ws_string (pp, M_("<unknown>"));
2044 break;
2045
2046 case VOID_CST:
2047 case INTEGER_CST:
2048 case REAL_CST:
2049 case STRING_CST:
2050 case COMPLEX_CST:
2051 pp->constant (t);
2052 break;
2053
2054 case USERDEF_LITERAL:
2055 pp_cxx_userdef_literal (pp, t);
2056 break;
2057
2058 case THROW_EXPR:
2059 /* While waiting for caret diagnostics, avoid printing
2060 __cxa_allocate_exception, __cxa_throw, and the like. */
2061 pp_cxx_ws_string (pp, M_("<throw-expression>"));
2062 break;
2063
2064 case PTRMEM_CST:
2065 pp_ampersand (pp);
2066 dump_type (pp, PTRMEM_CST_CLASS (t), flags);
2067 pp_cxx_colon_colon (pp);
2068 pp_cxx_tree_identifier (pp, DECL_NAME (PTRMEM_CST_MEMBER (t)));
2069 break;
2070
2071 case COMPOUND_EXPR:
2072 pp_cxx_left_paren (pp);
2073 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2074 pp_separate_with_comma (pp);
2075 dump_expr (pp, TREE_OPERAND (t, 1), flags | TFF_EXPR_IN_PARENS);
2076 pp_cxx_right_paren (pp);
2077 break;
2078
2079 case COND_EXPR:
2080 case VEC_COND_EXPR:
2081 pp_cxx_left_paren (pp);
2082 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2083 pp_string (pp, " ? ");
2084 dump_expr (pp, TREE_OPERAND (t, 1), flags | TFF_EXPR_IN_PARENS);
2085 pp_string (pp, " : ");
2086 dump_expr (pp, TREE_OPERAND (t, 2), flags | TFF_EXPR_IN_PARENS);
2087 pp_cxx_right_paren (pp);
2088 break;
2089
2090 case SAVE_EXPR:
2091 if (TREE_HAS_CONSTRUCTOR (t))
2092 {
2093 pp_cxx_ws_string (pp, "new");
2094 pp_cxx_whitespace (pp);
2095 dump_type (pp, TREE_TYPE (TREE_TYPE (t)), flags);
2096 }
2097 else
2098 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2099 break;
2100
2101 case AGGR_INIT_EXPR:
2102 {
2103 tree fn = NULL_TREE;
2104
2105 if (TREE_CODE (AGGR_INIT_EXPR_FN (t)) == ADDR_EXPR)
2106 fn = TREE_OPERAND (AGGR_INIT_EXPR_FN (t), 0);
2107
2108 if (fn && TREE_CODE (fn) == FUNCTION_DECL)
2109 {
2110 if (DECL_CONSTRUCTOR_P (fn))
2111 dump_type (pp, DECL_CONTEXT (fn), flags);
2112 else
2113 dump_decl (pp, fn, 0);
2114 }
2115 else
2116 dump_expr (pp, AGGR_INIT_EXPR_FN (t), 0);
2117 }
2118 dump_aggr_init_expr_args (pp, t, flags, true);
2119 break;
2120
2121 case CALL_EXPR:
2122 {
2123 tree fn = CALL_EXPR_FN (t);
2124 bool skipfirst = false;
2125
2126 /* Deal with internal functions. */
2127 if (fn == NULL_TREE)
2128 {
2129 pp_string (pp, internal_fn_name (CALL_EXPR_IFN (t)));
2130 dump_call_expr_args (pp, t, flags, skipfirst);
2131 break;
2132 }
2133
2134 if (TREE_CODE (fn) == ADDR_EXPR)
2135 fn = TREE_OPERAND (fn, 0);
2136
2137 /* Nobody is interested in seeing the guts of vcalls. */
2138 if (TREE_CODE (fn) == OBJ_TYPE_REF)
2139 fn = resolve_virtual_fun_from_obj_type_ref (fn);
2140
2141 if (TREE_TYPE (fn) != NULL_TREE
2142 && NEXT_CODE (fn) == METHOD_TYPE
2143 && call_expr_nargs (t))
2144 {
2145 tree ob = CALL_EXPR_ARG (t, 0);
2146 if (TREE_CODE (ob) == ADDR_EXPR)
2147 {
2148 dump_expr (pp, TREE_OPERAND (ob, 0),
2149 flags | TFF_EXPR_IN_PARENS);
2150 pp_cxx_dot (pp);
2151 }
2152 else if (TREE_CODE (ob) != PARM_DECL
2153 || strcmp (IDENTIFIER_POINTER (DECL_NAME (ob)), "this"))
2154 {
2155 dump_expr (pp, ob, flags | TFF_EXPR_IN_PARENS);
2156 pp_cxx_arrow (pp);
2157 }
2158 skipfirst = true;
2159 }
2160 if (flag_sanitize & SANITIZE_UNDEFINED
2161 && is_ubsan_builtin_p (fn))
2162 {
2163 pp_string (cxx_pp, M_("<ubsan routine call>"));
2164 break;
2165 }
2166 dump_expr (pp, fn, flags | TFF_EXPR_IN_PARENS);
2167 dump_call_expr_args (pp, t, flags, skipfirst);
2168 }
2169 break;
2170
2171 case TARGET_EXPR:
2172 /* Note that this only works for G++ target exprs. If somebody
2173 builds a general TARGET_EXPR, there's no way to represent that
2174 it initializes anything other that the parameter slot for the
2175 default argument. Note we may have cleared out the first
2176 operand in expand_expr, so don't go killing ourselves. */
2177 if (TREE_OPERAND (t, 1))
2178 dump_expr (pp, TREE_OPERAND (t, 1), flags | TFF_EXPR_IN_PARENS);
2179 break;
2180
2181 case POINTER_PLUS_EXPR:
2182 dump_binary_op (pp, "+", t, flags);
2183 break;
2184
2185 case INIT_EXPR:
2186 case MODIFY_EXPR:
2187 dump_binary_op (pp, assignment_operator_name_info[NOP_EXPR].name,
2188 t, flags);
2189 break;
2190
2191 case PLUS_EXPR:
2192 case MINUS_EXPR:
2193 case MULT_EXPR:
2194 case TRUNC_DIV_EXPR:
2195 case TRUNC_MOD_EXPR:
2196 case MIN_EXPR:
2197 case MAX_EXPR:
2198 case LSHIFT_EXPR:
2199 case RSHIFT_EXPR:
2200 case BIT_IOR_EXPR:
2201 case BIT_XOR_EXPR:
2202 case BIT_AND_EXPR:
2203 case TRUTH_ANDIF_EXPR:
2204 case TRUTH_ORIF_EXPR:
2205 case LT_EXPR:
2206 case LE_EXPR:
2207 case GT_EXPR:
2208 case GE_EXPR:
2209 case EQ_EXPR:
2210 case NE_EXPR:
2211 case EXACT_DIV_EXPR:
2212 dump_binary_op (pp, operator_name_info[TREE_CODE (t)].name, t, flags);
2213 break;
2214
2215 case CEIL_DIV_EXPR:
2216 case FLOOR_DIV_EXPR:
2217 case ROUND_DIV_EXPR:
2218 case RDIV_EXPR:
2219 dump_binary_op (pp, "/", t, flags);
2220 break;
2221
2222 case CEIL_MOD_EXPR:
2223 case FLOOR_MOD_EXPR:
2224 case ROUND_MOD_EXPR:
2225 dump_binary_op (pp, "%", t, flags);
2226 break;
2227
2228 case COMPONENT_REF:
2229 {
2230 tree ob = TREE_OPERAND (t, 0);
2231 if (INDIRECT_REF_P (ob))
2232 {
2233 ob = TREE_OPERAND (ob, 0);
2234 if (TREE_CODE (ob) != PARM_DECL
2235 || (DECL_NAME (ob)
2236 && strcmp (IDENTIFIER_POINTER (DECL_NAME (ob)), "this")))
2237 {
2238 dump_expr (pp, ob, flags | TFF_EXPR_IN_PARENS);
2239 if (TREE_CODE (TREE_TYPE (ob)) == REFERENCE_TYPE)
2240 pp_cxx_dot (pp);
2241 else
2242 pp_cxx_arrow (pp);
2243 }
2244 }
2245 else
2246 {
2247 dump_expr (pp, ob, flags | TFF_EXPR_IN_PARENS);
2248 if (TREE_CODE (ob) != ARROW_EXPR)
2249 pp_cxx_dot (pp);
2250 }
2251 dump_expr (pp, TREE_OPERAND (t, 1), flags & ~TFF_EXPR_IN_PARENS);
2252 }
2253 break;
2254
2255 case ARRAY_REF:
2256 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2257 pp_cxx_left_bracket (pp);
2258 dump_expr (pp, TREE_OPERAND (t, 1), flags | TFF_EXPR_IN_PARENS);
2259 pp_cxx_right_bracket (pp);
2260 break;
2261
2262 case ARRAY_NOTATION_REF:
2263 dump_expr (pp, ARRAY_NOTATION_ARRAY (t), flags | TFF_EXPR_IN_PARENS);
2264 pp_cxx_left_bracket (pp);
2265 dump_expr (pp, ARRAY_NOTATION_START (t), flags | TFF_EXPR_IN_PARENS);
2266 pp_colon (pp);
2267 dump_expr (pp, ARRAY_NOTATION_LENGTH (t), flags | TFF_EXPR_IN_PARENS);
2268 pp_colon (pp);
2269 dump_expr (pp, ARRAY_NOTATION_STRIDE (t), flags | TFF_EXPR_IN_PARENS);
2270 pp_cxx_right_bracket (pp);
2271 break;
2272
2273 case UNARY_PLUS_EXPR:
2274 dump_unary_op (pp, "+", t, flags);
2275 break;
2276
2277 case ADDR_EXPR:
2278 if (TREE_CODE (TREE_OPERAND (t, 0)) == FUNCTION_DECL
2279 || TREE_CODE (TREE_OPERAND (t, 0)) == STRING_CST
2280 /* An ADDR_EXPR can have reference type. In that case, we
2281 shouldn't print the `&' doing so indicates to the user
2282 that the expression has pointer type. */
2283 || (TREE_TYPE (t)
2284 && TREE_CODE (TREE_TYPE (t)) == REFERENCE_TYPE))
2285 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2286 else if (TREE_CODE (TREE_OPERAND (t, 0)) == LABEL_DECL)
2287 dump_unary_op (pp, "&&", t, flags);
2288 else
2289 dump_unary_op (pp, "&", t, flags);
2290 break;
2291
2292 case INDIRECT_REF:
2293 if (TREE_HAS_CONSTRUCTOR (t))
2294 {
2295 t = TREE_OPERAND (t, 0);
2296 gcc_assert (TREE_CODE (t) == CALL_EXPR);
2297 dump_expr (pp, CALL_EXPR_FN (t), flags | TFF_EXPR_IN_PARENS);
2298 dump_call_expr_args (pp, t, flags, true);
2299 }
2300 else
2301 {
2302 if (TREE_OPERAND (t,0) != NULL_TREE
2303 && TREE_TYPE (TREE_OPERAND (t, 0))
2304 && NEXT_CODE (TREE_OPERAND (t, 0)) == REFERENCE_TYPE)
2305 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2306 else
2307 dump_unary_op (pp, "*", t, flags);
2308 }
2309 break;
2310
2311 case MEM_REF:
2312 if (TREE_CODE (TREE_OPERAND (t, 0)) == ADDR_EXPR
2313 && integer_zerop (TREE_OPERAND (t, 1)))
2314 dump_expr (pp, TREE_OPERAND (TREE_OPERAND (t, 0), 0), flags);
2315 else
2316 {
2317 pp_cxx_star (pp);
2318 if (!integer_zerop (TREE_OPERAND (t, 1)))
2319 {
2320 pp_cxx_left_paren (pp);
2321 if (!integer_onep (TYPE_SIZE_UNIT
2322 (TREE_TYPE (TREE_TYPE (TREE_OPERAND (t, 0))))))
2323 {
2324 pp_cxx_left_paren (pp);
2325 dump_type (pp, ptr_type_node, flags);
2326 pp_cxx_right_paren (pp);
2327 }
2328 }
2329 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2330 if (!integer_zerop (TREE_OPERAND (t, 1)))
2331 {
2332 pp_cxx_ws_string (pp, "+");
2333 dump_expr (pp, fold_convert (ssizetype, TREE_OPERAND (t, 1)),
2334 flags);
2335 pp_cxx_right_paren (pp);
2336 }
2337 }
2338 break;
2339
2340 case NEGATE_EXPR:
2341 case BIT_NOT_EXPR:
2342 case TRUTH_NOT_EXPR:
2343 case PREDECREMENT_EXPR:
2344 case PREINCREMENT_EXPR:
2345 dump_unary_op (pp, operator_name_info [TREE_CODE (t)].name, t, flags);
2346 break;
2347
2348 case POSTDECREMENT_EXPR:
2349 case POSTINCREMENT_EXPR:
2350 pp_cxx_left_paren (pp);
2351 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2352 pp_cxx_ws_string (pp, operator_name_info[TREE_CODE (t)].name);
2353 pp_cxx_right_paren (pp);
2354 break;
2355
2356 case NON_LVALUE_EXPR:
2357 /* FIXME: This is a KLUDGE workaround for a parsing problem. There
2358 should be another level of INDIRECT_REF so that I don't have to do
2359 this. */
2360 if (TREE_TYPE (t) != NULL_TREE && NEXT_CODE (t) == POINTER_TYPE)
2361 {
2362 tree next = TREE_TYPE (TREE_TYPE (t));
2363
2364 while (TYPE_PTR_P (next))
2365 next = TREE_TYPE (next);
2366
2367 if (TREE_CODE (next) == FUNCTION_TYPE)
2368 {
2369 if (flags & TFF_EXPR_IN_PARENS)
2370 pp_cxx_left_paren (pp);
2371 pp_cxx_star (pp);
2372 dump_expr (pp, TREE_OPERAND (t, 0), flags & ~TFF_EXPR_IN_PARENS);
2373 if (flags & TFF_EXPR_IN_PARENS)
2374 pp_cxx_right_paren (pp);
2375 break;
2376 }
2377 /* Else fall through. */
2378 }
2379 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2380 break;
2381
2382 CASE_CONVERT:
2383 case IMPLICIT_CONV_EXPR:
2384 case VIEW_CONVERT_EXPR:
2385 {
2386 tree op = TREE_OPERAND (t, 0);
2387 tree ttype = TREE_TYPE (t);
2388 tree optype = TREE_TYPE (op);
2389
2390 if (TREE_CODE (ttype) != TREE_CODE (optype)
2391 && POINTER_TYPE_P (ttype)
2392 && POINTER_TYPE_P (optype)
2393 && same_type_p (TREE_TYPE (optype),
2394 TREE_TYPE (ttype)))
2395 {
2396 if (TREE_CODE (ttype) == REFERENCE_TYPE)
2397 {
2398 STRIP_NOPS (op);
2399 if (TREE_CODE (op) == ADDR_EXPR)
2400 dump_expr (pp, TREE_OPERAND (op, 0), flags);
2401 else
2402 dump_unary_op (pp, "*", t, flags);
2403 }
2404 else
2405 dump_unary_op (pp, "&", t, flags);
2406 }
2407 else if (!same_type_p (TREE_TYPE (op), TREE_TYPE (t)))
2408 {
2409 /* It is a cast, but we cannot tell whether it is a
2410 reinterpret or static cast. Use the C style notation. */
2411 if (flags & TFF_EXPR_IN_PARENS)
2412 pp_cxx_left_paren (pp);
2413 pp_cxx_left_paren (pp);
2414 dump_type (pp, TREE_TYPE (t), flags);
2415 pp_cxx_right_paren (pp);
2416 dump_expr (pp, op, flags | TFF_EXPR_IN_PARENS);
2417 if (flags & TFF_EXPR_IN_PARENS)
2418 pp_cxx_right_paren (pp);
2419 }
2420 else
2421 dump_expr (pp, op, flags);
2422 break;
2423 }
2424
2425 case CONSTRUCTOR:
2426 if (TREE_TYPE (t) && TYPE_PTRMEMFUNC_P (TREE_TYPE (t)))
2427 {
2428 tree idx = build_ptrmemfunc_access_expr (t, pfn_identifier);
2429
2430 if (integer_zerop (idx))
2431 {
2432 /* A NULL pointer-to-member constant. */
2433 pp_cxx_left_paren (pp);
2434 pp_cxx_left_paren (pp);
2435 dump_type (pp, TREE_TYPE (t), flags);
2436 pp_cxx_right_paren (pp);
2437 pp_character (pp, '0');
2438 pp_cxx_right_paren (pp);
2439 break;
2440 }
2441 else if (tree_fits_shwi_p (idx))
2442 {
2443 tree virtuals;
2444 unsigned HOST_WIDE_INT n;
2445
2446 t = TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE (TREE_TYPE (t)));
2447 t = TYPE_METHOD_BASETYPE (t);
2448 virtuals = BINFO_VIRTUALS (TYPE_BINFO (TYPE_MAIN_VARIANT (t)));
2449
2450 n = tree_to_shwi (idx);
2451
2452 /* Map vtable index back one, to allow for the null pointer to
2453 member. */
2454 --n;
2455
2456 while (n > 0 && virtuals)
2457 {
2458 --n;
2459 virtuals = TREE_CHAIN (virtuals);
2460 }
2461 if (virtuals)
2462 {
2463 dump_expr (pp, BV_FN (virtuals),
2464 flags | TFF_EXPR_IN_PARENS);
2465 break;
2466 }
2467 }
2468 }
2469 if (TREE_TYPE (t) && LAMBDA_TYPE_P (TREE_TYPE (t)))
2470 pp_string (pp, "<lambda closure object>");
2471 if (TREE_TYPE (t) && EMPTY_CONSTRUCTOR_P (t))
2472 {
2473 dump_type (pp, TREE_TYPE (t), 0);
2474 pp_cxx_left_paren (pp);
2475 pp_cxx_right_paren (pp);
2476 }
2477 else
2478 {
2479 if (!BRACE_ENCLOSED_INITIALIZER_P (t))
2480 dump_type (pp, TREE_TYPE (t), 0);
2481 pp_cxx_left_brace (pp);
2482 dump_expr_init_vec (pp, CONSTRUCTOR_ELTS (t), flags);
2483 pp_cxx_right_brace (pp);
2484 }
2485
2486 break;
2487
2488 case OFFSET_REF:
2489 {
2490 tree ob = TREE_OPERAND (t, 0);
2491 if (is_dummy_object (ob))
2492 {
2493 t = TREE_OPERAND (t, 1);
2494 if (TREE_CODE (t) == FUNCTION_DECL)
2495 /* A::f */
2496 dump_expr (pp, t, flags | TFF_EXPR_IN_PARENS);
2497 else if (BASELINK_P (t))
2498 dump_expr (pp, OVL_FIRST (BASELINK_FUNCTIONS (t)),
2499 flags | TFF_EXPR_IN_PARENS);
2500 else
2501 dump_decl (pp, t, flags);
2502 }
2503 else
2504 {
2505 if (INDIRECT_REF_P (ob))
2506 {
2507 dump_expr (pp, TREE_OPERAND (ob, 0), flags | TFF_EXPR_IN_PARENS);
2508 pp_cxx_arrow (pp);
2509 pp_cxx_star (pp);
2510 }
2511 else
2512 {
2513 dump_expr (pp, ob, flags | TFF_EXPR_IN_PARENS);
2514 pp_cxx_dot (pp);
2515 pp_cxx_star (pp);
2516 }
2517 dump_expr (pp, TREE_OPERAND (t, 1), flags | TFF_EXPR_IN_PARENS);
2518 }
2519 break;
2520 }
2521
2522 case TEMPLATE_PARM_INDEX:
2523 dump_decl (pp, TEMPLATE_PARM_DECL (t), flags & ~TFF_DECL_SPECIFIERS);
2524 break;
2525
2526 case CAST_EXPR:
2527 if (TREE_OPERAND (t, 0) == NULL_TREE
2528 || TREE_CHAIN (TREE_OPERAND (t, 0)))
2529 {
2530 dump_type (pp, TREE_TYPE (t), flags);
2531 pp_cxx_left_paren (pp);
2532 dump_expr_list (pp, TREE_OPERAND (t, 0), flags);
2533 pp_cxx_right_paren (pp);
2534 }
2535 else
2536 {
2537 pp_cxx_left_paren (pp);
2538 dump_type (pp, TREE_TYPE (t), flags);
2539 pp_cxx_right_paren (pp);
2540 pp_cxx_left_paren (pp);
2541 dump_expr_list (pp, TREE_OPERAND (t, 0), flags);
2542 pp_cxx_right_paren (pp);
2543 }
2544 break;
2545
2546 case STATIC_CAST_EXPR:
2547 pp_cxx_ws_string (pp, "static_cast");
2548 goto cast;
2549 case REINTERPRET_CAST_EXPR:
2550 pp_cxx_ws_string (pp, "reinterpret_cast");
2551 goto cast;
2552 case CONST_CAST_EXPR:
2553 pp_cxx_ws_string (pp, "const_cast");
2554 goto cast;
2555 case DYNAMIC_CAST_EXPR:
2556 pp_cxx_ws_string (pp, "dynamic_cast");
2557 cast:
2558 pp_cxx_begin_template_argument_list (pp);
2559 dump_type (pp, TREE_TYPE (t), flags);
2560 pp_cxx_end_template_argument_list (pp);
2561 pp_cxx_left_paren (pp);
2562 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2563 pp_cxx_right_paren (pp);
2564 break;
2565
2566 case ARROW_EXPR:
2567 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2568 pp_cxx_arrow (pp);
2569 break;
2570
2571 case SIZEOF_EXPR:
2572 case ALIGNOF_EXPR:
2573 if (TREE_CODE (t) == SIZEOF_EXPR)
2574 pp_cxx_ws_string (pp, "sizeof");
2575 else
2576 {
2577 gcc_assert (TREE_CODE (t) == ALIGNOF_EXPR);
2578 pp_cxx_ws_string (pp, "__alignof__");
2579 }
2580 op = TREE_OPERAND (t, 0);
2581 if (PACK_EXPANSION_P (op))
2582 {
2583 pp_string (pp, "...");
2584 op = PACK_EXPANSION_PATTERN (op);
2585 }
2586 pp_cxx_whitespace (pp);
2587 pp_cxx_left_paren (pp);
2588 if (TREE_CODE (t) == SIZEOF_EXPR && SIZEOF_EXPR_TYPE_P (t))
2589 dump_type (pp, TREE_TYPE (op), flags);
2590 else if (TYPE_P (TREE_OPERAND (t, 0)))
2591 dump_type (pp, op, flags);
2592 else
2593 dump_expr (pp, op, flags);
2594 pp_cxx_right_paren (pp);
2595 break;
2596
2597 case AT_ENCODE_EXPR:
2598 pp_cxx_ws_string (pp, "@encode");
2599 pp_cxx_whitespace (pp);
2600 pp_cxx_left_paren (pp);
2601 dump_type (pp, TREE_OPERAND (t, 0), flags);
2602 pp_cxx_right_paren (pp);
2603 break;
2604
2605 case NOEXCEPT_EXPR:
2606 pp_cxx_ws_string (pp, "noexcept");
2607 pp_cxx_whitespace (pp);
2608 pp_cxx_left_paren (pp);
2609 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2610 pp_cxx_right_paren (pp);
2611 break;
2612
2613 case REALPART_EXPR:
2614 case IMAGPART_EXPR:
2615 pp_cxx_ws_string (pp, operator_name_info[TREE_CODE (t)].name);
2616 pp_cxx_whitespace (pp);
2617 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2618 break;
2619
2620 case DEFAULT_ARG:
2621 pp_string (pp, M_("<unparsed>"));
2622 break;
2623
2624 case TRY_CATCH_EXPR:
2625 case WITH_CLEANUP_EXPR:
2626 case CLEANUP_POINT_EXPR:
2627 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2628 break;
2629
2630 case PSEUDO_DTOR_EXPR:
2631 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2632 pp_cxx_dot (pp);
2633 if (TREE_OPERAND (t, 1))
2634 {
2635 dump_type (pp, TREE_OPERAND (t, 1), flags);
2636 pp_cxx_colon_colon (pp);
2637 }
2638 pp_cxx_complement (pp);
2639 dump_type (pp, TREE_OPERAND (t, 2), flags);
2640 break;
2641
2642 case TEMPLATE_ID_EXPR:
2643 dump_decl (pp, t, flags);
2644 break;
2645
2646 case BIND_EXPR:
2647 case STMT_EXPR:
2648 case EXPR_STMT:
2649 case STATEMENT_LIST:
2650 /* We don't yet have a way of dumping statements in a
2651 human-readable format. */
2652 pp_string (pp, "({...})");
2653 break;
2654
2655 case LOOP_EXPR:
2656 pp_string (pp, "while (1) { ");
2657 dump_expr (pp, TREE_OPERAND (t, 0), flags & ~TFF_EXPR_IN_PARENS);
2658 pp_cxx_right_brace (pp);
2659 break;
2660
2661 case EXIT_EXPR:
2662 pp_string (pp, "if (");
2663 dump_expr (pp, TREE_OPERAND (t, 0), flags & ~TFF_EXPR_IN_PARENS);
2664 pp_string (pp, ") break; ");
2665 break;
2666
2667 case BASELINK:
2668 dump_expr (pp, BASELINK_FUNCTIONS (t), flags & ~TFF_EXPR_IN_PARENS);
2669 break;
2670
2671 case EMPTY_CLASS_EXPR:
2672 dump_type (pp, TREE_TYPE (t), flags);
2673 pp_cxx_left_paren (pp);
2674 pp_cxx_right_paren (pp);
2675 break;
2676
2677 case NON_DEPENDENT_EXPR:
2678 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2679 break;
2680
2681 case ARGUMENT_PACK_SELECT:
2682 dump_template_argument (pp, ARGUMENT_PACK_SELECT_FROM_PACK (t), flags);
2683 break;
2684
2685 case RECORD_TYPE:
2686 case UNION_TYPE:
2687 case ENUMERAL_TYPE:
2688 case REAL_TYPE:
2689 case VOID_TYPE:
2690 case BOOLEAN_TYPE:
2691 case INTEGER_TYPE:
2692 case COMPLEX_TYPE:
2693 case VECTOR_TYPE:
2694 pp_type_specifier_seq (pp, t);
2695 break;
2696
2697 case TYPENAME_TYPE:
2698 /* We get here when we want to print a dependent type as an
2699 id-expression, without any disambiguator decoration. */
2700 pp->id_expression (t);
2701 break;
2702
2703 case TEMPLATE_TYPE_PARM:
2704 case TEMPLATE_TEMPLATE_PARM:
2705 case BOUND_TEMPLATE_TEMPLATE_PARM:
2706 dump_type (pp, t, flags);
2707 break;
2708
2709 case TRAIT_EXPR:
2710 pp_cxx_trait_expression (pp, t);
2711 break;
2712
2713 case VA_ARG_EXPR:
2714 pp_cxx_va_arg_expression (pp, t);
2715 break;
2716
2717 case OFFSETOF_EXPR:
2718 pp_cxx_offsetof_expression (pp, t);
2719 break;
2720
2721 case ADDRESSOF_EXPR:
2722 pp_cxx_addressof_expression (pp, t);
2723 break;
2724
2725 case SCOPE_REF:
2726 dump_decl (pp, t, flags);
2727 break;
2728
2729 case EXPR_PACK_EXPANSION:
2730 case UNARY_LEFT_FOLD_EXPR:
2731 case UNARY_RIGHT_FOLD_EXPR:
2732 case BINARY_LEFT_FOLD_EXPR:
2733 case BINARY_RIGHT_FOLD_EXPR:
2734 case TYPEID_EXPR:
2735 case MEMBER_REF:
2736 case DOTSTAR_EXPR:
2737 case NEW_EXPR:
2738 case VEC_NEW_EXPR:
2739 case DELETE_EXPR:
2740 case VEC_DELETE_EXPR:
2741 case MODOP_EXPR:
2742 case ABS_EXPR:
2743 case CONJ_EXPR:
2744 case VECTOR_CST:
2745 case FIXED_CST:
2746 case UNORDERED_EXPR:
2747 case ORDERED_EXPR:
2748 case UNLT_EXPR:
2749 case UNLE_EXPR:
2750 case UNGT_EXPR:
2751 case UNGE_EXPR:
2752 case UNEQ_EXPR:
2753 case LTGT_EXPR:
2754 case COMPLEX_EXPR:
2755 case BIT_FIELD_REF:
2756 case FIX_TRUNC_EXPR:
2757 case FLOAT_EXPR:
2758 pp->expression (t);
2759 break;
2760
2761 case TRUTH_AND_EXPR:
2762 case TRUTH_OR_EXPR:
2763 case TRUTH_XOR_EXPR:
2764 if (flags & TFF_EXPR_IN_PARENS)
2765 pp_cxx_left_paren (pp);
2766 pp->expression (t);
2767 if (flags & TFF_EXPR_IN_PARENS)
2768 pp_cxx_right_paren (pp);
2769 break;
2770
2771 case OBJ_TYPE_REF:
2772 dump_expr (pp, resolve_virtual_fun_from_obj_type_ref (t), flags);
2773 break;
2774
2775 case LAMBDA_EXPR:
2776 pp_string (pp, M_("<lambda>"));
2777 break;
2778
2779 case PAREN_EXPR:
2780 pp_cxx_left_paren (pp);
2781 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2782 pp_cxx_right_paren (pp);
2783 break;
2784
2785 case REQUIRES_EXPR:
2786 pp_cxx_requires_expr (cxx_pp, t);
2787 break;
2788
2789 case SIMPLE_REQ:
2790 pp_cxx_simple_requirement (cxx_pp, t);
2791 break;
2792
2793 case TYPE_REQ:
2794 pp_cxx_type_requirement (cxx_pp, t);
2795 break;
2796
2797 case COMPOUND_REQ:
2798 pp_cxx_compound_requirement (cxx_pp, t);
2799 break;
2800
2801 case NESTED_REQ:
2802 pp_cxx_nested_requirement (cxx_pp, t);
2803 break;
2804
2805 case PRED_CONSTR:
2806 case CHECK_CONSTR:
2807 case EXPR_CONSTR:
2808 case TYPE_CONSTR:
2809 case ICONV_CONSTR:
2810 case DEDUCT_CONSTR:
2811 case EXCEPT_CONSTR:
2812 case PARM_CONSTR:
2813 case CONJ_CONSTR:
2814 case DISJ_CONSTR:
2815 pp_cxx_constraint (cxx_pp, t);
2816 break;
2817
2818 case PLACEHOLDER_EXPR:
2819 pp_string (pp, M_("*this"));
2820 break;
2821
2822 case TREE_LIST:
2823 dump_expr_list (pp, t, flags);
2824 break;
2825
2826 /* This list is incomplete, but should suffice for now.
2827 It is very important that `sorry' does not call
2828 `report_error_function'. That could cause an infinite loop. */
2829 default:
2830 pp_unsupported_tree (pp, t);
2831 /* Fall through. */
2832 case ERROR_MARK:
2833 pp_string (pp, M_("<expression error>"));
2834 break;
2835 }
2836 }
2837
2838 static void
2839 dump_binary_op (cxx_pretty_printer *pp, const char *opstring, tree t,
2840 int flags)
2841 {
2842 pp_cxx_left_paren (pp);
2843 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2844 pp_cxx_whitespace (pp);
2845 if (opstring)
2846 pp_cxx_ws_string (pp, opstring);
2847 else
2848 pp_string (pp, M_("<unknown operator>"));
2849 pp_cxx_whitespace (pp);
2850 dump_expr (pp, TREE_OPERAND (t, 1), flags | TFF_EXPR_IN_PARENS);
2851 pp_cxx_right_paren (pp);
2852 }
2853
2854 static void
2855 dump_unary_op (cxx_pretty_printer *pp, const char *opstring, tree t, int flags)
2856 {
2857 if (flags & TFF_EXPR_IN_PARENS)
2858 pp_cxx_left_paren (pp);
2859 pp_cxx_ws_string (pp, opstring);
2860 dump_expr (pp, TREE_OPERAND (t, 0), flags & ~TFF_EXPR_IN_PARENS);
2861 if (flags & TFF_EXPR_IN_PARENS)
2862 pp_cxx_right_paren (pp);
2863 }
2864
2865 static void
2866 reinit_cxx_pp (void)
2867 {
2868 pp_clear_output_area (cxx_pp);
2869 cxx_pp->padding = pp_none;
2870 pp_indentation (cxx_pp) = 0;
2871 pp_needs_newline (cxx_pp) = false;
2872 cxx_pp->enclosing_scope = current_function_decl;
2873 }
2874
2875 /* Same as pp_formatted_text, except the return string is a separate
2876 copy and has a GGC storage duration, e.g. an indefinite lifetime. */
2877
2878 inline const char *
2879 pp_ggc_formatted_text (pretty_printer *pp)
2880 {
2881 return ggc_strdup (pp_formatted_text (pp));
2882 }
2883
2884 /* Exported interface to stringifying types, exprs and decls under TFF_*
2885 control. */
2886
2887 const char *
2888 type_as_string (tree typ, int flags)
2889 {
2890 reinit_cxx_pp ();
2891 pp_translate_identifiers (cxx_pp) = false;
2892 dump_type (cxx_pp, typ, flags);
2893 return pp_ggc_formatted_text (cxx_pp);
2894 }
2895
2896 const char *
2897 type_as_string_translate (tree typ, int flags)
2898 {
2899 reinit_cxx_pp ();
2900 dump_type (cxx_pp, typ, flags);
2901 return pp_ggc_formatted_text (cxx_pp);
2902 }
2903
2904 const char *
2905 expr_as_string (tree decl, int flags)
2906 {
2907 reinit_cxx_pp ();
2908 pp_translate_identifiers (cxx_pp) = false;
2909 dump_expr (cxx_pp, decl, flags);
2910 return pp_ggc_formatted_text (cxx_pp);
2911 }
2912
2913 /* Wrap decl_as_string with options appropriate for dwarf. */
2914
2915 const char *
2916 decl_as_dwarf_string (tree decl, int flags)
2917 {
2918 const char *name;
2919 /* Curiously, reinit_cxx_pp doesn't reset the flags field, so setting the flag
2920 here will be adequate to get the desired behavior. */
2921 cxx_pp->flags |= pp_c_flag_gnu_v3;
2922 name = decl_as_string (decl, flags);
2923 /* Subsequent calls to the pretty printer shouldn't use this style. */
2924 cxx_pp->flags &= ~pp_c_flag_gnu_v3;
2925 return name;
2926 }
2927
2928 const char *
2929 decl_as_string (tree decl, int flags)
2930 {
2931 reinit_cxx_pp ();
2932 pp_translate_identifiers (cxx_pp) = false;
2933 dump_decl (cxx_pp, decl, flags);
2934 return pp_ggc_formatted_text (cxx_pp);
2935 }
2936
2937 const char *
2938 decl_as_string_translate (tree decl, int flags)
2939 {
2940 reinit_cxx_pp ();
2941 dump_decl (cxx_pp, decl, flags);
2942 return pp_ggc_formatted_text (cxx_pp);
2943 }
2944
2945 /* Wrap lang_decl_name with options appropriate for dwarf. */
2946
2947 const char *
2948 lang_decl_dwarf_name (tree decl, int v, bool translate)
2949 {
2950 const char *name;
2951 /* Curiously, reinit_cxx_pp doesn't reset the flags field, so setting the flag
2952 here will be adequate to get the desired behavior. */
2953 cxx_pp->flags |= pp_c_flag_gnu_v3;
2954 name = lang_decl_name (decl, v, translate);
2955 /* Subsequent calls to the pretty printer shouldn't use this style. */
2956 cxx_pp->flags &= ~pp_c_flag_gnu_v3;
2957 return name;
2958 }
2959
2960 /* Generate the three forms of printable names for cxx_printable_name. */
2961
2962 const char *
2963 lang_decl_name (tree decl, int v, bool translate)
2964 {
2965 if (v >= 2)
2966 return (translate
2967 ? decl_as_string_translate (decl, TFF_DECL_SPECIFIERS)
2968 : decl_as_string (decl, TFF_DECL_SPECIFIERS));
2969
2970 reinit_cxx_pp ();
2971 pp_translate_identifiers (cxx_pp) = translate;
2972 if (v == 1
2973 && (DECL_CLASS_SCOPE_P (decl)
2974 || (DECL_NAMESPACE_SCOPE_P (decl)
2975 && CP_DECL_CONTEXT (decl) != global_namespace)))
2976 {
2977 dump_type (cxx_pp, CP_DECL_CONTEXT (decl), TFF_PLAIN_IDENTIFIER);
2978 pp_cxx_colon_colon (cxx_pp);
2979 }
2980
2981 if (TREE_CODE (decl) == FUNCTION_DECL)
2982 dump_function_name (cxx_pp, decl, TFF_PLAIN_IDENTIFIER);
2983 else if ((DECL_NAME (decl) == NULL_TREE)
2984 && TREE_CODE (decl) == NAMESPACE_DECL)
2985 dump_decl (cxx_pp, decl, TFF_PLAIN_IDENTIFIER | TFF_UNQUALIFIED_NAME);
2986 else
2987 dump_decl (cxx_pp, DECL_NAME (decl), TFF_PLAIN_IDENTIFIER);
2988
2989 return pp_ggc_formatted_text (cxx_pp);
2990 }
2991
2992 /* Return the location of a tree passed to %+ formats. */
2993
2994 location_t
2995 location_of (tree t)
2996 {
2997 if (TYPE_P (t))
2998 {
2999 t = TYPE_MAIN_DECL (t);
3000 if (t == NULL_TREE)
3001 return input_location;
3002 }
3003 else if (TREE_CODE (t) == OVERLOAD)
3004 t = OVL_FIRST (t);
3005
3006 if (DECL_P (t))
3007 return DECL_SOURCE_LOCATION (t);
3008 return EXPR_LOC_OR_LOC (t, input_location);
3009 }
3010
3011 /* Now the interfaces from error et al to dump_type et al. Each takes an
3012 on/off VERBOSE flag and supply the appropriate TFF_ flags to a dump_
3013 function. */
3014
3015 static const char *
3016 decl_to_string (tree decl, int verbose)
3017 {
3018 int flags = 0;
3019
3020 if (TREE_CODE (decl) == TYPE_DECL || TREE_CODE (decl) == RECORD_TYPE
3021 || TREE_CODE (decl) == UNION_TYPE || TREE_CODE (decl) == ENUMERAL_TYPE)
3022 flags = TFF_CLASS_KEY_OR_ENUM;
3023 if (verbose)
3024 flags |= TFF_DECL_SPECIFIERS;
3025 else if (TREE_CODE (decl) == FUNCTION_DECL)
3026 flags |= TFF_DECL_SPECIFIERS | TFF_RETURN_TYPE;
3027 flags |= TFF_TEMPLATE_HEADER;
3028
3029 reinit_cxx_pp ();
3030 dump_decl (cxx_pp, decl, flags);
3031 return pp_ggc_formatted_text (cxx_pp);
3032 }
3033
3034 static const char *
3035 expr_to_string (tree decl)
3036 {
3037 reinit_cxx_pp ();
3038 dump_expr (cxx_pp, decl, 0);
3039 return pp_ggc_formatted_text (cxx_pp);
3040 }
3041
3042 static const char *
3043 fndecl_to_string (tree fndecl, int verbose)
3044 {
3045 int flags;
3046
3047 flags = TFF_EXCEPTION_SPECIFICATION | TFF_DECL_SPECIFIERS
3048 | TFF_TEMPLATE_HEADER;
3049 if (verbose)
3050 flags |= TFF_FUNCTION_DEFAULT_ARGUMENTS;
3051 reinit_cxx_pp ();
3052 dump_decl (cxx_pp, fndecl, flags);
3053 return pp_ggc_formatted_text (cxx_pp);
3054 }
3055
3056
3057 static const char *
3058 code_to_string (enum tree_code c)
3059 {
3060 return get_tree_code_name (c);
3061 }
3062
3063 const char *
3064 language_to_string (enum languages c)
3065 {
3066 switch (c)
3067 {
3068 case lang_c:
3069 return "C";
3070
3071 case lang_cplusplus:
3072 return "C++";
3073
3074 default:
3075 gcc_unreachable ();
3076 }
3077 return NULL;
3078 }
3079
3080 /* Return the proper printed version of a parameter to a C++ function. */
3081
3082 static const char *
3083 parm_to_string (int p)
3084 {
3085 reinit_cxx_pp ();
3086 if (p < 0)
3087 pp_string (cxx_pp, "'this'");
3088 else
3089 pp_decimal_int (cxx_pp, p + 1);
3090 return pp_ggc_formatted_text (cxx_pp);
3091 }
3092
3093 static const char *
3094 op_to_string (enum tree_code p)
3095 {
3096 tree id = operator_name_info[p].identifier;
3097 return id ? IDENTIFIER_POINTER (id) : M_("<unknown>");
3098 }
3099
3100 static const char *
3101 type_to_string (tree typ, int verbose)
3102 {
3103 int flags = 0;
3104 if (verbose)
3105 flags |= TFF_CLASS_KEY_OR_ENUM;
3106 flags |= TFF_TEMPLATE_HEADER;
3107
3108 reinit_cxx_pp ();
3109 dump_type (cxx_pp, typ, flags);
3110 /* If we're printing a type that involves typedefs, also print the
3111 stripped version. But sometimes the stripped version looks
3112 exactly the same, so we don't want it after all. To avoid printing
3113 it in that case, we play ugly obstack games. */
3114 if (typ && TYPE_P (typ) && typ != TYPE_CANONICAL (typ)
3115 && !uses_template_parms (typ))
3116 {
3117 int aka_start, aka_len; char *p;
3118 struct obstack *ob = pp_buffer (cxx_pp)->obstack;
3119 /* Remember the end of the initial dump. */
3120 int len = obstack_object_size (ob);
3121 tree aka = strip_typedefs (typ);
3122 pp_string (cxx_pp, " {aka");
3123 pp_cxx_whitespace (cxx_pp);
3124 /* And remember the start of the aka dump. */
3125 aka_start = obstack_object_size (ob);
3126 dump_type (cxx_pp, aka, flags);
3127 aka_len = obstack_object_size (ob) - aka_start;
3128 pp_right_brace (cxx_pp);
3129 p = (char*)obstack_base (ob);
3130 /* If they are identical, cut off the aka with a NUL. */
3131 if (len == aka_len && memcmp (p, p+aka_start, len) == 0)
3132 p[len] = '\0';
3133 }
3134
3135 if (typ && TYPE_P (typ) && TREE_CODE (typ) == ENUMERAL_TYPE)
3136 pp_string (cxx_pp, M_(" {enum}"));
3137
3138 return pp_ggc_formatted_text (cxx_pp);
3139 }
3140
3141 static const char *
3142 assop_to_string (enum tree_code p)
3143 {
3144 tree id = assignment_operator_name_info[(int) p].identifier;
3145 return id ? IDENTIFIER_POINTER (id) : M_("{unknown}");
3146 }
3147
3148 static const char *
3149 args_to_string (tree p, int verbose)
3150 {
3151 int flags = 0;
3152 if (verbose)
3153 flags |= TFF_CLASS_KEY_OR_ENUM;
3154
3155 if (p == NULL_TREE)
3156 return "";
3157
3158 if (TYPE_P (TREE_VALUE (p)))
3159 return type_as_string_translate (p, flags);
3160
3161 reinit_cxx_pp ();
3162 for (; p; p = TREE_CHAIN (p))
3163 {
3164 if (TREE_VALUE (p) == null_node)
3165 pp_cxx_ws_string (cxx_pp, "NULL");
3166 else
3167 dump_type (cxx_pp, error_type (TREE_VALUE (p)), flags);
3168 if (TREE_CHAIN (p))
3169 pp_separate_with_comma (cxx_pp);
3170 }
3171 return pp_ggc_formatted_text (cxx_pp);
3172 }
3173
3174 /* Pretty-print a deduction substitution (from deduction_tsubst_fntype). P
3175 is a TREE_LIST with purpose the TEMPLATE_DECL, value the template
3176 arguments. */
3177
3178 static const char *
3179 subst_to_string (tree p)
3180 {
3181 tree decl = TREE_PURPOSE (p);
3182 tree targs = TREE_VALUE (p);
3183 tree tparms = DECL_TEMPLATE_PARMS (decl);
3184 int flags = (TFF_DECL_SPECIFIERS|TFF_TEMPLATE_HEADER
3185 |TFF_NO_TEMPLATE_BINDINGS);
3186
3187 if (p == NULL_TREE)
3188 return "";
3189
3190 reinit_cxx_pp ();
3191 dump_template_decl (cxx_pp, TREE_PURPOSE (p), flags);
3192 dump_substitution (cxx_pp, NULL, tparms, targs, /*flags=*/0);
3193 return pp_ggc_formatted_text (cxx_pp);
3194 }
3195
3196 static const char *
3197 cv_to_string (tree p, int v)
3198 {
3199 reinit_cxx_pp ();
3200 cxx_pp->padding = v ? pp_before : pp_none;
3201 pp_cxx_cv_qualifier_seq (cxx_pp, p);
3202 return pp_ggc_formatted_text (cxx_pp);
3203 }
3204
3205 static const char *
3206 eh_spec_to_string (tree p, int /*v*/)
3207 {
3208 int flags = 0;
3209 reinit_cxx_pp ();
3210 dump_exception_spec (cxx_pp, p, flags);
3211 return pp_ggc_formatted_text (cxx_pp);
3212 }
3213
3214 /* Langhook for print_error_function. */
3215 void
3216 cxx_print_error_function (diagnostic_context *context, const char *file,
3217 diagnostic_info *diagnostic)
3218 {
3219 lhd_print_error_function (context, file, diagnostic);
3220 pp_set_prefix (context->printer, file);
3221 maybe_print_instantiation_context (context);
3222 }
3223
3224 static void
3225 cp_diagnostic_starter (diagnostic_context *context,
3226 diagnostic_info *diagnostic)
3227 {
3228 diagnostic_report_current_module (context, diagnostic_location (diagnostic));
3229 cp_print_error_function (context, diagnostic);
3230 maybe_print_instantiation_context (context);
3231 maybe_print_constexpr_context (context);
3232 pp_set_prefix (context->printer, diagnostic_build_prefix (context,
3233 diagnostic));
3234 }
3235
3236 /* Print current function onto BUFFER, in the process of reporting
3237 a diagnostic message. Called from cp_diagnostic_starter. */
3238 static void
3239 cp_print_error_function (diagnostic_context *context,
3240 diagnostic_info *diagnostic)
3241 {
3242 /* If we are in an instantiation context, current_function_decl is likely
3243 to be wrong, so just rely on print_instantiation_full_context. */
3244 if (current_instantiation ())
3245 return;
3246 if (diagnostic_last_function_changed (context, diagnostic))
3247 {
3248 const char *old_prefix = context->printer->prefix;
3249 const char *file = LOCATION_FILE (diagnostic_location (diagnostic));
3250 tree abstract_origin = diagnostic_abstract_origin (diagnostic);
3251 char *new_prefix = (file && abstract_origin == NULL)
3252 ? file_name_as_prefix (context, file) : NULL;
3253
3254 pp_set_prefix (context->printer, new_prefix);
3255
3256 if (current_function_decl == NULL)
3257 pp_string (context->printer, _("At global scope:"));
3258 else
3259 {
3260 tree fndecl, ao;
3261
3262 if (abstract_origin)
3263 {
3264 ao = BLOCK_ABSTRACT_ORIGIN (abstract_origin);
3265 while (TREE_CODE (ao) == BLOCK
3266 && BLOCK_ABSTRACT_ORIGIN (ao)
3267 && BLOCK_ABSTRACT_ORIGIN (ao) != ao)
3268 ao = BLOCK_ABSTRACT_ORIGIN (ao);
3269 gcc_assert (TREE_CODE (ao) == FUNCTION_DECL);
3270 fndecl = ao;
3271 }
3272 else
3273 fndecl = current_function_decl;
3274
3275 pp_printf (context->printer, function_category (fndecl),
3276 cxx_printable_name_translate (fndecl, 2));
3277
3278 while (abstract_origin)
3279 {
3280 location_t *locus;
3281 tree block = abstract_origin;
3282
3283 locus = &BLOCK_SOURCE_LOCATION (block);
3284 fndecl = NULL;
3285 block = BLOCK_SUPERCONTEXT (block);
3286 while (block && TREE_CODE (block) == BLOCK
3287 && BLOCK_ABSTRACT_ORIGIN (block))
3288 {
3289 ao = BLOCK_ABSTRACT_ORIGIN (block);
3290
3291 while (TREE_CODE (ao) == BLOCK
3292 && BLOCK_ABSTRACT_ORIGIN (ao)
3293 && BLOCK_ABSTRACT_ORIGIN (ao) != ao)
3294 ao = BLOCK_ABSTRACT_ORIGIN (ao);
3295
3296 if (TREE_CODE (ao) == FUNCTION_DECL)
3297 {
3298 fndecl = ao;
3299 break;
3300 }
3301 else if (TREE_CODE (ao) != BLOCK)
3302 break;
3303
3304 block = BLOCK_SUPERCONTEXT (block);
3305 }
3306 if (fndecl)
3307 abstract_origin = block;
3308 else
3309 {
3310 while (block && TREE_CODE (block) == BLOCK)
3311 block = BLOCK_SUPERCONTEXT (block);
3312
3313 if (block && TREE_CODE (block) == FUNCTION_DECL)
3314 fndecl = block;
3315 abstract_origin = NULL;
3316 }
3317 if (fndecl)
3318 {
3319 expanded_location s = expand_location (*locus);
3320 pp_character (context->printer, ',');
3321 pp_newline (context->printer);
3322 if (s.file != NULL)
3323 {
3324 if (context->show_column && s.column != 0)
3325 pp_printf (context->printer,
3326 _(" inlined from %qs at %r%s:%d:%d%R"),
3327 cxx_printable_name_translate (fndecl, 2),
3328 "locus", s.file, s.line, s.column);
3329 else
3330 pp_printf (context->printer,
3331 _(" inlined from %qs at %r%s:%d%R"),
3332 cxx_printable_name_translate (fndecl, 2),
3333 "locus", s.file, s.line);
3334
3335 }
3336 else
3337 pp_printf (context->printer, _(" inlined from %qs"),
3338 cxx_printable_name_translate (fndecl, 2));
3339 }
3340 }
3341 pp_character (context->printer, ':');
3342 }
3343 pp_newline (context->printer);
3344
3345 diagnostic_set_last_function (context, diagnostic);
3346 pp_destroy_prefix (context->printer);
3347 context->printer->prefix = old_prefix;
3348 }
3349 }
3350
3351 /* Returns a description of FUNCTION using standard terminology. The
3352 result is a format string of the form "In CATEGORY %qs". */
3353 static const char *
3354 function_category (tree fn)
3355 {
3356 /* We can get called from the middle-end for diagnostics of function
3357 clones. Make sure we have language specific information before
3358 dereferencing it. */
3359 if (DECL_LANG_SPECIFIC (STRIP_TEMPLATE (fn))
3360 && DECL_FUNCTION_MEMBER_P (fn))
3361 {
3362 if (DECL_STATIC_FUNCTION_P (fn))
3363 return _("In static member function %qs");
3364 else if (DECL_COPY_CONSTRUCTOR_P (fn))
3365 return _("In copy constructor %qs");
3366 else if (DECL_CONSTRUCTOR_P (fn))
3367 return _("In constructor %qs");
3368 else if (DECL_DESTRUCTOR_P (fn))
3369 return _("In destructor %qs");
3370 else if (LAMBDA_FUNCTION_P (fn))
3371 return _("In lambda function");
3372 else
3373 return _("In member function %qs");
3374 }
3375 else
3376 return _("In function %qs");
3377 }
3378
3379 /* Report the full context of a current template instantiation,
3380 onto BUFFER. */
3381 static void
3382 print_instantiation_full_context (diagnostic_context *context)
3383 {
3384 struct tinst_level *p = current_instantiation ();
3385 location_t location = input_location;
3386
3387 if (p)
3388 {
3389 pp_verbatim (context->printer,
3390 TREE_CODE (p->decl) == TREE_LIST
3391 ? _("%s: In substitution of %qS:\n")
3392 : _("%s: In instantiation of %q#D:\n"),
3393 LOCATION_FILE (location),
3394 p->decl);
3395
3396 location = p->locus;
3397 p = p->next;
3398 }
3399
3400 print_instantiation_partial_context (context, p, location);
3401 }
3402
3403 /* Helper function of print_instantiation_partial_context() that
3404 prints a single line of instantiation context. */
3405
3406 static void
3407 print_instantiation_partial_context_line (diagnostic_context *context,
3408 const struct tinst_level *t,
3409 location_t loc, bool recursive_p)
3410 {
3411 if (loc == UNKNOWN_LOCATION)
3412 return;
3413
3414 expanded_location xloc = expand_location (loc);
3415
3416 if (context->show_column)
3417 pp_verbatim (context->printer, _("%r%s:%d:%d:%R "),
3418 "locus", xloc.file, xloc.line, xloc.column);
3419 else
3420 pp_verbatim (context->printer, _("%r%s:%d:%R "),
3421 "locus", xloc.file, xloc.line);
3422
3423 if (t != NULL)
3424 {
3425 if (TREE_CODE (t->decl) == TREE_LIST)
3426 pp_verbatim (context->printer,
3427 recursive_p
3428 ? _("recursively required by substitution of %qS\n")
3429 : _("required by substitution of %qS\n"),
3430 t->decl);
3431 else
3432 pp_verbatim (context->printer,
3433 recursive_p
3434 ? _("recursively required from %q#D\n")
3435 : _("required from %q#D\n"),
3436 t->decl);
3437 }
3438 else
3439 {
3440 pp_verbatim (context->printer,
3441 recursive_p
3442 ? _("recursively required from here\n")
3443 : _("required from here\n"));
3444 }
3445 }
3446
3447 /* Same as print_instantiation_full_context but less verbose. */
3448
3449 static void
3450 print_instantiation_partial_context (diagnostic_context *context,
3451 struct tinst_level *t0, location_t loc)
3452 {
3453 struct tinst_level *t;
3454 int n_total = 0;
3455 int n;
3456 location_t prev_loc = loc;
3457
3458 for (t = t0; t != NULL; t = t->next)
3459 if (prev_loc != t->locus)
3460 {
3461 prev_loc = t->locus;
3462 n_total++;
3463 }
3464
3465 t = t0;
3466
3467 if (template_backtrace_limit
3468 && n_total > template_backtrace_limit)
3469 {
3470 int skip = n_total - template_backtrace_limit;
3471 int head = template_backtrace_limit / 2;
3472
3473 /* Avoid skipping just 1. If so, skip 2. */
3474 if (skip == 1)
3475 {
3476 skip = 2;
3477 head = (template_backtrace_limit - 1) / 2;
3478 }
3479
3480 for (n = 0; n < head; n++)
3481 {
3482 gcc_assert (t != NULL);
3483 if (loc != t->locus)
3484 print_instantiation_partial_context_line (context, t, loc,
3485 /*recursive_p=*/false);
3486 loc = t->locus;
3487 t = t->next;
3488 }
3489 if (t != NULL && skip > 0)
3490 {
3491 expanded_location xloc;
3492 xloc = expand_location (loc);
3493 if (context->show_column)
3494 pp_verbatim (context->printer,
3495 _("%r%s:%d:%d:%R [ skipping %d instantiation "
3496 "contexts, use -ftemplate-backtrace-limit=0 to "
3497 "disable ]\n"),
3498 "locus", xloc.file, xloc.line, xloc.column, skip);
3499 else
3500 pp_verbatim (context->printer,
3501 _("%r%s:%d:%R [ skipping %d instantiation "
3502 "contexts, use -ftemplate-backtrace-limit=0 to "
3503 "disable ]\n"),
3504 "locus", xloc.file, xloc.line, skip);
3505
3506 do {
3507 loc = t->locus;
3508 t = t->next;
3509 } while (t != NULL && --skip > 0);
3510 }
3511 }
3512
3513 while (t != NULL)
3514 {
3515 while (t->next != NULL && t->locus == t->next->locus)
3516 {
3517 loc = t->locus;
3518 t = t->next;
3519 }
3520 print_instantiation_partial_context_line (context, t, loc,
3521 t->locus == loc);
3522 loc = t->locus;
3523 t = t->next;
3524 }
3525 print_instantiation_partial_context_line (context, NULL, loc,
3526 /*recursive_p=*/false);
3527 }
3528
3529 /* Called from cp_thing to print the template context for an error. */
3530 static void
3531 maybe_print_instantiation_context (diagnostic_context *context)
3532 {
3533 if (!problematic_instantiation_changed () || current_instantiation () == 0)
3534 return;
3535
3536 record_last_problematic_instantiation ();
3537 print_instantiation_full_context (context);
3538 }
3539 \f
3540 /* Report what constexpr call(s) we're trying to expand, if any. */
3541
3542 void
3543 maybe_print_constexpr_context (diagnostic_context *context)
3544 {
3545 vec<tree> call_stack = cx_error_context ();
3546 unsigned ix;
3547 tree t;
3548
3549 FOR_EACH_VEC_ELT (call_stack, ix, t)
3550 {
3551 expanded_location xloc = expand_location (EXPR_LOCATION (t));
3552 const char *s = expr_as_string (t, 0);
3553 if (context->show_column)
3554 pp_verbatim (context->printer,
3555 _("%r%s:%d:%d:%R in constexpr expansion of %qs"),
3556 "locus", xloc.file, xloc.line, xloc.column, s);
3557 else
3558 pp_verbatim (context->printer,
3559 _("%r%s:%d:%R in constexpr expansion of %qs"),
3560 "locus", xloc.file, xloc.line, s);
3561 pp_newline (context->printer);
3562 }
3563 }
3564 \f
3565 /* Called from output_format -- during diagnostic message processing --
3566 to handle C++ specific format specifier with the following meanings:
3567 %A function argument-list.
3568 %C tree code.
3569 %D declaration.
3570 %E expression.
3571 %F function declaration.
3572 %L language as used in extern "lang".
3573 %O binary operator.
3574 %P function parameter whose position is indicated by an integer.
3575 %Q assignment operator.
3576 %S substitution (template + args)
3577 %T type.
3578 %V cv-qualifier.
3579 %X exception-specification. */
3580 static bool
3581 cp_printer (pretty_printer *pp, text_info *text, const char *spec,
3582 int precision, bool wide, bool set_locus, bool verbose)
3583 {
3584 const char *result;
3585 tree t = NULL;
3586 #define next_tree (t = va_arg (*text->args_ptr, tree))
3587 #define next_tcode ((enum tree_code) va_arg (*text->args_ptr, int))
3588 #define next_lang ((enum languages) va_arg (*text->args_ptr, int))
3589 #define next_int va_arg (*text->args_ptr, int)
3590
3591 if (precision != 0 || wide)
3592 return false;
3593
3594 switch (*spec)
3595 {
3596 case 'A': result = args_to_string (next_tree, verbose); break;
3597 case 'C': result = code_to_string (next_tcode); break;
3598 case 'D':
3599 {
3600 tree temp = next_tree;
3601 if (VAR_P (temp)
3602 && DECL_HAS_DEBUG_EXPR_P (temp))
3603 {
3604 temp = DECL_DEBUG_EXPR (temp);
3605 if (!DECL_P (temp))
3606 {
3607 result = expr_to_string (temp);
3608 break;
3609 }
3610 }
3611 result = decl_to_string (temp, verbose);
3612 }
3613 break;
3614 case 'E': result = expr_to_string (next_tree); break;
3615 case 'F': result = fndecl_to_string (next_tree, verbose); break;
3616 case 'L': result = language_to_string (next_lang); break;
3617 case 'O': result = op_to_string (next_tcode); break;
3618 case 'P': result = parm_to_string (next_int); break;
3619 case 'Q': result = assop_to_string (next_tcode); break;
3620 case 'S': result = subst_to_string (next_tree); break;
3621 case 'T': result = type_to_string (next_tree, verbose); break;
3622 case 'V': result = cv_to_string (next_tree, verbose); break;
3623 case 'X': result = eh_spec_to_string (next_tree, verbose); break;
3624
3625 case 'K':
3626 percent_K_format (text);
3627 return true;
3628
3629 default:
3630 return false;
3631 }
3632
3633 pp_string (pp, result);
3634 if (set_locus && t != NULL)
3635 text->set_location (0, location_of (t), true);
3636 return true;
3637 #undef next_tree
3638 #undef next_tcode
3639 #undef next_lang
3640 #undef next_int
3641 }
3642 \f
3643 /* Warn about the use of C++0x features when appropriate. */
3644 void
3645 maybe_warn_cpp0x (cpp0x_warn_str str)
3646 {
3647 if ((cxx_dialect == cxx98) && !in_system_header_at (input_location))
3648 /* We really want to suppress this warning in system headers,
3649 because libstdc++ uses variadic templates even when we aren't
3650 in C++0x mode. */
3651 switch (str)
3652 {
3653 case CPP0X_INITIALIZER_LISTS:
3654 pedwarn (input_location, 0,
3655 "extended initializer lists "
3656 "only available with -std=c++11 or -std=gnu++11");
3657 break;
3658 case CPP0X_EXPLICIT_CONVERSION:
3659 pedwarn (input_location, 0,
3660 "explicit conversion operators "
3661 "only available with -std=c++11 or -std=gnu++11");
3662 break;
3663 case CPP0X_VARIADIC_TEMPLATES:
3664 pedwarn (input_location, 0,
3665 "variadic templates "
3666 "only available with -std=c++11 or -std=gnu++11");
3667 break;
3668 case CPP0X_LAMBDA_EXPR:
3669 pedwarn (input_location, 0,
3670 "lambda expressions "
3671 "only available with -std=c++11 or -std=gnu++11");
3672 break;
3673 case CPP0X_AUTO:
3674 pedwarn (input_location, 0,
3675 "C++11 auto only available with -std=c++11 or -std=gnu++11");
3676 break;
3677 case CPP0X_SCOPED_ENUMS:
3678 pedwarn (input_location, 0,
3679 "scoped enums only available with -std=c++11 or -std=gnu++11");
3680 break;
3681 case CPP0X_DEFAULTED_DELETED:
3682 pedwarn (input_location, 0,
3683 "defaulted and deleted functions "
3684 "only available with -std=c++11 or -std=gnu++11");
3685 break;
3686 case CPP0X_INLINE_NAMESPACES:
3687 pedwarn (input_location, OPT_Wpedantic,
3688 "inline namespaces "
3689 "only available with -std=c++11 or -std=gnu++11");
3690 break;
3691 case CPP0X_OVERRIDE_CONTROLS:
3692 pedwarn (input_location, 0,
3693 "override controls (override/final) "
3694 "only available with -std=c++11 or -std=gnu++11");
3695 break;
3696 case CPP0X_NSDMI:
3697 pedwarn (input_location, 0,
3698 "non-static data member initializers "
3699 "only available with -std=c++11 or -std=gnu++11");
3700 break;
3701 case CPP0X_USER_DEFINED_LITERALS:
3702 pedwarn (input_location, 0,
3703 "user-defined literals "
3704 "only available with -std=c++11 or -std=gnu++11");
3705 break;
3706 case CPP0X_DELEGATING_CTORS:
3707 pedwarn (input_location, 0,
3708 "delegating constructors "
3709 "only available with -std=c++11 or -std=gnu++11");
3710 break;
3711 case CPP0X_INHERITING_CTORS:
3712 pedwarn (input_location, 0,
3713 "inheriting constructors "
3714 "only available with -std=c++11 or -std=gnu++11");
3715 break;
3716 case CPP0X_ATTRIBUTES:
3717 pedwarn (input_location, 0,
3718 "c++11 attributes "
3719 "only available with -std=c++11 or -std=gnu++11");
3720 break;
3721 case CPP0X_REF_QUALIFIER:
3722 pedwarn (input_location, 0,
3723 "ref-qualifiers "
3724 "only available with -std=c++11 or -std=gnu++11");
3725 break;
3726 default:
3727 gcc_unreachable ();
3728 }
3729 }
3730
3731 /* Warn about the use of variadic templates when appropriate. */
3732 void
3733 maybe_warn_variadic_templates (void)
3734 {
3735 maybe_warn_cpp0x (CPP0X_VARIADIC_TEMPLATES);
3736 }
3737
3738
3739 /* Issue an ISO C++98 pedantic warning at LOCATION, conditional on
3740 option OPT with text GMSGID. Use this function to report
3741 diagnostics for constructs that are invalid C++98, but valid
3742 C++0x. */
3743 bool
3744 pedwarn_cxx98 (location_t location, int opt, const char *gmsgid, ...)
3745 {
3746 diagnostic_info diagnostic;
3747 va_list ap;
3748 bool ret;
3749 rich_location richloc (line_table, location);
3750
3751 va_start (ap, gmsgid);
3752 diagnostic_set_info (&diagnostic, gmsgid, &ap, &richloc,
3753 (cxx_dialect == cxx98) ? DK_PEDWARN : DK_WARNING);
3754 diagnostic.option_index = opt;
3755 ret = diagnostic_report_diagnostic (global_dc, &diagnostic);
3756 va_end (ap);
3757 return ret;
3758 }
3759
3760 /* Issue a diagnostic that NAME cannot be found in SCOPE. DECL is what
3761 we found when we tried to do the lookup. LOCATION is the location of
3762 the NAME identifier. */
3763
3764 void
3765 qualified_name_lookup_error (tree scope, tree name,
3766 tree decl, location_t location)
3767 {
3768 if (scope == error_mark_node)
3769 ; /* We already complained. */
3770 else if (TYPE_P (scope))
3771 {
3772 if (!COMPLETE_TYPE_P (scope))
3773 error_at (location, "incomplete type %qT used in nested name specifier",
3774 scope);
3775 else if (TREE_CODE (decl) == TREE_LIST)
3776 {
3777 error_at (location, "reference to %<%T::%D%> is ambiguous",
3778 scope, name);
3779 print_candidates (decl);
3780 }
3781 else
3782 error_at (location, "%qD is not a member of %qT", name, scope);
3783 }
3784 else if (scope != global_namespace)
3785 {
3786 error_at (location, "%qD is not a member of %qD", name, scope);
3787 if (!suggest_alternative_in_explicit_scope (location, name, scope))
3788 suggest_alternatives_for (location, name, false);
3789 }
3790 else
3791 {
3792 error_at (location, "%<::%D%> has not been declared", name);
3793 suggest_alternatives_for (location, name, true);
3794 }
3795 }