C++: fix fix-it hints for misspellings within explicit namespaces
[official-gcc.git] / gcc / cp / error.c
blob4f4c11df570a957c5af6eb1f0c4ccce5efac0884
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.
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.
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.
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/>. */
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"
34 #define pp_separate_with_comma(PP) pp_cxx_separate_with (PP, ',')
35 #define pp_separate_with_semicolon(PP) pp_cxx_separate_with (PP, ';')
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;
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))
49 # define NEXT_CODE(T) (TREE_CODE (TREE_TYPE (T)))
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);
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 *);
101 static bool cp_printer (pretty_printer *, text_info *, const char *,
102 int, bool, bool, bool);
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. */
111 void
112 cxx_initialize_diagnostics (diagnostic_context *context)
114 pretty_printer *base = context->printer;
115 cxx_pretty_printer *pp = XNEW (cxx_pretty_printer);
116 context->printer = new (pp) cxx_pretty_printer ();
118 /* It is safe to free this object because it was previously XNEW()'d. */
119 base->~pretty_printer ();
120 XDELETE (base);
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;
128 /* Dump a scope, if deemed necessary. */
130 static void
131 dump_scope (cxx_pretty_printer *pp, tree scope, int flags)
133 int f = flags & (TFF_SCOPE | TFF_CHASE_TYPEDEF);
135 if (scope == NULL_TREE)
136 return;
138 if (TREE_CODE (scope) == NAMESPACE_DECL)
140 if (scope != global_namespace)
142 dump_decl (pp, scope, f);
143 pp_cxx_colon_colon (pp);
146 else if (AGGREGATE_TYPE_P (scope))
148 dump_type (pp, scope, f);
149 pp_cxx_colon_colon (pp);
151 else if ((flags & TFF_SCOPE) && TREE_CODE (scope) == FUNCTION_DECL)
153 dump_function_decl (pp, scope, f);
154 pp_cxx_colon_colon (pp);
158 /* Dump the template ARGument under control of FLAGS. */
160 static void
161 dump_template_argument (cxx_pretty_printer *pp, tree arg, int flags)
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
171 if (TREE_CODE (arg) == TREE_LIST)
172 arg = TREE_VALUE (arg);
174 /* Strip implicit conversions. */
175 while (CONVERT_EXPR_P (arg))
176 arg = TREE_OPERAND (arg, 0);
178 dump_expr (pp, arg, (flags | TFF_EXPR_IN_PARENS) & ~TFF_CLASS_KEY_OR_ENUM);
182 /* Count the number of template arguments ARGS whose value does not
183 match the (optional) default template parameter in PARAMS */
185 static int
186 get_non_default_template_args_count (tree args, int flags)
188 int n = TREE_VEC_LENGTH (INNERMOST_TEMPLATE_ARGS (args));
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;
199 return GET_NON_DEFAULT_TEMPLATE_ARGS_COUNT (INNERMOST_TEMPLATE_ARGS (args));
202 /* Dump a template-argument-list ARGS (always a TREE_VEC) under control
203 of FLAGS. */
205 static void
206 dump_template_argument_list (cxx_pretty_printer *pp, tree args, int flags)
208 int n = get_non_default_template_args_count (args, flags);
209 int need_comma = 0;
210 int i;
212 for (i = 0; i < n; ++i)
214 tree arg = TREE_VEC_ELT (args, i);
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);
224 dump_template_argument (pp, arg, flags);
225 need_comma = 1;
229 /* Dump a template parameter PARM (a TREE_LIST) under control of FLAGS. */
231 static void
232 dump_template_parameter (cxx_pretty_printer *pp, tree parm, int flags)
234 tree p;
235 tree a;
237 if (parm == error_mark_node)
238 return;
240 p = TREE_VALUE (parm);
241 a = TREE_PURPOSE (parm);
243 if (TREE_CODE (p) == TYPE_DECL)
245 if (flags & TFF_DECL_SPECIFIERS)
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));
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));
258 else
259 dump_decl (pp, p, flags | TFF_DECL_SPECIFIERS);
261 if ((flags & TFF_FUNCTION_DEFAULT_ARGUMENTS) && a != NULL_TREE)
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);
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. */
277 static void
278 dump_template_bindings (cxx_pretty_printer *pp, tree parms, tree args,
279 vec<tree, va_gc> *typenames)
281 bool need_semicolon = false;
282 int i;
283 tree t;
285 while (parms)
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;
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);
297 for (i = 0; i < TREE_VEC_LENGTH (p); ++i)
299 tree arg = NULL_TREE;
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);
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)
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);
320 else
321 pp_string (pp, M_("<missing>"));
323 ++arg_idx;
324 need_semicolon = true;
327 parms = TREE_CHAIN (parms);
330 /* Don't bother with typenames for a partial instantiation. */
331 if (vec_safe_is_empty (typenames) || uses_template_parms (args))
332 return;
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;
339 /* Don't try to do this once cgraph starts throwing away front-end
340 information. */
341 if (at_eof >= 2)
342 return;
344 FOR_EACH_VEC_SAFE_ELT (typenames, i, t)
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);
362 /* Dump a human-readable equivalent of the alias template
363 specialization of T. */
365 static void
366 dump_alias_template_specialization (cxx_pretty_printer *pp, tree t, int flags)
368 gcc_assert (alias_template_specialization_p (t));
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);
379 /* Dump a human-readable equivalent of TYPE. FLAGS controls the
380 format. */
382 static void
383 dump_type (cxx_pretty_printer *pp, tree t, int flags)
385 if (t == NULL_TREE)
386 return;
388 /* Don't print e.g. "struct mytypedef". */
389 if (TYPE_P (t) && typedef_variant_p (t))
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))
399 dump_alias_template_specialization (pp, t, flags);
400 return;
402 else if (same_type_p (t, TREE_TYPE (decl)))
403 t = decl;
404 else
406 pp_cxx_cv_qualifier_seq (pp, t);
407 pp_cxx_tree_identifier (pp, TYPE_IDENTIFIER (t));
408 return;
412 if (TYPE_PTRMEMFUNC_P (t))
413 goto offset_type;
415 switch (TREE_CODE (t))
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
424 pp_cxx_cv_qualifier_seq (pp, t);
425 pp_cxx_tree_identifier (pp, TYPE_IDENTIFIER (t));
427 break;
429 case TREE_LIST:
430 /* A list of function parms. */
431 dump_parameters (pp, t, flags);
432 break;
434 case IDENTIFIER_NODE:
435 pp_cxx_tree_identifier (pp, t);
436 break;
438 case TREE_BINFO:
439 dump_type (pp, BINFO_TYPE (t), flags);
440 break;
442 case RECORD_TYPE:
443 case UNION_TYPE:
444 case ENUMERAL_TYPE:
445 dump_aggr_type (pp, t, flags);
446 break;
448 case TYPE_DECL:
449 if (flags & TFF_CHASE_TYPEDEF)
451 dump_type (pp, DECL_ORIGINAL_TYPE (t)
452 ? DECL_ORIGINAL_TYPE (t) : TREE_TYPE (t), flags);
453 break;
455 /* Fall through. */
457 case TEMPLATE_DECL:
458 case NAMESPACE_DECL:
459 dump_decl (pp, t, flags & ~TFF_DECL_SPECIFIERS);
460 break;
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;
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;
480 case BOUND_TEMPLATE_TEMPLATE_PARM:
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);
489 break;
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;
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:
512 dump_type_prefix (pp, t, flags);
513 dump_type_suffix (pp, t, flags);
514 break;
516 case TYPENAME_TYPE:
517 if (! (flags & TFF_CHASE_TYPEDEF)
518 && DECL_ORIGINAL_TYPE (TYPE_NAME (t)))
520 dump_decl (pp, TYPE_NAME (t), TFF_PLAIN_IDENTIFIER);
521 break;
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;
531 case UNBOUND_CLASS_TEMPLATE:
532 if (! (flags & TFF_UNQUALIFIED_NAME))
534 dump_type (pp, TYPE_CONTEXT (t), flags);
535 pp_cxx_colon_colon (pp);
537 pp_cxx_ws_string (pp, "template");
538 dump_type (pp, TYPE_IDENTIFIER (t), flags);
539 break;
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;
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;
557 case TYPE_PACK_EXPANSION:
558 dump_type (pp, PACK_EXPANSION_PATTERN (t), flags);
559 pp_cxx_ws_string (pp, "...");
560 break;
562 case TYPE_ARGUMENT_PACK:
563 dump_template_argument (pp, t, flags);
564 break;
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;
574 case NULLPTR_TYPE:
575 pp_string (pp, "std::nullptr_t");
576 break;
578 default:
579 pp_unsupported_tree (pp, t);
580 /* Fall through. */
582 case ERROR_MARK:
583 pp_string (pp, M_("<type error>"));
584 break;
588 /* Dump a TYPENAME_TYPE. We need to notice when the context is itself
589 a TYPENAME_TYPE. */
591 static void
592 dump_typename (cxx_pretty_printer *pp, tree t, int flags)
594 tree ctx = TYPE_CONTEXT (t);
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);
604 /* Return the name of the supplied aggregate, or enumeral type. */
606 const char *
607 class_key_or_enum_as_string (tree t)
609 if (TREE_CODE (t) == ENUMERAL_TYPE)
611 if (SCOPED_ENUM_P (t))
612 return "enum class";
613 else
614 return "enum";
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";
624 /* Print out a class declaration T under the control of FLAGS,
625 in the form `class foo'. */
627 static void
628 dump_aggr_type (cxx_pretty_printer *pp, tree t, int flags)
630 tree name;
631 const char *variety = class_key_or_enum_as_string (t);
632 int typdef = 0;
633 int tmplate = 0;
635 pp_cxx_cv_qualifier_seq (pp, t);
637 if (flags & TFF_CLASS_KEY_OR_ENUM)
638 pp_cxx_ws_string (pp, variety);
640 name = TYPE_NAME (t);
642 if (name)
644 typdef = (!DECL_ARTIFICIAL (name)
645 /* An alias specialization is not considered to be a
646 typedef. */
647 && !alias_template_specialization_p (t));
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))
655 t = TYPE_MAIN_VARIANT (t);
656 name = TYPE_NAME (t);
657 typdef = 0;
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)));
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)
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);
674 while (DECL_TEMPLATE_INFO (tpl))
675 tpl = DECL_TI_TEMPLATE (tpl);
676 name = tpl;
678 name = DECL_NAME (name);
681 if (name == 0 || anon_aggrname_p (name))
683 if (flags & TFF_CLASS_KEY_OR_ENUM)
684 pp_string (pp, M_("<unnamed>"));
685 else
686 pp_printf (pp, M_("<unnamed %s>"), variety);
688 else if (LAMBDA_TYPE_P (t))
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);
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);
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:
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.
714 Arrays must also do this for DECL nodes, like int a[], and for things like
715 int *[]&. */
717 static void
718 dump_type_prefix (cxx_pretty_printer *pp, tree t, int flags)
720 if (TYPE_PTRMEMFUNC_P (t))
722 t = TYPE_PTRMEMFUNC_FN_TYPE (t);
723 goto offset_type;
726 switch (TREE_CODE (t))
728 case POINTER_TYPE:
729 case REFERENCE_TYPE:
731 tree sub = TREE_TYPE (t);
733 dump_type_prefix (pp, sub, flags);
734 if (TREE_CODE (sub) == ARRAY_TYPE
735 || TREE_CODE (sub) == FUNCTION_TYPE)
737 pp_cxx_whitespace (pp);
738 pp_cxx_left_paren (pp);
739 pp_c_attributes_display (pp, TYPE_ATTRIBUTES (sub));
741 if (TYPE_PTR_P (t))
742 pp_star (pp);
743 else if (TREE_CODE (t) == REFERENCE_TYPE)
745 if (TYPE_REF_IS_RVALUE (t))
746 pp_ampersand_ampersand (pp);
747 else
748 pp_ampersand (pp);
750 pp->padding = pp_before;
751 pp_cxx_cv_qualifier_seq (pp, t);
753 break;
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 */
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);
766 pp_cxx_star (pp);
767 pp_cxx_cv_qualifier_seq (pp, t);
768 pp->padding = pp_before;
769 break;
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;
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;
785 case ARRAY_TYPE:
786 dump_type_prefix (pp, TREE_TYPE (t), flags);
787 break;
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;
817 default:
818 pp_unsupported_tree (pp, t);
819 /* fall through. */
820 case ERROR_MARK:
821 pp_string (pp, M_("<typeprefixerror>"));
822 break;
826 /* Dump the suffix of type T, under control of FLAGS. This is the part
827 which appears after the identifier (or function parms). */
829 static void
830 dump_type_suffix (cxx_pretty_printer *pp, tree t, int flags)
832 if (TYPE_PTRMEMFUNC_P (t))
833 t = TYPE_PTRMEMFUNC_FN_TYPE (t);
835 switch (TREE_CODE (t))
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;
848 case FUNCTION_TYPE:
849 case METHOD_TYPE:
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);
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);
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;
875 case ARRAY_TYPE:
876 pp_maybe_space (pp);
877 pp_cxx_left_bracket (pp);
878 if (tree dtype = TYPE_DOMAIN (t))
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
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)
894 max = TREE_OPERAND (max, 0);
895 while (CONVERT_EXPR_P (max))
896 max = TREE_OPERAND (max, 0);
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);
905 pp_cxx_right_bracket (pp);
906 dump_type_suffix (pp, TREE_TYPE (t), flags);
907 break;
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;
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;
944 static void
945 dump_global_iord (cxx_pretty_printer *pp, tree t)
947 const char *p = NULL;
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 ();
956 pp_printf (pp, p, DECL_SOURCE_FILE (t));
959 static void
960 dump_simple_decl (cxx_pretty_printer *pp, tree t, tree type, int flags)
962 if (flags & TFF_DECL_SPECIFIERS)
964 if (VAR_P (t) && DECL_DECLARED_CONSTEXPR_P (t))
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");
971 dump_type_prefix (pp, type, flags & ~TFF_UNQUALIFIED_NAME);
972 pp_maybe_space (pp);
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))
986 if (TREE_CODE (t) == FIELD_DECL && DECL_NORMAL_CAPTURE_P (t))
988 pp_less (pp);
989 pp_string (pp, IDENTIFIER_POINTER (DECL_NAME (t)) + 2);
990 pp_string (pp, " capture>");
992 else
993 dump_decl (pp, DECL_NAME (t), flags);
995 else
996 pp_string (pp, M_("<anonymous>"));
997 if (flags & TFF_DECL_SPECIFIERS)
998 dump_type_suffix (pp, type, flags);
1001 /* Print an IDENTIFIER_NODE that is the name of a declaration. */
1003 static void
1004 dump_decl_name (cxx_pretty_printer *pp, tree t, int flags)
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))
1010 pp_cxx_ws_string (pp, "operator");
1011 /* Not exactly IDENTIFIER_TYPE_VALUE. */
1012 dump_type (pp, TREE_TYPE (t), flags);
1013 return;
1015 if (dguide_name_p (t))
1017 dump_decl (pp, CLASSTYPE_TI_TEMPLATE (TREE_TYPE (t)),
1018 TFF_PLAIN_IDENTIFIER);
1019 return;
1022 const char *str = IDENTIFIER_POINTER (t);
1023 if (!strncmp (str, "_ZGR", 3))
1025 pp_cxx_ws_string (pp, "<temporary>");
1026 return;
1029 pp_cxx_tree_identifier (pp, t);
1032 /* Dump a human readable string for the decl T under control of FLAGS. */
1034 static void
1035 dump_decl (cxx_pretty_printer *pp, tree t, int flags)
1037 if (t == NULL_TREE)
1038 return;
1040 /* If doing Objective-C++, give Objective-C a chance to demangle
1041 Objective-C method names. */
1042 if (c_dialect_objc ())
1044 const char *demangled = objc_maybe_printable_name (t, flags);
1045 if (demangled)
1047 pp_string (pp, demangled);
1048 return;
1052 switch (TREE_CODE (t))
1054 case TYPE_DECL:
1055 /* Don't say 'typedef class A' */
1056 if (DECL_ARTIFICIAL (t) && !DECL_SELF_REFERENCE_P (t))
1058 if ((flags & TFF_DECL_SPECIFIERS)
1059 && TREE_CODE (TREE_TYPE (t)) == TEMPLATE_TYPE_PARM)
1061 /* Say `class T' not just `T'. */
1062 pp_cxx_ws_string (pp, "class");
1064 /* Emit the `...' for a parameter pack. */
1065 if (TEMPLATE_TYPE_PARAMETER_PACK (TREE_TYPE (t)))
1066 pp_cxx_ws_string (pp, "...");
1069 dump_type (pp, TREE_TYPE (t), flags);
1070 break;
1072 if (TYPE_DECL_ALIAS_P (t)
1073 && (flags & TFF_DECL_SPECIFIERS
1074 || flags & TFF_CLASS_KEY_OR_ENUM))
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;
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;
1094 case VAR_DECL:
1095 if (DECL_NAME (t) && VTABLE_NAME_P (DECL_NAME (t)))
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;
1102 /* Fall through. */
1103 case FIELD_DECL:
1104 case PARM_DECL:
1105 dump_simple_decl (pp, t, TREE_TYPE (t), flags);
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)))
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);
1118 break;
1120 case RESULT_DECL:
1121 pp_string (pp, M_("<return value> "));
1122 dump_simple_decl (pp, t, TREE_TYPE (t), flags);
1123 break;
1125 case NAMESPACE_DECL:
1126 if (flags & TFF_DECL_SPECIFIERS)
1127 pp->declaration (t);
1128 else
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)
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)"));
1140 else
1141 pp_cxx_tree_identifier (pp, DECL_NAME (t));
1143 break;
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;
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;
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;
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;
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;
1183 case TYPE_EXPR:
1184 gcc_unreachable ();
1185 break;
1187 case IDENTIFIER_NODE:
1188 dump_decl_name (pp, t, flags);
1189 break;
1191 case OVERLOAD:
1192 if (OVL_CHAIN (t))
1194 t = OVL_CURRENT (t);
1195 if (DECL_CLASS_SCOPE_P (t))
1197 dump_type (pp, DECL_CONTEXT (t), flags);
1198 pp_cxx_colon_colon (pp);
1200 else if (!DECL_FILE_SCOPE_P (t))
1202 dump_decl (pp, DECL_CONTEXT (t), flags);
1203 pp_cxx_colon_colon (pp);
1205 dump_decl (pp, DECL_NAME (t), flags);
1206 break;
1209 /* If there's only one function, just treat it like an ordinary
1210 FUNCTION_DECL. */
1211 t = OVL_CURRENT (t);
1212 /* Fall through. */
1214 case FUNCTION_DECL:
1215 if (! DECL_LANG_SPECIFIC (t))
1217 if (DECL_ABSTRACT_ORIGIN (t)
1218 && DECL_ABSTRACT_ORIGIN (t) != t)
1219 dump_decl (pp, DECL_ABSTRACT_ORIGIN (t), flags);
1220 else
1221 dump_function_name (pp, t, flags);
1223 else if (DECL_GLOBAL_CTOR_P (t) || DECL_GLOBAL_DTOR_P (t))
1224 dump_global_iord (pp, t);
1225 else
1226 dump_function_decl (pp, t, flags);
1227 break;
1229 case TEMPLATE_DECL:
1230 dump_template_decl (pp, t, flags);
1231 break;
1233 case TEMPLATE_ID_EXPR:
1235 tree name = TREE_OPERAND (t, 0);
1236 tree args = TREE_OPERAND (t, 1);
1238 if (is_overloaded_fn (name))
1239 name = get_first_fn (name);
1240 if (DECL_P (name))
1241 name = DECL_NAME (name);
1242 dump_decl (pp, name, flags);
1243 pp_cxx_begin_template_argument_list (pp);
1244 if (args == error_mark_node)
1245 pp_string (pp, M_("<template arguments error>"));
1246 else if (args)
1247 dump_template_argument_list
1248 (pp, args, flags|TFF_NO_OMIT_DEFAULT_TEMPLATE_ARGUMENTS);
1249 pp_cxx_end_template_argument_list (pp);
1251 break;
1253 case LABEL_DECL:
1254 pp_cxx_tree_identifier (pp, DECL_NAME (t));
1255 break;
1257 case CONST_DECL:
1258 if ((TREE_TYPE (t) != NULL_TREE && NEXT_CODE (t) == ENUMERAL_TYPE)
1259 || (DECL_INITIAL (t) &&
1260 TREE_CODE (DECL_INITIAL (t)) == TEMPLATE_PARM_INDEX))
1261 dump_simple_decl (pp, t, TREE_TYPE (t), flags);
1262 else if (DECL_NAME (t))
1263 dump_decl (pp, DECL_NAME (t), flags);
1264 else if (DECL_INITIAL (t))
1265 dump_expr (pp, DECL_INITIAL (t), flags | TFF_EXPR_IN_PARENS);
1266 else
1267 pp_string (pp, M_("<enumerator>"));
1268 break;
1270 case USING_DECL:
1272 pp_cxx_ws_string (pp, "using");
1273 tree scope = USING_DECL_SCOPE (t);
1274 bool variadic = false;
1275 if (PACK_EXPANSION_P (scope))
1277 scope = PACK_EXPANSION_PATTERN (scope);
1278 variadic = true;
1280 dump_type (pp, scope, flags);
1281 pp_cxx_colon_colon (pp);
1282 dump_decl (pp, DECL_NAME (t), flags);
1283 if (variadic)
1284 pp_cxx_ws_string (pp, "...");
1286 break;
1288 case STATIC_ASSERT:
1289 pp->declaration (t);
1290 break;
1292 case BASELINK:
1293 dump_decl (pp, BASELINK_FUNCTIONS (t), flags);
1294 break;
1296 case NON_DEPENDENT_EXPR:
1297 dump_expr (pp, t, flags);
1298 break;
1300 case TEMPLATE_TYPE_PARM:
1301 if (flags & TFF_DECL_SPECIFIERS)
1302 pp->declaration (t);
1303 else
1304 pp->type_id (t);
1305 break;
1307 case UNBOUND_CLASS_TEMPLATE:
1308 case TYPE_PACK_EXPANSION:
1309 case TREE_BINFO:
1310 dump_type (pp, t, flags);
1311 break;
1313 default:
1314 pp_unsupported_tree (pp, t);
1315 /* Fall through. */
1317 case ERROR_MARK:
1318 pp_string (pp, M_("<declaration error>"));
1319 break;
1323 /* Dump a template declaration T under control of FLAGS. This means the
1324 'template <...> leaders plus the 'class X' or 'void fn(...)' part. */
1326 static void
1327 dump_template_decl (cxx_pretty_printer *pp, tree t, int flags)
1329 tree orig_parms = DECL_TEMPLATE_PARMS (t);
1330 tree parms;
1331 int i;
1333 if (flags & TFF_TEMPLATE_HEADER)
1335 for (parms = orig_parms = nreverse (orig_parms);
1336 parms;
1337 parms = TREE_CHAIN (parms))
1339 tree inner_parms = INNERMOST_TEMPLATE_PARMS (parms);
1340 int len = TREE_VEC_LENGTH (inner_parms);
1342 if (len == 0)
1344 /* Skip over the dummy template levels of a template template
1345 parm. */
1346 gcc_assert (TREE_CODE (TREE_TYPE (t)) == TEMPLATE_TEMPLATE_PARM);
1347 continue;
1350 pp_cxx_ws_string (pp, "template");
1351 pp_cxx_begin_template_argument_list (pp);
1353 /* If we've shown the template prefix, we'd better show the
1354 parameters' and decl's type too. */
1355 flags |= TFF_DECL_SPECIFIERS;
1357 for (i = 0; i < len; i++)
1359 if (i)
1360 pp_separate_with_comma (pp);
1361 dump_template_parameter (pp, TREE_VEC_ELT (inner_parms, i),
1362 flags);
1364 pp_cxx_end_template_argument_list (pp);
1365 pp_cxx_whitespace (pp);
1367 nreverse(orig_parms);
1369 if (DECL_TEMPLATE_TEMPLATE_PARM_P (t))
1371 /* Say `template<arg> class TT' not just `template<arg> TT'. */
1372 pp_cxx_ws_string (pp, "class");
1374 /* If this is a parameter pack, print the ellipsis. */
1375 if (TEMPLATE_TYPE_PARAMETER_PACK (TREE_TYPE (t)))
1376 pp_cxx_ws_string (pp, "...");
1379 /* Only print the requirements if we're also printing
1380 the template header. */
1381 if (flag_concepts)
1382 if (tree ci = get_constraints (t))
1383 if (check_constraint_info (ci))
1384 if (tree reqs = CI_TEMPLATE_REQS (ci))
1386 pp_cxx_requires_clause (pp, reqs);
1387 pp_cxx_whitespace (pp);
1392 if (DECL_CLASS_TEMPLATE_P (t))
1393 dump_type (pp, TREE_TYPE (t),
1394 ((flags & ~TFF_CLASS_KEY_OR_ENUM) | TFF_TEMPLATE_NAME
1395 | (flags & TFF_DECL_SPECIFIERS ? TFF_CLASS_KEY_OR_ENUM : 0)));
1396 else if (DECL_TEMPLATE_RESULT (t)
1397 && (VAR_P (DECL_TEMPLATE_RESULT (t))
1398 /* Alias template. */
1399 || DECL_TYPE_TEMPLATE_P (t)))
1400 dump_decl (pp, DECL_TEMPLATE_RESULT (t), flags | TFF_TEMPLATE_NAME);
1401 else
1403 gcc_assert (TREE_TYPE (t));
1404 switch (NEXT_CODE (t))
1406 case METHOD_TYPE:
1407 case FUNCTION_TYPE:
1408 dump_function_decl (pp, t, flags | TFF_TEMPLATE_NAME);
1409 break;
1410 default:
1411 /* This case can occur with some invalid code. */
1412 dump_type (pp, TREE_TYPE (t),
1413 (flags & ~TFF_CLASS_KEY_OR_ENUM) | TFF_TEMPLATE_NAME
1414 | (flags & TFF_DECL_SPECIFIERS
1415 ? TFF_CLASS_KEY_OR_ENUM : 0));
1420 /* find_typenames looks through the type of the function template T
1421 and returns a vec containing any typedefs, decltypes or TYPENAME_TYPEs
1422 it finds. */
1424 struct find_typenames_t
1426 hash_set<tree> *p_set;
1427 vec<tree, va_gc> *typenames;
1430 static tree
1431 find_typenames_r (tree *tp, int *walk_subtrees, void *data)
1433 struct find_typenames_t *d = (struct find_typenames_t *)data;
1434 tree mv = NULL_TREE;
1436 if (TYPE_P (*tp) && is_typedef_decl (TYPE_NAME (*tp)))
1437 /* Add the type of the typedef without any additional cv-quals. */
1438 mv = TREE_TYPE (TYPE_NAME (*tp));
1439 else if (TREE_CODE (*tp) == TYPENAME_TYPE
1440 || TREE_CODE (*tp) == DECLTYPE_TYPE)
1441 /* Add the typename without any cv-qualifiers. */
1442 mv = TYPE_MAIN_VARIANT (*tp);
1444 if (TREE_CODE (*tp) == TYPE_PACK_EXPANSION)
1446 /* Don't mess with parameter packs since we don't remember
1447 the pack expansion context for a particular typename. */
1448 *walk_subtrees = false;
1449 return NULL_TREE;
1452 if (mv && (mv == *tp || !d->p_set->add (mv)))
1453 vec_safe_push (d->typenames, mv);
1455 /* Search into class template arguments, which cp_walk_subtrees
1456 doesn't do. */
1457 if (CLASS_TYPE_P (*tp) && CLASSTYPE_TEMPLATE_INFO (*tp))
1458 cp_walk_tree (&CLASSTYPE_TI_ARGS (*tp), find_typenames_r,
1459 data, d->p_set);
1461 return NULL_TREE;
1464 static vec<tree, va_gc> *
1465 find_typenames (tree t)
1467 struct find_typenames_t ft;
1468 ft.p_set = new hash_set<tree>;
1469 ft.typenames = NULL;
1470 cp_walk_tree (&TREE_TYPE (DECL_TEMPLATE_RESULT (t)),
1471 find_typenames_r, &ft, ft.p_set);
1472 delete ft.p_set;
1473 return ft.typenames;
1476 /* Output the "[with ...]" clause for a template instantiation T iff
1477 TEMPLATE_PARMS, TEMPLATE_ARGS and FLAGS are suitable. T may be NULL if
1478 formatting a deduction/substitution diagnostic rather than an
1479 instantiation. */
1481 static void
1482 dump_substitution (cxx_pretty_printer *pp,
1483 tree t, tree template_parms, tree template_args,
1484 int flags)
1486 if (template_parms != NULL_TREE && template_args != NULL_TREE
1487 && !(flags & TFF_NO_TEMPLATE_BINDINGS))
1489 vec<tree, va_gc> *typenames = t ? find_typenames (t) : NULL;
1490 pp_cxx_whitespace (pp);
1491 pp_cxx_left_bracket (pp);
1492 pp->translate_string ("with");
1493 pp_cxx_whitespace (pp);
1494 dump_template_bindings (pp, template_parms, template_args, typenames);
1495 pp_cxx_right_bracket (pp);
1499 /* Dump the lambda function FN including its 'mutable' qualifier and any
1500 template bindings. */
1502 static void
1503 dump_lambda_function (cxx_pretty_printer *pp,
1504 tree fn, tree template_parms, tree template_args,
1505 int flags)
1507 /* A lambda's signature is essentially its "type". */
1508 dump_type (pp, DECL_CONTEXT (fn), flags);
1509 if (!(TYPE_QUALS (class_of_this_parm (TREE_TYPE (fn))) & TYPE_QUAL_CONST))
1511 pp->padding = pp_before;
1512 pp_c_ws_string (pp, "mutable");
1514 dump_substitution (pp, fn, template_parms, template_args, flags);
1517 /* Pretty print a function decl. There are several ways we want to print a
1518 function declaration. The TFF_ bits in FLAGS tells us how to behave.
1519 As error can only apply the '#' flag once to give 0 and 1 for V, there
1520 is %D which doesn't print the throw specs, and %F which does. */
1522 static void
1523 dump_function_decl (cxx_pretty_printer *pp, tree t, int flags)
1525 tree fntype;
1526 tree parmtypes;
1527 tree cname = NULL_TREE;
1528 tree template_args = NULL_TREE;
1529 tree template_parms = NULL_TREE;
1530 int show_return = flags & TFF_RETURN_TYPE || flags & TFF_DECL_SPECIFIERS;
1531 int do_outer_scope = ! (flags & TFF_UNQUALIFIED_NAME);
1532 tree exceptions;
1533 bool constexpr_p;
1535 flags &= ~(TFF_UNQUALIFIED_NAME | TFF_TEMPLATE_NAME);
1536 if (TREE_CODE (t) == TEMPLATE_DECL)
1537 t = DECL_TEMPLATE_RESULT (t);
1539 /* Save the exceptions, in case t is a specialization and we are
1540 emitting an error about incompatible specifications. */
1541 exceptions = TYPE_RAISES_EXCEPTIONS (TREE_TYPE (t));
1543 /* Likewise for the constexpr specifier, in case t is a specialization. */
1544 constexpr_p = DECL_DECLARED_CONSTEXPR_P (t);
1546 /* Pretty print template instantiations only. */
1547 if (DECL_USE_TEMPLATE (t) && DECL_TEMPLATE_INFO (t)
1548 && !(flags & TFF_NO_TEMPLATE_BINDINGS)
1549 && flag_pretty_templates)
1551 tree tmpl;
1553 template_args = DECL_TI_ARGS (t);
1554 tmpl = most_general_template (t);
1555 if (tmpl && TREE_CODE (tmpl) == TEMPLATE_DECL)
1557 template_parms = DECL_TEMPLATE_PARMS (tmpl);
1558 t = tmpl;
1562 if (DECL_NAME (t) && LAMBDA_FUNCTION_P (t))
1563 return dump_lambda_function (pp, t, template_parms, template_args, flags);
1565 fntype = TREE_TYPE (t);
1566 parmtypes = FUNCTION_FIRST_USER_PARMTYPE (t);
1568 if (DECL_CLASS_SCOPE_P (t))
1569 cname = DECL_CONTEXT (t);
1570 /* This is for partially instantiated template methods. */
1571 else if (TREE_CODE (fntype) == METHOD_TYPE)
1572 cname = TREE_TYPE (TREE_VALUE (parmtypes));
1574 if (flags & TFF_DECL_SPECIFIERS)
1576 if (DECL_STATIC_FUNCTION_P (t))
1577 pp_cxx_ws_string (pp, "static");
1578 else if (DECL_VIRTUAL_P (t))
1579 pp_cxx_ws_string (pp, "virtual");
1581 if (constexpr_p)
1583 if (DECL_DECLARED_CONCEPT_P (t))
1584 pp_cxx_ws_string (pp, "concept");
1585 else
1586 pp_cxx_ws_string (pp, "constexpr");
1590 /* Print the return type? */
1591 if (show_return)
1592 show_return = (!DECL_CONV_FN_P (t) && !DECL_CONSTRUCTOR_P (t)
1593 && !DECL_DESTRUCTOR_P (t) && !deduction_guide_p (t));
1594 if (show_return)
1596 tree ret = fndecl_declared_return_type (t);
1597 dump_type_prefix (pp, ret, flags);
1600 /* Print the function name. */
1601 if (!do_outer_scope)
1602 /* Nothing. */;
1603 else if (cname)
1605 dump_type (pp, cname, flags);
1606 pp_cxx_colon_colon (pp);
1608 else
1609 dump_scope (pp, CP_DECL_CONTEXT (t), flags);
1611 dump_function_name (pp, t, flags);
1613 if (!(flags & TFF_NO_FUNCTION_ARGUMENTS))
1615 dump_parameters (pp, parmtypes, flags);
1617 if (TREE_CODE (fntype) == METHOD_TYPE)
1619 pp->padding = pp_before;
1620 pp_cxx_cv_qualifier_seq (pp, class_of_this_parm (fntype));
1621 dump_ref_qualifier (pp, fntype, flags);
1624 if (tx_safe_fn_type_p (fntype))
1626 pp->padding = pp_before;
1627 pp_cxx_ws_string (pp, "transaction_safe");
1630 if (flags & TFF_EXCEPTION_SPECIFICATION)
1632 pp->padding = pp_before;
1633 dump_exception_spec (pp, exceptions, flags);
1636 if (show_return)
1637 dump_type_suffix (pp, TREE_TYPE (fntype), flags);
1638 else if (deduction_guide_p (t))
1640 pp_cxx_ws_string (pp, "->");
1641 dump_type (pp, TREE_TYPE (TREE_TYPE (t)), flags);
1644 if (flag_concepts)
1645 if (tree ci = get_constraints (t))
1646 if (tree reqs = CI_DECLARATOR_REQS (ci))
1647 pp_cxx_requires_clause (pp, reqs);
1649 dump_substitution (pp, t, template_parms, template_args, flags);
1651 if (tree base = DECL_INHERITED_CTOR_BASE (t))
1653 pp_cxx_ws_string (pp, "[inherited from");
1654 dump_type (pp, base, TFF_PLAIN_IDENTIFIER);
1655 pp_character (pp, ']');
1658 else if (template_args)
1660 bool need_comma = false;
1661 int i;
1662 pp_cxx_begin_template_argument_list (pp);
1663 template_args = INNERMOST_TEMPLATE_ARGS (template_args);
1664 for (i = 0; i < TREE_VEC_LENGTH (template_args); ++i)
1666 tree arg = TREE_VEC_ELT (template_args, i);
1667 if (need_comma)
1668 pp_separate_with_comma (pp);
1669 if (ARGUMENT_PACK_P (arg))
1670 pp_cxx_left_brace (pp);
1671 dump_template_argument (pp, arg, TFF_PLAIN_IDENTIFIER);
1672 if (ARGUMENT_PACK_P (arg))
1673 pp_cxx_right_brace (pp);
1674 need_comma = true;
1676 pp_cxx_end_template_argument_list (pp);
1680 /* Print a parameter list. If this is for a member function, the
1681 member object ptr (and any other hidden args) should have
1682 already been removed. */
1684 static void
1685 dump_parameters (cxx_pretty_printer *pp, tree parmtypes, int flags)
1687 int first = 1;
1688 flags &= ~TFF_SCOPE;
1689 pp_cxx_left_paren (pp);
1691 for (first = 1; parmtypes != void_list_node;
1692 parmtypes = TREE_CHAIN (parmtypes))
1694 if (!first)
1695 pp_separate_with_comma (pp);
1696 first = 0;
1697 if (!parmtypes)
1699 pp_cxx_ws_string (pp, "...");
1700 break;
1703 dump_type (pp, TREE_VALUE (parmtypes), flags);
1705 if ((flags & TFF_FUNCTION_DEFAULT_ARGUMENTS) && TREE_PURPOSE (parmtypes))
1707 pp_cxx_whitespace (pp);
1708 pp_equal (pp);
1709 pp_cxx_whitespace (pp);
1710 dump_expr (pp, TREE_PURPOSE (parmtypes), flags | TFF_EXPR_IN_PARENS);
1714 pp_cxx_right_paren (pp);
1717 /* Print ref-qualifier of a FUNCTION_TYPE or METHOD_TYPE. FLAGS are ignored. */
1719 static void
1720 dump_ref_qualifier (cxx_pretty_printer *pp, tree t, int flags ATTRIBUTE_UNUSED)
1722 if (FUNCTION_REF_QUALIFIED (t))
1724 pp->padding = pp_before;
1725 if (FUNCTION_RVALUE_QUALIFIED (t))
1726 pp_cxx_ws_string (pp, "&&");
1727 else
1728 pp_cxx_ws_string (pp, "&");
1732 /* Print an exception specification. T is the exception specification. */
1734 static void
1735 dump_exception_spec (cxx_pretty_printer *pp, tree t, int flags)
1737 if (t && TREE_PURPOSE (t))
1739 pp_cxx_ws_string (pp, "noexcept");
1740 if (!integer_onep (TREE_PURPOSE (t)))
1742 pp_cxx_whitespace (pp);
1743 pp_cxx_left_paren (pp);
1744 if (DEFERRED_NOEXCEPT_SPEC_P (t))
1745 pp_cxx_ws_string (pp, "<uninstantiated>");
1746 else
1747 dump_expr (pp, TREE_PURPOSE (t), flags);
1748 pp_cxx_right_paren (pp);
1751 else if (t)
1753 pp_cxx_ws_string (pp, "throw");
1754 pp_cxx_whitespace (pp);
1755 pp_cxx_left_paren (pp);
1756 if (TREE_VALUE (t) != NULL_TREE)
1757 while (1)
1759 dump_type (pp, TREE_VALUE (t), flags);
1760 t = TREE_CHAIN (t);
1761 if (!t)
1762 break;
1763 pp_separate_with_comma (pp);
1765 pp_cxx_right_paren (pp);
1769 /* Handle the function name for a FUNCTION_DECL node, grokking operators
1770 and destructors properly. */
1772 static void
1773 dump_function_name (cxx_pretty_printer *pp, tree t, int flags)
1775 tree name = DECL_NAME (t);
1777 /* We can get here with a decl that was synthesized by language-
1778 independent machinery (e.g. coverage.c) in which case it won't
1779 have a lang_specific structure attached and DECL_CONSTRUCTOR_P
1780 will crash. In this case it is safe just to print out the
1781 literal name. */
1782 if (!DECL_LANG_SPECIFIC (t))
1784 pp_cxx_tree_identifier (pp, name);
1785 return;
1788 if (TREE_CODE (t) == TEMPLATE_DECL)
1789 t = DECL_TEMPLATE_RESULT (t);
1791 /* Don't let the user see __comp_ctor et al. */
1792 if (DECL_CONSTRUCTOR_P (t)
1793 || DECL_DESTRUCTOR_P (t))
1795 if (LAMBDA_TYPE_P (DECL_CONTEXT (t)))
1796 name = get_identifier ("<lambda>");
1797 else if (TYPE_UNNAMED_P (DECL_CONTEXT (t)))
1798 name = get_identifier ("<constructor>");
1799 else
1800 name = constructor_name (DECL_CONTEXT (t));
1803 if (DECL_DESTRUCTOR_P (t))
1805 pp_cxx_complement (pp);
1806 dump_decl (pp, name, TFF_PLAIN_IDENTIFIER);
1808 else if (DECL_CONV_FN_P (t))
1810 /* This cannot use the hack that the operator's return
1811 type is stashed off of its name because it may be
1812 used for error reporting. In the case of conflicting
1813 declarations, both will have the same name, yet
1814 the types will be different, hence the TREE_TYPE field
1815 of the first name will be clobbered by the second. */
1816 pp_cxx_ws_string (pp, "operator");
1817 dump_type (pp, TREE_TYPE (TREE_TYPE (t)), flags);
1819 else
1820 dump_decl (pp, name, flags);
1822 if (DECL_TEMPLATE_INFO (t)
1823 && !DECL_FRIEND_PSEUDO_TEMPLATE_INSTANTIATION (t)
1824 && (TREE_CODE (DECL_TI_TEMPLATE (t)) != TEMPLATE_DECL
1825 || PRIMARY_TEMPLATE_P (DECL_TI_TEMPLATE (t))))
1826 dump_template_parms (pp, DECL_TEMPLATE_INFO (t), !DECL_USE_TEMPLATE (t),
1827 flags);
1830 /* Dump the template parameters from the template info INFO under control of
1831 FLAGS. PRIMARY indicates whether this is a primary template decl, or
1832 specialization (partial or complete). For partial specializations we show
1833 the specialized parameter values. For a primary template we show no
1834 decoration. */
1836 static void
1837 dump_template_parms (cxx_pretty_printer *pp, tree info,
1838 int primary, int flags)
1840 tree args = info ? TI_ARGS (info) : NULL_TREE;
1842 if (primary && flags & TFF_TEMPLATE_NAME)
1843 return;
1844 flags &= ~(TFF_CLASS_KEY_OR_ENUM | TFF_TEMPLATE_NAME);
1845 pp_cxx_begin_template_argument_list (pp);
1847 /* Be careful only to print things when we have them, so as not
1848 to crash producing error messages. */
1849 if (args && !primary)
1851 int len, ix;
1852 len = get_non_default_template_args_count (args, flags);
1854 args = INNERMOST_TEMPLATE_ARGS (args);
1855 for (ix = 0; ix != len; ix++)
1857 tree arg = TREE_VEC_ELT (args, ix);
1859 /* Only print a comma if we know there is an argument coming. In
1860 the case of an empty template argument pack, no actual
1861 argument will be printed. */
1862 if (ix
1863 && (!ARGUMENT_PACK_P (arg)
1864 || TREE_VEC_LENGTH (ARGUMENT_PACK_ARGS (arg)) > 0))
1865 pp_separate_with_comma (pp);
1867 if (!arg)
1868 pp_string (pp, M_("<template parameter error>"));
1869 else
1870 dump_template_argument (pp, arg, flags);
1873 else if (primary)
1875 tree tpl = TI_TEMPLATE (info);
1876 tree parms = DECL_TEMPLATE_PARMS (tpl);
1877 int len, ix;
1879 parms = TREE_CODE (parms) == TREE_LIST ? TREE_VALUE (parms) : NULL_TREE;
1880 len = parms ? TREE_VEC_LENGTH (parms) : 0;
1882 for (ix = 0; ix != len; ix++)
1884 tree parm;
1886 if (TREE_VEC_ELT (parms, ix) == error_mark_node)
1888 pp_string (pp, M_("<template parameter error>"));
1889 continue;
1892 parm = TREE_VALUE (TREE_VEC_ELT (parms, ix));
1894 if (ix)
1895 pp_separate_with_comma (pp);
1897 dump_decl (pp, parm, flags & ~TFF_DECL_SPECIFIERS);
1900 pp_cxx_end_template_argument_list (pp);
1903 /* Print out the arguments of CALL_EXPR T as a parenthesized list using
1904 flags FLAGS. Skip over the first argument if SKIPFIRST is true. */
1906 static void
1907 dump_call_expr_args (cxx_pretty_printer *pp, tree t, int flags, bool skipfirst)
1909 tree arg;
1910 call_expr_arg_iterator iter;
1912 pp_cxx_left_paren (pp);
1913 FOR_EACH_CALL_EXPR_ARG (arg, iter, t)
1915 if (skipfirst)
1916 skipfirst = false;
1917 else
1919 dump_expr (pp, arg, flags | TFF_EXPR_IN_PARENS);
1920 if (more_call_expr_args_p (&iter))
1921 pp_separate_with_comma (pp);
1924 pp_cxx_right_paren (pp);
1927 /* Print out the arguments of AGGR_INIT_EXPR T as a parenthesized list
1928 using flags FLAGS. Skip over the first argument if SKIPFIRST is
1929 true. */
1931 static void
1932 dump_aggr_init_expr_args (cxx_pretty_printer *pp, tree t, int flags,
1933 bool skipfirst)
1935 tree arg;
1936 aggr_init_expr_arg_iterator iter;
1938 pp_cxx_left_paren (pp);
1939 FOR_EACH_AGGR_INIT_EXPR_ARG (arg, iter, t)
1941 if (skipfirst)
1942 skipfirst = false;
1943 else
1945 dump_expr (pp, arg, flags | TFF_EXPR_IN_PARENS);
1946 if (more_aggr_init_expr_args_p (&iter))
1947 pp_separate_with_comma (pp);
1950 pp_cxx_right_paren (pp);
1953 /* Print out a list of initializers (subr of dump_expr). */
1955 static void
1956 dump_expr_list (cxx_pretty_printer *pp, tree l, int flags)
1958 while (l)
1960 dump_expr (pp, TREE_VALUE (l), flags | TFF_EXPR_IN_PARENS);
1961 l = TREE_CHAIN (l);
1962 if (l)
1963 pp_separate_with_comma (pp);
1967 /* Print out a vector of initializers (subr of dump_expr). */
1969 static void
1970 dump_expr_init_vec (cxx_pretty_printer *pp, vec<constructor_elt, va_gc> *v,
1971 int flags)
1973 unsigned HOST_WIDE_INT idx;
1974 tree value;
1976 FOR_EACH_CONSTRUCTOR_VALUE (v, idx, value)
1978 dump_expr (pp, value, flags | TFF_EXPR_IN_PARENS);
1979 if (idx != v->length () - 1)
1980 pp_separate_with_comma (pp);
1985 /* We've gotten an indirect REFERENCE (an OBJ_TYPE_REF) to a virtual
1986 function. Resolve it to a close relative -- in the sense of static
1987 type -- variant being overridden. That is close to what was written in
1988 the source code. Subroutine of dump_expr. */
1990 static tree
1991 resolve_virtual_fun_from_obj_type_ref (tree ref)
1993 tree obj_type = TREE_TYPE (OBJ_TYPE_REF_OBJECT (ref));
1994 HOST_WIDE_INT index = tree_to_uhwi (OBJ_TYPE_REF_TOKEN (ref));
1995 tree fun = BINFO_VIRTUALS (TYPE_BINFO (TREE_TYPE (obj_type)));
1996 while (index)
1998 fun = TREE_CHAIN (fun);
1999 index -= (TARGET_VTABLE_USES_DESCRIPTORS
2000 ? TARGET_VTABLE_USES_DESCRIPTORS : 1);
2003 return BV_FN (fun);
2006 /* Print out an expression E under control of FLAGS. */
2008 static void
2009 dump_expr (cxx_pretty_printer *pp, tree t, int flags)
2011 tree op;
2013 if (t == 0)
2014 return;
2016 if (STATEMENT_CLASS_P (t))
2018 pp_cxx_ws_string (pp, M_("<statement>"));
2019 return;
2022 switch (TREE_CODE (t))
2024 case VAR_DECL:
2025 case PARM_DECL:
2026 case FIELD_DECL:
2027 case CONST_DECL:
2028 case FUNCTION_DECL:
2029 case TEMPLATE_DECL:
2030 case NAMESPACE_DECL:
2031 case LABEL_DECL:
2032 case OVERLOAD:
2033 case TYPE_DECL:
2034 case IDENTIFIER_NODE:
2035 dump_decl (pp, t, ((flags & ~(TFF_DECL_SPECIFIERS|TFF_RETURN_TYPE
2036 |TFF_TEMPLATE_HEADER))
2037 | TFF_NO_TEMPLATE_BINDINGS
2038 | TFF_NO_FUNCTION_ARGUMENTS));
2039 break;
2041 case SSA_NAME:
2042 if (SSA_NAME_VAR (t)
2043 && !DECL_ARTIFICIAL (SSA_NAME_VAR (t)))
2044 dump_expr (pp, SSA_NAME_VAR (t), flags);
2045 else
2046 pp_cxx_ws_string (pp, M_("<unknown>"));
2047 break;
2049 case VOID_CST:
2050 case INTEGER_CST:
2051 case REAL_CST:
2052 case STRING_CST:
2053 case COMPLEX_CST:
2054 pp->constant (t);
2055 break;
2057 case USERDEF_LITERAL:
2058 pp_cxx_userdef_literal (pp, t);
2059 break;
2061 case THROW_EXPR:
2062 /* While waiting for caret diagnostics, avoid printing
2063 __cxa_allocate_exception, __cxa_throw, and the like. */
2064 pp_cxx_ws_string (pp, M_("<throw-expression>"));
2065 break;
2067 case PTRMEM_CST:
2068 pp_ampersand (pp);
2069 dump_type (pp, PTRMEM_CST_CLASS (t), flags);
2070 pp_cxx_colon_colon (pp);
2071 pp_cxx_tree_identifier (pp, DECL_NAME (PTRMEM_CST_MEMBER (t)));
2072 break;
2074 case COMPOUND_EXPR:
2075 pp_cxx_left_paren (pp);
2076 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2077 pp_separate_with_comma (pp);
2078 dump_expr (pp, TREE_OPERAND (t, 1), flags | TFF_EXPR_IN_PARENS);
2079 pp_cxx_right_paren (pp);
2080 break;
2082 case COND_EXPR:
2083 pp_cxx_left_paren (pp);
2084 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2085 pp_string (pp, " ? ");
2086 dump_expr (pp, TREE_OPERAND (t, 1), flags | TFF_EXPR_IN_PARENS);
2087 pp_string (pp, " : ");
2088 dump_expr (pp, TREE_OPERAND (t, 2), flags | TFF_EXPR_IN_PARENS);
2089 pp_cxx_right_paren (pp);
2090 break;
2092 case SAVE_EXPR:
2093 if (TREE_HAS_CONSTRUCTOR (t))
2095 pp_cxx_ws_string (pp, "new");
2096 pp_cxx_whitespace (pp);
2097 dump_type (pp, TREE_TYPE (TREE_TYPE (t)), flags);
2099 else
2100 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2101 break;
2103 case AGGR_INIT_EXPR:
2105 tree fn = NULL_TREE;
2107 if (TREE_CODE (AGGR_INIT_EXPR_FN (t)) == ADDR_EXPR)
2108 fn = TREE_OPERAND (AGGR_INIT_EXPR_FN (t), 0);
2110 if (fn && TREE_CODE (fn) == FUNCTION_DECL)
2112 if (DECL_CONSTRUCTOR_P (fn))
2113 dump_type (pp, DECL_CONTEXT (fn), flags);
2114 else
2115 dump_decl (pp, fn, 0);
2117 else
2118 dump_expr (pp, AGGR_INIT_EXPR_FN (t), 0);
2120 dump_aggr_init_expr_args (pp, t, flags, true);
2121 break;
2123 case CALL_EXPR:
2125 tree fn = CALL_EXPR_FN (t);
2126 bool skipfirst = false;
2128 /* Deal with internal functions. */
2129 if (fn == NULL_TREE)
2131 pp_string (pp, internal_fn_name (CALL_EXPR_IFN (t)));
2132 dump_call_expr_args (pp, t, flags, skipfirst);
2133 break;
2136 if (TREE_CODE (fn) == ADDR_EXPR)
2137 fn = TREE_OPERAND (fn, 0);
2139 /* Nobody is interested in seeing the guts of vcalls. */
2140 if (TREE_CODE (fn) == OBJ_TYPE_REF)
2141 fn = resolve_virtual_fun_from_obj_type_ref (fn);
2143 if (TREE_TYPE (fn) != NULL_TREE
2144 && NEXT_CODE (fn) == METHOD_TYPE
2145 && call_expr_nargs (t))
2147 tree ob = CALL_EXPR_ARG (t, 0);
2148 if (TREE_CODE (ob) == ADDR_EXPR)
2150 dump_expr (pp, TREE_OPERAND (ob, 0),
2151 flags | TFF_EXPR_IN_PARENS);
2152 pp_cxx_dot (pp);
2154 else if (TREE_CODE (ob) != PARM_DECL
2155 || strcmp (IDENTIFIER_POINTER (DECL_NAME (ob)), "this"))
2157 dump_expr (pp, ob, flags | TFF_EXPR_IN_PARENS);
2158 pp_cxx_arrow (pp);
2160 skipfirst = true;
2162 if (flag_sanitize & SANITIZE_UNDEFINED
2163 && is_ubsan_builtin_p (fn))
2165 pp_string (cxx_pp, M_("<ubsan routine call>"));
2166 break;
2168 dump_expr (pp, fn, flags | TFF_EXPR_IN_PARENS);
2169 dump_call_expr_args (pp, t, flags, skipfirst);
2171 break;
2173 case TARGET_EXPR:
2174 /* Note that this only works for G++ target exprs. If somebody
2175 builds a general TARGET_EXPR, there's no way to represent that
2176 it initializes anything other that the parameter slot for the
2177 default argument. Note we may have cleared out the first
2178 operand in expand_expr, so don't go killing ourselves. */
2179 if (TREE_OPERAND (t, 1))
2180 dump_expr (pp, TREE_OPERAND (t, 1), flags | TFF_EXPR_IN_PARENS);
2181 break;
2183 case POINTER_PLUS_EXPR:
2184 dump_binary_op (pp, "+", t, flags);
2185 break;
2187 case INIT_EXPR:
2188 case MODIFY_EXPR:
2189 dump_binary_op (pp, assignment_operator_name_info[NOP_EXPR].name,
2190 t, flags);
2191 break;
2193 case PLUS_EXPR:
2194 case MINUS_EXPR:
2195 case MULT_EXPR:
2196 case TRUNC_DIV_EXPR:
2197 case TRUNC_MOD_EXPR:
2198 case MIN_EXPR:
2199 case MAX_EXPR:
2200 case LSHIFT_EXPR:
2201 case RSHIFT_EXPR:
2202 case BIT_IOR_EXPR:
2203 case BIT_XOR_EXPR:
2204 case BIT_AND_EXPR:
2205 case TRUTH_ANDIF_EXPR:
2206 case TRUTH_ORIF_EXPR:
2207 case LT_EXPR:
2208 case LE_EXPR:
2209 case GT_EXPR:
2210 case GE_EXPR:
2211 case EQ_EXPR:
2212 case NE_EXPR:
2213 case EXACT_DIV_EXPR:
2214 dump_binary_op (pp, operator_name_info[TREE_CODE (t)].name, t, flags);
2215 break;
2217 case CEIL_DIV_EXPR:
2218 case FLOOR_DIV_EXPR:
2219 case ROUND_DIV_EXPR:
2220 case RDIV_EXPR:
2221 dump_binary_op (pp, "/", t, flags);
2222 break;
2224 case CEIL_MOD_EXPR:
2225 case FLOOR_MOD_EXPR:
2226 case ROUND_MOD_EXPR:
2227 dump_binary_op (pp, "%", t, flags);
2228 break;
2230 case COMPONENT_REF:
2232 tree ob = TREE_OPERAND (t, 0);
2233 if (INDIRECT_REF_P (ob))
2235 ob = TREE_OPERAND (ob, 0);
2236 if (TREE_CODE (ob) != PARM_DECL
2237 || (DECL_NAME (ob)
2238 && strcmp (IDENTIFIER_POINTER (DECL_NAME (ob)), "this")))
2240 dump_expr (pp, ob, flags | TFF_EXPR_IN_PARENS);
2241 if (TREE_CODE (TREE_TYPE (ob)) == REFERENCE_TYPE)
2242 pp_cxx_dot (pp);
2243 else
2244 pp_cxx_arrow (pp);
2247 else
2249 dump_expr (pp, ob, flags | TFF_EXPR_IN_PARENS);
2250 pp_cxx_dot (pp);
2252 dump_expr (pp, TREE_OPERAND (t, 1), flags & ~TFF_EXPR_IN_PARENS);
2254 break;
2256 case ARRAY_REF:
2257 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2258 pp_cxx_left_bracket (pp);
2259 dump_expr (pp, TREE_OPERAND (t, 1), flags | TFF_EXPR_IN_PARENS);
2260 pp_cxx_right_bracket (pp);
2261 break;
2263 case ARRAY_NOTATION_REF:
2264 dump_expr (pp, ARRAY_NOTATION_ARRAY (t), flags | TFF_EXPR_IN_PARENS);
2265 pp_cxx_left_bracket (pp);
2266 dump_expr (pp, ARRAY_NOTATION_START (t), flags | TFF_EXPR_IN_PARENS);
2267 pp_colon (pp);
2268 dump_expr (pp, ARRAY_NOTATION_LENGTH (t), flags | TFF_EXPR_IN_PARENS);
2269 pp_colon (pp);
2270 dump_expr (pp, ARRAY_NOTATION_STRIDE (t), flags | TFF_EXPR_IN_PARENS);
2271 pp_cxx_right_bracket (pp);
2272 break;
2274 case UNARY_PLUS_EXPR:
2275 dump_unary_op (pp, "+", t, flags);
2276 break;
2278 case ADDR_EXPR:
2279 if (TREE_CODE (TREE_OPERAND (t, 0)) == FUNCTION_DECL
2280 || TREE_CODE (TREE_OPERAND (t, 0)) == STRING_CST
2281 /* An ADDR_EXPR can have reference type. In that case, we
2282 shouldn't print the `&' doing so indicates to the user
2283 that the expression has pointer type. */
2284 || (TREE_TYPE (t)
2285 && TREE_CODE (TREE_TYPE (t)) == REFERENCE_TYPE))
2286 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2287 else if (TREE_CODE (TREE_OPERAND (t, 0)) == LABEL_DECL)
2288 dump_unary_op (pp, "&&", t, flags);
2289 else
2290 dump_unary_op (pp, "&", t, flags);
2291 break;
2293 case INDIRECT_REF:
2294 if (TREE_HAS_CONSTRUCTOR (t))
2296 t = TREE_OPERAND (t, 0);
2297 gcc_assert (TREE_CODE (t) == CALL_EXPR);
2298 dump_expr (pp, CALL_EXPR_FN (t), flags | TFF_EXPR_IN_PARENS);
2299 dump_call_expr_args (pp, t, flags, true);
2301 else
2303 if (TREE_OPERAND (t,0) != NULL_TREE
2304 && TREE_TYPE (TREE_OPERAND (t, 0))
2305 && NEXT_CODE (TREE_OPERAND (t, 0)) == REFERENCE_TYPE)
2306 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2307 else
2308 dump_unary_op (pp, "*", t, flags);
2310 break;
2312 case MEM_REF:
2313 if (TREE_CODE (TREE_OPERAND (t, 0)) == ADDR_EXPR
2314 && integer_zerop (TREE_OPERAND (t, 1)))
2315 dump_expr (pp, TREE_OPERAND (TREE_OPERAND (t, 0), 0), flags);
2316 else
2318 pp_cxx_star (pp);
2319 if (!integer_zerop (TREE_OPERAND (t, 1)))
2321 pp_cxx_left_paren (pp);
2322 if (!integer_onep (TYPE_SIZE_UNIT
2323 (TREE_TYPE (TREE_TYPE (TREE_OPERAND (t, 0))))))
2325 pp_cxx_left_paren (pp);
2326 dump_type (pp, ptr_type_node, flags);
2327 pp_cxx_right_paren (pp);
2330 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2331 if (!integer_zerop (TREE_OPERAND (t, 1)))
2333 pp_cxx_ws_string (pp, "+");
2334 dump_expr (pp, fold_convert (ssizetype, TREE_OPERAND (t, 1)),
2335 flags);
2336 pp_cxx_right_paren (pp);
2339 break;
2341 case NEGATE_EXPR:
2342 case BIT_NOT_EXPR:
2343 case TRUTH_NOT_EXPR:
2344 case PREDECREMENT_EXPR:
2345 case PREINCREMENT_EXPR:
2346 dump_unary_op (pp, operator_name_info [TREE_CODE (t)].name, t, flags);
2347 break;
2349 case POSTDECREMENT_EXPR:
2350 case POSTINCREMENT_EXPR:
2351 pp_cxx_left_paren (pp);
2352 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2353 pp_cxx_ws_string (pp, operator_name_info[TREE_CODE (t)].name);
2354 pp_cxx_right_paren (pp);
2355 break;
2357 case NON_LVALUE_EXPR:
2358 /* FIXME: This is a KLUDGE workaround for a parsing problem. There
2359 should be another level of INDIRECT_REF so that I don't have to do
2360 this. */
2361 if (TREE_TYPE (t) != NULL_TREE && NEXT_CODE (t) == POINTER_TYPE)
2363 tree next = TREE_TYPE (TREE_TYPE (t));
2365 while (TYPE_PTR_P (next))
2366 next = TREE_TYPE (next);
2368 if (TREE_CODE (next) == FUNCTION_TYPE)
2370 if (flags & TFF_EXPR_IN_PARENS)
2371 pp_cxx_left_paren (pp);
2372 pp_cxx_star (pp);
2373 dump_expr (pp, TREE_OPERAND (t, 0), flags & ~TFF_EXPR_IN_PARENS);
2374 if (flags & TFF_EXPR_IN_PARENS)
2375 pp_cxx_right_paren (pp);
2376 break;
2378 /* Else fall through. */
2380 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2381 break;
2383 CASE_CONVERT:
2384 case IMPLICIT_CONV_EXPR:
2385 case VIEW_CONVERT_EXPR:
2387 tree op = TREE_OPERAND (t, 0);
2388 tree ttype = TREE_TYPE (t);
2389 tree optype = TREE_TYPE (op);
2391 if (TREE_CODE (ttype) != TREE_CODE (optype)
2392 && POINTER_TYPE_P (ttype)
2393 && POINTER_TYPE_P (optype)
2394 && same_type_p (TREE_TYPE (optype),
2395 TREE_TYPE (ttype)))
2397 if (TREE_CODE (ttype) == REFERENCE_TYPE)
2399 STRIP_NOPS (op);
2400 if (TREE_CODE (op) == ADDR_EXPR)
2401 dump_expr (pp, TREE_OPERAND (op, 0), flags);
2402 else
2403 dump_unary_op (pp, "*", t, flags);
2405 else
2406 dump_unary_op (pp, "&", t, flags);
2408 else if (!same_type_p (TREE_TYPE (op), TREE_TYPE (t)))
2410 /* It is a cast, but we cannot tell whether it is a
2411 reinterpret or static cast. Use the C style notation. */
2412 if (flags & TFF_EXPR_IN_PARENS)
2413 pp_cxx_left_paren (pp);
2414 pp_cxx_left_paren (pp);
2415 dump_type (pp, TREE_TYPE (t), flags);
2416 pp_cxx_right_paren (pp);
2417 dump_expr (pp, op, flags | TFF_EXPR_IN_PARENS);
2418 if (flags & TFF_EXPR_IN_PARENS)
2419 pp_cxx_right_paren (pp);
2421 else
2422 dump_expr (pp, op, flags);
2423 break;
2426 case CONSTRUCTOR:
2427 if (TREE_TYPE (t) && TYPE_PTRMEMFUNC_P (TREE_TYPE (t)))
2429 tree idx = build_ptrmemfunc_access_expr (t, pfn_identifier);
2431 if (integer_zerop (idx))
2433 /* A NULL pointer-to-member constant. */
2434 pp_cxx_left_paren (pp);
2435 pp_cxx_left_paren (pp);
2436 dump_type (pp, TREE_TYPE (t), flags);
2437 pp_cxx_right_paren (pp);
2438 pp_character (pp, '0');
2439 pp_cxx_right_paren (pp);
2440 break;
2442 else if (tree_fits_shwi_p (idx))
2444 tree virtuals;
2445 unsigned HOST_WIDE_INT n;
2447 t = TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE (TREE_TYPE (t)));
2448 t = TYPE_METHOD_BASETYPE (t);
2449 virtuals = BINFO_VIRTUALS (TYPE_BINFO (TYPE_MAIN_VARIANT (t)));
2451 n = tree_to_shwi (idx);
2453 /* Map vtable index back one, to allow for the null pointer to
2454 member. */
2455 --n;
2457 while (n > 0 && virtuals)
2459 --n;
2460 virtuals = TREE_CHAIN (virtuals);
2462 if (virtuals)
2464 dump_expr (pp, BV_FN (virtuals),
2465 flags | TFF_EXPR_IN_PARENS);
2466 break;
2470 if (TREE_TYPE (t) && LAMBDA_TYPE_P (TREE_TYPE (t)))
2471 pp_string (pp, "<lambda closure object>");
2472 if (TREE_TYPE (t) && EMPTY_CONSTRUCTOR_P (t))
2474 dump_type (pp, TREE_TYPE (t), 0);
2475 pp_cxx_left_paren (pp);
2476 pp_cxx_right_paren (pp);
2478 else
2480 if (!BRACE_ENCLOSED_INITIALIZER_P (t))
2481 dump_type (pp, TREE_TYPE (t), 0);
2482 pp_cxx_left_brace (pp);
2483 dump_expr_init_vec (pp, CONSTRUCTOR_ELTS (t), flags);
2484 pp_cxx_right_brace (pp);
2487 break;
2489 case OFFSET_REF:
2491 tree ob = TREE_OPERAND (t, 0);
2492 if (is_dummy_object (ob))
2494 t = TREE_OPERAND (t, 1);
2495 if (TREE_CODE (t) == FUNCTION_DECL)
2496 /* A::f */
2497 dump_expr (pp, t, flags | TFF_EXPR_IN_PARENS);
2498 else if (BASELINK_P (t))
2499 dump_expr (pp, OVL_CURRENT (BASELINK_FUNCTIONS (t)),
2500 flags | TFF_EXPR_IN_PARENS);
2501 else
2502 dump_decl (pp, t, flags);
2504 else
2506 if (INDIRECT_REF_P (ob))
2508 dump_expr (pp, TREE_OPERAND (ob, 0), flags | TFF_EXPR_IN_PARENS);
2509 pp_cxx_arrow (pp);
2510 pp_cxx_star (pp);
2512 else
2514 dump_expr (pp, ob, flags | TFF_EXPR_IN_PARENS);
2515 pp_cxx_dot (pp);
2516 pp_cxx_star (pp);
2518 dump_expr (pp, TREE_OPERAND (t, 1), flags | TFF_EXPR_IN_PARENS);
2520 break;
2523 case TEMPLATE_PARM_INDEX:
2524 dump_decl (pp, TEMPLATE_PARM_DECL (t), flags & ~TFF_DECL_SPECIFIERS);
2525 break;
2527 case CAST_EXPR:
2528 if (TREE_OPERAND (t, 0) == NULL_TREE
2529 || TREE_CHAIN (TREE_OPERAND (t, 0)))
2531 dump_type (pp, TREE_TYPE (t), flags);
2532 pp_cxx_left_paren (pp);
2533 dump_expr_list (pp, TREE_OPERAND (t, 0), flags);
2534 pp_cxx_right_paren (pp);
2536 else
2538 pp_cxx_left_paren (pp);
2539 dump_type (pp, TREE_TYPE (t), flags);
2540 pp_cxx_right_paren (pp);
2541 pp_cxx_left_paren (pp);
2542 dump_expr_list (pp, TREE_OPERAND (t, 0), flags);
2543 pp_cxx_right_paren (pp);
2545 break;
2547 case STATIC_CAST_EXPR:
2548 pp_cxx_ws_string (pp, "static_cast");
2549 goto cast;
2550 case REINTERPRET_CAST_EXPR:
2551 pp_cxx_ws_string (pp, "reinterpret_cast");
2552 goto cast;
2553 case CONST_CAST_EXPR:
2554 pp_cxx_ws_string (pp, "const_cast");
2555 goto cast;
2556 case DYNAMIC_CAST_EXPR:
2557 pp_cxx_ws_string (pp, "dynamic_cast");
2558 cast:
2559 pp_cxx_begin_template_argument_list (pp);
2560 dump_type (pp, TREE_TYPE (t), flags);
2561 pp_cxx_end_template_argument_list (pp);
2562 pp_cxx_left_paren (pp);
2563 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2564 pp_cxx_right_paren (pp);
2565 break;
2567 case ARROW_EXPR:
2568 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2569 pp_cxx_arrow (pp);
2570 break;
2572 case SIZEOF_EXPR:
2573 case ALIGNOF_EXPR:
2574 if (TREE_CODE (t) == SIZEOF_EXPR)
2575 pp_cxx_ws_string (pp, "sizeof");
2576 else
2578 gcc_assert (TREE_CODE (t) == ALIGNOF_EXPR);
2579 pp_cxx_ws_string (pp, "__alignof__");
2581 op = TREE_OPERAND (t, 0);
2582 if (PACK_EXPANSION_P (op))
2584 pp_string (pp, "...");
2585 op = PACK_EXPANSION_PATTERN (op);
2587 pp_cxx_whitespace (pp);
2588 pp_cxx_left_paren (pp);
2589 if (TREE_CODE (t) == SIZEOF_EXPR && SIZEOF_EXPR_TYPE_P (t))
2590 dump_type (pp, TREE_TYPE (op), flags);
2591 else if (TYPE_P (TREE_OPERAND (t, 0)))
2592 dump_type (pp, op, flags);
2593 else
2594 dump_expr (pp, op, flags);
2595 pp_cxx_right_paren (pp);
2596 break;
2598 case AT_ENCODE_EXPR:
2599 pp_cxx_ws_string (pp, "@encode");
2600 pp_cxx_whitespace (pp);
2601 pp_cxx_left_paren (pp);
2602 dump_type (pp, TREE_OPERAND (t, 0), flags);
2603 pp_cxx_right_paren (pp);
2604 break;
2606 case NOEXCEPT_EXPR:
2607 pp_cxx_ws_string (pp, "noexcept");
2608 pp_cxx_whitespace (pp);
2609 pp_cxx_left_paren (pp);
2610 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2611 pp_cxx_right_paren (pp);
2612 break;
2614 case REALPART_EXPR:
2615 case IMAGPART_EXPR:
2616 pp_cxx_ws_string (pp, operator_name_info[TREE_CODE (t)].name);
2617 pp_cxx_whitespace (pp);
2618 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2619 break;
2621 case DEFAULT_ARG:
2622 pp_string (pp, M_("<unparsed>"));
2623 break;
2625 case TRY_CATCH_EXPR:
2626 case WITH_CLEANUP_EXPR:
2627 case CLEANUP_POINT_EXPR:
2628 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2629 break;
2631 case PSEUDO_DTOR_EXPR:
2632 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2633 pp_cxx_dot (pp);
2634 if (TREE_OPERAND (t, 1))
2636 dump_type (pp, TREE_OPERAND (t, 1), flags);
2637 pp_cxx_colon_colon (pp);
2639 pp_cxx_complement (pp);
2640 dump_type (pp, TREE_OPERAND (t, 2), flags);
2641 break;
2643 case TEMPLATE_ID_EXPR:
2644 dump_decl (pp, t, flags);
2645 break;
2647 case BIND_EXPR:
2648 case STMT_EXPR:
2649 case EXPR_STMT:
2650 case STATEMENT_LIST:
2651 /* We don't yet have a way of dumping statements in a
2652 human-readable format. */
2653 pp_string (pp, "({...})");
2654 break;
2656 case LOOP_EXPR:
2657 pp_string (pp, "while (1) { ");
2658 dump_expr (pp, TREE_OPERAND (t, 0), flags & ~TFF_EXPR_IN_PARENS);
2659 pp_cxx_right_brace (pp);
2660 break;
2662 case EXIT_EXPR:
2663 pp_string (pp, "if (");
2664 dump_expr (pp, TREE_OPERAND (t, 0), flags & ~TFF_EXPR_IN_PARENS);
2665 pp_string (pp, ") break; ");
2666 break;
2668 case BASELINK:
2669 dump_expr (pp, BASELINK_FUNCTIONS (t), flags & ~TFF_EXPR_IN_PARENS);
2670 break;
2672 case EMPTY_CLASS_EXPR:
2673 dump_type (pp, TREE_TYPE (t), flags);
2674 pp_cxx_left_paren (pp);
2675 pp_cxx_right_paren (pp);
2676 break;
2678 case NON_DEPENDENT_EXPR:
2679 dump_expr (pp, TREE_OPERAND (t, 0), flags);
2680 break;
2682 case ARGUMENT_PACK_SELECT:
2683 dump_template_argument (pp, ARGUMENT_PACK_SELECT_FROM_PACK (t), flags);
2684 break;
2686 case RECORD_TYPE:
2687 case UNION_TYPE:
2688 case ENUMERAL_TYPE:
2689 case REAL_TYPE:
2690 case VOID_TYPE:
2691 case BOOLEAN_TYPE:
2692 case INTEGER_TYPE:
2693 case COMPLEX_TYPE:
2694 case VECTOR_TYPE:
2695 pp_type_specifier_seq (pp, t);
2696 break;
2698 case TYPENAME_TYPE:
2699 /* We get here when we want to print a dependent type as an
2700 id-expression, without any disambiguator decoration. */
2701 pp->id_expression (t);
2702 break;
2704 case TEMPLATE_TYPE_PARM:
2705 case TEMPLATE_TEMPLATE_PARM:
2706 case BOUND_TEMPLATE_TEMPLATE_PARM:
2707 dump_type (pp, t, flags);
2708 break;
2710 case TRAIT_EXPR:
2711 pp_cxx_trait_expression (pp, t);
2712 break;
2714 case VA_ARG_EXPR:
2715 pp_cxx_va_arg_expression (pp, t);
2716 break;
2718 case OFFSETOF_EXPR:
2719 pp_cxx_offsetof_expression (pp, t);
2720 break;
2722 case ADDRESSOF_EXPR:
2723 pp_cxx_addressof_expression (pp, t);
2724 break;
2726 case SCOPE_REF:
2727 dump_decl (pp, t, flags);
2728 break;
2730 case EXPR_PACK_EXPANSION:
2731 case UNARY_LEFT_FOLD_EXPR:
2732 case UNARY_RIGHT_FOLD_EXPR:
2733 case BINARY_LEFT_FOLD_EXPR:
2734 case BINARY_RIGHT_FOLD_EXPR:
2735 case TYPEID_EXPR:
2736 case MEMBER_REF:
2737 case DOTSTAR_EXPR:
2738 case NEW_EXPR:
2739 case VEC_NEW_EXPR:
2740 case DELETE_EXPR:
2741 case VEC_DELETE_EXPR:
2742 case MODOP_EXPR:
2743 case ABS_EXPR:
2744 case CONJ_EXPR:
2745 case VECTOR_CST:
2746 case FIXED_CST:
2747 case UNORDERED_EXPR:
2748 case ORDERED_EXPR:
2749 case UNLT_EXPR:
2750 case UNLE_EXPR:
2751 case UNGT_EXPR:
2752 case UNGE_EXPR:
2753 case UNEQ_EXPR:
2754 case LTGT_EXPR:
2755 case COMPLEX_EXPR:
2756 case BIT_FIELD_REF:
2757 case FIX_TRUNC_EXPR:
2758 case FLOAT_EXPR:
2759 pp->expression (t);
2760 break;
2762 case TRUTH_AND_EXPR:
2763 case TRUTH_OR_EXPR:
2764 case TRUTH_XOR_EXPR:
2765 if (flags & TFF_EXPR_IN_PARENS)
2766 pp_cxx_left_paren (pp);
2767 pp->expression (t);
2768 if (flags & TFF_EXPR_IN_PARENS)
2769 pp_cxx_right_paren (pp);
2770 break;
2772 case OBJ_TYPE_REF:
2773 dump_expr (pp, resolve_virtual_fun_from_obj_type_ref (t), flags);
2774 break;
2776 case LAMBDA_EXPR:
2777 pp_string (pp, M_("<lambda>"));
2778 break;
2780 case PAREN_EXPR:
2781 pp_cxx_left_paren (pp);
2782 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2783 pp_cxx_right_paren (pp);
2784 break;
2786 case REQUIRES_EXPR:
2787 pp_cxx_requires_expr (cxx_pp, t);
2788 break;
2790 case SIMPLE_REQ:
2791 pp_cxx_simple_requirement (cxx_pp, t);
2792 break;
2794 case TYPE_REQ:
2795 pp_cxx_type_requirement (cxx_pp, t);
2796 break;
2798 case COMPOUND_REQ:
2799 pp_cxx_compound_requirement (cxx_pp, t);
2800 break;
2802 case NESTED_REQ:
2803 pp_cxx_nested_requirement (cxx_pp, t);
2804 break;
2806 case PRED_CONSTR:
2807 case CHECK_CONSTR:
2808 case EXPR_CONSTR:
2809 case TYPE_CONSTR:
2810 case ICONV_CONSTR:
2811 case DEDUCT_CONSTR:
2812 case EXCEPT_CONSTR:
2813 case PARM_CONSTR:
2814 case CONJ_CONSTR:
2815 case DISJ_CONSTR:
2816 pp_cxx_constraint (cxx_pp, t);
2817 break;
2819 case PLACEHOLDER_EXPR:
2820 pp_string (pp, M_("*this"));
2821 break;
2823 /* This list is incomplete, but should suffice for now.
2824 It is very important that `sorry' does not call
2825 `report_error_function'. That could cause an infinite loop. */
2826 default:
2827 pp_unsupported_tree (pp, t);
2828 /* Fall through. */
2829 case ERROR_MARK:
2830 pp_string (pp, M_("<expression error>"));
2831 break;
2835 static void
2836 dump_binary_op (cxx_pretty_printer *pp, const char *opstring, tree t,
2837 int flags)
2839 pp_cxx_left_paren (pp);
2840 dump_expr (pp, TREE_OPERAND (t, 0), flags | TFF_EXPR_IN_PARENS);
2841 pp_cxx_whitespace (pp);
2842 if (opstring)
2843 pp_cxx_ws_string (pp, opstring);
2844 else
2845 pp_string (pp, M_("<unknown operator>"));
2846 pp_cxx_whitespace (pp);
2847 dump_expr (pp, TREE_OPERAND (t, 1), flags | TFF_EXPR_IN_PARENS);
2848 pp_cxx_right_paren (pp);
2851 static void
2852 dump_unary_op (cxx_pretty_printer *pp, const char *opstring, tree t, int flags)
2854 if (flags & TFF_EXPR_IN_PARENS)
2855 pp_cxx_left_paren (pp);
2856 pp_cxx_ws_string (pp, opstring);
2857 dump_expr (pp, TREE_OPERAND (t, 0), flags & ~TFF_EXPR_IN_PARENS);
2858 if (flags & TFF_EXPR_IN_PARENS)
2859 pp_cxx_right_paren (pp);
2862 static void
2863 reinit_cxx_pp (void)
2865 pp_clear_output_area (cxx_pp);
2866 cxx_pp->padding = pp_none;
2867 pp_indentation (cxx_pp) = 0;
2868 pp_needs_newline (cxx_pp) = false;
2869 cxx_pp->enclosing_scope = current_function_decl;
2872 /* Same as pp_formatted_text, except the return string is a separate
2873 copy and has a GGC storage duration, e.g. an indefinite lifetime. */
2875 inline const char *
2876 pp_ggc_formatted_text (pretty_printer *pp)
2878 return ggc_strdup (pp_formatted_text (pp));
2881 /* Exported interface to stringifying types, exprs and decls under TFF_*
2882 control. */
2884 const char *
2885 type_as_string (tree typ, int flags)
2887 reinit_cxx_pp ();
2888 pp_translate_identifiers (cxx_pp) = false;
2889 dump_type (cxx_pp, typ, flags);
2890 return pp_ggc_formatted_text (cxx_pp);
2893 const char *
2894 type_as_string_translate (tree typ, int flags)
2896 reinit_cxx_pp ();
2897 dump_type (cxx_pp, typ, flags);
2898 return pp_ggc_formatted_text (cxx_pp);
2901 const char *
2902 expr_as_string (tree decl, int flags)
2904 reinit_cxx_pp ();
2905 pp_translate_identifiers (cxx_pp) = false;
2906 dump_expr (cxx_pp, decl, flags);
2907 return pp_ggc_formatted_text (cxx_pp);
2910 /* Wrap decl_as_string with options appropriate for dwarf. */
2912 const char *
2913 decl_as_dwarf_string (tree decl, int flags)
2915 const char *name;
2916 /* Curiously, reinit_cxx_pp doesn't reset the flags field, so setting the flag
2917 here will be adequate to get the desired behavior. */
2918 cxx_pp->flags |= pp_c_flag_gnu_v3;
2919 name = decl_as_string (decl, flags);
2920 /* Subsequent calls to the pretty printer shouldn't use this style. */
2921 cxx_pp->flags &= ~pp_c_flag_gnu_v3;
2922 return name;
2925 const char *
2926 decl_as_string (tree decl, int flags)
2928 reinit_cxx_pp ();
2929 pp_translate_identifiers (cxx_pp) = false;
2930 dump_decl (cxx_pp, decl, flags);
2931 return pp_ggc_formatted_text (cxx_pp);
2934 const char *
2935 decl_as_string_translate (tree decl, int flags)
2937 reinit_cxx_pp ();
2938 dump_decl (cxx_pp, decl, flags);
2939 return pp_ggc_formatted_text (cxx_pp);
2942 /* Wrap lang_decl_name with options appropriate for dwarf. */
2944 const char *
2945 lang_decl_dwarf_name (tree decl, int v, bool translate)
2947 const char *name;
2948 /* Curiously, reinit_cxx_pp doesn't reset the flags field, so setting the flag
2949 here will be adequate to get the desired behavior. */
2950 cxx_pp->flags |= pp_c_flag_gnu_v3;
2951 name = lang_decl_name (decl, v, translate);
2952 /* Subsequent calls to the pretty printer shouldn't use this style. */
2953 cxx_pp->flags &= ~pp_c_flag_gnu_v3;
2954 return name;
2957 /* Generate the three forms of printable names for cxx_printable_name. */
2959 const char *
2960 lang_decl_name (tree decl, int v, bool translate)
2962 if (v >= 2)
2963 return (translate
2964 ? decl_as_string_translate (decl, TFF_DECL_SPECIFIERS)
2965 : decl_as_string (decl, TFF_DECL_SPECIFIERS));
2967 reinit_cxx_pp ();
2968 pp_translate_identifiers (cxx_pp) = translate;
2969 if (v == 1
2970 && (DECL_CLASS_SCOPE_P (decl)
2971 || (DECL_NAMESPACE_SCOPE_P (decl)
2972 && CP_DECL_CONTEXT (decl) != global_namespace)))
2974 dump_type (cxx_pp, CP_DECL_CONTEXT (decl), TFF_PLAIN_IDENTIFIER);
2975 pp_cxx_colon_colon (cxx_pp);
2978 if (TREE_CODE (decl) == FUNCTION_DECL)
2979 dump_function_name (cxx_pp, decl, TFF_PLAIN_IDENTIFIER);
2980 else if ((DECL_NAME (decl) == NULL_TREE)
2981 && TREE_CODE (decl) == NAMESPACE_DECL)
2982 dump_decl (cxx_pp, decl, TFF_PLAIN_IDENTIFIER | TFF_UNQUALIFIED_NAME);
2983 else
2984 dump_decl (cxx_pp, DECL_NAME (decl), TFF_PLAIN_IDENTIFIER);
2986 return pp_ggc_formatted_text (cxx_pp);
2989 /* Return the location of a tree passed to %+ formats. */
2991 location_t
2992 location_of (tree t)
2994 if (TYPE_P (t))
2996 t = TYPE_MAIN_DECL (t);
2997 if (t == NULL_TREE)
2998 return input_location;
3000 else if (TREE_CODE (t) == OVERLOAD)
3001 t = OVL_FUNCTION (t);
3003 if (DECL_P (t))
3004 return DECL_SOURCE_LOCATION (t);
3005 return EXPR_LOC_OR_LOC (t, input_location);
3008 /* Now the interfaces from error et al to dump_type et al. Each takes an
3009 on/off VERBOSE flag and supply the appropriate TFF_ flags to a dump_
3010 function. */
3012 static const char *
3013 decl_to_string (tree decl, int verbose)
3015 int flags = 0;
3017 if (TREE_CODE (decl) == TYPE_DECL || TREE_CODE (decl) == RECORD_TYPE
3018 || TREE_CODE (decl) == UNION_TYPE || TREE_CODE (decl) == ENUMERAL_TYPE)
3019 flags = TFF_CLASS_KEY_OR_ENUM;
3020 if (verbose)
3021 flags |= TFF_DECL_SPECIFIERS;
3022 else if (TREE_CODE (decl) == FUNCTION_DECL)
3023 flags |= TFF_DECL_SPECIFIERS | TFF_RETURN_TYPE;
3024 flags |= TFF_TEMPLATE_HEADER;
3026 reinit_cxx_pp ();
3027 dump_decl (cxx_pp, decl, flags);
3028 return pp_ggc_formatted_text (cxx_pp);
3031 static const char *
3032 expr_to_string (tree decl)
3034 reinit_cxx_pp ();
3035 dump_expr (cxx_pp, decl, 0);
3036 return pp_ggc_formatted_text (cxx_pp);
3039 static const char *
3040 fndecl_to_string (tree fndecl, int verbose)
3042 int flags;
3044 flags = TFF_EXCEPTION_SPECIFICATION | TFF_DECL_SPECIFIERS
3045 | TFF_TEMPLATE_HEADER;
3046 if (verbose)
3047 flags |= TFF_FUNCTION_DEFAULT_ARGUMENTS;
3048 reinit_cxx_pp ();
3049 dump_decl (cxx_pp, fndecl, flags);
3050 return pp_ggc_formatted_text (cxx_pp);
3054 static const char *
3055 code_to_string (enum tree_code c)
3057 return get_tree_code_name (c);
3060 const char *
3061 language_to_string (enum languages c)
3063 switch (c)
3065 case lang_c:
3066 return "C";
3068 case lang_cplusplus:
3069 return "C++";
3071 default:
3072 gcc_unreachable ();
3074 return NULL;
3077 /* Return the proper printed version of a parameter to a C++ function. */
3079 static const char *
3080 parm_to_string (int p)
3082 reinit_cxx_pp ();
3083 if (p < 0)
3084 pp_string (cxx_pp, "'this'");
3085 else
3086 pp_decimal_int (cxx_pp, p + 1);
3087 return pp_ggc_formatted_text (cxx_pp);
3090 static const char *
3091 op_to_string (enum tree_code p)
3093 tree id = operator_name_info[p].identifier;
3094 return id ? IDENTIFIER_POINTER (id) : M_("<unknown>");
3097 static const char *
3098 type_to_string (tree typ, int verbose)
3100 int flags = 0;
3101 if (verbose)
3102 flags |= TFF_CLASS_KEY_OR_ENUM;
3103 flags |= TFF_TEMPLATE_HEADER;
3105 reinit_cxx_pp ();
3106 dump_type (cxx_pp, typ, flags);
3107 /* If we're printing a type that involves typedefs, also print the
3108 stripped version. But sometimes the stripped version looks
3109 exactly the same, so we don't want it after all. To avoid printing
3110 it in that case, we play ugly obstack games. */
3111 if (typ && TYPE_P (typ) && typ != TYPE_CANONICAL (typ)
3112 && !uses_template_parms (typ))
3114 int aka_start, aka_len; char *p;
3115 struct obstack *ob = pp_buffer (cxx_pp)->obstack;
3116 /* Remember the end of the initial dump. */
3117 int len = obstack_object_size (ob);
3118 tree aka = strip_typedefs (typ);
3119 pp_string (cxx_pp, " {aka");
3120 pp_cxx_whitespace (cxx_pp);
3121 /* And remember the start of the aka dump. */
3122 aka_start = obstack_object_size (ob);
3123 dump_type (cxx_pp, aka, flags);
3124 aka_len = obstack_object_size (ob) - aka_start;
3125 pp_right_brace (cxx_pp);
3126 p = (char*)obstack_base (ob);
3127 /* If they are identical, cut off the aka with a NUL. */
3128 if (len == aka_len && memcmp (p, p+aka_start, len) == 0)
3129 p[len] = '\0';
3131 return pp_ggc_formatted_text (cxx_pp);
3134 static const char *
3135 assop_to_string (enum tree_code p)
3137 tree id = assignment_operator_name_info[(int) p].identifier;
3138 return id ? IDENTIFIER_POINTER (id) : M_("{unknown}");
3141 static const char *
3142 args_to_string (tree p, int verbose)
3144 int flags = 0;
3145 if (verbose)
3146 flags |= TFF_CLASS_KEY_OR_ENUM;
3148 if (p == NULL_TREE)
3149 return "";
3151 if (TYPE_P (TREE_VALUE (p)))
3152 return type_as_string_translate (p, flags);
3154 reinit_cxx_pp ();
3155 for (; p; p = TREE_CHAIN (p))
3157 if (TREE_VALUE (p) == null_node)
3158 pp_cxx_ws_string (cxx_pp, "NULL");
3159 else
3160 dump_type (cxx_pp, error_type (TREE_VALUE (p)), flags);
3161 if (TREE_CHAIN (p))
3162 pp_separate_with_comma (cxx_pp);
3164 return pp_ggc_formatted_text (cxx_pp);
3167 /* Pretty-print a deduction substitution (from deduction_tsubst_fntype). P
3168 is a TREE_LIST with purpose the TEMPLATE_DECL, value the template
3169 arguments. */
3171 static const char *
3172 subst_to_string (tree p)
3174 tree decl = TREE_PURPOSE (p);
3175 tree targs = TREE_VALUE (p);
3176 tree tparms = DECL_TEMPLATE_PARMS (decl);
3177 int flags = (TFF_DECL_SPECIFIERS|TFF_TEMPLATE_HEADER
3178 |TFF_NO_TEMPLATE_BINDINGS);
3180 if (p == NULL_TREE)
3181 return "";
3183 reinit_cxx_pp ();
3184 dump_template_decl (cxx_pp, TREE_PURPOSE (p), flags);
3185 dump_substitution (cxx_pp, NULL, tparms, targs, /*flags=*/0);
3186 return pp_ggc_formatted_text (cxx_pp);
3189 static const char *
3190 cv_to_string (tree p, int v)
3192 reinit_cxx_pp ();
3193 cxx_pp->padding = v ? pp_before : pp_none;
3194 pp_cxx_cv_qualifier_seq (cxx_pp, p);
3195 return pp_ggc_formatted_text (cxx_pp);
3198 static const char *
3199 eh_spec_to_string (tree p, int /*v*/)
3201 int flags = 0;
3202 reinit_cxx_pp ();
3203 dump_exception_spec (cxx_pp, p, flags);
3204 return pp_ggc_formatted_text (cxx_pp);
3207 /* Langhook for print_error_function. */
3208 void
3209 cxx_print_error_function (diagnostic_context *context, const char *file,
3210 diagnostic_info *diagnostic)
3212 lhd_print_error_function (context, file, diagnostic);
3213 pp_set_prefix (context->printer, file);
3214 maybe_print_instantiation_context (context);
3217 static void
3218 cp_diagnostic_starter (diagnostic_context *context,
3219 diagnostic_info *diagnostic)
3221 diagnostic_report_current_module (context, diagnostic_location (diagnostic));
3222 cp_print_error_function (context, diagnostic);
3223 maybe_print_instantiation_context (context);
3224 maybe_print_constexpr_context (context);
3225 pp_set_prefix (context->printer, diagnostic_build_prefix (context,
3226 diagnostic));
3229 /* Print current function onto BUFFER, in the process of reporting
3230 a diagnostic message. Called from cp_diagnostic_starter. */
3231 static void
3232 cp_print_error_function (diagnostic_context *context,
3233 diagnostic_info *diagnostic)
3235 /* If we are in an instantiation context, current_function_decl is likely
3236 to be wrong, so just rely on print_instantiation_full_context. */
3237 if (current_instantiation ())
3238 return;
3239 if (diagnostic_last_function_changed (context, diagnostic))
3241 const char *old_prefix = context->printer->prefix;
3242 const char *file = LOCATION_FILE (diagnostic_location (diagnostic));
3243 tree abstract_origin = diagnostic_abstract_origin (diagnostic);
3244 char *new_prefix = (file && abstract_origin == NULL)
3245 ? file_name_as_prefix (context, file) : NULL;
3247 pp_set_prefix (context->printer, new_prefix);
3249 if (current_function_decl == NULL)
3250 pp_string (context->printer, _("At global scope:"));
3251 else
3253 tree fndecl, ao;
3255 if (abstract_origin)
3257 ao = BLOCK_ABSTRACT_ORIGIN (abstract_origin);
3258 while (TREE_CODE (ao) == BLOCK
3259 && BLOCK_ABSTRACT_ORIGIN (ao)
3260 && BLOCK_ABSTRACT_ORIGIN (ao) != ao)
3261 ao = BLOCK_ABSTRACT_ORIGIN (ao);
3262 gcc_assert (TREE_CODE (ao) == FUNCTION_DECL);
3263 fndecl = ao;
3265 else
3266 fndecl = current_function_decl;
3268 pp_printf (context->printer, function_category (fndecl),
3269 cxx_printable_name_translate (fndecl, 2));
3271 while (abstract_origin)
3273 location_t *locus;
3274 tree block = abstract_origin;
3276 locus = &BLOCK_SOURCE_LOCATION (block);
3277 fndecl = NULL;
3278 block = BLOCK_SUPERCONTEXT (block);
3279 while (block && TREE_CODE (block) == BLOCK
3280 && BLOCK_ABSTRACT_ORIGIN (block))
3282 ao = BLOCK_ABSTRACT_ORIGIN (block);
3284 while (TREE_CODE (ao) == BLOCK
3285 && BLOCK_ABSTRACT_ORIGIN (ao)
3286 && BLOCK_ABSTRACT_ORIGIN (ao) != ao)
3287 ao = BLOCK_ABSTRACT_ORIGIN (ao);
3289 if (TREE_CODE (ao) == FUNCTION_DECL)
3291 fndecl = ao;
3292 break;
3294 else if (TREE_CODE (ao) != BLOCK)
3295 break;
3297 block = BLOCK_SUPERCONTEXT (block);
3299 if (fndecl)
3300 abstract_origin = block;
3301 else
3303 while (block && TREE_CODE (block) == BLOCK)
3304 block = BLOCK_SUPERCONTEXT (block);
3306 if (block && TREE_CODE (block) == FUNCTION_DECL)
3307 fndecl = block;
3308 abstract_origin = NULL;
3310 if (fndecl)
3312 expanded_location s = expand_location (*locus);
3313 pp_character (context->printer, ',');
3314 pp_newline (context->printer);
3315 if (s.file != NULL)
3317 if (context->show_column && s.column != 0)
3318 pp_printf (context->printer,
3319 _(" inlined from %qs at %r%s:%d:%d%R"),
3320 cxx_printable_name_translate (fndecl, 2),
3321 "locus", s.file, s.line, s.column);
3322 else
3323 pp_printf (context->printer,
3324 _(" inlined from %qs at %r%s:%d%R"),
3325 cxx_printable_name_translate (fndecl, 2),
3326 "locus", s.file, s.line);
3329 else
3330 pp_printf (context->printer, _(" inlined from %qs"),
3331 cxx_printable_name_translate (fndecl, 2));
3334 pp_character (context->printer, ':');
3336 pp_newline (context->printer);
3338 diagnostic_set_last_function (context, diagnostic);
3339 pp_destroy_prefix (context->printer);
3340 context->printer->prefix = old_prefix;
3344 /* Returns a description of FUNCTION using standard terminology. The
3345 result is a format string of the form "In CATEGORY %qs". */
3346 static const char *
3347 function_category (tree fn)
3349 /* We can get called from the middle-end for diagnostics of function
3350 clones. Make sure we have language specific information before
3351 dereferencing it. */
3352 if (DECL_LANG_SPECIFIC (STRIP_TEMPLATE (fn))
3353 && DECL_FUNCTION_MEMBER_P (fn))
3355 if (DECL_STATIC_FUNCTION_P (fn))
3356 return _("In static member function %qs");
3357 else if (DECL_COPY_CONSTRUCTOR_P (fn))
3358 return _("In copy constructor %qs");
3359 else if (DECL_CONSTRUCTOR_P (fn))
3360 return _("In constructor %qs");
3361 else if (DECL_DESTRUCTOR_P (fn))
3362 return _("In destructor %qs");
3363 else if (LAMBDA_FUNCTION_P (fn))
3364 return _("In lambda function");
3365 else
3366 return _("In member function %qs");
3368 else
3369 return _("In function %qs");
3372 /* Report the full context of a current template instantiation,
3373 onto BUFFER. */
3374 static void
3375 print_instantiation_full_context (diagnostic_context *context)
3377 struct tinst_level *p = current_instantiation ();
3378 location_t location = input_location;
3380 if (p)
3382 pp_verbatim (context->printer,
3383 TREE_CODE (p->decl) == TREE_LIST
3384 ? _("%s: In substitution of %qS:\n")
3385 : _("%s: In instantiation of %q#D:\n"),
3386 LOCATION_FILE (location),
3387 p->decl);
3389 location = p->locus;
3390 p = p->next;
3393 print_instantiation_partial_context (context, p, location);
3396 /* Helper function of print_instantiation_partial_context() that
3397 prints a single line of instantiation context. */
3399 static void
3400 print_instantiation_partial_context_line (diagnostic_context *context,
3401 const struct tinst_level *t,
3402 location_t loc, bool recursive_p)
3404 if (loc == UNKNOWN_LOCATION)
3405 return;
3407 expanded_location xloc = expand_location (loc);
3409 if (context->show_column)
3410 pp_verbatim (context->printer, _("%r%s:%d:%d:%R "),
3411 "locus", xloc.file, xloc.line, xloc.column);
3412 else
3413 pp_verbatim (context->printer, _("%r%s:%d:%R "),
3414 "locus", xloc.file, xloc.line);
3416 if (t != NULL)
3418 if (TREE_CODE (t->decl) == TREE_LIST)
3419 pp_verbatim (context->printer,
3420 recursive_p
3421 ? _("recursively required by substitution of %qS\n")
3422 : _("required by substitution of %qS\n"),
3423 t->decl);
3424 else
3425 pp_verbatim (context->printer,
3426 recursive_p
3427 ? _("recursively required from %q#D\n")
3428 : _("required from %q#D\n"),
3429 t->decl);
3431 else
3433 pp_verbatim (context->printer,
3434 recursive_p
3435 ? _("recursively required from here\n")
3436 : _("required from here\n"));
3440 /* Same as print_instantiation_full_context but less verbose. */
3442 static void
3443 print_instantiation_partial_context (diagnostic_context *context,
3444 struct tinst_level *t0, location_t loc)
3446 struct tinst_level *t;
3447 int n_total = 0;
3448 int n;
3449 location_t prev_loc = loc;
3451 for (t = t0; t != NULL; t = t->next)
3452 if (prev_loc != t->locus)
3454 prev_loc = t->locus;
3455 n_total++;
3458 t = t0;
3460 if (template_backtrace_limit
3461 && n_total > template_backtrace_limit)
3463 int skip = n_total - template_backtrace_limit;
3464 int head = template_backtrace_limit / 2;
3466 /* Avoid skipping just 1. If so, skip 2. */
3467 if (skip == 1)
3469 skip = 2;
3470 head = (template_backtrace_limit - 1) / 2;
3473 for (n = 0; n < head; n++)
3475 gcc_assert (t != NULL);
3476 if (loc != t->locus)
3477 print_instantiation_partial_context_line (context, t, loc,
3478 /*recursive_p=*/false);
3479 loc = t->locus;
3480 t = t->next;
3482 if (t != NULL && skip > 0)
3484 expanded_location xloc;
3485 xloc = expand_location (loc);
3486 if (context->show_column)
3487 pp_verbatim (context->printer,
3488 _("%r%s:%d:%d:%R [ skipping %d instantiation "
3489 "contexts, use -ftemplate-backtrace-limit=0 to "
3490 "disable ]\n"),
3491 "locus", xloc.file, xloc.line, xloc.column, skip);
3492 else
3493 pp_verbatim (context->printer,
3494 _("%r%s:%d:%R [ skipping %d instantiation "
3495 "contexts, use -ftemplate-backtrace-limit=0 to "
3496 "disable ]\n"),
3497 "locus", xloc.file, xloc.line, skip);
3499 do {
3500 loc = t->locus;
3501 t = t->next;
3502 } while (t != NULL && --skip > 0);
3506 while (t != NULL)
3508 while (t->next != NULL && t->locus == t->next->locus)
3510 loc = t->locus;
3511 t = t->next;
3513 print_instantiation_partial_context_line (context, t, loc,
3514 t->locus == loc);
3515 loc = t->locus;
3516 t = t->next;
3518 print_instantiation_partial_context_line (context, NULL, loc,
3519 /*recursive_p=*/false);
3522 /* Called from cp_thing to print the template context for an error. */
3523 static void
3524 maybe_print_instantiation_context (diagnostic_context *context)
3526 if (!problematic_instantiation_changed () || current_instantiation () == 0)
3527 return;
3529 record_last_problematic_instantiation ();
3530 print_instantiation_full_context (context);
3533 /* Report what constexpr call(s) we're trying to expand, if any. */
3535 void
3536 maybe_print_constexpr_context (diagnostic_context *context)
3538 vec<tree> call_stack = cx_error_context ();
3539 unsigned ix;
3540 tree t;
3542 FOR_EACH_VEC_ELT (call_stack, ix, t)
3544 expanded_location xloc = expand_location (EXPR_LOCATION (t));
3545 const char *s = expr_as_string (t, 0);
3546 if (context->show_column)
3547 pp_verbatim (context->printer,
3548 _("%r%s:%d:%d:%R in constexpr expansion of %qs"),
3549 "locus", xloc.file, xloc.line, xloc.column, s);
3550 else
3551 pp_verbatim (context->printer,
3552 _("%r%s:%d:%R in constexpr expansion of %qs"),
3553 "locus", xloc.file, xloc.line, s);
3554 pp_newline (context->printer);
3558 /* Called from output_format -- during diagnostic message processing --
3559 to handle C++ specific format specifier with the following meanings:
3560 %A function argument-list.
3561 %C tree code.
3562 %D declaration.
3563 %E expression.
3564 %F function declaration.
3565 %L language as used in extern "lang".
3566 %O binary operator.
3567 %P function parameter whose position is indicated by an integer.
3568 %Q assignment operator.
3569 %S substitution (template + args)
3570 %T type.
3571 %V cv-qualifier.
3572 %X exception-specification. */
3573 static bool
3574 cp_printer (pretty_printer *pp, text_info *text, const char *spec,
3575 int precision, bool wide, bool set_locus, bool verbose)
3577 const char *result;
3578 tree t = NULL;
3579 #define next_tree (t = va_arg (*text->args_ptr, tree))
3580 #define next_tcode ((enum tree_code) va_arg (*text->args_ptr, int))
3581 #define next_lang ((enum languages) va_arg (*text->args_ptr, int))
3582 #define next_int va_arg (*text->args_ptr, int)
3584 if (precision != 0 || wide)
3585 return false;
3587 switch (*spec)
3589 case 'A': result = args_to_string (next_tree, verbose); break;
3590 case 'C': result = code_to_string (next_tcode); break;
3591 case 'D':
3593 tree temp = next_tree;
3594 if (VAR_P (temp)
3595 && DECL_HAS_DEBUG_EXPR_P (temp))
3597 temp = DECL_DEBUG_EXPR (temp);
3598 if (!DECL_P (temp))
3600 result = expr_to_string (temp);
3601 break;
3604 result = decl_to_string (temp, verbose);
3606 break;
3607 case 'E': result = expr_to_string (next_tree); break;
3608 case 'F': result = fndecl_to_string (next_tree, verbose); break;
3609 case 'L': result = language_to_string (next_lang); break;
3610 case 'O': result = op_to_string (next_tcode); break;
3611 case 'P': result = parm_to_string (next_int); break;
3612 case 'Q': result = assop_to_string (next_tcode); break;
3613 case 'S': result = subst_to_string (next_tree); break;
3614 case 'T': result = type_to_string (next_tree, verbose); break;
3615 case 'V': result = cv_to_string (next_tree, verbose); break;
3616 case 'X': result = eh_spec_to_string (next_tree, verbose); break;
3618 case 'K':
3619 percent_K_format (text);
3620 return true;
3622 default:
3623 return false;
3626 pp_string (pp, result);
3627 if (set_locus && t != NULL)
3628 text->set_location (0, location_of (t), true);
3629 return true;
3630 #undef next_tree
3631 #undef next_tcode
3632 #undef next_lang
3633 #undef next_int
3636 /* Warn about the use of C++0x features when appropriate. */
3637 void
3638 maybe_warn_cpp0x (cpp0x_warn_str str)
3640 if ((cxx_dialect == cxx98) && !in_system_header_at (input_location))
3641 /* We really want to suppress this warning in system headers,
3642 because libstdc++ uses variadic templates even when we aren't
3643 in C++0x mode. */
3644 switch (str)
3646 case CPP0X_INITIALIZER_LISTS:
3647 pedwarn (input_location, 0,
3648 "extended initializer lists "
3649 "only available with -std=c++11 or -std=gnu++11");
3650 break;
3651 case CPP0X_EXPLICIT_CONVERSION:
3652 pedwarn (input_location, 0,
3653 "explicit conversion operators "
3654 "only available with -std=c++11 or -std=gnu++11");
3655 break;
3656 case CPP0X_VARIADIC_TEMPLATES:
3657 pedwarn (input_location, 0,
3658 "variadic templates "
3659 "only available with -std=c++11 or -std=gnu++11");
3660 break;
3661 case CPP0X_LAMBDA_EXPR:
3662 pedwarn (input_location, 0,
3663 "lambda expressions "
3664 "only available with -std=c++11 or -std=gnu++11");
3665 break;
3666 case CPP0X_AUTO:
3667 pedwarn (input_location, 0,
3668 "C++11 auto only available with -std=c++11 or -std=gnu++11");
3669 break;
3670 case CPP0X_SCOPED_ENUMS:
3671 pedwarn (input_location, 0,
3672 "scoped enums only available with -std=c++11 or -std=gnu++11");
3673 break;
3674 case CPP0X_DEFAULTED_DELETED:
3675 pedwarn (input_location, 0,
3676 "defaulted and deleted functions "
3677 "only available with -std=c++11 or -std=gnu++11");
3678 break;
3679 case CPP0X_INLINE_NAMESPACES:
3680 pedwarn (input_location, OPT_Wpedantic,
3681 "inline namespaces "
3682 "only available with -std=c++11 or -std=gnu++11");
3683 break;
3684 case CPP0X_OVERRIDE_CONTROLS:
3685 pedwarn (input_location, 0,
3686 "override controls (override/final) "
3687 "only available with -std=c++11 or -std=gnu++11");
3688 break;
3689 case CPP0X_NSDMI:
3690 pedwarn (input_location, 0,
3691 "non-static data member initializers "
3692 "only available with -std=c++11 or -std=gnu++11");
3693 break;
3694 case CPP0X_USER_DEFINED_LITERALS:
3695 pedwarn (input_location, 0,
3696 "user-defined literals "
3697 "only available with -std=c++11 or -std=gnu++11");
3698 break;
3699 case CPP0X_DELEGATING_CTORS:
3700 pedwarn (input_location, 0,
3701 "delegating constructors "
3702 "only available with -std=c++11 or -std=gnu++11");
3703 break;
3704 case CPP0X_INHERITING_CTORS:
3705 pedwarn (input_location, 0,
3706 "inheriting constructors "
3707 "only available with -std=c++11 or -std=gnu++11");
3708 break;
3709 case CPP0X_ATTRIBUTES:
3710 pedwarn (input_location, 0,
3711 "c++11 attributes "
3712 "only available with -std=c++11 or -std=gnu++11");
3713 break;
3714 case CPP0X_REF_QUALIFIER:
3715 pedwarn (input_location, 0,
3716 "ref-qualifiers "
3717 "only available with -std=c++11 or -std=gnu++11");
3718 break;
3719 default:
3720 gcc_unreachable ();
3724 /* Warn about the use of variadic templates when appropriate. */
3725 void
3726 maybe_warn_variadic_templates (void)
3728 maybe_warn_cpp0x (CPP0X_VARIADIC_TEMPLATES);
3732 /* Issue an ISO C++98 pedantic warning at LOCATION, conditional on
3733 option OPT with text GMSGID. Use this function to report
3734 diagnostics for constructs that are invalid C++98, but valid
3735 C++0x. */
3736 bool
3737 pedwarn_cxx98 (location_t location, int opt, const char *gmsgid, ...)
3739 diagnostic_info diagnostic;
3740 va_list ap;
3741 bool ret;
3742 rich_location richloc (line_table, location);
3744 va_start (ap, gmsgid);
3745 diagnostic_set_info (&diagnostic, gmsgid, &ap, &richloc,
3746 (cxx_dialect == cxx98) ? DK_PEDWARN : DK_WARNING);
3747 diagnostic.option_index = opt;
3748 ret = report_diagnostic (&diagnostic);
3749 va_end (ap);
3750 return ret;
3753 /* Issue a diagnostic that NAME cannot be found in SCOPE. DECL is what
3754 we found when we tried to do the lookup. LOCATION is the location of
3755 the NAME identifier. */
3757 void
3758 qualified_name_lookup_error (tree scope, tree name,
3759 tree decl, location_t location)
3761 if (scope == error_mark_node)
3762 ; /* We already complained. */
3763 else if (TYPE_P (scope))
3765 if (!COMPLETE_TYPE_P (scope))
3766 error_at (location, "incomplete type %qT used in nested name specifier",
3767 scope);
3768 else if (TREE_CODE (decl) == TREE_LIST)
3770 error_at (location, "reference to %<%T::%D%> is ambiguous",
3771 scope, name);
3772 print_candidates (decl);
3774 else
3775 error_at (location, "%qD is not a member of %qT", name, scope);
3777 else if (scope != global_namespace)
3779 error_at (location, "%qD is not a member of %qD", name, scope);
3780 if (!suggest_alternative_in_explicit_scope (location, name, scope))
3781 suggest_alternatives_for (location, name, false);
3783 else
3785 error_at (location, "%<::%D%> has not been declared", name);
3786 suggest_alternatives_for (location, name, true);