* decl.c (poplevel): Don't warn about unused vars in template scope.
[official-gcc.git] / gcc / cp / decl.c
blob12a9f43de2f809b3aa759dd2b036d814eaa66c27
1 /* Process declarations and variables for C++ compiler.
2 Copyright (C) 1988-2014 Free Software Foundation, Inc.
3 Contributed by Michael Tiemann (tiemann@cygnus.com)
5 This file is part of GCC.
7 GCC is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3, or (at your option)
10 any later version.
12 GCC is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING3. If not see
19 <http://www.gnu.org/licenses/>. */
22 /* Process declarations and symbol lookup for C++ front end.
23 Also constructs types; the standard scalar types at initialization,
24 and structure, union, array and enum types when they are declared. */
26 /* ??? not all decl nodes are given the most useful possible
27 line numbers. For example, the CONST_DECLs for enum values. */
29 #include "config.h"
30 #include "system.h"
31 #include "coretypes.h"
32 #include "tm.h"
33 #include "tree.h"
34 #include "stringpool.h"
35 #include "stor-layout.h"
36 #include "varasm.h"
37 #include "attribs.h"
38 #include "calls.h"
39 #include "flags.h"
40 #include "cp-tree.h"
41 #include "tree-iterator.h"
42 #include "tree-inline.h"
43 #include "decl.h"
44 #include "intl.h"
45 #include "toplev.h"
46 #include "hashtab.h"
47 #include "tm_p.h"
48 #include "target.h"
49 #include "c-family/c-common.h"
50 #include "c-family/c-objc.h"
51 #include "c-family/c-pragma.h"
52 #include "c-family/c-target.h"
53 #include "c-family/c-ubsan.h"
54 #include "diagnostic.h"
55 #include "intl.h"
56 #include "debug.h"
57 #include "timevar.h"
58 #include "splay-tree.h"
59 #include "plugin.h"
60 #include "cgraph.h"
61 #include "cilk.h"
62 #include "wide-int.h"
63 #include "builtins.h"
65 /* Possible cases of bad specifiers type used by bad_specifiers. */
66 enum bad_spec_place {
67 BSP_VAR, /* variable */
68 BSP_PARM, /* parameter */
69 BSP_TYPE, /* type */
70 BSP_FIELD /* field */
73 static tree grokparms (tree parmlist, tree *);
74 static const char *redeclaration_error_message (tree, tree);
76 static int decl_jump_unsafe (tree);
77 static void require_complete_types_for_parms (tree);
78 static int ambi_op_p (enum tree_code);
79 static int unary_op_p (enum tree_code);
80 static void push_local_name (tree);
81 static tree grok_reference_init (tree, tree, tree, int);
82 static tree grokvardecl (tree, tree, tree, const cp_decl_specifier_seq *,
83 int, int, int, tree);
84 static int check_static_variable_definition (tree, tree);
85 static void record_unknown_type (tree, const char *);
86 static tree builtin_function_1 (tree, tree, bool);
87 static int member_function_or_else (tree, tree, enum overload_flags);
88 static void bad_specifiers (tree, enum bad_spec_place, int, int, int, int,
89 int);
90 static void check_for_uninitialized_const_var (tree);
91 static hashval_t typename_hash (const void *);
92 static int typename_compare (const void *, const void *);
93 static tree local_variable_p_walkfn (tree *, int *, void *);
94 static tree record_builtin_java_type (const char *, int);
95 static const char *tag_name (enum tag_types);
96 static tree lookup_and_check_tag (enum tag_types, tree, tag_scope, bool);
97 static int walk_namespaces_r (tree, walk_namespaces_fn, void *);
98 static void maybe_deduce_size_from_array_init (tree, tree);
99 static void layout_var_decl (tree);
100 static tree check_initializer (tree, tree, int, vec<tree, va_gc> **);
101 static void make_rtl_for_nonlocal_decl (tree, tree, const char *);
102 static void save_function_data (tree);
103 static void copy_type_enum (tree , tree);
104 static void check_function_type (tree, tree);
105 static void finish_constructor_body (void);
106 static void begin_destructor_body (void);
107 static void finish_destructor_body (void);
108 static void record_key_method_defined (tree);
109 static tree create_array_type_for_decl (tree, tree, tree);
110 static tree get_atexit_node (void);
111 static tree get_dso_handle_node (void);
112 static tree start_cleanup_fn (void);
113 static void end_cleanup_fn (void);
114 static tree cp_make_fname_decl (location_t, tree, int);
115 static void initialize_predefined_identifiers (void);
116 static tree check_special_function_return_type
117 (special_function_kind, tree, tree);
118 static tree push_cp_library_fn (enum tree_code, tree, int);
119 static tree build_cp_library_fn (tree, enum tree_code, tree, int);
120 static void store_parm_decls (tree);
121 static void initialize_local_var (tree, tree);
122 static void expand_static_init (tree, tree);
124 /* The following symbols are subsumed in the cp_global_trees array, and
125 listed here individually for documentation purposes.
127 C++ extensions
128 tree wchar_decl_node;
130 tree vtable_entry_type;
131 tree delta_type_node;
132 tree __t_desc_type_node;
134 tree class_type_node;
135 tree unknown_type_node;
137 Array type `vtable_entry_type[]'
139 tree vtbl_type_node;
140 tree vtbl_ptr_type_node;
142 Namespaces,
144 tree std_node;
145 tree abi_node;
147 A FUNCTION_DECL which can call `abort'. Not necessarily the
148 one that the user will declare, but sufficient to be called
149 by routines that want to abort the program.
151 tree abort_fndecl;
153 The FUNCTION_DECL for the default `::operator delete'.
155 tree global_delete_fndecl;
157 Used by RTTI
158 tree type_info_type_node, tinfo_decl_id, tinfo_decl_type;
159 tree tinfo_var_id; */
161 tree cp_global_trees[CPTI_MAX];
163 /* Indicates that there is a type value in some namespace, although
164 that is not necessarily in scope at the moment. */
166 tree global_type_node;
168 /* The node that holds the "name" of the global scope. */
169 tree global_scope_name;
171 #define local_names cp_function_chain->x_local_names
173 /* A list of objects which have constructors or destructors
174 which reside in the global scope. The decl is stored in
175 the TREE_VALUE slot and the initializer is stored
176 in the TREE_PURPOSE slot. */
177 tree static_aggregates;
179 /* Like static_aggregates, but for thread_local variables. */
180 tree tls_aggregates;
182 /* -- end of C++ */
184 /* A node for the integer constant 2. */
186 tree integer_two_node;
188 /* Used only for jumps to as-yet undefined labels, since jumps to
189 defined labels can have their validity checked immediately. */
191 struct GTY((chain_next ("%h.next"))) named_label_use_entry {
192 struct named_label_use_entry *next;
193 /* The binding level to which this entry is *currently* attached.
194 This is initially the binding level in which the goto appeared,
195 but is modified as scopes are closed. */
196 cp_binding_level *binding_level;
197 /* The head of the names list that was current when the goto appeared,
198 or the inner scope popped. These are the decls that will *not* be
199 skipped when jumping to the label. */
200 tree names_in_scope;
201 /* The location of the goto, for error reporting. */
202 location_t o_goto_locus;
203 /* True if an OpenMP structured block scope has been closed since
204 the goto appeared. This means that the branch from the label will
205 illegally exit an OpenMP scope. */
206 bool in_omp_scope;
209 /* A list of all LABEL_DECLs in the function that have names. Here so
210 we can clear out their names' definitions at the end of the
211 function, and so we can check the validity of jumps to these labels. */
213 struct GTY(()) named_label_entry {
214 /* The decl itself. */
215 tree label_decl;
217 /* The binding level to which the label is *currently* attached.
218 This is initially set to the binding level in which the label
219 is defined, but is modified as scopes are closed. */
220 cp_binding_level *binding_level;
221 /* The head of the names list that was current when the label was
222 defined, or the inner scope popped. These are the decls that will
223 be skipped when jumping to the label. */
224 tree names_in_scope;
225 /* A vector of all decls from all binding levels that would be
226 crossed by a backward branch to the label. */
227 vec<tree, va_gc> *bad_decls;
229 /* A list of uses of the label, before the label is defined. */
230 struct named_label_use_entry *uses;
232 /* The following bits are set after the label is defined, and are
233 updated as scopes are popped. They indicate that a backward jump
234 to the label will illegally enter a scope of the given flavor. */
235 bool in_try_scope;
236 bool in_catch_scope;
237 bool in_omp_scope;
240 #define named_labels cp_function_chain->x_named_labels
242 /* The number of function bodies which we are currently processing.
243 (Zero if we are at namespace scope, one inside the body of a
244 function, two inside the body of a function in a local class, etc.) */
245 int function_depth;
247 /* To avoid unwanted recursion, finish_function defers all mark_used calls
248 encountered during its execution until it finishes. */
249 bool defer_mark_used_calls;
250 vec<tree, va_gc> *deferred_mark_used_calls;
252 /* States indicating how grokdeclarator() should handle declspecs marked
253 with __attribute__((deprecated)). An object declared as
254 __attribute__((deprecated)) suppresses warnings of uses of other
255 deprecated items. */
256 enum deprecated_states deprecated_state = DEPRECATED_NORMAL;
259 /* A list of VAR_DECLs whose type was incomplete at the time the
260 variable was declared. */
262 typedef struct GTY(()) incomplete_var_d {
263 tree decl;
264 tree incomplete_type;
265 } incomplete_var;
268 static GTY(()) vec<incomplete_var, va_gc> *incomplete_vars;
270 /* Returns the kind of template specialization we are currently
271 processing, given that it's declaration contained N_CLASS_SCOPES
272 explicit scope qualifications. */
274 tmpl_spec_kind
275 current_tmpl_spec_kind (int n_class_scopes)
277 int n_template_parm_scopes = 0;
278 int seen_specialization_p = 0;
279 int innermost_specialization_p = 0;
280 cp_binding_level *b;
282 /* Scan through the template parameter scopes. */
283 for (b = current_binding_level;
284 b->kind == sk_template_parms;
285 b = b->level_chain)
287 /* If we see a specialization scope inside a parameter scope,
288 then something is wrong. That corresponds to a declaration
289 like:
291 template <class T> template <> ...
293 which is always invalid since [temp.expl.spec] forbids the
294 specialization of a class member template if the enclosing
295 class templates are not explicitly specialized as well. */
296 if (b->explicit_spec_p)
298 if (n_template_parm_scopes == 0)
299 innermost_specialization_p = 1;
300 else
301 seen_specialization_p = 1;
303 else if (seen_specialization_p == 1)
304 return tsk_invalid_member_spec;
306 ++n_template_parm_scopes;
309 /* Handle explicit instantiations. */
310 if (processing_explicit_instantiation)
312 if (n_template_parm_scopes != 0)
313 /* We've seen a template parameter list during an explicit
314 instantiation. For example:
316 template <class T> template void f(int);
318 This is erroneous. */
319 return tsk_invalid_expl_inst;
320 else
321 return tsk_expl_inst;
324 if (n_template_parm_scopes < n_class_scopes)
325 /* We've not seen enough template headers to match all the
326 specialized classes present. For example:
328 template <class T> void R<T>::S<T>::f(int);
330 This is invalid; there needs to be one set of template
331 parameters for each class. */
332 return tsk_insufficient_parms;
333 else if (n_template_parm_scopes == n_class_scopes)
334 /* We're processing a non-template declaration (even though it may
335 be a member of a template class.) For example:
337 template <class T> void S<T>::f(int);
339 The `class T' matches the `S<T>', leaving no template headers
340 corresponding to the `f'. */
341 return tsk_none;
342 else if (n_template_parm_scopes > n_class_scopes + 1)
343 /* We've got too many template headers. For example:
345 template <> template <class T> void f (T);
347 There need to be more enclosing classes. */
348 return tsk_excessive_parms;
349 else
350 /* This must be a template. It's of the form:
352 template <class T> template <class U> void S<T>::f(U);
354 This is a specialization if the innermost level was a
355 specialization; otherwise it's just a definition of the
356 template. */
357 return innermost_specialization_p ? tsk_expl_spec : tsk_template;
360 /* Exit the current scope. */
362 void
363 finish_scope (void)
365 poplevel (0, 0, 0);
368 /* When a label goes out of scope, check to see if that label was used
369 in a valid manner, and issue any appropriate warnings or errors. */
371 static void
372 pop_label (tree label, tree old_value)
374 if (!processing_template_decl)
376 if (DECL_INITIAL (label) == NULL_TREE)
378 location_t location;
380 error ("label %q+D used but not defined", label);
381 location = input_location;
382 /* FIXME want (LOCATION_FILE (input_location), (line)0) */
383 /* Avoid crashing later. */
384 define_label (location, DECL_NAME (label));
386 else
387 warn_for_unused_label (label);
390 SET_IDENTIFIER_LABEL_VALUE (DECL_NAME (label), old_value);
393 /* At the end of a function, all labels declared within the function
394 go out of scope. BLOCK is the top-level block for the
395 function. */
397 static int
398 pop_labels_1 (void **slot, void *data)
400 struct named_label_entry *ent = (struct named_label_entry *) *slot;
401 tree block = (tree) data;
403 pop_label (ent->label_decl, NULL_TREE);
405 /* Put the labels into the "variables" of the top-level block,
406 so debugger can see them. */
407 DECL_CHAIN (ent->label_decl) = BLOCK_VARS (block);
408 BLOCK_VARS (block) = ent->label_decl;
410 htab_clear_slot (named_labels, slot);
412 return 1;
415 static void
416 pop_labels (tree block)
418 if (named_labels)
420 htab_traverse (named_labels, pop_labels_1, block);
421 named_labels = NULL;
425 /* At the end of a block with local labels, restore the outer definition. */
427 static void
428 pop_local_label (tree label, tree old_value)
430 struct named_label_entry dummy;
431 void **slot;
433 pop_label (label, old_value);
435 dummy.label_decl = label;
436 slot = htab_find_slot (named_labels, &dummy, NO_INSERT);
437 htab_clear_slot (named_labels, slot);
440 /* The following two routines are used to interface to Objective-C++.
441 The binding level is purposely treated as an opaque type. */
443 void *
444 objc_get_current_scope (void)
446 return current_binding_level;
449 /* The following routine is used by the NeXT-style SJLJ exceptions;
450 variables get marked 'volatile' so as to not be clobbered by
451 _setjmp()/_longjmp() calls. All variables in the current scope,
452 as well as parent scopes up to (but not including) ENCLOSING_BLK
453 shall be thusly marked. */
455 void
456 objc_mark_locals_volatile (void *enclosing_blk)
458 cp_binding_level *scope;
460 for (scope = current_binding_level;
461 scope && scope != enclosing_blk;
462 scope = scope->level_chain)
464 tree decl;
466 for (decl = scope->names; decl; decl = TREE_CHAIN (decl))
467 objc_volatilize_decl (decl);
469 /* Do not climb up past the current function. */
470 if (scope->kind == sk_function_parms)
471 break;
475 /* Update data for defined and undefined labels when leaving a scope. */
477 static int
478 poplevel_named_label_1 (void **slot, void *data)
480 struct named_label_entry *ent = (struct named_label_entry *) *slot;
481 cp_binding_level *bl = (cp_binding_level *) data;
482 cp_binding_level *obl = bl->level_chain;
484 if (ent->binding_level == bl)
486 tree decl;
488 /* ENT->NAMES_IN_SCOPE may contain a mixture of DECLs and
489 TREE_LISTs representing OVERLOADs, so be careful. */
490 for (decl = ent->names_in_scope; decl; decl = (DECL_P (decl)
491 ? DECL_CHAIN (decl)
492 : TREE_CHAIN (decl)))
493 if (decl_jump_unsafe (decl))
494 vec_safe_push (ent->bad_decls, decl);
496 ent->binding_level = obl;
497 ent->names_in_scope = obl->names;
498 switch (bl->kind)
500 case sk_try:
501 ent->in_try_scope = true;
502 break;
503 case sk_catch:
504 ent->in_catch_scope = true;
505 break;
506 case sk_omp:
507 ent->in_omp_scope = true;
508 break;
509 default:
510 break;
513 else if (ent->uses)
515 struct named_label_use_entry *use;
517 for (use = ent->uses; use ; use = use->next)
518 if (use->binding_level == bl)
520 use->binding_level = obl;
521 use->names_in_scope = obl->names;
522 if (bl->kind == sk_omp)
523 use->in_omp_scope = true;
527 return 1;
530 /* Saved errorcount to avoid -Wunused-but-set-{parameter,variable} warnings
531 when errors were reported, except for -Werror-unused-but-set-*. */
532 static int unused_but_set_errorcount;
534 /* Exit a binding level.
535 Pop the level off, and restore the state of the identifier-decl mappings
536 that were in effect when this level was entered.
538 If KEEP == 1, this level had explicit declarations, so
539 and create a "block" (a BLOCK node) for the level
540 to record its declarations and subblocks for symbol table output.
542 If FUNCTIONBODY is nonzero, this level is the body of a function,
543 so create a block as if KEEP were set and also clear out all
544 label names.
546 If REVERSE is nonzero, reverse the order of decls before putting
547 them into the BLOCK. */
549 tree
550 poplevel (int keep, int reverse, int functionbody)
552 tree link;
553 /* The chain of decls was accumulated in reverse order.
554 Put it into forward order, just for cleanliness. */
555 tree decls;
556 tree subblocks;
557 tree block;
558 tree decl;
559 int leaving_for_scope;
560 scope_kind kind;
561 unsigned ix;
562 cp_label_binding *label_bind;
564 bool subtime = timevar_cond_start (TV_NAME_LOOKUP);
565 restart:
567 block = NULL_TREE;
569 gcc_assert (current_binding_level->kind != sk_class);
571 if (current_binding_level->kind == sk_cleanup)
572 functionbody = 0;
573 subblocks = functionbody >= 0 ? current_binding_level->blocks : 0;
575 gcc_assert (!vec_safe_length (current_binding_level->class_shadowed));
577 /* We used to use KEEP == 2 to indicate that the new block should go
578 at the beginning of the list of blocks at this binding level,
579 rather than the end. This hack is no longer used. */
580 gcc_assert (keep == 0 || keep == 1);
582 if (current_binding_level->keep)
583 keep = 1;
585 /* Any uses of undefined labels, and any defined labels, now operate
586 under constraints of next binding contour. */
587 if (cfun && !functionbody && named_labels)
588 htab_traverse (named_labels, poplevel_named_label_1,
589 current_binding_level);
591 /* Get the decls in the order they were written.
592 Usually current_binding_level->names is in reverse order.
593 But parameter decls were previously put in forward order. */
595 if (reverse)
596 current_binding_level->names
597 = decls = nreverse (current_binding_level->names);
598 else
599 decls = current_binding_level->names;
601 /* If there were any declarations or structure tags in that level,
602 or if this level is a function body,
603 create a BLOCK to record them for the life of this function. */
604 block = NULL_TREE;
605 if (keep == 1 || functionbody)
606 block = make_node (BLOCK);
607 if (block != NULL_TREE)
609 BLOCK_VARS (block) = decls;
610 BLOCK_SUBBLOCKS (block) = subblocks;
613 /* In each subblock, record that this is its superior. */
614 if (keep >= 0)
615 for (link = subblocks; link; link = BLOCK_CHAIN (link))
616 BLOCK_SUPERCONTEXT (link) = block;
618 /* We still support the old for-scope rules, whereby the variables
619 in a for-init statement were in scope after the for-statement
620 ended. We only use the new rules if flag_new_for_scope is
621 nonzero. */
622 leaving_for_scope
623 = current_binding_level->kind == sk_for && flag_new_for_scope == 1;
625 /* Before we remove the declarations first check for unused variables. */
626 if ((warn_unused_variable || warn_unused_but_set_variable)
627 && current_binding_level->kind != sk_template_parms
628 && !processing_template_decl)
629 for (tree d = getdecls (); d; d = TREE_CHAIN (d))
631 /* There are cases where D itself is a TREE_LIST. See in
632 push_local_binding where the list of decls returned by
633 getdecls is built. */
634 decl = TREE_CODE (d) == TREE_LIST ? TREE_VALUE (d) : d;
635 // See through references for improved -Wunused-variable (PR 38958).
636 tree type = non_reference (TREE_TYPE (decl));
637 if (VAR_P (decl)
638 && (! TREE_USED (decl) || !DECL_READ_P (decl))
639 && ! DECL_IN_SYSTEM_HEADER (decl)
640 && DECL_NAME (decl) && ! DECL_ARTIFICIAL (decl)
641 && type != error_mark_node
642 && (!CLASS_TYPE_P (type)
643 || !TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type)
644 || lookup_attribute ("warn_unused",
645 TYPE_ATTRIBUTES (TREE_TYPE (decl)))))
647 if (! TREE_USED (decl))
648 warning (OPT_Wunused_variable, "unused variable %q+D", decl);
649 else if (DECL_CONTEXT (decl) == current_function_decl
650 // For -Wunused-but-set-variable leave references alone.
651 && TREE_CODE (TREE_TYPE (decl)) != REFERENCE_TYPE
652 && errorcount == unused_but_set_errorcount)
654 warning (OPT_Wunused_but_set_variable,
655 "variable %q+D set but not used", decl);
656 unused_but_set_errorcount = errorcount;
661 /* Remove declarations for all the DECLs in this level. */
662 for (link = decls; link; link = TREE_CHAIN (link))
664 if (leaving_for_scope && VAR_P (link)
665 /* It's hard to make this ARM compatibility hack play nicely with
666 lambdas, and it really isn't necessary in C++11 mode. */
667 && cxx_dialect < cxx11
668 && DECL_NAME (link))
670 tree name = DECL_NAME (link);
671 cxx_binding *ob;
672 tree ns_binding;
674 ob = outer_binding (name,
675 IDENTIFIER_BINDING (name),
676 /*class_p=*/true);
677 if (!ob)
678 ns_binding = IDENTIFIER_NAMESPACE_VALUE (name);
679 else
680 ns_binding = NULL_TREE;
682 if (ob && ob->scope == current_binding_level->level_chain)
683 /* We have something like:
685 int i;
686 for (int i; ;);
688 and we are leaving the `for' scope. There's no reason to
689 keep the binding of the inner `i' in this case. */
690 pop_binding (name, link);
691 else if ((ob && (TREE_CODE (ob->value) == TYPE_DECL))
692 || (ns_binding && TREE_CODE (ns_binding) == TYPE_DECL))
693 /* Here, we have something like:
695 typedef int I;
697 void f () {
698 for (int I; ;);
701 We must pop the for-scope binding so we know what's a
702 type and what isn't. */
703 pop_binding (name, link);
704 else
706 /* Mark this VAR_DECL as dead so that we can tell we left it
707 there only for backward compatibility. */
708 DECL_DEAD_FOR_LOCAL (link) = 1;
710 /* Keep track of what should have happened when we
711 popped the binding. */
712 if (ob && ob->value)
714 SET_DECL_SHADOWED_FOR_VAR (link, ob->value);
715 DECL_HAS_SHADOWED_FOR_VAR_P (link) = 1;
718 /* Add it to the list of dead variables in the next
719 outermost binding to that we can remove these when we
720 leave that binding. */
721 vec_safe_push (
722 current_binding_level->level_chain->dead_vars_from_for,
723 link);
725 /* Although we don't pop the cxx_binding, we do clear
726 its SCOPE since the scope is going away now. */
727 IDENTIFIER_BINDING (name)->scope
728 = current_binding_level->level_chain;
731 else
733 tree name;
735 /* Remove the binding. */
736 decl = link;
738 if (TREE_CODE (decl) == TREE_LIST)
739 decl = TREE_VALUE (decl);
740 name = decl;
742 if (TREE_CODE (name) == OVERLOAD)
743 name = OVL_FUNCTION (name);
745 gcc_assert (DECL_P (name));
746 pop_binding (DECL_NAME (name), decl);
750 /* Remove declarations for any `for' variables from inner scopes
751 that we kept around. */
752 FOR_EACH_VEC_SAFE_ELT_REVERSE (current_binding_level->dead_vars_from_for,
753 ix, decl)
754 pop_binding (DECL_NAME (decl), decl);
756 /* Restore the IDENTIFIER_TYPE_VALUEs. */
757 for (link = current_binding_level->type_shadowed;
758 link; link = TREE_CHAIN (link))
759 SET_IDENTIFIER_TYPE_VALUE (TREE_PURPOSE (link), TREE_VALUE (link));
761 /* Restore the IDENTIFIER_LABEL_VALUEs for local labels. */
762 FOR_EACH_VEC_SAFE_ELT_REVERSE (current_binding_level->shadowed_labels,
763 ix, label_bind)
764 pop_local_label (label_bind->label, label_bind->prev_value);
766 /* There may be OVERLOADs (wrapped in TREE_LISTs) on the BLOCK_VARs
767 list if a `using' declaration put them there. The debugging
768 back ends won't understand OVERLOAD, so we remove them here.
769 Because the BLOCK_VARS are (temporarily) shared with
770 CURRENT_BINDING_LEVEL->NAMES we must do this fixup after we have
771 popped all the bindings. */
772 if (block)
774 tree* d;
776 for (d = &BLOCK_VARS (block); *d; )
778 if (TREE_CODE (*d) == TREE_LIST)
779 *d = TREE_CHAIN (*d);
780 else
781 d = &DECL_CHAIN (*d);
785 /* If the level being exited is the top level of a function,
786 check over all the labels. */
787 if (functionbody)
789 /* Since this is the top level block of a function, the vars are
790 the function's parameters. Don't leave them in the BLOCK
791 because they are found in the FUNCTION_DECL instead. */
792 BLOCK_VARS (block) = 0;
793 pop_labels (block);
796 kind = current_binding_level->kind;
797 if (kind == sk_cleanup)
799 tree stmt;
801 /* If this is a temporary binding created for a cleanup, then we'll
802 have pushed a statement list level. Pop that, create a new
803 BIND_EXPR for the block, and insert it into the stream. */
804 stmt = pop_stmt_list (current_binding_level->statement_list);
805 stmt = c_build_bind_expr (input_location, block, stmt);
806 add_stmt (stmt);
809 leave_scope ();
810 if (functionbody)
812 /* The current function is being defined, so its DECL_INITIAL
813 should be error_mark_node. */
814 gcc_assert (DECL_INITIAL (current_function_decl) == error_mark_node);
815 DECL_INITIAL (current_function_decl) = block;
817 else if (block)
818 current_binding_level->blocks
819 = block_chainon (current_binding_level->blocks, block);
821 /* If we did not make a block for the level just exited,
822 any blocks made for inner levels
823 (since they cannot be recorded as subblocks in that level)
824 must be carried forward so they will later become subblocks
825 of something else. */
826 else if (subblocks)
827 current_binding_level->blocks
828 = block_chainon (current_binding_level->blocks, subblocks);
830 /* Each and every BLOCK node created here in `poplevel' is important
831 (e.g. for proper debugging information) so if we created one
832 earlier, mark it as "used". */
833 if (block)
834 TREE_USED (block) = 1;
836 /* All temporary bindings created for cleanups are popped silently. */
837 if (kind == sk_cleanup)
838 goto restart;
840 timevar_cond_stop (TV_NAME_LOOKUP, subtime);
841 return block;
844 /* Walk all the namespaces contained NAMESPACE, including NAMESPACE
845 itself, calling F for each. The DATA is passed to F as well. */
847 static int
848 walk_namespaces_r (tree name_space, walk_namespaces_fn f, void* data)
850 int result = 0;
851 tree current = NAMESPACE_LEVEL (name_space)->namespaces;
853 result |= (*f) (name_space, data);
855 for (; current; current = DECL_CHAIN (current))
856 result |= walk_namespaces_r (current, f, data);
858 return result;
861 /* Walk all the namespaces, calling F for each. The DATA is passed to
862 F as well. */
865 walk_namespaces (walk_namespaces_fn f, void* data)
867 return walk_namespaces_r (global_namespace, f, data);
870 /* Call wrapup_globals_declarations for the globals in NAMESPACE. If
871 DATA is non-NULL, this is the last time we will call
872 wrapup_global_declarations for this NAMESPACE. */
875 wrapup_globals_for_namespace (tree name_space, void* data)
877 cp_binding_level *level = NAMESPACE_LEVEL (name_space);
878 vec<tree, va_gc> *statics = level->static_decls;
879 tree *vec = statics->address ();
880 int len = statics->length ();
881 int last_time = (data != 0);
883 if (last_time)
885 check_global_declarations (vec, len);
886 emit_debug_global_declarations (vec, len);
887 return 0;
890 /* Write out any globals that need to be output. */
891 return wrapup_global_declarations (vec, len);
895 /* In C++, you don't have to write `struct S' to refer to `S'; you
896 can just use `S'. We accomplish this by creating a TYPE_DECL as
897 if the user had written `typedef struct S S'. Create and return
898 the TYPE_DECL for TYPE. */
900 tree
901 create_implicit_typedef (tree name, tree type)
903 tree decl;
905 decl = build_decl (input_location, TYPE_DECL, name, type);
906 DECL_ARTIFICIAL (decl) = 1;
907 /* There are other implicit type declarations, like the one *within*
908 a class that allows you to write `S::S'. We must distinguish
909 amongst these. */
910 SET_DECL_IMPLICIT_TYPEDEF_P (decl);
911 TYPE_NAME (type) = decl;
912 TYPE_STUB_DECL (type) = decl;
914 return decl;
917 /* Remember a local name for name-mangling purposes. */
919 static void
920 push_local_name (tree decl)
922 size_t i, nelts;
923 tree t, name;
925 timevar_start (TV_NAME_LOOKUP);
927 name = DECL_NAME (decl);
929 nelts = vec_safe_length (local_names);
930 for (i = 0; i < nelts; i++)
932 t = (*local_names)[i];
933 if (DECL_NAME (t) == name)
935 if (!DECL_LANG_SPECIFIC (decl))
936 retrofit_lang_decl (decl);
937 DECL_LANG_SPECIFIC (decl)->u.base.u2sel = 1;
938 if (DECL_DISCRIMINATOR_SET_P (t))
939 DECL_DISCRIMINATOR (decl) = DECL_DISCRIMINATOR (t) + 1;
940 else
941 DECL_DISCRIMINATOR (decl) = 1;
943 (*local_names)[i] = decl;
944 timevar_stop (TV_NAME_LOOKUP);
945 return;
949 vec_safe_push (local_names, decl);
950 timevar_stop (TV_NAME_LOOKUP);
953 /* Subroutine of duplicate_decls: return truthvalue of whether
954 or not types of these decls match.
956 For C++, we must compare the parameter list so that `int' can match
957 `int&' in a parameter position, but `int&' is not confused with
958 `const int&'. */
961 decls_match (tree newdecl, tree olddecl)
963 int types_match;
965 if (newdecl == olddecl)
966 return 1;
968 if (TREE_CODE (newdecl) != TREE_CODE (olddecl))
969 /* If the two DECLs are not even the same kind of thing, we're not
970 interested in their types. */
971 return 0;
973 gcc_assert (DECL_P (newdecl));
975 if (TREE_CODE (newdecl) == FUNCTION_DECL)
977 tree f1 = TREE_TYPE (newdecl);
978 tree f2 = TREE_TYPE (olddecl);
979 tree p1 = TYPE_ARG_TYPES (f1);
980 tree p2 = TYPE_ARG_TYPES (f2);
981 tree r2;
983 /* Specializations of different templates are different functions
984 even if they have the same type. */
985 tree t1 = (DECL_USE_TEMPLATE (newdecl)
986 ? DECL_TI_TEMPLATE (newdecl)
987 : NULL_TREE);
988 tree t2 = (DECL_USE_TEMPLATE (olddecl)
989 ? DECL_TI_TEMPLATE (olddecl)
990 : NULL_TREE);
991 if (t1 != t2)
992 return 0;
994 if (CP_DECL_CONTEXT (newdecl) != CP_DECL_CONTEXT (olddecl)
995 && ! (DECL_EXTERN_C_P (newdecl)
996 && DECL_EXTERN_C_P (olddecl)))
997 return 0;
999 /* A new declaration doesn't match a built-in one unless it
1000 is also extern "C". */
1001 if (DECL_IS_BUILTIN (olddecl)
1002 && DECL_EXTERN_C_P (olddecl) && !DECL_EXTERN_C_P (newdecl))
1003 return 0;
1005 if (TREE_CODE (f1) != TREE_CODE (f2))
1006 return 0;
1008 /* A declaration with deduced return type should use its pre-deduction
1009 type for declaration matching. */
1010 r2 = fndecl_declared_return_type (olddecl);
1012 if (same_type_p (TREE_TYPE (f1), r2))
1014 if (!prototype_p (f2) && DECL_EXTERN_C_P (olddecl)
1015 && (DECL_BUILT_IN (olddecl)
1016 #ifndef NO_IMPLICIT_EXTERN_C
1017 || (DECL_IN_SYSTEM_HEADER (newdecl) && !DECL_CLASS_SCOPE_P (newdecl))
1018 || (DECL_IN_SYSTEM_HEADER (olddecl) && !DECL_CLASS_SCOPE_P (olddecl))
1019 #endif
1022 types_match = self_promoting_args_p (p1);
1023 if (p1 == void_list_node)
1024 TREE_TYPE (newdecl) = TREE_TYPE (olddecl);
1026 #ifndef NO_IMPLICIT_EXTERN_C
1027 else if (!prototype_p (f1)
1028 && (DECL_EXTERN_C_P (olddecl)
1029 && DECL_IN_SYSTEM_HEADER (olddecl)
1030 && !DECL_CLASS_SCOPE_P (olddecl))
1031 && (DECL_EXTERN_C_P (newdecl)
1032 && DECL_IN_SYSTEM_HEADER (newdecl)
1033 && !DECL_CLASS_SCOPE_P (newdecl)))
1035 types_match = self_promoting_args_p (p2);
1036 TREE_TYPE (newdecl) = TREE_TYPE (olddecl);
1038 #endif
1039 else
1040 types_match =
1041 compparms (p1, p2)
1042 && type_memfn_rqual (f1) == type_memfn_rqual (f2)
1043 && (TYPE_ATTRIBUTES (TREE_TYPE (newdecl)) == NULL_TREE
1044 || comp_type_attributes (TREE_TYPE (newdecl),
1045 TREE_TYPE (olddecl)) != 0);
1047 else
1048 types_match = 0;
1050 /* The decls dont match if they correspond to two different versions
1051 of the same function. Disallow extern "C" functions to be
1052 versions for now. */
1053 if (types_match
1054 && !DECL_EXTERN_C_P (newdecl)
1055 && !DECL_EXTERN_C_P (olddecl)
1056 && targetm.target_option.function_versions (newdecl, olddecl))
1058 /* Mark functions as versions if necessary. Modify the mangled decl
1059 name if necessary. */
1060 if (DECL_FUNCTION_VERSIONED (newdecl)
1061 && DECL_FUNCTION_VERSIONED (olddecl))
1062 return 0;
1063 if (!DECL_FUNCTION_VERSIONED (newdecl))
1065 DECL_FUNCTION_VERSIONED (newdecl) = 1;
1066 if (DECL_ASSEMBLER_NAME_SET_P (newdecl))
1067 mangle_decl (newdecl);
1069 if (!DECL_FUNCTION_VERSIONED (olddecl))
1071 DECL_FUNCTION_VERSIONED (olddecl) = 1;
1072 if (DECL_ASSEMBLER_NAME_SET_P (olddecl))
1073 mangle_decl (olddecl);
1075 cgraph_node::record_function_versions (olddecl, newdecl);
1076 return 0;
1079 else if (TREE_CODE (newdecl) == TEMPLATE_DECL)
1081 if (TREE_CODE (DECL_TEMPLATE_RESULT (newdecl))
1082 != TREE_CODE (DECL_TEMPLATE_RESULT (olddecl)))
1083 return 0;
1085 if (!comp_template_parms (DECL_TEMPLATE_PARMS (newdecl),
1086 DECL_TEMPLATE_PARMS (olddecl)))
1087 return 0;
1089 if (TREE_CODE (DECL_TEMPLATE_RESULT (newdecl)) == TYPE_DECL)
1090 types_match = same_type_p (TREE_TYPE (DECL_TEMPLATE_RESULT (olddecl)),
1091 TREE_TYPE (DECL_TEMPLATE_RESULT (newdecl)));
1092 else
1093 types_match = decls_match (DECL_TEMPLATE_RESULT (olddecl),
1094 DECL_TEMPLATE_RESULT (newdecl));
1096 else
1098 /* Need to check scope for variable declaration (VAR_DECL).
1099 For typedef (TYPE_DECL), scope is ignored. */
1100 if (VAR_P (newdecl)
1101 && CP_DECL_CONTEXT (newdecl) != CP_DECL_CONTEXT (olddecl)
1102 /* [dcl.link]
1103 Two declarations for an object with C language linkage
1104 with the same name (ignoring the namespace that qualify
1105 it) that appear in different namespace scopes refer to
1106 the same object. */
1107 && !(DECL_EXTERN_C_P (olddecl) && DECL_EXTERN_C_P (newdecl)))
1108 return 0;
1110 if (TREE_TYPE (newdecl) == error_mark_node)
1111 types_match = TREE_TYPE (olddecl) == error_mark_node;
1112 else if (TREE_TYPE (olddecl) == NULL_TREE)
1113 types_match = TREE_TYPE (newdecl) == NULL_TREE;
1114 else if (TREE_TYPE (newdecl) == NULL_TREE)
1115 types_match = 0;
1116 else
1117 types_match = comptypes (TREE_TYPE (newdecl),
1118 TREE_TYPE (olddecl),
1119 COMPARE_REDECLARATION);
1122 return types_match;
1125 /* If NEWDECL is `static' and an `extern' was seen previously,
1126 warn about it. OLDDECL is the previous declaration.
1128 Note that this does not apply to the C++ case of declaring
1129 a variable `extern const' and then later `const'.
1131 Don't complain about built-in functions, since they are beyond
1132 the user's control. */
1134 void
1135 warn_extern_redeclared_static (tree newdecl, tree olddecl)
1137 if (TREE_CODE (newdecl) == TYPE_DECL
1138 || TREE_CODE (newdecl) == TEMPLATE_DECL
1139 || TREE_CODE (newdecl) == CONST_DECL
1140 || TREE_CODE (newdecl) == NAMESPACE_DECL)
1141 return;
1143 /* Don't get confused by static member functions; that's a different
1144 use of `static'. */
1145 if (TREE_CODE (newdecl) == FUNCTION_DECL
1146 && DECL_STATIC_FUNCTION_P (newdecl))
1147 return;
1149 /* If the old declaration was `static', or the new one isn't, then
1150 everything is OK. */
1151 if (DECL_THIS_STATIC (olddecl) || !DECL_THIS_STATIC (newdecl))
1152 return;
1154 /* It's OK to declare a builtin function as `static'. */
1155 if (TREE_CODE (olddecl) == FUNCTION_DECL
1156 && DECL_ARTIFICIAL (olddecl))
1157 return;
1159 if (permerror (input_location,
1160 "%qD was declared %<extern%> and later %<static%>", newdecl))
1161 inform (input_location, "previous declaration of %q+D", olddecl);
1164 /* NEW_DECL is a redeclaration of OLD_DECL; both are functions or
1165 function templates. If their exception specifications do not
1166 match, issue a diagnostic. */
1168 static void
1169 check_redeclaration_exception_specification (tree new_decl,
1170 tree old_decl)
1172 tree new_exceptions = TYPE_RAISES_EXCEPTIONS (TREE_TYPE (new_decl));
1173 tree old_exceptions = TYPE_RAISES_EXCEPTIONS (TREE_TYPE (old_decl));
1175 /* Two default specs are equivalent, don't force evaluation. */
1176 if (UNEVALUATED_NOEXCEPT_SPEC_P (new_exceptions)
1177 && UNEVALUATED_NOEXCEPT_SPEC_P (old_exceptions))
1178 return;
1180 maybe_instantiate_noexcept (new_decl);
1181 maybe_instantiate_noexcept (old_decl);
1182 new_exceptions = TYPE_RAISES_EXCEPTIONS (TREE_TYPE (new_decl));
1183 old_exceptions = TYPE_RAISES_EXCEPTIONS (TREE_TYPE (old_decl));
1185 /* [except.spec]
1187 If any declaration of a function has an exception-specification,
1188 all declarations, including the definition and an explicit
1189 specialization, of that function shall have an
1190 exception-specification with the same set of type-ids. */
1191 if ((pedantic || ! DECL_IN_SYSTEM_HEADER (old_decl))
1192 && ! DECL_IS_BUILTIN (old_decl)
1193 && flag_exceptions
1194 && !comp_except_specs (new_exceptions, old_exceptions, ce_normal))
1196 error ("declaration of %qF has a different exception specifier",
1197 new_decl);
1198 error ("from previous declaration %q+F", old_decl);
1202 /* Return true if OLD_DECL and NEW_DECL agree on constexprness.
1203 Otherwise issue diagnostics. */
1205 static bool
1206 validate_constexpr_redeclaration (tree old_decl, tree new_decl)
1208 old_decl = STRIP_TEMPLATE (old_decl);
1209 new_decl = STRIP_TEMPLATE (new_decl);
1210 if (!VAR_OR_FUNCTION_DECL_P (old_decl)
1211 || !VAR_OR_FUNCTION_DECL_P (new_decl))
1212 return true;
1213 if (DECL_DECLARED_CONSTEXPR_P (old_decl)
1214 == DECL_DECLARED_CONSTEXPR_P (new_decl))
1215 return true;
1216 if (TREE_CODE (old_decl) == FUNCTION_DECL)
1218 if (DECL_BUILT_IN (old_decl))
1220 /* Hide a built-in declaration. */
1221 DECL_DECLARED_CONSTEXPR_P (old_decl)
1222 = DECL_DECLARED_CONSTEXPR_P (new_decl);
1223 return true;
1225 /* 7.1.5 [dcl.constexpr]
1226 Note: An explicit specialization can differ from the template
1227 declaration with respect to the constexpr specifier. */
1228 if (! DECL_TEMPLATE_SPECIALIZATION (old_decl)
1229 && DECL_TEMPLATE_SPECIALIZATION (new_decl))
1230 return true;
1232 error ("redeclaration %qD differs in %<constexpr%>", new_decl);
1233 error ("from previous declaration %q+D", old_decl);
1234 return false;
1236 return true;
1239 /* DECL is a redeclaration of a function or function template. If
1240 it does have default arguments issue a diagnostic. Note: this
1241 function is used to enforce the requirements in C++11 8.3.6 about
1242 no default arguments in redeclarations. */
1244 static void
1245 check_redeclaration_no_default_args (tree decl)
1247 gcc_assert (DECL_DECLARES_FUNCTION_P (decl));
1249 for (tree t = FUNCTION_FIRST_USER_PARMTYPE (decl);
1250 t && t != void_list_node; t = TREE_CHAIN (t))
1251 if (TREE_PURPOSE (t))
1253 permerror (input_location,
1254 "redeclaration of %q#D may not have default "
1255 "arguments", decl);
1256 return;
1260 #define GNU_INLINE_P(fn) (DECL_DECLARED_INLINE_P (fn) \
1261 && lookup_attribute ("gnu_inline", \
1262 DECL_ATTRIBUTES (fn)))
1264 /* If NEWDECL is a redeclaration of OLDDECL, merge the declarations.
1265 If the redeclaration is invalid, a diagnostic is issued, and the
1266 error_mark_node is returned. Otherwise, OLDDECL is returned.
1268 If NEWDECL is not a redeclaration of OLDDECL, NULL_TREE is
1269 returned.
1271 NEWDECL_IS_FRIEND is true if NEWDECL was declared as a friend. */
1273 tree
1274 duplicate_decls (tree newdecl, tree olddecl, bool newdecl_is_friend)
1276 unsigned olddecl_uid = DECL_UID (olddecl);
1277 int olddecl_friend = 0, types_match = 0, hidden_friend = 0;
1278 int new_defines_function = 0;
1279 tree new_template_info;
1281 if (newdecl == olddecl)
1282 return olddecl;
1284 types_match = decls_match (newdecl, olddecl);
1286 /* If either the type of the new decl or the type of the old decl is an
1287 error_mark_node, then that implies that we have already issued an
1288 error (earlier) for some bogus type specification, and in that case,
1289 it is rather pointless to harass the user with yet more error message
1290 about the same declaration, so just pretend the types match here. */
1291 if (TREE_TYPE (newdecl) == error_mark_node
1292 || TREE_TYPE (olddecl) == error_mark_node)
1293 return error_mark_node;
1295 if (UDLIT_OPER_P (DECL_NAME (newdecl))
1296 && UDLIT_OPER_P (DECL_NAME (olddecl)))
1298 if (TREE_CODE (newdecl) == TEMPLATE_DECL
1299 && TREE_CODE (olddecl) != TEMPLATE_DECL
1300 && check_raw_literal_operator (olddecl))
1301 error ("literal operator template %q+D conflicts with"
1302 " raw literal operator %qD", newdecl, olddecl);
1303 else if (TREE_CODE (newdecl) != TEMPLATE_DECL
1304 && TREE_CODE (olddecl) == TEMPLATE_DECL
1305 && check_raw_literal_operator (newdecl))
1306 error ("raw literal operator %q+D conflicts with"
1307 " literal operator template %qD", newdecl, olddecl);
1310 if (DECL_P (olddecl)
1311 && TREE_CODE (newdecl) == FUNCTION_DECL
1312 && TREE_CODE (olddecl) == FUNCTION_DECL
1313 && (DECL_UNINLINABLE (newdecl) || DECL_UNINLINABLE (olddecl)))
1315 if (DECL_DECLARED_INLINE_P (newdecl)
1316 && DECL_UNINLINABLE (newdecl)
1317 && lookup_attribute ("noinline", DECL_ATTRIBUTES (newdecl)))
1318 /* Already warned elsewhere. */;
1319 else if (DECL_DECLARED_INLINE_P (olddecl)
1320 && DECL_UNINLINABLE (olddecl)
1321 && lookup_attribute ("noinline", DECL_ATTRIBUTES (olddecl)))
1322 /* Already warned. */;
1323 else if (DECL_DECLARED_INLINE_P (newdecl)
1324 && DECL_UNINLINABLE (olddecl)
1325 && lookup_attribute ("noinline", DECL_ATTRIBUTES (olddecl)))
1327 if (warning (OPT_Wattributes, "function %q+D redeclared as inline",
1328 newdecl))
1329 inform (DECL_SOURCE_LOCATION (olddecl),
1330 "previous declaration of %qD with attribute noinline",
1331 olddecl);
1333 else if (DECL_DECLARED_INLINE_P (olddecl)
1334 && DECL_UNINLINABLE (newdecl)
1335 && lookup_attribute ("noinline", DECL_ATTRIBUTES (newdecl)))
1337 if (warning (OPT_Wattributes, "function %q+D redeclared with "
1338 "attribute noinline", newdecl))
1339 inform (DECL_SOURCE_LOCATION (olddecl),
1340 "previous declaration of %qD was inline",
1341 olddecl);
1345 /* Check for redeclaration and other discrepancies. */
1346 if (TREE_CODE (olddecl) == FUNCTION_DECL
1347 && DECL_ARTIFICIAL (olddecl))
1349 gcc_assert (!DECL_HIDDEN_FRIEND_P (olddecl));
1350 if (TREE_CODE (newdecl) != FUNCTION_DECL)
1352 /* Avoid warnings redeclaring built-ins which have not been
1353 explicitly declared. */
1354 if (DECL_ANTICIPATED (olddecl))
1355 return NULL_TREE;
1357 /* If you declare a built-in or predefined function name as static,
1358 the old definition is overridden, but optionally warn this was a
1359 bad choice of name. */
1360 if (! TREE_PUBLIC (newdecl))
1362 warning (OPT_Wshadow,
1363 DECL_BUILT_IN (olddecl)
1364 ? G_("shadowing built-in function %q#D")
1365 : G_("shadowing library function %q#D"), olddecl);
1366 /* Discard the old built-in function. */
1367 return NULL_TREE;
1369 /* If the built-in is not ansi, then programs can override
1370 it even globally without an error. */
1371 else if (! DECL_BUILT_IN (olddecl))
1372 warning (0, "library function %q#D redeclared as non-function %q#D",
1373 olddecl, newdecl);
1374 else
1375 error ("declaration of %q#D conflicts with built-in "
1376 "declaration %q#D", newdecl, olddecl);
1377 return NULL_TREE;
1379 else if (DECL_OMP_DECLARE_REDUCTION_P (olddecl))
1381 gcc_assert (DECL_OMP_DECLARE_REDUCTION_P (newdecl));
1382 error_at (DECL_SOURCE_LOCATION (newdecl),
1383 "redeclaration of %<pragma omp declare reduction%>");
1384 inform (DECL_SOURCE_LOCATION (olddecl),
1385 "previous %<pragma omp declare reduction%> declaration");
1386 return error_mark_node;
1388 else if (!types_match)
1390 /* Avoid warnings redeclaring built-ins which have not been
1391 explicitly declared. */
1392 if (DECL_ANTICIPATED (olddecl))
1394 /* Deal with fileptr_type_node. FILE type is not known
1395 at the time we create the builtins. */
1396 tree t1, t2;
1398 for (t1 = TYPE_ARG_TYPES (TREE_TYPE (newdecl)),
1399 t2 = TYPE_ARG_TYPES (TREE_TYPE (olddecl));
1400 t1 || t2;
1401 t1 = TREE_CHAIN (t1), t2 = TREE_CHAIN (t2))
1402 if (!t1 || !t2)
1403 break;
1404 else if (TREE_VALUE (t2) == fileptr_type_node)
1406 tree t = TREE_VALUE (t1);
1408 if (TYPE_PTR_P (t)
1409 && TYPE_IDENTIFIER (TREE_TYPE (t))
1410 == get_identifier ("FILE")
1411 && compparms (TREE_CHAIN (t1), TREE_CHAIN (t2)))
1413 tree oldargs = TYPE_ARG_TYPES (TREE_TYPE (olddecl));
1415 TYPE_ARG_TYPES (TREE_TYPE (olddecl))
1416 = TYPE_ARG_TYPES (TREE_TYPE (newdecl));
1417 types_match = decls_match (newdecl, olddecl);
1418 if (types_match)
1419 return duplicate_decls (newdecl, olddecl,
1420 newdecl_is_friend);
1421 TYPE_ARG_TYPES (TREE_TYPE (olddecl)) = oldargs;
1424 else if (! same_type_p (TREE_VALUE (t1), TREE_VALUE (t2)))
1425 break;
1427 else if ((DECL_EXTERN_C_P (newdecl)
1428 && DECL_EXTERN_C_P (olddecl))
1429 || compparms (TYPE_ARG_TYPES (TREE_TYPE (newdecl)),
1430 TYPE_ARG_TYPES (TREE_TYPE (olddecl))))
1432 /* A near match; override the builtin. */
1434 if (TREE_PUBLIC (newdecl))
1435 warning (0, "new declaration %q#D ambiguates built-in "
1436 "declaration %q#D", newdecl, olddecl);
1437 else
1438 warning (OPT_Wshadow,
1439 DECL_BUILT_IN (olddecl)
1440 ? G_("shadowing built-in function %q#D")
1441 : G_("shadowing library function %q#D"), olddecl);
1443 else
1444 /* Discard the old built-in function. */
1445 return NULL_TREE;
1447 /* Replace the old RTL to avoid problems with inlining. */
1448 COPY_DECL_RTL (newdecl, olddecl);
1450 /* Even if the types match, prefer the new declarations type for
1451 built-ins which have not been explicitly declared, for
1452 exception lists, etc... */
1453 else if (DECL_IS_BUILTIN (olddecl))
1455 tree type = TREE_TYPE (newdecl);
1456 tree attribs = (*targetm.merge_type_attributes)
1457 (TREE_TYPE (olddecl), type);
1459 type = cp_build_type_attribute_variant (type, attribs);
1460 TREE_TYPE (newdecl) = TREE_TYPE (olddecl) = type;
1463 /* If a function is explicitly declared "throw ()", propagate that to
1464 the corresponding builtin. */
1465 if (DECL_BUILT_IN_CLASS (olddecl) == BUILT_IN_NORMAL
1466 && DECL_ANTICIPATED (olddecl)
1467 && TREE_NOTHROW (newdecl)
1468 && !TREE_NOTHROW (olddecl))
1470 enum built_in_function fncode = DECL_FUNCTION_CODE (olddecl);
1471 tree tmpdecl = builtin_decl_explicit (fncode);
1472 if (tmpdecl && tmpdecl != olddecl && types_match)
1473 TREE_NOTHROW (tmpdecl) = 1;
1476 /* Whether or not the builtin can throw exceptions has no
1477 bearing on this declarator. */
1478 TREE_NOTHROW (olddecl) = 0;
1480 if (DECL_THIS_STATIC (newdecl) && !DECL_THIS_STATIC (olddecl))
1482 /* If a builtin function is redeclared as `static', merge
1483 the declarations, but make the original one static. */
1484 DECL_THIS_STATIC (olddecl) = 1;
1485 TREE_PUBLIC (olddecl) = 0;
1487 /* Make the old declaration consistent with the new one so
1488 that all remnants of the builtin-ness of this function
1489 will be banished. */
1490 SET_DECL_LANGUAGE (olddecl, DECL_LANGUAGE (newdecl));
1491 COPY_DECL_RTL (newdecl, olddecl);
1494 else if (TREE_CODE (olddecl) != TREE_CODE (newdecl))
1496 /* C++ Standard, 3.3, clause 4:
1497 "[Note: a namespace name or a class template name must be unique
1498 in its declarative region (7.3.2, clause 14). ]" */
1499 if (TREE_CODE (olddecl) != NAMESPACE_DECL
1500 && TREE_CODE (newdecl) != NAMESPACE_DECL
1501 && (TREE_CODE (olddecl) != TEMPLATE_DECL
1502 || TREE_CODE (DECL_TEMPLATE_RESULT (olddecl)) != TYPE_DECL)
1503 && (TREE_CODE (newdecl) != TEMPLATE_DECL
1504 || TREE_CODE (DECL_TEMPLATE_RESULT (newdecl)) != TYPE_DECL))
1506 if ((TREE_CODE (olddecl) == TYPE_DECL && DECL_ARTIFICIAL (olddecl)
1507 && TREE_CODE (newdecl) != TYPE_DECL)
1508 || (TREE_CODE (newdecl) == TYPE_DECL && DECL_ARTIFICIAL (newdecl)
1509 && TREE_CODE (olddecl) != TYPE_DECL))
1511 /* We do nothing special here, because C++ does such nasty
1512 things with TYPE_DECLs. Instead, just let the TYPE_DECL
1513 get shadowed, and know that if we need to find a TYPE_DECL
1514 for a given name, we can look in the IDENTIFIER_TYPE_VALUE
1515 slot of the identifier. */
1516 return NULL_TREE;
1519 if ((TREE_CODE (newdecl) == FUNCTION_DECL
1520 && DECL_FUNCTION_TEMPLATE_P (olddecl))
1521 || (TREE_CODE (olddecl) == FUNCTION_DECL
1522 && DECL_FUNCTION_TEMPLATE_P (newdecl)))
1523 return NULL_TREE;
1526 error ("%q#D redeclared as different kind of symbol", newdecl);
1527 if (TREE_CODE (olddecl) == TREE_LIST)
1528 olddecl = TREE_VALUE (olddecl);
1529 inform (DECL_SOURCE_LOCATION (olddecl),
1530 "previous declaration %q#D", olddecl);
1532 return error_mark_node;
1534 else if (!types_match)
1536 if (CP_DECL_CONTEXT (newdecl) != CP_DECL_CONTEXT (olddecl))
1537 /* These are certainly not duplicate declarations; they're
1538 from different scopes. */
1539 return NULL_TREE;
1541 if (TREE_CODE (newdecl) == TEMPLATE_DECL)
1543 /* The name of a class template may not be declared to refer to
1544 any other template, class, function, object, namespace, value,
1545 or type in the same scope. */
1546 if (TREE_CODE (DECL_TEMPLATE_RESULT (olddecl)) == TYPE_DECL
1547 || TREE_CODE (DECL_TEMPLATE_RESULT (newdecl)) == TYPE_DECL)
1549 error ("conflicting declaration of template %q#D", newdecl);
1550 inform (DECL_SOURCE_LOCATION (olddecl),
1551 "previous declaration %q#D", olddecl);
1552 return error_mark_node;
1554 else if (TREE_CODE (DECL_TEMPLATE_RESULT (olddecl)) == FUNCTION_DECL
1555 && TREE_CODE (DECL_TEMPLATE_RESULT (newdecl)) == FUNCTION_DECL
1556 && compparms (TYPE_ARG_TYPES (TREE_TYPE (DECL_TEMPLATE_RESULT (olddecl))),
1557 TYPE_ARG_TYPES (TREE_TYPE (DECL_TEMPLATE_RESULT (newdecl))))
1558 && comp_template_parms (DECL_TEMPLATE_PARMS (newdecl),
1559 DECL_TEMPLATE_PARMS (olddecl))
1560 /* Template functions can be disambiguated by
1561 return type. */
1562 && same_type_p (TREE_TYPE (TREE_TYPE (newdecl)),
1563 TREE_TYPE (TREE_TYPE (olddecl))))
1565 error ("ambiguating new declaration %q#D", newdecl);
1566 inform (DECL_SOURCE_LOCATION (olddecl),
1567 "old declaration %q#D", olddecl);
1569 return NULL_TREE;
1571 if (TREE_CODE (newdecl) == FUNCTION_DECL)
1573 if (DECL_EXTERN_C_P (newdecl) && DECL_EXTERN_C_P (olddecl))
1575 error ("conflicting declaration of C function %q#D",
1576 newdecl);
1577 inform (DECL_SOURCE_LOCATION (olddecl),
1578 "previous declaration %q#D", olddecl);
1579 return NULL_TREE;
1581 /* For function versions, params and types match, but they
1582 are not ambiguous. */
1583 else if ((!DECL_FUNCTION_VERSIONED (newdecl)
1584 && !DECL_FUNCTION_VERSIONED (olddecl))
1585 && compparms (TYPE_ARG_TYPES (TREE_TYPE (newdecl)),
1586 TYPE_ARG_TYPES (TREE_TYPE (olddecl))))
1588 error ("ambiguating new declaration of %q#D", newdecl);
1589 inform (DECL_SOURCE_LOCATION (olddecl),
1590 "old declaration %q#D", olddecl);
1591 return error_mark_node;
1593 else
1594 return NULL_TREE;
1596 else
1598 error ("conflicting declaration %q#D", newdecl);
1599 inform (DECL_SOURCE_LOCATION (olddecl),
1600 "previous declaration as %q#D", olddecl);
1601 return error_mark_node;
1604 else if (TREE_CODE (newdecl) == FUNCTION_DECL
1605 && ((DECL_TEMPLATE_SPECIALIZATION (olddecl)
1606 && (!DECL_TEMPLATE_INFO (newdecl)
1607 || (DECL_TI_TEMPLATE (newdecl)
1608 != DECL_TI_TEMPLATE (olddecl))))
1609 || (DECL_TEMPLATE_SPECIALIZATION (newdecl)
1610 && (!DECL_TEMPLATE_INFO (olddecl)
1611 || (DECL_TI_TEMPLATE (olddecl)
1612 != DECL_TI_TEMPLATE (newdecl))))))
1613 /* It's OK to have a template specialization and a non-template
1614 with the same type, or to have specializations of two
1615 different templates with the same type. Note that if one is a
1616 specialization, and the other is an instantiation of the same
1617 template, that we do not exit at this point. That situation
1618 can occur if we instantiate a template class, and then
1619 specialize one of its methods. This situation is valid, but
1620 the declarations must be merged in the usual way. */
1621 return NULL_TREE;
1622 else if (TREE_CODE (newdecl) == FUNCTION_DECL
1623 && ((DECL_TEMPLATE_INSTANTIATION (olddecl)
1624 && !DECL_USE_TEMPLATE (newdecl))
1625 || (DECL_TEMPLATE_INSTANTIATION (newdecl)
1626 && !DECL_USE_TEMPLATE (olddecl))))
1627 /* One of the declarations is a template instantiation, and the
1628 other is not a template at all. That's OK. */
1629 return NULL_TREE;
1630 else if (TREE_CODE (newdecl) == NAMESPACE_DECL)
1632 /* In [namespace.alias] we have:
1634 In a declarative region, a namespace-alias-definition can be
1635 used to redefine a namespace-alias declared in that declarative
1636 region to refer only to the namespace to which it already
1637 refers.
1639 Therefore, if we encounter a second alias directive for the same
1640 alias, we can just ignore the second directive. */
1641 if (DECL_NAMESPACE_ALIAS (newdecl)
1642 && (DECL_NAMESPACE_ALIAS (newdecl)
1643 == DECL_NAMESPACE_ALIAS (olddecl)))
1644 return olddecl;
1645 /* [namespace.alias]
1647 A namespace-name or namespace-alias shall not be declared as
1648 the name of any other entity in the same declarative region.
1649 A namespace-name defined at global scope shall not be
1650 declared as the name of any other entity in any global scope
1651 of the program. */
1652 error ("conflicting declaration of namespace %qD", newdecl);
1653 inform (DECL_SOURCE_LOCATION (olddecl),
1654 "previous declaration of namespace %qD here", olddecl);
1655 return error_mark_node;
1657 else
1659 const char *errmsg = redeclaration_error_message (newdecl, olddecl);
1660 if (errmsg)
1662 error_at (DECL_SOURCE_LOCATION (newdecl), errmsg, newdecl);
1663 if (DECL_NAME (olddecl) != NULL_TREE)
1664 inform (input_location,
1665 (DECL_INITIAL (olddecl) && namespace_bindings_p ())
1666 ? G_("%q+#D previously defined here")
1667 : G_("%q+#D previously declared here"), olddecl);
1668 return error_mark_node;
1670 else if (TREE_CODE (olddecl) == FUNCTION_DECL
1671 && DECL_INITIAL (olddecl) != NULL_TREE
1672 && !prototype_p (TREE_TYPE (olddecl))
1673 && prototype_p (TREE_TYPE (newdecl)))
1675 /* Prototype decl follows defn w/o prototype. */
1676 if (warning_at (DECL_SOURCE_LOCATION (newdecl), 0,
1677 "prototype specified for %q#D", newdecl))
1678 inform (DECL_SOURCE_LOCATION (olddecl),
1679 "previous non-prototype definition here");
1681 else if (VAR_OR_FUNCTION_DECL_P (olddecl)
1682 && DECL_LANGUAGE (newdecl) != DECL_LANGUAGE (olddecl))
1684 /* [dcl.link]
1685 If two declarations of the same function or object
1686 specify different linkage-specifications ..., the program
1687 is ill-formed.... Except for functions with C++ linkage,
1688 a function declaration without a linkage specification
1689 shall not precede the first linkage specification for
1690 that function. A function can be declared without a
1691 linkage specification after an explicit linkage
1692 specification has been seen; the linkage explicitly
1693 specified in the earlier declaration is not affected by
1694 such a function declaration.
1696 DR 563 raises the question why the restrictions on
1697 functions should not also apply to objects. Older
1698 versions of G++ silently ignore the linkage-specification
1699 for this example:
1701 namespace N {
1702 extern int i;
1703 extern "C" int i;
1706 which is clearly wrong. Therefore, we now treat objects
1707 like functions. */
1708 if (current_lang_depth () == 0)
1710 /* There is no explicit linkage-specification, so we use
1711 the linkage from the previous declaration. */
1712 if (!DECL_LANG_SPECIFIC (newdecl))
1713 retrofit_lang_decl (newdecl);
1714 SET_DECL_LANGUAGE (newdecl, DECL_LANGUAGE (olddecl));
1716 else
1718 error ("conflicting declaration of %q#D with %qL linkage",
1719 newdecl, DECL_LANGUAGE (newdecl));
1720 inform (DECL_SOURCE_LOCATION (olddecl),
1721 "previous declaration with %qL linkage",
1722 DECL_LANGUAGE (olddecl));
1726 if (DECL_LANG_SPECIFIC (olddecl) && DECL_USE_TEMPLATE (olddecl))
1728 else if (TREE_CODE (olddecl) == FUNCTION_DECL)
1730 /* Note: free functions, as TEMPLATE_DECLs, are handled below. */
1731 if (DECL_FUNCTION_MEMBER_P (olddecl)
1732 && (/* grokfndecl passes member function templates too
1733 as FUNCTION_DECLs. */
1734 DECL_TEMPLATE_INFO (olddecl)
1735 /* C++11 8.3.6/6.
1736 Default arguments for a member function of a class
1737 template shall be specified on the initial declaration
1738 of the member function within the class template. */
1739 || CLASSTYPE_TEMPLATE_INFO (CP_DECL_CONTEXT (olddecl))))
1740 check_redeclaration_no_default_args (newdecl);
1741 else
1743 tree t1 = FUNCTION_FIRST_USER_PARMTYPE (olddecl);
1744 tree t2 = FUNCTION_FIRST_USER_PARMTYPE (newdecl);
1745 int i = 1;
1747 for (; t1 && t1 != void_list_node;
1748 t1 = TREE_CHAIN (t1), t2 = TREE_CHAIN (t2), i++)
1749 if (TREE_PURPOSE (t1) && TREE_PURPOSE (t2))
1751 if (1 == simple_cst_equal (TREE_PURPOSE (t1),
1752 TREE_PURPOSE (t2)))
1754 if (permerror (input_location,
1755 "default argument given for parameter "
1756 "%d of %q#D", i, newdecl))
1757 inform (DECL_SOURCE_LOCATION (olddecl),
1758 "previous specification in %q#D here",
1759 olddecl);
1761 else
1763 error ("default argument given for parameter %d "
1764 "of %q#D", i, newdecl);
1765 inform (DECL_SOURCE_LOCATION (olddecl),
1766 "previous specification in %q#D here",
1767 olddecl);
1774 /* Do not merge an implicit typedef with an explicit one. In:
1776 class A;
1778 typedef class A A __attribute__ ((foo));
1780 the attribute should apply only to the typedef. */
1781 if (TREE_CODE (olddecl) == TYPE_DECL
1782 && (DECL_IMPLICIT_TYPEDEF_P (olddecl)
1783 || DECL_IMPLICIT_TYPEDEF_P (newdecl)))
1784 return NULL_TREE;
1786 /* If new decl is `static' and an `extern' was seen previously,
1787 warn about it. */
1788 warn_extern_redeclared_static (newdecl, olddecl);
1790 if (!validate_constexpr_redeclaration (olddecl, newdecl))
1791 return error_mark_node;
1793 /* We have committed to returning 1 at this point. */
1794 if (TREE_CODE (newdecl) == FUNCTION_DECL)
1796 /* Now that functions must hold information normally held
1797 by field decls, there is extra work to do so that
1798 declaration information does not get destroyed during
1799 definition. */
1800 if (DECL_VINDEX (olddecl))
1801 DECL_VINDEX (newdecl) = DECL_VINDEX (olddecl);
1802 if (DECL_CONTEXT (olddecl))
1803 DECL_CONTEXT (newdecl) = DECL_CONTEXT (olddecl);
1804 DECL_STATIC_CONSTRUCTOR (newdecl) |= DECL_STATIC_CONSTRUCTOR (olddecl);
1805 DECL_STATIC_DESTRUCTOR (newdecl) |= DECL_STATIC_DESTRUCTOR (olddecl);
1806 DECL_PURE_VIRTUAL_P (newdecl) |= DECL_PURE_VIRTUAL_P (olddecl);
1807 DECL_VIRTUAL_P (newdecl) |= DECL_VIRTUAL_P (olddecl);
1808 DECL_INVALID_OVERRIDER_P (newdecl) |= DECL_INVALID_OVERRIDER_P (olddecl);
1809 DECL_THIS_STATIC (newdecl) |= DECL_THIS_STATIC (olddecl);
1810 if (DECL_OVERLOADED_OPERATOR_P (olddecl) != ERROR_MARK)
1811 SET_OVERLOADED_OPERATOR_CODE
1812 (newdecl, DECL_OVERLOADED_OPERATOR_P (olddecl));
1813 new_defines_function = DECL_INITIAL (newdecl) != NULL_TREE;
1815 /* Optionally warn about more than one declaration for the same
1816 name, but don't warn about a function declaration followed by a
1817 definition. */
1818 if (warn_redundant_decls && ! DECL_ARTIFICIAL (olddecl)
1819 && !(new_defines_function && DECL_INITIAL (olddecl) == NULL_TREE)
1820 /* Don't warn about extern decl followed by definition. */
1821 && !(DECL_EXTERNAL (olddecl) && ! DECL_EXTERNAL (newdecl))
1822 /* Don't warn about friends, let add_friend take care of it. */
1823 && ! (newdecl_is_friend || DECL_FRIEND_P (olddecl))
1824 /* Don't warn about declaration followed by specialization. */
1825 && (! DECL_TEMPLATE_SPECIALIZATION (newdecl)
1826 || DECL_TEMPLATE_SPECIALIZATION (olddecl)))
1828 if (warning (OPT_Wredundant_decls,
1829 "redundant redeclaration of %qD in same scope",
1830 newdecl))
1831 inform (DECL_SOURCE_LOCATION (olddecl),
1832 "previous declaration of %qD", olddecl);
1835 if (!(DECL_TEMPLATE_INSTANTIATION (olddecl)
1836 && DECL_TEMPLATE_SPECIALIZATION (newdecl)))
1838 if (DECL_DELETED_FN (newdecl))
1840 error ("deleted definition of %qD", newdecl);
1841 inform (DECL_SOURCE_LOCATION (olddecl),
1842 "previous declaration of %qD", olddecl);
1844 DECL_DELETED_FN (newdecl) |= DECL_DELETED_FN (olddecl);
1848 /* Deal with C++: must preserve virtual function table size. */
1849 if (TREE_CODE (olddecl) == TYPE_DECL)
1851 tree newtype = TREE_TYPE (newdecl);
1852 tree oldtype = TREE_TYPE (olddecl);
1854 if (newtype != error_mark_node && oldtype != error_mark_node
1855 && TYPE_LANG_SPECIFIC (newtype) && TYPE_LANG_SPECIFIC (oldtype))
1856 CLASSTYPE_FRIEND_CLASSES (newtype)
1857 = CLASSTYPE_FRIEND_CLASSES (oldtype);
1859 DECL_ORIGINAL_TYPE (newdecl) = DECL_ORIGINAL_TYPE (olddecl);
1862 /* Copy all the DECL_... slots specified in the new decl
1863 except for any that we copy here from the old type. */
1864 DECL_ATTRIBUTES (newdecl)
1865 = (*targetm.merge_decl_attributes) (olddecl, newdecl);
1867 if (TREE_CODE (newdecl) == TEMPLATE_DECL)
1869 tree old_result;
1870 tree new_result;
1871 old_result = DECL_TEMPLATE_RESULT (olddecl);
1872 new_result = DECL_TEMPLATE_RESULT (newdecl);
1873 TREE_TYPE (olddecl) = TREE_TYPE (old_result);
1874 DECL_TEMPLATE_SPECIALIZATIONS (olddecl)
1875 = chainon (DECL_TEMPLATE_SPECIALIZATIONS (olddecl),
1876 DECL_TEMPLATE_SPECIALIZATIONS (newdecl));
1878 DECL_ATTRIBUTES (old_result)
1879 = (*targetm.merge_decl_attributes) (old_result, new_result);
1881 if (DECL_FUNCTION_TEMPLATE_P (newdecl))
1883 /* Per C++11 8.3.6/4, default arguments cannot be added in later
1884 declarations of a function template. */
1885 check_redeclaration_no_default_args (newdecl);
1887 check_default_args (newdecl);
1889 if (GNU_INLINE_P (old_result) != GNU_INLINE_P (new_result)
1890 && DECL_INITIAL (new_result))
1892 if (DECL_INITIAL (old_result))
1893 DECL_UNINLINABLE (old_result) = 1;
1894 else
1895 DECL_UNINLINABLE (old_result) = DECL_UNINLINABLE (new_result);
1896 DECL_EXTERNAL (old_result) = DECL_EXTERNAL (new_result);
1897 DECL_NOT_REALLY_EXTERN (old_result)
1898 = DECL_NOT_REALLY_EXTERN (new_result);
1899 DECL_INTERFACE_KNOWN (old_result)
1900 = DECL_INTERFACE_KNOWN (new_result);
1901 DECL_DECLARED_INLINE_P (old_result)
1902 = DECL_DECLARED_INLINE_P (new_result);
1903 DECL_DISREGARD_INLINE_LIMITS (old_result)
1904 |= DECL_DISREGARD_INLINE_LIMITS (new_result);
1907 else
1909 DECL_DECLARED_INLINE_P (old_result)
1910 |= DECL_DECLARED_INLINE_P (new_result);
1911 DECL_DISREGARD_INLINE_LIMITS (old_result)
1912 |= DECL_DISREGARD_INLINE_LIMITS (new_result);
1913 check_redeclaration_exception_specification (newdecl, olddecl);
1917 /* If the new declaration is a definition, update the file and
1918 line information on the declaration, and also make
1919 the old declaration the same definition. */
1920 if (DECL_INITIAL (new_result) != NULL_TREE)
1922 DECL_SOURCE_LOCATION (olddecl)
1923 = DECL_SOURCE_LOCATION (old_result)
1924 = DECL_SOURCE_LOCATION (newdecl);
1925 DECL_INITIAL (old_result) = DECL_INITIAL (new_result);
1926 if (DECL_FUNCTION_TEMPLATE_P (newdecl))
1928 tree parm;
1929 DECL_ARGUMENTS (old_result)
1930 = DECL_ARGUMENTS (new_result);
1931 for (parm = DECL_ARGUMENTS (old_result); parm;
1932 parm = DECL_CHAIN (parm))
1933 DECL_CONTEXT (parm) = old_result;
1937 return olddecl;
1940 if (types_match)
1942 if (TREE_CODE (newdecl) == FUNCTION_DECL)
1943 check_redeclaration_exception_specification (newdecl, olddecl);
1945 /* Automatically handles default parameters. */
1946 tree oldtype = TREE_TYPE (olddecl);
1947 tree newtype;
1949 /* For typedefs use the old type, as the new type's DECL_NAME points
1950 at newdecl, which will be ggc_freed. */
1951 if (TREE_CODE (newdecl) == TYPE_DECL)
1952 newtype = oldtype;
1953 else
1954 /* Merge the data types specified in the two decls. */
1955 newtype = merge_types (TREE_TYPE (newdecl), TREE_TYPE (olddecl));
1957 if (VAR_P (newdecl))
1959 DECL_THIS_EXTERN (newdecl) |= DECL_THIS_EXTERN (olddecl);
1960 DECL_INITIALIZED_P (newdecl) |= DECL_INITIALIZED_P (olddecl);
1961 DECL_NONTRIVIALLY_INITIALIZED_P (newdecl)
1962 |= DECL_NONTRIVIALLY_INITIALIZED_P (olddecl);
1963 DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P (newdecl)
1964 |= DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P (olddecl);
1966 /* Merge the threadprivate attribute from OLDDECL into NEWDECL. */
1967 if (DECL_LANG_SPECIFIC (olddecl)
1968 && CP_DECL_THREADPRIVATE_P (olddecl))
1970 /* Allocate a LANG_SPECIFIC structure for NEWDECL, if needed. */
1971 if (!DECL_LANG_SPECIFIC (newdecl))
1972 retrofit_lang_decl (newdecl);
1974 set_decl_tls_model (newdecl, DECL_TLS_MODEL (olddecl));
1975 CP_DECL_THREADPRIVATE_P (newdecl) = 1;
1979 TREE_TYPE (newdecl) = TREE_TYPE (olddecl) = newtype;
1981 if (TREE_CODE (newdecl) == FUNCTION_DECL)
1982 check_default_args (newdecl);
1984 /* Lay the type out, unless already done. */
1985 if (! same_type_p (newtype, oldtype)
1986 && TREE_TYPE (newdecl) != error_mark_node
1987 && !(processing_template_decl && uses_template_parms (newdecl)))
1988 layout_type (TREE_TYPE (newdecl));
1990 if ((VAR_P (newdecl)
1991 || TREE_CODE (newdecl) == PARM_DECL
1992 || TREE_CODE (newdecl) == RESULT_DECL
1993 || TREE_CODE (newdecl) == FIELD_DECL
1994 || TREE_CODE (newdecl) == TYPE_DECL)
1995 && !(processing_template_decl && uses_template_parms (newdecl)))
1996 layout_decl (newdecl, 0);
1998 /* Merge the type qualifiers. */
1999 if (TREE_READONLY (newdecl))
2000 TREE_READONLY (olddecl) = 1;
2001 if (TREE_THIS_VOLATILE (newdecl))
2002 TREE_THIS_VOLATILE (olddecl) = 1;
2003 if (TREE_NOTHROW (newdecl))
2004 TREE_NOTHROW (olddecl) = 1;
2006 /* Merge deprecatedness. */
2007 if (TREE_DEPRECATED (newdecl))
2008 TREE_DEPRECATED (olddecl) = 1;
2010 /* Preserve function specific target and optimization options */
2011 if (TREE_CODE (newdecl) == FUNCTION_DECL)
2013 if (DECL_FUNCTION_SPECIFIC_TARGET (olddecl)
2014 && !DECL_FUNCTION_SPECIFIC_TARGET (newdecl))
2015 DECL_FUNCTION_SPECIFIC_TARGET (newdecl)
2016 = DECL_FUNCTION_SPECIFIC_TARGET (olddecl);
2018 if (DECL_FUNCTION_SPECIFIC_OPTIMIZATION (olddecl)
2019 && !DECL_FUNCTION_SPECIFIC_OPTIMIZATION (newdecl))
2020 DECL_FUNCTION_SPECIFIC_OPTIMIZATION (newdecl)
2021 = DECL_FUNCTION_SPECIFIC_OPTIMIZATION (olddecl);
2024 /* Merge the initialization information. */
2025 if (DECL_INITIAL (newdecl) == NULL_TREE
2026 && DECL_INITIAL (olddecl) != NULL_TREE)
2028 DECL_INITIAL (newdecl) = DECL_INITIAL (olddecl);
2029 DECL_SOURCE_LOCATION (newdecl) = DECL_SOURCE_LOCATION (olddecl);
2030 if (TREE_CODE (newdecl) == FUNCTION_DECL)
2032 DECL_SAVED_TREE (newdecl) = DECL_SAVED_TREE (olddecl);
2033 DECL_STRUCT_FUNCTION (newdecl) = DECL_STRUCT_FUNCTION (olddecl);
2037 /* Merge the section attribute.
2038 We want to issue an error if the sections conflict but that must be
2039 done later in decl_attributes since we are called before attributes
2040 are assigned. */
2041 if ((DECL_EXTERNAL (olddecl) || TREE_PUBLIC (olddecl) || TREE_STATIC (olddecl))
2042 && DECL_SECTION_NAME (newdecl) == NULL
2043 && DECL_SECTION_NAME (olddecl) != NULL)
2044 set_decl_section_name (newdecl, DECL_SECTION_NAME (olddecl));
2046 if (TREE_CODE (newdecl) == FUNCTION_DECL)
2048 DECL_NO_INSTRUMENT_FUNCTION_ENTRY_EXIT (newdecl)
2049 |= DECL_NO_INSTRUMENT_FUNCTION_ENTRY_EXIT (olddecl);
2050 DECL_NO_LIMIT_STACK (newdecl) |= DECL_NO_LIMIT_STACK (olddecl);
2051 TREE_THIS_VOLATILE (newdecl) |= TREE_THIS_VOLATILE (olddecl);
2052 TREE_NOTHROW (newdecl) |= TREE_NOTHROW (olddecl);
2053 DECL_IS_MALLOC (newdecl) |= DECL_IS_MALLOC (olddecl);
2054 DECL_IS_OPERATOR_NEW (newdecl) |= DECL_IS_OPERATOR_NEW (olddecl);
2055 DECL_PURE_P (newdecl) |= DECL_PURE_P (olddecl);
2056 TREE_READONLY (newdecl) |= TREE_READONLY (olddecl);
2057 DECL_LOOPING_CONST_OR_PURE_P (newdecl)
2058 |= DECL_LOOPING_CONST_OR_PURE_P (olddecl);
2059 /* Keep the old RTL. */
2060 COPY_DECL_RTL (olddecl, newdecl);
2062 else if (VAR_P (newdecl)
2063 && (DECL_SIZE (olddecl) || !DECL_SIZE (newdecl)))
2065 /* Keep the old RTL. We cannot keep the old RTL if the old
2066 declaration was for an incomplete object and the new
2067 declaration is not since many attributes of the RTL will
2068 change. */
2069 COPY_DECL_RTL (olddecl, newdecl);
2072 /* If cannot merge, then use the new type and qualifiers,
2073 and don't preserve the old rtl. */
2074 else
2076 /* Clean out any memory we had of the old declaration. */
2077 tree oldstatic = value_member (olddecl, static_aggregates);
2078 if (oldstatic)
2079 TREE_VALUE (oldstatic) = error_mark_node;
2081 TREE_TYPE (olddecl) = TREE_TYPE (newdecl);
2082 TREE_READONLY (olddecl) = TREE_READONLY (newdecl);
2083 TREE_THIS_VOLATILE (olddecl) = TREE_THIS_VOLATILE (newdecl);
2084 TREE_SIDE_EFFECTS (olddecl) = TREE_SIDE_EFFECTS (newdecl);
2087 /* Merge the storage class information. */
2088 merge_weak (newdecl, olddecl);
2090 if ((TREE_CODE (olddecl) == FUNCTION_DECL || TREE_CODE (olddecl) == VAR_DECL)
2091 && (DECL_EXTERNAL (olddecl) || TREE_PUBLIC (olddecl) || TREE_STATIC (olddecl))
2092 && DECL_ONE_ONLY (olddecl))
2094 struct symtab_node *symbol;
2095 if (TREE_CODE (olddecl) == FUNCTION_DECL)
2096 symbol = cgraph_node::get_create (newdecl);
2097 else
2098 symbol = varpool_node::get_create (newdecl);
2099 symbol->set_comdat_group (symtab_node::get
2100 (olddecl)->get_comdat_group ());
2103 DECL_DEFER_OUTPUT (newdecl) |= DECL_DEFER_OUTPUT (olddecl);
2104 TREE_PUBLIC (newdecl) = TREE_PUBLIC (olddecl);
2105 TREE_STATIC (olddecl) = TREE_STATIC (newdecl) |= TREE_STATIC (olddecl);
2106 if (! DECL_EXTERNAL (olddecl))
2107 DECL_EXTERNAL (newdecl) = 0;
2109 new_template_info = NULL_TREE;
2110 if (DECL_LANG_SPECIFIC (newdecl) && DECL_LANG_SPECIFIC (olddecl))
2112 bool new_redefines_gnu_inline = false;
2114 if (new_defines_function
2115 && ((DECL_INTERFACE_KNOWN (olddecl)
2116 && TREE_CODE (olddecl) == FUNCTION_DECL)
2117 || (TREE_CODE (olddecl) == TEMPLATE_DECL
2118 && (TREE_CODE (DECL_TEMPLATE_RESULT (olddecl))
2119 == FUNCTION_DECL))))
2121 tree fn = olddecl;
2123 if (TREE_CODE (fn) == TEMPLATE_DECL)
2124 fn = DECL_TEMPLATE_RESULT (olddecl);
2126 new_redefines_gnu_inline = GNU_INLINE_P (fn) && DECL_INITIAL (fn);
2129 if (!new_redefines_gnu_inline)
2131 DECL_INTERFACE_KNOWN (newdecl) |= DECL_INTERFACE_KNOWN (olddecl);
2132 DECL_NOT_REALLY_EXTERN (newdecl) |= DECL_NOT_REALLY_EXTERN (olddecl);
2133 DECL_COMDAT (newdecl) |= DECL_COMDAT (olddecl);
2135 DECL_TEMPLATE_INSTANTIATED (newdecl)
2136 |= DECL_TEMPLATE_INSTANTIATED (olddecl);
2137 DECL_ODR_USED (newdecl) |= DECL_ODR_USED (olddecl);
2139 /* If the OLDDECL is an instantiation and/or specialization,
2140 then the NEWDECL must be too. But, it may not yet be marked
2141 as such if the caller has created NEWDECL, but has not yet
2142 figured out that it is a redeclaration. */
2143 if (!DECL_USE_TEMPLATE (newdecl))
2144 DECL_USE_TEMPLATE (newdecl) = DECL_USE_TEMPLATE (olddecl);
2146 /* Don't really know how much of the language-specific
2147 values we should copy from old to new. */
2148 DECL_IN_AGGR_P (newdecl) = DECL_IN_AGGR_P (olddecl);
2149 DECL_REPO_AVAILABLE_P (newdecl) = DECL_REPO_AVAILABLE_P (olddecl);
2150 DECL_INITIALIZED_IN_CLASS_P (newdecl)
2151 |= DECL_INITIALIZED_IN_CLASS_P (olddecl);
2153 if (LANG_DECL_HAS_MIN (newdecl))
2155 DECL_LANG_SPECIFIC (newdecl)->u.min.u2 =
2156 DECL_LANG_SPECIFIC (olddecl)->u.min.u2;
2157 if (DECL_TEMPLATE_INFO (newdecl))
2158 new_template_info = DECL_TEMPLATE_INFO (newdecl);
2159 DECL_TEMPLATE_INFO (newdecl) = DECL_TEMPLATE_INFO (olddecl);
2161 /* Only functions have these fields. */
2162 if (DECL_DECLARES_FUNCTION_P (newdecl))
2164 DECL_NONCONVERTING_P (newdecl) = DECL_NONCONVERTING_P (olddecl);
2165 olddecl_friend = DECL_FRIEND_P (olddecl);
2166 hidden_friend = (DECL_ANTICIPATED (olddecl)
2167 && DECL_HIDDEN_FRIEND_P (olddecl)
2168 && newdecl_is_friend);
2169 DECL_BEFRIENDING_CLASSES (newdecl)
2170 = chainon (DECL_BEFRIENDING_CLASSES (newdecl),
2171 DECL_BEFRIENDING_CLASSES (olddecl));
2172 /* DECL_THUNKS is only valid for virtual functions,
2173 otherwise it is a DECL_FRIEND_CONTEXT. */
2174 if (DECL_VIRTUAL_P (newdecl))
2175 SET_DECL_THUNKS (newdecl, DECL_THUNKS (olddecl));
2177 /* Only variables have this field. */
2178 else if (VAR_P (newdecl)
2179 && VAR_HAD_UNKNOWN_BOUND (olddecl))
2180 SET_VAR_HAD_UNKNOWN_BOUND (newdecl);
2183 if (TREE_CODE (newdecl) == FUNCTION_DECL)
2185 tree parm;
2187 /* Merge parameter attributes. */
2188 tree oldarg, newarg;
2189 for (oldarg = DECL_ARGUMENTS(olddecl),
2190 newarg = DECL_ARGUMENTS(newdecl);
2191 oldarg && newarg;
2192 oldarg = DECL_CHAIN(oldarg), newarg = DECL_CHAIN(newarg)) {
2193 DECL_ATTRIBUTES (newarg)
2194 = (*targetm.merge_decl_attributes) (oldarg, newarg);
2195 DECL_ATTRIBUTES (oldarg) = DECL_ATTRIBUTES (newarg);
2198 if (DECL_TEMPLATE_INSTANTIATION (olddecl)
2199 && !DECL_TEMPLATE_INSTANTIATION (newdecl))
2201 /* If newdecl is not a specialization, then it is not a
2202 template-related function at all. And that means that we
2203 should have exited above, returning 0. */
2204 gcc_assert (DECL_TEMPLATE_SPECIALIZATION (newdecl));
2206 if (DECL_ODR_USED (olddecl))
2207 /* From [temp.expl.spec]:
2209 If a template, a member template or the member of a class
2210 template is explicitly specialized then that
2211 specialization shall be declared before the first use of
2212 that specialization that would cause an implicit
2213 instantiation to take place, in every translation unit in
2214 which such a use occurs. */
2215 error ("explicit specialization of %qD after first use",
2216 olddecl);
2218 SET_DECL_TEMPLATE_SPECIALIZATION (olddecl);
2219 DECL_COMDAT (newdecl) = (TREE_PUBLIC (newdecl)
2220 && DECL_DECLARED_INLINE_P (newdecl));
2222 /* Don't propagate visibility from the template to the
2223 specialization here. We'll do that in determine_visibility if
2224 appropriate. */
2225 DECL_VISIBILITY_SPECIFIED (olddecl) = 0;
2227 /* [temp.expl.spec/14] We don't inline explicit specialization
2228 just because the primary template says so. */
2230 /* But still keep DECL_DISREGARD_INLINE_LIMITS in sync with
2231 the always_inline attribute. */
2232 if (DECL_DISREGARD_INLINE_LIMITS (olddecl)
2233 && !DECL_DISREGARD_INLINE_LIMITS (newdecl))
2235 if (DECL_DECLARED_INLINE_P (newdecl))
2236 DECL_DISREGARD_INLINE_LIMITS (newdecl) = true;
2237 else
2238 DECL_ATTRIBUTES (newdecl)
2239 = remove_attribute ("always_inline",
2240 DECL_ATTRIBUTES (newdecl));
2243 else if (new_defines_function && DECL_INITIAL (olddecl))
2245 /* Never inline re-defined extern inline functions.
2246 FIXME: this could be better handled by keeping both
2247 function as separate declarations. */
2248 DECL_UNINLINABLE (newdecl) = 1;
2250 else
2252 if (DECL_PENDING_INLINE_INFO (newdecl) == 0)
2253 DECL_PENDING_INLINE_INFO (newdecl) = DECL_PENDING_INLINE_INFO (olddecl);
2255 DECL_DECLARED_INLINE_P (newdecl) |= DECL_DECLARED_INLINE_P (olddecl);
2257 DECL_UNINLINABLE (newdecl) = DECL_UNINLINABLE (olddecl)
2258 = (DECL_UNINLINABLE (newdecl) || DECL_UNINLINABLE (olddecl));
2260 DECL_DISREGARD_INLINE_LIMITS (newdecl)
2261 = DECL_DISREGARD_INLINE_LIMITS (olddecl)
2262 = (DECL_DISREGARD_INLINE_LIMITS (newdecl)
2263 || DECL_DISREGARD_INLINE_LIMITS (olddecl));
2266 /* Preserve abstractness on cloned [cd]tors. */
2267 DECL_ABSTRACT (newdecl) = DECL_ABSTRACT (olddecl);
2269 /* Update newdecl's parms to point at olddecl. */
2270 for (parm = DECL_ARGUMENTS (newdecl); parm;
2271 parm = DECL_CHAIN (parm))
2272 DECL_CONTEXT (parm) = olddecl;
2274 if (! types_match)
2276 SET_DECL_LANGUAGE (olddecl, DECL_LANGUAGE (newdecl));
2277 COPY_DECL_ASSEMBLER_NAME (newdecl, olddecl);
2278 COPY_DECL_RTL (newdecl, olddecl);
2280 if (! types_match || new_defines_function)
2282 /* These need to be copied so that the names are available.
2283 Note that if the types do match, we'll preserve inline
2284 info and other bits, but if not, we won't. */
2285 DECL_ARGUMENTS (olddecl) = DECL_ARGUMENTS (newdecl);
2286 DECL_RESULT (olddecl) = DECL_RESULT (newdecl);
2288 /* If redeclaring a builtin function, it stays built in
2289 if newdecl is a gnu_inline definition, or if newdecl is just
2290 a declaration. */
2291 if (DECL_BUILT_IN (olddecl)
2292 && (new_defines_function ? GNU_INLINE_P (newdecl) : types_match))
2294 DECL_BUILT_IN_CLASS (newdecl) = DECL_BUILT_IN_CLASS (olddecl);
2295 DECL_FUNCTION_CODE (newdecl) = DECL_FUNCTION_CODE (olddecl);
2296 /* If we're keeping the built-in definition, keep the rtl,
2297 regardless of declaration matches. */
2298 COPY_DECL_RTL (olddecl, newdecl);
2299 if (DECL_BUILT_IN_CLASS (newdecl) == BUILT_IN_NORMAL)
2301 enum built_in_function fncode = DECL_FUNCTION_CODE (newdecl);
2302 switch (fncode)
2304 /* If a compatible prototype of these builtin functions
2305 is seen, assume the runtime implements it with the
2306 expected semantics. */
2307 case BUILT_IN_STPCPY:
2308 if (builtin_decl_explicit_p (fncode))
2309 set_builtin_decl_implicit_p (fncode, true);
2310 break;
2311 default:
2312 break;
2316 if (new_defines_function)
2317 /* If defining a function declared with other language
2318 linkage, use the previously declared language linkage. */
2319 SET_DECL_LANGUAGE (newdecl, DECL_LANGUAGE (olddecl));
2320 else if (types_match)
2322 DECL_RESULT (newdecl) = DECL_RESULT (olddecl);
2323 /* Don't clear out the arguments if we're just redeclaring a
2324 function. */
2325 if (DECL_ARGUMENTS (olddecl))
2326 DECL_ARGUMENTS (newdecl) = DECL_ARGUMENTS (olddecl);
2329 else if (TREE_CODE (newdecl) == NAMESPACE_DECL)
2330 NAMESPACE_LEVEL (newdecl) = NAMESPACE_LEVEL (olddecl);
2332 /* Now preserve various other info from the definition. */
2333 TREE_ADDRESSABLE (newdecl) = TREE_ADDRESSABLE (olddecl);
2334 TREE_ASM_WRITTEN (newdecl) = TREE_ASM_WRITTEN (olddecl);
2335 DECL_COMMON (newdecl) = DECL_COMMON (olddecl);
2336 COPY_DECL_ASSEMBLER_NAME (olddecl, newdecl);
2338 /* Warn about conflicting visibility specifications. */
2339 if (DECL_VISIBILITY_SPECIFIED (olddecl)
2340 && DECL_VISIBILITY_SPECIFIED (newdecl)
2341 && DECL_VISIBILITY (newdecl) != DECL_VISIBILITY (olddecl))
2343 if (warning_at (DECL_SOURCE_LOCATION (newdecl), OPT_Wattributes,
2344 "%qD: visibility attribute ignored because it "
2345 "conflicts with previous declaration", newdecl))
2346 inform (DECL_SOURCE_LOCATION (olddecl),
2347 "previous declaration of %qD", olddecl);
2349 /* Choose the declaration which specified visibility. */
2350 if (DECL_VISIBILITY_SPECIFIED (olddecl))
2352 DECL_VISIBILITY (newdecl) = DECL_VISIBILITY (olddecl);
2353 DECL_VISIBILITY_SPECIFIED (newdecl) = 1;
2355 /* Init priority used to be merged from newdecl to olddecl by the memcpy,
2356 so keep this behavior. */
2357 if (VAR_P (newdecl) && DECL_HAS_INIT_PRIORITY_P (newdecl))
2359 SET_DECL_INIT_PRIORITY (olddecl, DECL_INIT_PRIORITY (newdecl));
2360 DECL_HAS_INIT_PRIORITY_P (olddecl) = 1;
2362 /* Likewise for DECL_ALIGN, DECL_USER_ALIGN and DECL_PACKED. */
2363 if (DECL_ALIGN (olddecl) > DECL_ALIGN (newdecl))
2365 DECL_ALIGN (newdecl) = DECL_ALIGN (olddecl);
2366 DECL_USER_ALIGN (newdecl) |= DECL_USER_ALIGN (olddecl);
2368 DECL_USER_ALIGN (olddecl) = DECL_USER_ALIGN (newdecl);
2369 if (TREE_CODE (newdecl) == FIELD_DECL)
2370 DECL_PACKED (olddecl) = DECL_PACKED (newdecl);
2372 /* The DECL_LANG_SPECIFIC information in OLDDECL will be replaced
2373 with that from NEWDECL below. */
2374 if (DECL_LANG_SPECIFIC (olddecl))
2376 gcc_assert (DECL_LANG_SPECIFIC (olddecl)
2377 != DECL_LANG_SPECIFIC (newdecl));
2378 ggc_free (DECL_LANG_SPECIFIC (olddecl));
2381 /* Merge the USED information. */
2382 if (TREE_USED (olddecl))
2383 TREE_USED (newdecl) = 1;
2384 else if (TREE_USED (newdecl))
2385 TREE_USED (olddecl) = 1;
2386 if (VAR_P (newdecl))
2388 if (DECL_READ_P (olddecl))
2389 DECL_READ_P (newdecl) = 1;
2390 else if (DECL_READ_P (newdecl))
2391 DECL_READ_P (olddecl) = 1;
2393 if (DECL_PRESERVE_P (olddecl))
2394 DECL_PRESERVE_P (newdecl) = 1;
2395 else if (DECL_PRESERVE_P (newdecl))
2396 DECL_PRESERVE_P (olddecl) = 1;
2398 /* Merge the DECL_FUNCTION_VERSIONED information. newdecl will be copied
2399 to olddecl and deleted. */
2400 if (TREE_CODE (newdecl) == FUNCTION_DECL
2401 && DECL_FUNCTION_VERSIONED (olddecl))
2403 /* Set the flag for newdecl so that it gets copied to olddecl. */
2404 DECL_FUNCTION_VERSIONED (newdecl) = 1;
2405 /* newdecl will be purged after copying to olddecl and is no longer
2406 a version. */
2407 cgraph_node::delete_function_version (newdecl);
2410 if (TREE_CODE (newdecl) == FUNCTION_DECL)
2412 int function_size;
2413 struct symtab_node *snode = symtab_node::get (olddecl);
2415 function_size = sizeof (struct tree_decl_common);
2417 memcpy ((char *) olddecl + sizeof (struct tree_common),
2418 (char *) newdecl + sizeof (struct tree_common),
2419 function_size - sizeof (struct tree_common));
2421 memcpy ((char *) olddecl + sizeof (struct tree_decl_common),
2422 (char *) newdecl + sizeof (struct tree_decl_common),
2423 sizeof (struct tree_function_decl) - sizeof (struct tree_decl_common));
2425 /* Preserve symtab node mapping. */
2426 olddecl->decl_with_vis.symtab_node = snode;
2428 if (new_template_info)
2429 /* If newdecl is a template instantiation, it is possible that
2430 the following sequence of events has occurred:
2432 o A friend function was declared in a class template. The
2433 class template was instantiated.
2435 o The instantiation of the friend declaration was
2436 recorded on the instantiation list, and is newdecl.
2438 o Later, however, instantiate_class_template called pushdecl
2439 on the newdecl to perform name injection. But, pushdecl in
2440 turn called duplicate_decls when it discovered that another
2441 declaration of a global function with the same name already
2442 existed.
2444 o Here, in duplicate_decls, we decided to clobber newdecl.
2446 If we're going to do that, we'd better make sure that
2447 olddecl, and not newdecl, is on the list of
2448 instantiations so that if we try to do the instantiation
2449 again we won't get the clobbered declaration. */
2450 reregister_specialization (newdecl,
2451 new_template_info,
2452 olddecl);
2454 else
2456 size_t size = tree_code_size (TREE_CODE (olddecl));
2458 memcpy ((char *) olddecl + sizeof (struct tree_common),
2459 (char *) newdecl + sizeof (struct tree_common),
2460 sizeof (struct tree_decl_common) - sizeof (struct tree_common));
2461 switch (TREE_CODE (olddecl))
2463 case LABEL_DECL:
2464 case VAR_DECL:
2465 case RESULT_DECL:
2466 case PARM_DECL:
2467 case FIELD_DECL:
2468 case TYPE_DECL:
2469 case CONST_DECL:
2471 struct symtab_node *snode = NULL;
2473 if (TREE_CODE (olddecl) == VAR_DECL
2474 && (TREE_STATIC (olddecl) || TREE_PUBLIC (olddecl) || DECL_EXTERNAL (olddecl)))
2475 snode = symtab_node::get (olddecl);
2476 memcpy ((char *) olddecl + sizeof (struct tree_decl_common),
2477 (char *) newdecl + sizeof (struct tree_decl_common),
2478 size - sizeof (struct tree_decl_common)
2479 + TREE_CODE_LENGTH (TREE_CODE (newdecl)) * sizeof (char *));
2480 if (TREE_CODE (olddecl) == VAR_DECL)
2481 olddecl->decl_with_vis.symtab_node = snode;
2483 break;
2484 default:
2485 memcpy ((char *) olddecl + sizeof (struct tree_decl_common),
2486 (char *) newdecl + sizeof (struct tree_decl_common),
2487 sizeof (struct tree_decl_non_common) - sizeof (struct tree_decl_common)
2488 + TREE_CODE_LENGTH (TREE_CODE (newdecl)) * sizeof (char *));
2489 break;
2492 DECL_UID (olddecl) = olddecl_uid;
2493 if (olddecl_friend)
2494 DECL_FRIEND_P (olddecl) = 1;
2495 if (hidden_friend)
2497 DECL_ANTICIPATED (olddecl) = 1;
2498 DECL_HIDDEN_FRIEND_P (olddecl) = 1;
2501 /* NEWDECL contains the merged attribute lists.
2502 Update OLDDECL to be the same. */
2503 DECL_ATTRIBUTES (olddecl) = DECL_ATTRIBUTES (newdecl);
2505 /* If OLDDECL had its DECL_RTL instantiated, re-invoke make_decl_rtl
2506 so that encode_section_info has a chance to look at the new decl
2507 flags and attributes. */
2508 if (DECL_RTL_SET_P (olddecl)
2509 && (TREE_CODE (olddecl) == FUNCTION_DECL
2510 || (VAR_P (olddecl)
2511 && TREE_STATIC (olddecl))))
2512 make_decl_rtl (olddecl);
2514 /* The NEWDECL will no longer be needed. Because every out-of-class
2515 declaration of a member results in a call to duplicate_decls,
2516 freeing these nodes represents in a significant savings.
2518 Before releasing the node, be sore to remove function from symbol
2519 table that might have been inserted there to record comdat group.
2520 Be sure to however do not free DECL_STRUCT_FUNCTION becuase this
2521 structure is shared in between newdecl and oldecl. */
2522 if (TREE_CODE (newdecl) == FUNCTION_DECL)
2523 DECL_STRUCT_FUNCTION (newdecl) = NULL;
2524 if (TREE_CODE (newdecl) == FUNCTION_DECL
2525 || TREE_CODE (newdecl) == VAR_DECL)
2527 struct symtab_node *snode = symtab_node::get (newdecl);
2528 if (snode)
2529 snode->remove ();
2531 ggc_free (newdecl);
2533 return olddecl;
2536 /* Return zero if the declaration NEWDECL is valid
2537 when the declaration OLDDECL (assumed to be for the same name)
2538 has already been seen.
2539 Otherwise return an error message format string with a %s
2540 where the identifier should go. */
2542 static const char *
2543 redeclaration_error_message (tree newdecl, tree olddecl)
2545 if (TREE_CODE (newdecl) == TYPE_DECL)
2547 /* Because C++ can put things into name space for free,
2548 constructs like "typedef struct foo { ... } foo"
2549 would look like an erroneous redeclaration. */
2550 if (same_type_p (TREE_TYPE (newdecl), TREE_TYPE (olddecl)))
2551 return NULL;
2552 else
2553 return G_("redefinition of %q#D");
2555 else if (TREE_CODE (newdecl) == FUNCTION_DECL)
2557 /* If this is a pure function, its olddecl will actually be
2558 the original initialization to `0' (which we force to call
2559 abort()). Don't complain about redefinition in this case. */
2560 if (DECL_LANG_SPECIFIC (olddecl) && DECL_PURE_VIRTUAL_P (olddecl)
2561 && DECL_INITIAL (olddecl) == NULL_TREE)
2562 return NULL;
2564 /* If both functions come from different namespaces, this is not
2565 a redeclaration - this is a conflict with a used function. */
2566 if (DECL_NAMESPACE_SCOPE_P (olddecl)
2567 && DECL_CONTEXT (olddecl) != DECL_CONTEXT (newdecl)
2568 && ! decls_match (olddecl, newdecl))
2569 return G_("%qD conflicts with used function");
2571 /* We'll complain about linkage mismatches in
2572 warn_extern_redeclared_static. */
2574 /* Defining the same name twice is no good. */
2575 if (DECL_INITIAL (olddecl) != NULL_TREE
2576 && DECL_INITIAL (newdecl) != NULL_TREE)
2578 if (DECL_NAME (olddecl) == NULL_TREE)
2579 return G_("%q#D not declared in class");
2580 else if (!GNU_INLINE_P (olddecl)
2581 || GNU_INLINE_P (newdecl))
2582 return G_("redefinition of %q#D");
2585 if (DECL_DECLARED_INLINE_P (olddecl) && DECL_DECLARED_INLINE_P (newdecl))
2587 bool olda = GNU_INLINE_P (olddecl);
2588 bool newa = GNU_INLINE_P (newdecl);
2590 if (olda != newa)
2592 if (newa)
2593 return G_("%q+D redeclared inline with "
2594 "%<gnu_inline%> attribute");
2595 else
2596 return G_("%q+D redeclared inline without "
2597 "%<gnu_inline%> attribute");
2601 check_abi_tag_redeclaration
2602 (olddecl, lookup_attribute ("abi_tag", DECL_ATTRIBUTES (olddecl)),
2603 lookup_attribute ("abi_tag", DECL_ATTRIBUTES (newdecl)));
2605 return NULL;
2607 else if (TREE_CODE (newdecl) == TEMPLATE_DECL)
2609 tree nt, ot;
2611 if (TREE_CODE (DECL_TEMPLATE_RESULT (newdecl)) == TYPE_DECL)
2613 if (COMPLETE_TYPE_P (TREE_TYPE (newdecl))
2614 && COMPLETE_TYPE_P (TREE_TYPE (olddecl)))
2615 return G_("redefinition of %q#D");
2616 return NULL;
2619 if (TREE_CODE (DECL_TEMPLATE_RESULT (newdecl)) != FUNCTION_DECL
2620 || (DECL_TEMPLATE_RESULT (newdecl)
2621 == DECL_TEMPLATE_RESULT (olddecl)))
2622 return NULL;
2624 nt = DECL_TEMPLATE_RESULT (newdecl);
2625 if (DECL_TEMPLATE_INFO (nt))
2626 nt = DECL_TEMPLATE_RESULT (template_for_substitution (nt));
2627 ot = DECL_TEMPLATE_RESULT (olddecl);
2628 if (DECL_TEMPLATE_INFO (ot))
2629 ot = DECL_TEMPLATE_RESULT (template_for_substitution (ot));
2630 if (DECL_INITIAL (nt) && DECL_INITIAL (ot)
2631 && (!GNU_INLINE_P (ot) || GNU_INLINE_P (nt)))
2632 return G_("redefinition of %q#D");
2634 if (DECL_DECLARED_INLINE_P (ot) && DECL_DECLARED_INLINE_P (nt))
2636 bool olda = GNU_INLINE_P (ot);
2637 bool newa = GNU_INLINE_P (nt);
2639 if (olda != newa)
2641 if (newa)
2642 return G_("%q+D redeclared inline with "
2643 "%<gnu_inline%> attribute");
2644 else
2645 return G_("%q+D redeclared inline without "
2646 "%<gnu_inline%> attribute");
2650 /* Core issue #226 (C++0x):
2652 If a friend function template declaration specifies a
2653 default template-argument, that declaration shall be a
2654 definition and shall be the only declaration of the
2655 function template in the translation unit. */
2656 if ((cxx_dialect != cxx98)
2657 && TREE_CODE (ot) == FUNCTION_DECL && DECL_FRIEND_P (ot)
2658 && !check_default_tmpl_args (nt, DECL_TEMPLATE_PARMS (newdecl),
2659 /*is_primary=*/true,
2660 /*is_partial=*/false,
2661 /*is_friend_decl=*/2))
2662 return G_("redeclaration of friend %q#D "
2663 "may not have default template arguments");
2665 return NULL;
2667 else if (VAR_P (newdecl)
2668 && DECL_THREAD_LOCAL_P (newdecl) != DECL_THREAD_LOCAL_P (olddecl)
2669 && (! DECL_LANG_SPECIFIC (olddecl)
2670 || ! CP_DECL_THREADPRIVATE_P (olddecl)
2671 || DECL_THREAD_LOCAL_P (newdecl)))
2673 /* Only variables can be thread-local, and all declarations must
2674 agree on this property. */
2675 if (DECL_THREAD_LOCAL_P (newdecl))
2676 return G_("thread-local declaration of %q#D follows "
2677 "non-thread-local declaration");
2678 else
2679 return G_("non-thread-local declaration of %q#D follows "
2680 "thread-local declaration");
2682 else if (toplevel_bindings_p () || DECL_NAMESPACE_SCOPE_P (newdecl))
2684 /* The objects have been declared at namespace scope. If either
2685 is a member of an anonymous union, then this is an invalid
2686 redeclaration. For example:
2688 int i;
2689 union { int i; };
2691 is invalid. */
2692 if ((VAR_P (newdecl) && DECL_ANON_UNION_VAR_P (newdecl))
2693 || (VAR_P (olddecl) && DECL_ANON_UNION_VAR_P (olddecl)))
2694 return G_("redeclaration of %q#D");
2695 /* If at least one declaration is a reference, there is no
2696 conflict. For example:
2698 int i = 3;
2699 extern int i;
2701 is valid. */
2702 if (DECL_EXTERNAL (newdecl) || DECL_EXTERNAL (olddecl))
2703 return NULL;
2704 /* Reject two definitions. */
2705 return G_("redefinition of %q#D");
2707 else
2709 /* Objects declared with block scope: */
2710 /* Reject two definitions, and reject a definition
2711 together with an external reference. */
2712 if (!(DECL_EXTERNAL (newdecl) && DECL_EXTERNAL (olddecl)))
2713 return G_("redeclaration of %q#D");
2714 return NULL;
2718 /* Hash and equality functions for the named_label table. */
2720 static hashval_t
2721 named_label_entry_hash (const void *data)
2723 const struct named_label_entry *ent = (const struct named_label_entry *) data;
2724 return DECL_UID (ent->label_decl);
2727 static int
2728 named_label_entry_eq (const void *a, const void *b)
2730 const struct named_label_entry *ent_a = (const struct named_label_entry *) a;
2731 const struct named_label_entry *ent_b = (const struct named_label_entry *) b;
2732 return ent_a->label_decl == ent_b->label_decl;
2735 /* Create a new label, named ID. */
2737 static tree
2738 make_label_decl (tree id, int local_p)
2740 struct named_label_entry *ent;
2741 void **slot;
2742 tree decl;
2744 decl = build_decl (input_location, LABEL_DECL, id, void_type_node);
2746 DECL_CONTEXT (decl) = current_function_decl;
2747 DECL_MODE (decl) = VOIDmode;
2748 C_DECLARED_LABEL_FLAG (decl) = local_p;
2750 /* Say where one reference is to the label, for the sake of the
2751 error if it is not defined. */
2752 DECL_SOURCE_LOCATION (decl) = input_location;
2754 /* Record the fact that this identifier is bound to this label. */
2755 SET_IDENTIFIER_LABEL_VALUE (id, decl);
2757 /* Create the label htab for the function on demand. */
2758 if (!named_labels)
2759 named_labels = htab_create_ggc (13, named_label_entry_hash,
2760 named_label_entry_eq, NULL);
2762 /* Record this label on the list of labels used in this function.
2763 We do this before calling make_label_decl so that we get the
2764 IDENTIFIER_LABEL_VALUE before the new label is declared. */
2765 ent = ggc_cleared_alloc<named_label_entry> ();
2766 ent->label_decl = decl;
2768 slot = htab_find_slot (named_labels, ent, INSERT);
2769 gcc_assert (*slot == NULL);
2770 *slot = ent;
2772 return decl;
2775 /* Look for a label named ID in the current function. If one cannot
2776 be found, create one. (We keep track of used, but undefined,
2777 labels, and complain about them at the end of a function.) */
2779 static tree
2780 lookup_label_1 (tree id)
2782 tree decl;
2784 /* You can't use labels at global scope. */
2785 if (current_function_decl == NULL_TREE)
2787 error ("label %qE referenced outside of any function", id);
2788 return NULL_TREE;
2791 /* See if we've already got this label. */
2792 decl = IDENTIFIER_LABEL_VALUE (id);
2793 if (decl != NULL_TREE && DECL_CONTEXT (decl) == current_function_decl)
2794 return decl;
2796 decl = make_label_decl (id, /*local_p=*/0);
2797 return decl;
2800 /* Wrapper for lookup_label_1. */
2802 tree
2803 lookup_label (tree id)
2805 tree ret;
2806 bool subtime = timevar_cond_start (TV_NAME_LOOKUP);
2807 ret = lookup_label_1 (id);
2808 timevar_cond_stop (TV_NAME_LOOKUP, subtime);
2809 return ret;
2812 /* Declare a local label named ID. */
2814 tree
2815 declare_local_label (tree id)
2817 tree decl;
2818 cp_label_binding bind;
2820 /* Add a new entry to the SHADOWED_LABELS list so that when we leave
2821 this scope we can restore the old value of IDENTIFIER_TYPE_VALUE. */
2822 bind.prev_value = IDENTIFIER_LABEL_VALUE (id);
2824 decl = make_label_decl (id, /*local_p=*/1);
2825 bind.label = decl;
2826 vec_safe_push (current_binding_level->shadowed_labels, bind);
2828 return decl;
2831 /* Returns nonzero if it is ill-formed to jump past the declaration of
2832 DECL. Returns 2 if it's also a real problem. */
2834 static int
2835 decl_jump_unsafe (tree decl)
2837 /* [stmt.dcl]/3: A program that jumps from a point where a local variable
2838 with automatic storage duration is not in scope to a point where it is
2839 in scope is ill-formed unless the variable has scalar type, class type
2840 with a trivial default constructor and a trivial destructor, a
2841 cv-qualified version of one of these types, or an array of one of the
2842 preceding types and is declared without an initializer (8.5). */
2843 tree type = TREE_TYPE (decl);
2845 if (!VAR_P (decl) || TREE_STATIC (decl)
2846 || type == error_mark_node)
2847 return 0;
2849 if (DECL_NONTRIVIALLY_INITIALIZED_P (decl)
2850 || variably_modified_type_p (type, NULL_TREE))
2851 return 2;
2853 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type))
2854 return 1;
2856 return 0;
2859 /* A subroutine of check_previous_goto_1 to identify a branch to the user. */
2861 static void
2862 identify_goto (tree decl, const location_t *locus)
2864 if (decl)
2865 permerror (input_location, "jump to label %qD", decl);
2866 else
2867 permerror (input_location, "jump to case label");
2868 if (locus)
2869 permerror (*locus, " from here");
2872 /* Check that a single previously seen jump to a newly defined label
2873 is OK. DECL is the LABEL_DECL or 0; LEVEL is the binding_level for
2874 the jump context; NAMES are the names in scope in LEVEL at the jump
2875 context; LOCUS is the source position of the jump or 0. Returns
2876 true if all is well. */
2878 static bool
2879 check_previous_goto_1 (tree decl, cp_binding_level* level, tree names,
2880 bool exited_omp, const location_t *locus)
2882 cp_binding_level *b;
2883 bool identified = false, saw_eh = false, saw_omp = false;
2885 if (exited_omp)
2887 identify_goto (decl, locus);
2888 error (" exits OpenMP structured block");
2889 identified = saw_omp = true;
2892 for (b = current_binding_level; b ; b = b->level_chain)
2894 tree new_decls, old_decls = (b == level ? names : NULL_TREE);
2896 for (new_decls = b->names; new_decls != old_decls;
2897 new_decls = (DECL_P (new_decls) ? DECL_CHAIN (new_decls)
2898 : TREE_CHAIN (new_decls)))
2900 int problem = decl_jump_unsafe (new_decls);
2901 if (! problem)
2902 continue;
2904 if (!identified)
2906 identify_goto (decl, locus);
2907 identified = true;
2909 if (problem > 1)
2910 error (" crosses initialization of %q+#D", new_decls);
2911 else
2912 permerror (input_location, " enters scope of %q+#D which has "
2913 "non-trivial destructor", new_decls);
2916 if (b == level)
2917 break;
2918 if ((b->kind == sk_try || b->kind == sk_catch) && !saw_eh)
2920 if (!identified)
2922 identify_goto (decl, locus);
2923 identified = true;
2925 if (b->kind == sk_try)
2926 error (" enters try block");
2927 else
2928 error (" enters catch block");
2929 saw_eh = true;
2931 if (b->kind == sk_omp && !saw_omp)
2933 if (!identified)
2935 identify_goto (decl, locus);
2936 identified = true;
2938 error (" enters OpenMP structured block");
2939 saw_omp = true;
2943 return !identified;
2946 static void
2947 check_previous_goto (tree decl, struct named_label_use_entry *use)
2949 check_previous_goto_1 (decl, use->binding_level,
2950 use->names_in_scope, use->in_omp_scope,
2951 &use->o_goto_locus);
2954 static bool
2955 check_switch_goto (cp_binding_level* level)
2957 return check_previous_goto_1 (NULL_TREE, level, level->names, false, NULL);
2960 /* Check that a new jump to a label DECL is OK. Called by
2961 finish_goto_stmt. */
2963 void
2964 check_goto (tree decl)
2966 struct named_label_entry *ent, dummy;
2967 bool saw_catch = false, identified = false;
2968 tree bad;
2969 unsigned ix;
2971 /* We can't know where a computed goto is jumping.
2972 So we assume that it's OK. */
2973 if (TREE_CODE (decl) != LABEL_DECL)
2974 return;
2976 /* We didn't record any information about this label when we created it,
2977 and there's not much point since it's trivial to analyze as a return. */
2978 if (decl == cdtor_label)
2979 return;
2981 dummy.label_decl = decl;
2982 ent = (struct named_label_entry *) htab_find (named_labels, &dummy);
2983 gcc_assert (ent != NULL);
2985 /* If the label hasn't been defined yet, defer checking. */
2986 if (! DECL_INITIAL (decl))
2988 struct named_label_use_entry *new_use;
2990 /* Don't bother creating another use if the last goto had the
2991 same data, and will therefore create the same set of errors. */
2992 if (ent->uses
2993 && ent->uses->names_in_scope == current_binding_level->names)
2994 return;
2996 new_use = ggc_alloc<named_label_use_entry> ();
2997 new_use->binding_level = current_binding_level;
2998 new_use->names_in_scope = current_binding_level->names;
2999 new_use->o_goto_locus = input_location;
3000 new_use->in_omp_scope = false;
3002 new_use->next = ent->uses;
3003 ent->uses = new_use;
3004 return;
3007 if (ent->in_try_scope || ent->in_catch_scope
3008 || ent->in_omp_scope || !vec_safe_is_empty (ent->bad_decls))
3010 permerror (input_location, "jump to label %q+D", decl);
3011 permerror (input_location, " from here");
3012 identified = true;
3015 FOR_EACH_VEC_SAFE_ELT (ent->bad_decls, ix, bad)
3017 int u = decl_jump_unsafe (bad);
3019 if (u > 1 && DECL_ARTIFICIAL (bad))
3021 /* Can't skip init of __exception_info. */
3022 error_at (DECL_SOURCE_LOCATION (bad), " enters catch block");
3023 saw_catch = true;
3025 else if (u > 1)
3026 error (" skips initialization of %q+#D", bad);
3027 else
3028 permerror (input_location, " enters scope of %q+#D which has "
3029 "non-trivial destructor", bad);
3032 if (ent->in_try_scope)
3033 error (" enters try block");
3034 else if (ent->in_catch_scope && !saw_catch)
3035 error (" enters catch block");
3037 if (ent->in_omp_scope)
3038 error (" enters OpenMP structured block");
3039 else if (flag_openmp)
3041 cp_binding_level *b;
3042 for (b = current_binding_level; b ; b = b->level_chain)
3044 if (b == ent->binding_level)
3045 break;
3046 if (b->kind == sk_omp)
3048 if (!identified)
3050 permerror (input_location, "jump to label %q+D", decl);
3051 permerror (input_location, " from here");
3052 identified = true;
3054 error (" exits OpenMP structured block");
3055 break;
3061 /* Check that a return is ok wrt OpenMP structured blocks.
3062 Called by finish_return_stmt. Returns true if all is well. */
3064 bool
3065 check_omp_return (void)
3067 cp_binding_level *b;
3068 for (b = current_binding_level; b ; b = b->level_chain)
3069 if (b->kind == sk_omp)
3071 error ("invalid exit from OpenMP structured block");
3072 return false;
3074 else if (b->kind == sk_function_parms)
3075 break;
3076 return true;
3079 /* Define a label, specifying the location in the source file.
3080 Return the LABEL_DECL node for the label. */
3082 static tree
3083 define_label_1 (location_t location, tree name)
3085 struct named_label_entry *ent, dummy;
3086 cp_binding_level *p;
3087 tree decl;
3089 decl = lookup_label (name);
3091 dummy.label_decl = decl;
3092 ent = (struct named_label_entry *) htab_find (named_labels, &dummy);
3093 gcc_assert (ent != NULL);
3095 /* After labels, make any new cleanups in the function go into their
3096 own new (temporary) binding contour. */
3097 for (p = current_binding_level;
3098 p->kind != sk_function_parms;
3099 p = p->level_chain)
3100 p->more_cleanups_ok = 0;
3102 if (name == get_identifier ("wchar_t"))
3103 permerror (input_location, "label named wchar_t");
3105 if (DECL_INITIAL (decl) != NULL_TREE)
3107 error ("duplicate label %qD", decl);
3108 return error_mark_node;
3110 else
3112 struct named_label_use_entry *use;
3114 /* Mark label as having been defined. */
3115 DECL_INITIAL (decl) = error_mark_node;
3116 /* Say where in the source. */
3117 DECL_SOURCE_LOCATION (decl) = location;
3119 ent->binding_level = current_binding_level;
3120 ent->names_in_scope = current_binding_level->names;
3122 for (use = ent->uses; use ; use = use->next)
3123 check_previous_goto (decl, use);
3124 ent->uses = NULL;
3127 return decl;
3130 /* Wrapper for define_label_1. */
3132 tree
3133 define_label (location_t location, tree name)
3135 tree ret;
3136 bool running = timevar_cond_start (TV_NAME_LOOKUP);
3137 ret = define_label_1 (location, name);
3138 timevar_cond_stop (TV_NAME_LOOKUP, running);
3139 return ret;
3143 struct cp_switch
3145 cp_binding_level *level;
3146 struct cp_switch *next;
3147 /* The SWITCH_STMT being built. */
3148 tree switch_stmt;
3149 /* A splay-tree mapping the low element of a case range to the high
3150 element, or NULL_TREE if there is no high element. Used to
3151 determine whether or not a new case label duplicates an old case
3152 label. We need a tree, rather than simply a hash table, because
3153 of the GNU case range extension. */
3154 splay_tree cases;
3157 /* A stack of the currently active switch statements. The innermost
3158 switch statement is on the top of the stack. There is no need to
3159 mark the stack for garbage collection because it is only active
3160 during the processing of the body of a function, and we never
3161 collect at that point. */
3163 static struct cp_switch *switch_stack;
3165 /* Called right after a switch-statement condition is parsed.
3166 SWITCH_STMT is the switch statement being parsed. */
3168 void
3169 push_switch (tree switch_stmt)
3171 struct cp_switch *p = XNEW (struct cp_switch);
3172 p->level = current_binding_level;
3173 p->next = switch_stack;
3174 p->switch_stmt = switch_stmt;
3175 p->cases = splay_tree_new (case_compare, NULL, NULL);
3176 switch_stack = p;
3179 void
3180 pop_switch (void)
3182 struct cp_switch *cs = switch_stack;
3183 location_t switch_location;
3185 /* Emit warnings as needed. */
3186 switch_location = EXPR_LOC_OR_LOC (cs->switch_stmt, input_location);
3187 if (!processing_template_decl)
3188 c_do_switch_warnings (cs->cases, switch_location,
3189 SWITCH_STMT_TYPE (cs->switch_stmt),
3190 SWITCH_STMT_COND (cs->switch_stmt));
3192 splay_tree_delete (cs->cases);
3193 switch_stack = switch_stack->next;
3194 free (cs);
3197 /* Convert a case constant VALUE in a switch to the type TYPE of the switch
3198 condition. Note that if TYPE and VALUE are already integral we don't
3199 really do the conversion because the language-independent
3200 warning/optimization code will work better that way. */
3202 static tree
3203 case_conversion (tree type, tree value)
3205 if (value == NULL_TREE)
3206 return value;
3208 if (cxx_dialect >= cxx11
3209 && (SCOPED_ENUM_P (type)
3210 || !INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (TREE_TYPE (value))))
3212 if (INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type))
3213 type = type_promotes_to (type);
3214 value = (perform_implicit_conversion_flags
3215 (type, value, tf_warning_or_error,
3216 LOOKUP_IMPLICIT | LOOKUP_NO_NON_INTEGRAL));
3218 return cxx_constant_value (value);
3221 /* Note that we've seen a definition of a case label, and complain if this
3222 is a bad place for one. */
3224 tree
3225 finish_case_label (location_t loc, tree low_value, tree high_value)
3227 tree cond, r;
3228 cp_binding_level *p;
3229 tree type;
3231 if (processing_template_decl)
3233 tree label;
3235 /* For templates, just add the case label; we'll do semantic
3236 analysis at instantiation-time. */
3237 label = build_decl (loc, LABEL_DECL, NULL_TREE, NULL_TREE);
3238 return add_stmt (build_case_label (low_value, high_value, label));
3241 /* Find the condition on which this switch statement depends. */
3242 cond = SWITCH_STMT_COND (switch_stack->switch_stmt);
3243 if (cond && TREE_CODE (cond) == TREE_LIST)
3244 cond = TREE_VALUE (cond);
3246 if (!check_switch_goto (switch_stack->level))
3247 return error_mark_node;
3249 type = SWITCH_STMT_TYPE (switch_stack->switch_stmt);
3251 low_value = case_conversion (type, low_value);
3252 high_value = case_conversion (type, high_value);
3254 r = c_add_case_label (loc, switch_stack->cases, cond, type,
3255 low_value, high_value);
3257 /* After labels, make any new cleanups in the function go into their
3258 own new (temporary) binding contour. */
3259 for (p = current_binding_level;
3260 p->kind != sk_function_parms;
3261 p = p->level_chain)
3262 p->more_cleanups_ok = 0;
3264 return r;
3267 /* Hash a TYPENAME_TYPE. K is really of type `tree'. */
3269 static hashval_t
3270 typename_hash (const void* k)
3272 hashval_t hash;
3273 const_tree const t = (const_tree) k;
3275 hash = (htab_hash_pointer (TYPE_CONTEXT (t))
3276 ^ htab_hash_pointer (TYPE_IDENTIFIER (t)));
3278 return hash;
3281 typedef struct typename_info {
3282 tree scope;
3283 tree name;
3284 tree template_id;
3285 bool enum_p;
3286 bool class_p;
3287 } typename_info;
3289 /* Compare two TYPENAME_TYPEs. K1 is really of type `tree', K2 is
3290 really of type `typename_info*' */
3292 static int
3293 typename_compare (const void * k1, const void * k2)
3295 const_tree const t1 = (const_tree) k1;
3296 const typename_info *const t2 = (const typename_info *) k2;
3298 return (TYPE_IDENTIFIER (t1) == t2->name
3299 && TYPE_CONTEXT (t1) == t2->scope
3300 && TYPENAME_TYPE_FULLNAME (t1) == t2->template_id
3301 && TYPENAME_IS_ENUM_P (t1) == t2->enum_p
3302 && TYPENAME_IS_CLASS_P (t1) == t2->class_p);
3305 /* Build a TYPENAME_TYPE. If the type is `typename T::t', CONTEXT is
3306 the type of `T', NAME is the IDENTIFIER_NODE for `t'.
3308 Returns the new TYPENAME_TYPE. */
3310 static GTY ((param_is (union tree_node))) htab_t typename_htab;
3312 static tree
3313 build_typename_type (tree context, tree name, tree fullname,
3314 enum tag_types tag_type)
3316 tree t;
3317 tree d;
3318 typename_info ti;
3319 void **e;
3320 hashval_t hash;
3322 if (typename_htab == NULL)
3323 typename_htab = htab_create_ggc (61, &typename_hash,
3324 &typename_compare, NULL);
3326 ti.scope = FROB_CONTEXT (context);
3327 ti.name = name;
3328 ti.template_id = fullname;
3329 ti.enum_p = tag_type == enum_type;
3330 ti.class_p = (tag_type == class_type
3331 || tag_type == record_type
3332 || tag_type == union_type);
3333 hash = (htab_hash_pointer (ti.scope)
3334 ^ htab_hash_pointer (ti.name));
3336 /* See if we already have this type. */
3337 e = htab_find_slot_with_hash (typename_htab, &ti, hash, INSERT);
3338 if (*e)
3339 t = (tree) *e;
3340 else
3342 /* Build the TYPENAME_TYPE. */
3343 t = cxx_make_type (TYPENAME_TYPE);
3344 TYPE_CONTEXT (t) = ti.scope;
3345 TYPENAME_TYPE_FULLNAME (t) = ti.template_id;
3346 TYPENAME_IS_ENUM_P (t) = ti.enum_p;
3347 TYPENAME_IS_CLASS_P (t) = ti.class_p;
3349 /* Build the corresponding TYPE_DECL. */
3350 d = build_decl (input_location, TYPE_DECL, name, t);
3351 TYPE_NAME (TREE_TYPE (d)) = d;
3352 TYPE_STUB_DECL (TREE_TYPE (d)) = d;
3353 DECL_CONTEXT (d) = FROB_CONTEXT (context);
3354 DECL_ARTIFICIAL (d) = 1;
3356 /* Store it in the hash table. */
3357 *e = t;
3359 /* TYPENAME_TYPEs must always be compared structurally, because
3360 they may or may not resolve down to another type depending on
3361 the currently open classes. */
3362 SET_TYPE_STRUCTURAL_EQUALITY (t);
3365 return t;
3368 /* Resolve `typename CONTEXT::NAME'. TAG_TYPE indicates the tag
3369 provided to name the type. Returns an appropriate type, unless an
3370 error occurs, in which case error_mark_node is returned. If we
3371 locate a non-artificial TYPE_DECL and TF_KEEP_TYPE_DECL is set, we
3372 return that, rather than the _TYPE it corresponds to, in other
3373 cases we look through the type decl. If TF_ERROR is set, complain
3374 about errors, otherwise be quiet. */
3376 tree
3377 make_typename_type (tree context, tree name, enum tag_types tag_type,
3378 tsubst_flags_t complain)
3380 tree fullname;
3381 tree t;
3382 bool want_template;
3384 if (name == error_mark_node
3385 || context == NULL_TREE
3386 || context == error_mark_node)
3387 return error_mark_node;
3389 if (TYPE_P (name))
3391 if (!(TYPE_LANG_SPECIFIC (name)
3392 && (CLASSTYPE_IS_TEMPLATE (name)
3393 || CLASSTYPE_USE_TEMPLATE (name))))
3394 name = TYPE_IDENTIFIER (name);
3395 else
3396 /* Create a TEMPLATE_ID_EXPR for the type. */
3397 name = build_nt (TEMPLATE_ID_EXPR,
3398 CLASSTYPE_TI_TEMPLATE (name),
3399 CLASSTYPE_TI_ARGS (name));
3401 else if (TREE_CODE (name) == TYPE_DECL)
3402 name = DECL_NAME (name);
3404 fullname = name;
3406 if (TREE_CODE (name) == TEMPLATE_ID_EXPR)
3408 name = TREE_OPERAND (name, 0);
3409 if (TREE_CODE (name) == TEMPLATE_DECL)
3410 name = TREE_OPERAND (fullname, 0) = DECL_NAME (name);
3411 else if (TREE_CODE (name) == OVERLOAD)
3413 if (complain & tf_error)
3414 error ("%qD is not a type", name);
3415 return error_mark_node;
3418 if (TREE_CODE (name) == TEMPLATE_DECL)
3420 if (complain & tf_error)
3421 error ("%qD used without template parameters", name);
3422 return error_mark_node;
3424 gcc_assert (identifier_p (name));
3425 gcc_assert (TYPE_P (context));
3427 if (!MAYBE_CLASS_TYPE_P (context))
3429 if (complain & tf_error)
3430 error ("%q#T is not a class", context);
3431 return error_mark_node;
3434 /* When the CONTEXT is a dependent type, NAME could refer to a
3435 dependent base class of CONTEXT. But look inside it anyway
3436 if CONTEXT is a currently open scope, in case it refers to a
3437 member of the current instantiation or a non-dependent base;
3438 lookup will stop when we hit a dependent base. */
3439 if (!dependent_scope_p (context))
3440 /* We should only set WANT_TYPE when we're a nested typename type.
3441 Then we can give better diagnostics if we find a non-type. */
3442 t = lookup_field (context, name, 2, /*want_type=*/true);
3443 else
3444 t = NULL_TREE;
3446 if ((!t || TREE_CODE (t) == TREE_LIST) && dependent_type_p (context))
3447 return build_typename_type (context, name, fullname, tag_type);
3449 want_template = TREE_CODE (fullname) == TEMPLATE_ID_EXPR;
3451 if (!t)
3453 if (complain & tf_error)
3454 error (want_template ? G_("no class template named %q#T in %q#T")
3455 : G_("no type named %q#T in %q#T"), name, context);
3456 return error_mark_node;
3459 /* Pull out the template from an injected-class-name (or multiple). */
3460 if (want_template)
3461 t = maybe_get_template_decl_from_type_decl (t);
3463 if (TREE_CODE (t) == TREE_LIST)
3465 if (complain & tf_error)
3467 error ("lookup of %qT in %qT is ambiguous", name, context);
3468 print_candidates (t);
3470 return error_mark_node;
3473 if (want_template && !DECL_TYPE_TEMPLATE_P (t))
3475 if (complain & tf_error)
3476 error ("%<typename %T::%D%> names %q#T, which is not a class template",
3477 context, name, t);
3478 return error_mark_node;
3480 if (!want_template && TREE_CODE (t) != TYPE_DECL)
3482 if (complain & tf_error)
3483 error ("%<typename %T::%D%> names %q#T, which is not a type",
3484 context, name, t);
3485 return error_mark_node;
3488 if (!perform_or_defer_access_check (TYPE_BINFO (context), t, t, complain))
3489 return error_mark_node;
3491 /* If we are currently parsing a template and if T is a typedef accessed
3492 through CONTEXT then we need to remember and check access of T at
3493 template instantiation time. */
3494 add_typedef_to_current_template_for_access_check (t, context, input_location);
3496 if (want_template)
3497 return lookup_template_class (t, TREE_OPERAND (fullname, 1),
3498 NULL_TREE, context,
3499 /*entering_scope=*/0,
3500 tf_warning_or_error | tf_user);
3502 if (DECL_ARTIFICIAL (t) || !(complain & tf_keep_type_decl))
3503 t = TREE_TYPE (t);
3505 maybe_record_typedef_use (t);
3507 return t;
3510 /* Resolve `CONTEXT::template NAME'. Returns a TEMPLATE_DECL if the name
3511 can be resolved or an UNBOUND_CLASS_TEMPLATE, unless an error occurs,
3512 in which case error_mark_node is returned.
3514 If PARM_LIST is non-NULL, also make sure that the template parameter
3515 list of TEMPLATE_DECL matches.
3517 If COMPLAIN zero, don't complain about any errors that occur. */
3519 tree
3520 make_unbound_class_template (tree context, tree name, tree parm_list,
3521 tsubst_flags_t complain)
3523 tree t;
3524 tree d;
3526 if (TYPE_P (name))
3527 name = TYPE_IDENTIFIER (name);
3528 else if (DECL_P (name))
3529 name = DECL_NAME (name);
3530 gcc_assert (identifier_p (name));
3532 if (!dependent_type_p (context)
3533 || currently_open_class (context))
3535 tree tmpl = NULL_TREE;
3537 if (MAYBE_CLASS_TYPE_P (context))
3538 tmpl = lookup_field (context, name, 0, false);
3540 if (tmpl && TREE_CODE (tmpl) == TYPE_DECL)
3541 tmpl = maybe_get_template_decl_from_type_decl (tmpl);
3543 if (!tmpl || !DECL_TYPE_TEMPLATE_P (tmpl))
3545 if (complain & tf_error)
3546 error ("no class template named %q#T in %q#T", name, context);
3547 return error_mark_node;
3550 if (parm_list
3551 && !comp_template_parms (DECL_TEMPLATE_PARMS (tmpl), parm_list))
3553 if (complain & tf_error)
3555 error ("template parameters do not match template %qD", tmpl);
3556 inform (DECL_SOURCE_LOCATION (tmpl),
3557 "%qD declared here", tmpl);
3559 return error_mark_node;
3562 if (!perform_or_defer_access_check (TYPE_BINFO (context), tmpl, tmpl,
3563 complain))
3564 return error_mark_node;
3566 return tmpl;
3569 /* Build the UNBOUND_CLASS_TEMPLATE. */
3570 t = cxx_make_type (UNBOUND_CLASS_TEMPLATE);
3571 TYPE_CONTEXT (t) = FROB_CONTEXT (context);
3572 TREE_TYPE (t) = NULL_TREE;
3573 SET_TYPE_STRUCTURAL_EQUALITY (t);
3575 /* Build the corresponding TEMPLATE_DECL. */
3576 d = build_decl (input_location, TEMPLATE_DECL, name, t);
3577 TYPE_NAME (TREE_TYPE (d)) = d;
3578 TYPE_STUB_DECL (TREE_TYPE (d)) = d;
3579 DECL_CONTEXT (d) = FROB_CONTEXT (context);
3580 DECL_ARTIFICIAL (d) = 1;
3581 DECL_TEMPLATE_PARMS (d) = parm_list;
3583 return t;
3588 /* Push the declarations of builtin types into the namespace.
3589 RID_INDEX is the index of the builtin type in the array
3590 RID_POINTERS. NAME is the name used when looking up the builtin
3591 type. TYPE is the _TYPE node for the builtin type. */
3593 void
3594 record_builtin_type (enum rid rid_index,
3595 const char* name,
3596 tree type)
3598 tree rname = NULL_TREE, tname = NULL_TREE;
3599 tree tdecl = NULL_TREE;
3601 if ((int) rid_index < (int) RID_MAX)
3602 rname = ridpointers[(int) rid_index];
3603 if (name)
3604 tname = get_identifier (name);
3606 /* The calls to SET_IDENTIFIER_GLOBAL_VALUE below should be
3607 eliminated. Built-in types should not be looked up name; their
3608 names are keywords that the parser can recognize. However, there
3609 is code in c-common.c that uses identifier_global_value to look
3610 up built-in types by name. */
3611 if (tname)
3613 tdecl = build_decl (BUILTINS_LOCATION, TYPE_DECL, tname, type);
3614 DECL_ARTIFICIAL (tdecl) = 1;
3615 SET_IDENTIFIER_GLOBAL_VALUE (tname, tdecl);
3617 if (rname)
3619 if (!tdecl)
3621 tdecl = build_decl (BUILTINS_LOCATION, TYPE_DECL, rname, type);
3622 DECL_ARTIFICIAL (tdecl) = 1;
3624 SET_IDENTIFIER_GLOBAL_VALUE (rname, tdecl);
3627 if (!TYPE_NAME (type))
3628 TYPE_NAME (type) = tdecl;
3630 if (tdecl)
3631 debug_hooks->type_decl (tdecl, 0);
3634 /* Record one of the standard Java types.
3635 * Declare it as having the given NAME.
3636 * If SIZE > 0, it is the size of one of the integral types;
3637 * otherwise it is the negative of the size of one of the other types. */
3639 static tree
3640 record_builtin_java_type (const char* name, int size)
3642 tree type, decl;
3643 if (size > 0)
3645 type = build_nonstandard_integer_type (size, 0);
3646 type = build_distinct_type_copy (type);
3648 else if (size > -32)
3650 tree stype;
3651 /* "__java_char" or ""__java_boolean". */
3652 type = build_nonstandard_integer_type (-size, 1);
3653 type = build_distinct_type_copy (type);
3654 /* Get the signed type cached and attached to the unsigned type,
3655 so it doesn't get garbage-collected at "random" times,
3656 causing potential codegen differences out of different UIDs
3657 and different alias set numbers. */
3658 stype = build_nonstandard_integer_type (-size, 0);
3659 stype = build_distinct_type_copy (stype);
3660 TREE_CHAIN (type) = stype;
3661 /*if (size == -1) TREE_SET_CODE (type, BOOLEAN_TYPE);*/
3663 else
3664 { /* "__java_float" or ""__java_double". */
3665 type = make_node (REAL_TYPE);
3666 TYPE_PRECISION (type) = - size;
3667 layout_type (type);
3669 record_builtin_type (RID_MAX, name, type);
3670 decl = TYPE_NAME (type);
3672 /* Suppress generate debug symbol entries for these types,
3673 since for normal C++ they are just clutter.
3674 However, push_lang_context undoes this if extern "Java" is seen. */
3675 DECL_IGNORED_P (decl) = 1;
3677 TYPE_FOR_JAVA (type) = 1;
3678 return type;
3681 /* Push a type into the namespace so that the back ends ignore it. */
3683 static void
3684 record_unknown_type (tree type, const char* name)
3686 tree decl = pushdecl (build_decl (UNKNOWN_LOCATION,
3687 TYPE_DECL, get_identifier (name), type));
3688 /* Make sure the "unknown type" typedecl gets ignored for debug info. */
3689 DECL_IGNORED_P (decl) = 1;
3690 TYPE_DECL_SUPPRESS_DEBUG (decl) = 1;
3691 TYPE_SIZE (type) = TYPE_SIZE (void_type_node);
3692 TYPE_ALIGN (type) = 1;
3693 TYPE_USER_ALIGN (type) = 0;
3694 SET_TYPE_MODE (type, TYPE_MODE (void_type_node));
3697 /* A string for which we should create an IDENTIFIER_NODE at
3698 startup. */
3700 typedef struct predefined_identifier
3702 /* The name of the identifier. */
3703 const char *const name;
3704 /* The place where the IDENTIFIER_NODE should be stored. */
3705 tree *const node;
3706 /* Nonzero if this is the name of a constructor or destructor. */
3707 const int ctor_or_dtor_p;
3708 } predefined_identifier;
3710 /* Create all the predefined identifiers. */
3712 static void
3713 initialize_predefined_identifiers (void)
3715 const predefined_identifier *pid;
3717 /* A table of identifiers to create at startup. */
3718 static const predefined_identifier predefined_identifiers[] = {
3719 { "C++", &lang_name_cplusplus, 0 },
3720 { "C", &lang_name_c, 0 },
3721 { "Java", &lang_name_java, 0 },
3722 /* Some of these names have a trailing space so that it is
3723 impossible for them to conflict with names written by users. */
3724 { "__ct ", &ctor_identifier, 1 },
3725 { "__base_ctor ", &base_ctor_identifier, 1 },
3726 { "__comp_ctor ", &complete_ctor_identifier, 1 },
3727 { "__dt ", &dtor_identifier, 1 },
3728 { "__comp_dtor ", &complete_dtor_identifier, 1 },
3729 { "__base_dtor ", &base_dtor_identifier, 1 },
3730 { "__deleting_dtor ", &deleting_dtor_identifier, 1 },
3731 { IN_CHARGE_NAME, &in_charge_identifier, 0 },
3732 { "nelts", &nelts_identifier, 0 },
3733 { THIS_NAME, &this_identifier, 0 },
3734 { VTABLE_DELTA_NAME, &delta_identifier, 0 },
3735 { VTABLE_PFN_NAME, &pfn_identifier, 0 },
3736 { "_vptr", &vptr_identifier, 0 },
3737 { "__vtt_parm", &vtt_parm_identifier, 0 },
3738 { "::", &global_scope_name, 0 },
3739 { "std", &std_identifier, 0 },
3740 { NULL, NULL, 0 }
3743 for (pid = predefined_identifiers; pid->name; ++pid)
3745 *pid->node = get_identifier (pid->name);
3746 if (pid->ctor_or_dtor_p)
3747 IDENTIFIER_CTOR_OR_DTOR_P (*pid->node) = 1;
3751 /* Create the predefined scalar types of C,
3752 and some nodes representing standard constants (0, 1, (void *)0).
3753 Initialize the global binding level.
3754 Make definitions for built-in primitive functions. */
3756 void
3757 cxx_init_decl_processing (void)
3759 tree void_ftype;
3760 tree void_ftype_ptr;
3762 /* Create all the identifiers we need. */
3763 initialize_predefined_identifiers ();
3765 /* Create the global variables. */
3766 push_to_top_level ();
3768 current_function_decl = NULL_TREE;
3769 current_binding_level = NULL;
3770 /* Enter the global namespace. */
3771 gcc_assert (global_namespace == NULL_TREE);
3772 global_namespace = build_lang_decl (NAMESPACE_DECL, global_scope_name,
3773 void_type_node);
3774 DECL_CONTEXT (global_namespace) = build_translation_unit_decl (NULL_TREE);
3775 TREE_PUBLIC (global_namespace) = 1;
3776 begin_scope (sk_namespace, global_namespace);
3778 if (flag_visibility_ms_compat)
3779 default_visibility = VISIBILITY_HIDDEN;
3781 /* Initially, C. */
3782 current_lang_name = lang_name_c;
3784 /* Create the `std' namespace. */
3785 push_namespace (std_identifier);
3786 std_node = current_namespace;
3787 pop_namespace ();
3789 c_common_nodes_and_builtins ();
3791 java_byte_type_node = record_builtin_java_type ("__java_byte", 8);
3792 java_short_type_node = record_builtin_java_type ("__java_short", 16);
3793 java_int_type_node = record_builtin_java_type ("__java_int", 32);
3794 java_long_type_node = record_builtin_java_type ("__java_long", 64);
3795 java_float_type_node = record_builtin_java_type ("__java_float", -32);
3796 java_double_type_node = record_builtin_java_type ("__java_double", -64);
3797 java_char_type_node = record_builtin_java_type ("__java_char", -16);
3798 java_boolean_type_node = record_builtin_java_type ("__java_boolean", -1);
3800 integer_two_node = build_int_cst (NULL_TREE, 2);
3802 record_builtin_type (RID_BOOL, "bool", boolean_type_node);
3803 truthvalue_type_node = boolean_type_node;
3804 truthvalue_false_node = boolean_false_node;
3805 truthvalue_true_node = boolean_true_node;
3807 empty_except_spec = build_tree_list (NULL_TREE, NULL_TREE);
3808 noexcept_true_spec = build_tree_list (boolean_true_node, NULL_TREE);
3809 noexcept_false_spec = build_tree_list (boolean_false_node, NULL_TREE);
3811 #if 0
3812 record_builtin_type (RID_MAX, NULL, string_type_node);
3813 #endif
3815 delta_type_node = ptrdiff_type_node;
3816 vtable_index_type = ptrdiff_type_node;
3818 vtt_parm_type = build_pointer_type (const_ptr_type_node);
3819 void_ftype = build_function_type_list (void_type_node, NULL_TREE);
3820 void_ftype_ptr = build_function_type_list (void_type_node,
3821 ptr_type_node, NULL_TREE);
3822 void_ftype_ptr
3823 = build_exception_variant (void_ftype_ptr, empty_except_spec);
3825 /* C++ extensions */
3827 unknown_type_node = make_node (LANG_TYPE);
3828 record_unknown_type (unknown_type_node, "unknown type");
3830 /* Indirecting an UNKNOWN_TYPE node yields an UNKNOWN_TYPE node. */
3831 TREE_TYPE (unknown_type_node) = unknown_type_node;
3833 /* Looking up TYPE_POINTER_TO and TYPE_REFERENCE_TO yield the same
3834 result. */
3835 TYPE_POINTER_TO (unknown_type_node) = unknown_type_node;
3836 TYPE_REFERENCE_TO (unknown_type_node) = unknown_type_node;
3838 init_list_type_node = make_node (LANG_TYPE);
3839 record_unknown_type (init_list_type_node, "init list");
3842 /* Make sure we get a unique function type, so we can give
3843 its pointer type a name. (This wins for gdb.) */
3844 tree vfunc_type = make_node (FUNCTION_TYPE);
3845 TREE_TYPE (vfunc_type) = integer_type_node;
3846 TYPE_ARG_TYPES (vfunc_type) = NULL_TREE;
3847 layout_type (vfunc_type);
3849 vtable_entry_type = build_pointer_type (vfunc_type);
3851 record_builtin_type (RID_MAX, VTBL_PTR_TYPE, vtable_entry_type);
3853 vtbl_type_node
3854 = build_cplus_array_type (vtable_entry_type, NULL_TREE);
3855 layout_type (vtbl_type_node);
3856 vtbl_type_node = cp_build_qualified_type (vtbl_type_node, TYPE_QUAL_CONST);
3857 record_builtin_type (RID_MAX, NULL, vtbl_type_node);
3858 vtbl_ptr_type_node = build_pointer_type (vtable_entry_type);
3859 layout_type (vtbl_ptr_type_node);
3860 record_builtin_type (RID_MAX, NULL, vtbl_ptr_type_node);
3862 push_namespace (get_identifier ("__cxxabiv1"));
3863 abi_node = current_namespace;
3864 pop_namespace ();
3866 global_type_node = make_node (LANG_TYPE);
3867 record_unknown_type (global_type_node, "global type");
3869 /* Now, C++. */
3870 current_lang_name = lang_name_cplusplus;
3873 tree newattrs, extvisattr;
3874 tree newtype, deltype;
3875 tree ptr_ftype_sizetype;
3876 tree new_eh_spec;
3878 ptr_ftype_sizetype
3879 = build_function_type_list (ptr_type_node, size_type_node, NULL_TREE);
3880 if (cxx_dialect == cxx98)
3882 tree bad_alloc_id;
3883 tree bad_alloc_type_node;
3884 tree bad_alloc_decl;
3886 push_namespace (std_identifier);
3887 bad_alloc_id = get_identifier ("bad_alloc");
3888 bad_alloc_type_node = make_class_type (RECORD_TYPE);
3889 TYPE_CONTEXT (bad_alloc_type_node) = current_namespace;
3890 bad_alloc_decl
3891 = create_implicit_typedef (bad_alloc_id, bad_alloc_type_node);
3892 DECL_CONTEXT (bad_alloc_decl) = current_namespace;
3893 pop_namespace ();
3895 new_eh_spec
3896 = add_exception_specifier (NULL_TREE, bad_alloc_type_node, -1);
3898 else
3899 new_eh_spec = noexcept_false_spec;
3901 /* Ensure attribs.c is initialized. */
3902 init_attributes ();
3903 extvisattr = build_tree_list (get_identifier ("externally_visible"),
3904 NULL_TREE);
3905 newattrs = tree_cons (get_identifier ("alloc_size"),
3906 build_tree_list (NULL_TREE, integer_one_node),
3907 extvisattr);
3908 newtype = cp_build_type_attribute_variant (ptr_ftype_sizetype, newattrs);
3909 newtype = build_exception_variant (newtype, new_eh_spec);
3910 deltype = cp_build_type_attribute_variant (void_ftype_ptr, extvisattr);
3911 deltype = build_exception_variant (deltype, empty_except_spec);
3912 tree opnew = push_cp_library_fn (NEW_EXPR, newtype, 0);
3913 DECL_IS_MALLOC (opnew) = 1;
3914 DECL_IS_OPERATOR_NEW (opnew) = 1;
3915 opnew = push_cp_library_fn (VEC_NEW_EXPR, newtype, 0);
3916 DECL_IS_MALLOC (opnew) = 1;
3917 DECL_IS_OPERATOR_NEW (opnew) = 1;
3918 global_delete_fndecl = push_cp_library_fn (DELETE_EXPR, deltype, ECF_NOTHROW);
3919 push_cp_library_fn (VEC_DELETE_EXPR, deltype, ECF_NOTHROW);
3921 nullptr_type_node = make_node (NULLPTR_TYPE);
3922 TYPE_SIZE (nullptr_type_node) = bitsize_int (GET_MODE_BITSIZE (ptr_mode));
3923 TYPE_SIZE_UNIT (nullptr_type_node) = size_int (GET_MODE_SIZE (ptr_mode));
3924 TYPE_UNSIGNED (nullptr_type_node) = 1;
3925 TYPE_PRECISION (nullptr_type_node) = GET_MODE_BITSIZE (ptr_mode);
3926 SET_TYPE_MODE (nullptr_type_node, ptr_mode);
3927 record_builtin_type (RID_MAX, "decltype(nullptr)", nullptr_type_node);
3928 nullptr_node = build_int_cst (nullptr_type_node, 0);
3931 abort_fndecl
3932 = build_library_fn_ptr ("__cxa_pure_virtual", void_ftype,
3933 ECF_NORETURN | ECF_NOTHROW);
3935 /* Perform other language dependent initializations. */
3936 init_class_processing ();
3937 init_rtti_processing ();
3938 init_template_processing ();
3940 if (flag_exceptions)
3941 init_exception_processing ();
3943 if (! supports_one_only ())
3944 flag_weak = 0;
3946 make_fname_decl = cp_make_fname_decl;
3947 start_fname_decls ();
3949 /* Show we use EH for cleanups. */
3950 if (flag_exceptions)
3951 using_eh_for_cleanups ();
3954 /* Generate an initializer for a function naming variable from
3955 NAME. NAME may be NULL, to indicate a dependent name. TYPE_P is
3956 filled in with the type of the init. */
3958 tree
3959 cp_fname_init (const char* name, tree *type_p)
3961 tree domain = NULL_TREE;
3962 tree type;
3963 tree init = NULL_TREE;
3964 size_t length = 0;
3966 if (name)
3968 length = strlen (name);
3969 domain = build_index_type (size_int (length));
3970 init = build_string (length + 1, name);
3973 type = cp_build_qualified_type (char_type_node, TYPE_QUAL_CONST);
3974 type = build_cplus_array_type (type, domain);
3976 *type_p = type;
3978 if (init)
3979 TREE_TYPE (init) = type;
3980 else
3981 init = error_mark_node;
3983 return init;
3986 /* Create the VAR_DECL for __FUNCTION__ etc. ID is the name to give
3987 the decl, LOC is the location to give the decl, NAME is the
3988 initialization string and TYPE_DEP indicates whether NAME depended
3989 on the type of the function. We make use of that to detect
3990 __PRETTY_FUNCTION__ inside a template fn. This is being done lazily
3991 at the point of first use, so we mustn't push the decl now. */
3993 static tree
3994 cp_make_fname_decl (location_t loc, tree id, int type_dep)
3996 const char *const name = (type_dep && processing_template_decl
3997 ? NULL : fname_as_string (type_dep));
3998 tree type;
3999 tree init = cp_fname_init (name, &type);
4000 tree decl = build_decl (loc, VAR_DECL, id, type);
4002 if (name)
4003 free (CONST_CAST (char *, name));
4005 /* As we're using pushdecl_with_scope, we must set the context. */
4006 DECL_CONTEXT (decl) = current_function_decl;
4008 TREE_STATIC (decl) = 1;
4009 TREE_READONLY (decl) = 1;
4010 DECL_ARTIFICIAL (decl) = 1;
4012 TREE_USED (decl) = 1;
4014 if (current_function_decl)
4016 cp_binding_level *b = current_binding_level;
4017 if (b->kind == sk_function_parms)
4018 return error_mark_node;
4019 while (b->level_chain->kind != sk_function_parms)
4020 b = b->level_chain;
4021 pushdecl_with_scope (decl, b, /*is_friend=*/false);
4022 cp_finish_decl (decl, init, /*init_const_expr_p=*/false, NULL_TREE,
4023 LOOKUP_ONLYCONVERTING);
4025 else
4027 DECL_THIS_STATIC (decl) = true;
4028 pushdecl_top_level_and_finish (decl, init);
4031 return decl;
4034 static tree
4035 builtin_function_1 (tree decl, tree context, bool is_global)
4037 tree id = DECL_NAME (decl);
4038 const char *name = IDENTIFIER_POINTER (id);
4040 retrofit_lang_decl (decl);
4042 DECL_ARTIFICIAL (decl) = 1;
4043 SET_OVERLOADED_OPERATOR_CODE (decl, ERROR_MARK);
4044 SET_DECL_LANGUAGE (decl, lang_c);
4045 /* Runtime library routines are, by definition, available in an
4046 external shared object. */
4047 DECL_VISIBILITY (decl) = VISIBILITY_DEFAULT;
4048 DECL_VISIBILITY_SPECIFIED (decl) = 1;
4050 DECL_CONTEXT (decl) = context;
4052 if (is_global)
4053 pushdecl_top_level (decl);
4054 else
4055 pushdecl (decl);
4057 /* A function in the user's namespace should have an explicit
4058 declaration before it is used. Mark the built-in function as
4059 anticipated but not actually declared. */
4060 if (name[0] != '_' || name[1] != '_')
4061 DECL_ANTICIPATED (decl) = 1;
4062 else if (strncmp (name + 2, "builtin_", strlen ("builtin_")) != 0)
4064 size_t len = strlen (name);
4066 /* Treat __*_chk fortification functions as anticipated as well,
4067 unless they are __builtin_*. */
4068 if (len > strlen ("___chk")
4069 && memcmp (name + len - strlen ("_chk"),
4070 "_chk", strlen ("_chk") + 1) == 0)
4071 DECL_ANTICIPATED (decl) = 1;
4074 return decl;
4077 tree
4078 cxx_builtin_function (tree decl)
4080 tree id = DECL_NAME (decl);
4081 const char *name = IDENTIFIER_POINTER (id);
4082 /* All builtins that don't begin with an '_' should additionally
4083 go in the 'std' namespace. */
4084 if (name[0] != '_')
4086 tree decl2 = copy_node(decl);
4087 push_namespace (std_identifier);
4088 builtin_function_1 (decl2, std_node, false);
4089 pop_namespace ();
4092 return builtin_function_1 (decl, NULL_TREE, false);
4095 /* Like cxx_builtin_function, but guarantee the function is added to the global
4096 scope. This is to allow function specific options to add new machine
4097 dependent builtins when the target ISA changes via attribute((target(...)))
4098 which saves space on program startup if the program does not use non-generic
4099 ISAs. */
4101 tree
4102 cxx_builtin_function_ext_scope (tree decl)
4105 tree id = DECL_NAME (decl);
4106 const char *name = IDENTIFIER_POINTER (id);
4107 /* All builtins that don't begin with an '_' should additionally
4108 go in the 'std' namespace. */
4109 if (name[0] != '_')
4111 tree decl2 = copy_node(decl);
4112 push_namespace (std_identifier);
4113 builtin_function_1 (decl2, std_node, true);
4114 pop_namespace ();
4117 return builtin_function_1 (decl, NULL_TREE, true);
4120 /* Generate a FUNCTION_DECL with the typical flags for a runtime library
4121 function. Not called directly. */
4123 static tree
4124 build_library_fn (tree name, enum tree_code operator_code, tree type,
4125 int ecf_flags)
4127 tree fn = build_lang_decl (FUNCTION_DECL, name, type);
4128 DECL_EXTERNAL (fn) = 1;
4129 TREE_PUBLIC (fn) = 1;
4130 DECL_ARTIFICIAL (fn) = 1;
4131 SET_OVERLOADED_OPERATOR_CODE (fn, operator_code);
4132 SET_DECL_LANGUAGE (fn, lang_c);
4133 /* Runtime library routines are, by definition, available in an
4134 external shared object. */
4135 DECL_VISIBILITY (fn) = VISIBILITY_DEFAULT;
4136 DECL_VISIBILITY_SPECIFIED (fn) = 1;
4137 set_call_expr_flags (fn, ecf_flags);
4138 return fn;
4141 /* Returns the _DECL for a library function with C++ linkage. */
4143 static tree
4144 build_cp_library_fn (tree name, enum tree_code operator_code, tree type,
4145 int ecf_flags)
4147 tree fn = build_library_fn (name, operator_code, type, ecf_flags);
4148 DECL_CONTEXT (fn) = FROB_CONTEXT (current_namespace);
4149 SET_DECL_LANGUAGE (fn, lang_cplusplus);
4150 return fn;
4153 /* Like build_library_fn, but takes a C string instead of an
4154 IDENTIFIER_NODE. */
4156 tree
4157 build_library_fn_ptr (const char* name, tree type, int ecf_flags)
4159 return build_library_fn (get_identifier (name), ERROR_MARK, type, ecf_flags);
4162 /* Like build_cp_library_fn, but takes a C string instead of an
4163 IDENTIFIER_NODE. */
4165 tree
4166 build_cp_library_fn_ptr (const char* name, tree type, int ecf_flags)
4168 return build_cp_library_fn (get_identifier (name), ERROR_MARK, type,
4169 ecf_flags);
4172 /* Like build_library_fn, but also pushes the function so that we will
4173 be able to find it via IDENTIFIER_GLOBAL_VALUE. Also, the function
4174 may throw exceptions listed in RAISES. */
4176 tree
4177 push_library_fn (tree name, tree type, tree raises, int ecf_flags)
4179 tree fn;
4181 if (raises)
4182 type = build_exception_variant (type, raises);
4184 fn = build_library_fn (name, ERROR_MARK, type, ecf_flags);
4185 pushdecl_top_level (fn);
4186 return fn;
4189 /* Like build_cp_library_fn, but also pushes the function so that it
4190 will be found by normal lookup. */
4192 static tree
4193 push_cp_library_fn (enum tree_code operator_code, tree type,
4194 int ecf_flags)
4196 tree fn = build_cp_library_fn (ansi_opname (operator_code),
4197 operator_code,
4198 type, ecf_flags);
4199 pushdecl (fn);
4200 if (flag_tm)
4201 apply_tm_attr (fn, get_identifier ("transaction_safe"));
4202 return fn;
4205 /* Like push_library_fn, but takes a TREE_LIST of parm types rather than
4206 a FUNCTION_TYPE. */
4208 tree
4209 push_void_library_fn (tree name, tree parmtypes, int ecf_flags)
4211 tree type = build_function_type (void_type_node, parmtypes);
4212 return push_library_fn (name, type, NULL_TREE, ecf_flags);
4215 /* Like push_library_fn, but also note that this function throws
4216 and does not return. Used for __throw_foo and the like. */
4218 tree
4219 push_throw_library_fn (tree name, tree type)
4221 tree fn = push_library_fn (name, type, NULL_TREE, ECF_NORETURN);
4222 return fn;
4225 /* When we call finish_struct for an anonymous union, we create
4226 default copy constructors and such. But, an anonymous union
4227 shouldn't have such things; this function undoes the damage to the
4228 anonymous union type T.
4230 (The reason that we create the synthesized methods is that we don't
4231 distinguish `union { int i; }' from `typedef union { int i; } U'.
4232 The first is an anonymous union; the second is just an ordinary
4233 union type.) */
4235 void
4236 fixup_anonymous_aggr (tree t)
4238 tree *q;
4240 /* Wipe out memory of synthesized methods. */
4241 TYPE_HAS_USER_CONSTRUCTOR (t) = 0;
4242 TYPE_HAS_DEFAULT_CONSTRUCTOR (t) = 0;
4243 TYPE_HAS_COPY_CTOR (t) = 0;
4244 TYPE_HAS_CONST_COPY_CTOR (t) = 0;
4245 TYPE_HAS_COPY_ASSIGN (t) = 0;
4246 TYPE_HAS_CONST_COPY_ASSIGN (t) = 0;
4248 /* Splice the implicitly generated functions out of the TYPE_METHODS
4249 list. */
4250 q = &TYPE_METHODS (t);
4251 while (*q)
4253 if (DECL_ARTIFICIAL (*q))
4254 *q = TREE_CHAIN (*q);
4255 else
4256 q = &DECL_CHAIN (*q);
4259 /* ISO C++ 9.5.3. Anonymous unions may not have function members. */
4260 if (TYPE_METHODS (t))
4262 tree decl = TYPE_MAIN_DECL (t);
4264 if (TREE_CODE (t) != UNION_TYPE)
4265 error_at (DECL_SOURCE_LOCATION (decl),
4266 "an anonymous struct cannot have function members");
4267 else
4268 error_at (DECL_SOURCE_LOCATION (decl),
4269 "an anonymous union cannot have function members");
4272 /* Anonymous aggregates cannot have fields with ctors, dtors or complex
4273 assignment operators (because they cannot have these methods themselves).
4274 For anonymous unions this is already checked because they are not allowed
4275 in any union, otherwise we have to check it. */
4276 if (TREE_CODE (t) != UNION_TYPE)
4278 tree field, type;
4280 for (field = TYPE_FIELDS (t); field; field = DECL_CHAIN (field))
4281 if (TREE_CODE (field) == FIELD_DECL)
4283 type = TREE_TYPE (field);
4284 if (CLASS_TYPE_P (type))
4286 if (TYPE_NEEDS_CONSTRUCTING (type))
4287 error ("member %q+#D with constructor not allowed "
4288 "in anonymous aggregate", field);
4289 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type))
4290 error ("member %q+#D with destructor not allowed "
4291 "in anonymous aggregate", field);
4292 if (TYPE_HAS_COMPLEX_COPY_ASSIGN (type))
4293 error ("member %q+#D with copy assignment operator "
4294 "not allowed in anonymous aggregate", field);
4300 /* Warn for an attribute located at LOCATION that appertains to the
4301 class type CLASS_TYPE that has not been properly placed after its
4302 class-key, in it class-specifier. */
4304 void
4305 warn_misplaced_attr_for_class_type (source_location location,
4306 tree class_type)
4308 gcc_assert (OVERLOAD_TYPE_P (class_type));
4310 if (warning_at (location, OPT_Wattributes,
4311 "attribute ignored in declaration "
4312 "of %q#T", class_type))
4313 inform (location,
4314 "attribute for %q#T must follow the %qs keyword",
4315 class_type, class_key_or_enum_as_string (class_type));
4318 /* Make sure that a declaration with no declarator is well-formed, i.e.
4319 just declares a tagged type or anonymous union.
4321 Returns the type declared; or NULL_TREE if none. */
4323 tree
4324 check_tag_decl (cp_decl_specifier_seq *declspecs,
4325 bool explicit_type_instantiation_p)
4327 int saw_friend = decl_spec_seq_has_spec_p (declspecs, ds_friend);
4328 int saw_typedef = decl_spec_seq_has_spec_p (declspecs, ds_typedef);
4329 /* If a class, struct, or enum type is declared by the DECLSPECS
4330 (i.e, if a class-specifier, enum-specifier, or non-typename
4331 elaborated-type-specifier appears in the DECLSPECS),
4332 DECLARED_TYPE is set to the corresponding type. */
4333 tree declared_type = NULL_TREE;
4334 bool error_p = false;
4336 if (declspecs->multiple_types_p)
4337 error ("multiple types in one declaration");
4338 else if (declspecs->redefined_builtin_type)
4340 if (!in_system_header_at (input_location))
4341 permerror (declspecs->locations[ds_redefined_builtin_type_spec],
4342 "redeclaration of C++ built-in type %qT",
4343 declspecs->redefined_builtin_type);
4344 return NULL_TREE;
4347 if (declspecs->type
4348 && TYPE_P (declspecs->type)
4349 && ((TREE_CODE (declspecs->type) != TYPENAME_TYPE
4350 && MAYBE_CLASS_TYPE_P (declspecs->type))
4351 || TREE_CODE (declspecs->type) == ENUMERAL_TYPE))
4352 declared_type = declspecs->type;
4353 else if (declspecs->type == error_mark_node)
4354 error_p = true;
4355 if (declared_type == NULL_TREE && ! saw_friend && !error_p)
4356 permerror (input_location, "declaration does not declare anything");
4357 else if (declared_type != NULL_TREE && type_uses_auto (declared_type))
4359 error ("%<auto%> can only be specified for variables "
4360 "or function declarations");
4361 return error_mark_node;
4363 /* Check for an anonymous union. */
4364 else if (declared_type && RECORD_OR_UNION_CODE_P (TREE_CODE (declared_type))
4365 && TYPE_ANONYMOUS_P (declared_type))
4367 /* 7/3 In a simple-declaration, the optional init-declarator-list
4368 can be omitted only when declaring a class (clause 9) or
4369 enumeration (7.2), that is, when the decl-specifier-seq contains
4370 either a class-specifier, an elaborated-type-specifier with
4371 a class-key (9.1), or an enum-specifier. In these cases and
4372 whenever a class-specifier or enum-specifier is present in the
4373 decl-specifier-seq, the identifiers in these specifiers are among
4374 the names being declared by the declaration (as class-name,
4375 enum-names, or enumerators, depending on the syntax). In such
4376 cases, and except for the declaration of an unnamed bit-field (9.6),
4377 the decl-specifier-seq shall introduce one or more names into the
4378 program, or shall redeclare a name introduced by a previous
4379 declaration. [Example:
4380 enum { }; // ill-formed
4381 typedef class { }; // ill-formed
4382 --end example] */
4383 if (saw_typedef)
4385 error ("missing type-name in typedef-declaration");
4386 return NULL_TREE;
4388 /* Anonymous unions are objects, so they can have specifiers. */;
4389 SET_ANON_AGGR_TYPE_P (declared_type);
4391 if (TREE_CODE (declared_type) != UNION_TYPE
4392 && !in_system_header_at (input_location))
4393 pedwarn (input_location, OPT_Wpedantic, "ISO C++ prohibits anonymous structs");
4396 else
4398 if (decl_spec_seq_has_spec_p (declspecs, ds_inline)
4399 || decl_spec_seq_has_spec_p (declspecs, ds_virtual))
4400 error ("%qs can only be specified for functions",
4401 decl_spec_seq_has_spec_p (declspecs, ds_inline)
4402 ? "inline" : "virtual");
4403 else if (saw_friend
4404 && (!current_class_type
4405 || current_scope () != current_class_type))
4406 error ("%<friend%> can only be specified inside a class");
4407 else if (decl_spec_seq_has_spec_p (declspecs, ds_explicit))
4408 error ("%<explicit%> can only be specified for constructors");
4409 else if (declspecs->storage_class)
4410 error ("a storage class can only be specified for objects "
4411 "and functions");
4412 else if (decl_spec_seq_has_spec_p (declspecs, ds_const)
4413 || decl_spec_seq_has_spec_p (declspecs, ds_volatile)
4414 || decl_spec_seq_has_spec_p (declspecs, ds_restrict)
4415 || decl_spec_seq_has_spec_p (declspecs, ds_thread))
4416 error ("qualifiers can only be specified for objects "
4417 "and functions");
4418 else if (saw_typedef)
4419 warning (0, "%<typedef%> was ignored in this declaration");
4420 else if (decl_spec_seq_has_spec_p (declspecs, ds_constexpr))
4421 error ("%<constexpr%> cannot be used for type declarations");
4424 if (declspecs->attributes && warn_attributes && declared_type)
4426 location_t loc;
4427 if (!CLASS_TYPE_P (declared_type)
4428 || !CLASSTYPE_TEMPLATE_INSTANTIATION (declared_type))
4429 /* For a non-template class, use the name location. */
4430 loc = location_of (declared_type);
4431 else
4432 /* For a template class (an explicit instantiation), use the
4433 current location. */
4434 loc = input_location;
4436 if (explicit_type_instantiation_p)
4437 /* [dcl.attr.grammar]/4:
4439 No attribute-specifier-seq shall appertain to an explicit
4440 instantiation. */
4442 if (warning_at (loc, OPT_Wattributes,
4443 "attribute ignored in explicit instantiation %q#T",
4444 declared_type))
4445 inform (loc,
4446 "no attribute can be applied to "
4447 "an explicit instantiation");
4449 else
4450 warn_misplaced_attr_for_class_type (loc, declared_type);
4453 return declared_type;
4456 /* Called when a declaration is seen that contains no names to declare.
4457 If its type is a reference to a structure, union or enum inherited
4458 from a containing scope, shadow that tag name for the current scope
4459 with a forward reference.
4460 If its type defines a new named structure or union
4461 or defines an enum, it is valid but we need not do anything here.
4462 Otherwise, it is an error.
4464 C++: may have to grok the declspecs to learn about static,
4465 complain for anonymous unions.
4467 Returns the TYPE declared -- or NULL_TREE if none. */
4469 tree
4470 shadow_tag (cp_decl_specifier_seq *declspecs)
4472 tree t = check_tag_decl (declspecs,
4473 /*explicit_type_instantiation_p=*/false);
4475 if (!t)
4476 return NULL_TREE;
4478 if (maybe_process_partial_specialization (t) == error_mark_node)
4479 return NULL_TREE;
4481 /* This is where the variables in an anonymous union are
4482 declared. An anonymous union declaration looks like:
4483 union { ... } ;
4484 because there is no declarator after the union, the parser
4485 sends that declaration here. */
4486 if (ANON_AGGR_TYPE_P (t))
4488 fixup_anonymous_aggr (t);
4490 if (TYPE_FIELDS (t))
4492 tree decl = grokdeclarator (/*declarator=*/NULL,
4493 declspecs, NORMAL, 0, NULL);
4494 finish_anon_union (decl);
4498 return t;
4501 /* Decode a "typename", such as "int **", returning a ..._TYPE node. */
4503 tree
4504 groktypename (cp_decl_specifier_seq *type_specifiers,
4505 const cp_declarator *declarator,
4506 bool is_template_arg)
4508 tree attrs;
4509 tree type;
4510 enum decl_context context
4511 = is_template_arg ? TEMPLATE_TYPE_ARG : TYPENAME;
4512 attrs = type_specifiers->attributes;
4513 type_specifiers->attributes = NULL_TREE;
4514 type = grokdeclarator (declarator, type_specifiers, context, 0, &attrs);
4515 if (attrs && type != error_mark_node)
4517 if (CLASS_TYPE_P (type))
4518 warning (OPT_Wattributes, "ignoring attributes applied to class type %qT "
4519 "outside of definition", type);
4520 else if (MAYBE_CLASS_TYPE_P (type))
4521 /* A template type parameter or other dependent type. */
4522 warning (OPT_Wattributes, "ignoring attributes applied to dependent "
4523 "type %qT without an associated declaration", type);
4524 else
4525 cplus_decl_attributes (&type, attrs, 0);
4527 return type;
4530 /* Process a DECLARATOR for a function-scope variable declaration,
4531 namespace-scope variable declaration, or function declaration.
4532 (Function definitions go through start_function; class member
4533 declarations appearing in the body of the class go through
4534 grokfield.) The DECL corresponding to the DECLARATOR is returned.
4535 If an error occurs, the error_mark_node is returned instead.
4537 DECLSPECS are the decl-specifiers for the declaration. INITIALIZED is
4538 SD_INITIALIZED if an explicit initializer is present, or SD_DEFAULTED
4539 for an explicitly defaulted function, or SD_DELETED for an explicitly
4540 deleted function, but 0 (SD_UNINITIALIZED) if this is a variable
4541 implicitly initialized via a default constructor. ATTRIBUTES and
4542 PREFIX_ATTRIBUTES are GNU attributes associated with this declaration.
4544 The scope represented by the context of the returned DECL is pushed
4545 (if it is not the global namespace) and is assigned to
4546 *PUSHED_SCOPE_P. The caller is then responsible for calling
4547 pop_scope on *PUSHED_SCOPE_P if it is set. */
4549 tree
4550 start_decl (const cp_declarator *declarator,
4551 cp_decl_specifier_seq *declspecs,
4552 int initialized,
4553 tree attributes,
4554 tree prefix_attributes,
4555 tree *pushed_scope_p)
4557 tree decl;
4558 tree context;
4559 bool was_public;
4560 int flags;
4561 bool alias;
4563 *pushed_scope_p = NULL_TREE;
4565 /* An object declared as __attribute__((deprecated)) suppresses
4566 warnings of uses of other deprecated items. */
4567 if (lookup_attribute ("deprecated", attributes))
4568 deprecated_state = DEPRECATED_SUPPRESS;
4570 attributes = chainon (attributes, prefix_attributes);
4572 decl = grokdeclarator (declarator, declspecs, NORMAL, initialized,
4573 &attributes);
4575 deprecated_state = DEPRECATED_NORMAL;
4577 if (decl == NULL_TREE || VOID_TYPE_P (decl)
4578 || decl == error_mark_node)
4579 return error_mark_node;
4581 context = CP_DECL_CONTEXT (decl);
4582 if (context != global_namespace)
4583 *pushed_scope_p = push_scope (context);
4585 if (initialized)
4586 /* Is it valid for this decl to have an initializer at all?
4587 If not, set INITIALIZED to zero, which will indirectly
4588 tell `cp_finish_decl' to ignore the initializer once it is parsed. */
4589 switch (TREE_CODE (decl))
4591 case TYPE_DECL:
4592 error ("typedef %qD is initialized (use decltype instead)", decl);
4593 return error_mark_node;
4595 case FUNCTION_DECL:
4596 if (initialized == SD_DELETED)
4597 /* We'll handle the rest of the semantics later, but we need to
4598 set this now so it's visible to duplicate_decls. */
4599 DECL_DELETED_FN (decl) = 1;
4600 break;
4602 default:
4603 break;
4606 if (initialized)
4608 if (! toplevel_bindings_p ()
4609 && DECL_EXTERNAL (decl))
4610 warning (0, "declaration of %q#D has %<extern%> and is initialized",
4611 decl);
4612 DECL_EXTERNAL (decl) = 0;
4613 if (toplevel_bindings_p ())
4614 TREE_STATIC (decl) = 1;
4616 alias = lookup_attribute ("alias", DECL_ATTRIBUTES (decl)) != 0;
4618 if (alias && TREE_CODE (decl) == FUNCTION_DECL)
4619 record_key_method_defined (decl);
4621 /* If this is a typedef that names the class for linkage purposes
4622 (7.1.3p8), apply any attributes directly to the type. */
4623 if (TREE_CODE (decl) == TYPE_DECL
4624 && OVERLOAD_TYPE_P (TREE_TYPE (decl))
4625 && decl == TYPE_NAME (TYPE_MAIN_VARIANT (TREE_TYPE (decl))))
4626 flags = ATTR_FLAG_TYPE_IN_PLACE;
4627 else
4628 flags = 0;
4630 /* Set attributes here so if duplicate decl, will have proper attributes. */
4631 cplus_decl_attributes (&decl, attributes, flags);
4633 /* Dllimported symbols cannot be defined. Static data members (which
4634 can be initialized in-class and dllimported) go through grokfield,
4635 not here, so we don't need to exclude those decls when checking for
4636 a definition. */
4637 if (initialized && DECL_DLLIMPORT_P (decl))
4639 error ("definition of %q#D is marked %<dllimport%>", decl);
4640 DECL_DLLIMPORT_P (decl) = 0;
4643 /* If #pragma weak was used, mark the decl weak now. */
4644 if (!processing_template_decl)
4645 maybe_apply_pragma_weak (decl);
4647 if (TREE_CODE (decl) == FUNCTION_DECL
4648 && DECL_DECLARED_INLINE_P (decl)
4649 && DECL_UNINLINABLE (decl)
4650 && lookup_attribute ("noinline", DECL_ATTRIBUTES (decl)))
4651 warning (0, "inline function %q+D given attribute noinline", decl);
4653 if (TYPE_P (context) && COMPLETE_TYPE_P (complete_type (context)))
4655 bool this_tmpl = (processing_template_decl
4656 > template_class_depth (context));
4657 if (VAR_P (decl))
4659 tree field = lookup_field (context, DECL_NAME (decl), 0, false);
4660 if (field == NULL_TREE
4661 || !(VAR_P (field) || variable_template_p (field)))
4662 error ("%q+#D is not a static data member of %q#T", decl, context);
4663 else if (variable_template_p (field) && !this_tmpl)
4665 if (DECL_LANG_SPECIFIC (decl)
4666 && DECL_TEMPLATE_SPECIALIZATION (decl))
4667 /* OK, specialization was already checked. */;
4668 else
4670 error_at (DECL_SOURCE_LOCATION (decl),
4671 "non-member-template declaration of %qD", decl);
4672 inform (DECL_SOURCE_LOCATION (field), "does not match "
4673 "member template declaration here");
4674 return error_mark_node;
4677 else
4679 if (variable_template_p (field))
4680 field = DECL_TEMPLATE_RESULT (field);
4682 if (DECL_CONTEXT (field) != context)
4684 if (!same_type_p (DECL_CONTEXT (field), context))
4685 permerror (input_location, "ISO C++ does not permit %<%T::%D%> "
4686 "to be defined as %<%T::%D%>",
4687 DECL_CONTEXT (field), DECL_NAME (decl),
4688 context, DECL_NAME (decl));
4689 DECL_CONTEXT (decl) = DECL_CONTEXT (field);
4691 /* Static data member are tricky; an in-class initialization
4692 still doesn't provide a definition, so the in-class
4693 declaration will have DECL_EXTERNAL set, but will have an
4694 initialization. Thus, duplicate_decls won't warn
4695 about this situation, and so we check here. */
4696 if (initialized && DECL_INITIALIZED_IN_CLASS_P (field))
4697 error ("duplicate initialization of %qD", decl);
4698 if (duplicate_decls (decl, field, /*newdecl_is_friend=*/false))
4699 decl = field;
4700 if (decl_spec_seq_has_spec_p (declspecs, ds_constexpr)
4701 && !DECL_DECLARED_CONSTEXPR_P (field))
4702 error ("%qD declared %<constexpr%> outside its class", field);
4705 else
4707 tree field = check_classfn (context, decl,
4708 this_tmpl
4709 ? current_template_parms
4710 : NULL_TREE);
4711 if (field && field != error_mark_node
4712 && duplicate_decls (decl, field,
4713 /*newdecl_is_friend=*/false))
4714 decl = field;
4717 /* cp_finish_decl sets DECL_EXTERNAL if DECL_IN_AGGR_P is set. */
4718 DECL_IN_AGGR_P (decl) = 0;
4719 /* Do not mark DECL as an explicit specialization if it was not
4720 already marked as an instantiation; a declaration should
4721 never be marked as a specialization unless we know what
4722 template is being specialized. */
4723 if (DECL_LANG_SPECIFIC (decl) && DECL_USE_TEMPLATE (decl))
4725 SET_DECL_TEMPLATE_SPECIALIZATION (decl);
4726 if (TREE_CODE (decl) == FUNCTION_DECL)
4727 DECL_COMDAT (decl) = (TREE_PUBLIC (decl)
4728 && DECL_DECLARED_INLINE_P (decl));
4729 else
4730 DECL_COMDAT (decl) = false;
4732 /* [temp.expl.spec] An explicit specialization of a static data
4733 member of a template is a definition if the declaration
4734 includes an initializer; otherwise, it is a declaration.
4736 We check for processing_specialization so this only applies
4737 to the new specialization syntax. */
4738 if (!initialized && processing_specialization)
4739 DECL_EXTERNAL (decl) = 1;
4742 if (DECL_EXTERNAL (decl) && ! DECL_TEMPLATE_SPECIALIZATION (decl)
4743 /* Aliases are definitions. */
4744 && !alias)
4745 permerror (input_location, "declaration of %q#D outside of class is not definition",
4746 decl);
4749 was_public = TREE_PUBLIC (decl);
4751 /* Enter this declaration into the symbol table. */
4752 decl = maybe_push_decl (decl);
4754 if (processing_template_decl)
4755 decl = push_template_decl (decl);
4756 if (decl == error_mark_node)
4757 return error_mark_node;
4759 if (VAR_P (decl)
4760 && DECL_NAMESPACE_SCOPE_P (decl) && !TREE_PUBLIC (decl) && !was_public
4761 && !DECL_THIS_STATIC (decl) && !DECL_ARTIFICIAL (decl))
4763 /* This is a const variable with implicit 'static'. Set
4764 DECL_THIS_STATIC so we can tell it from variables that are
4765 !TREE_PUBLIC because of the anonymous namespace. */
4766 gcc_assert (CP_TYPE_CONST_P (TREE_TYPE (decl)) || errorcount);
4767 DECL_THIS_STATIC (decl) = 1;
4770 if (!processing_template_decl && VAR_P (decl))
4771 start_decl_1 (decl, initialized);
4773 return decl;
4776 /* Process the declaration of a variable DECL. INITIALIZED is true
4777 iff DECL is explicitly initialized. (INITIALIZED is false if the
4778 variable is initialized via an implicitly-called constructor.)
4779 This function must be called for ordinary variables (including, for
4780 example, implicit instantiations of templates), but must not be
4781 called for template declarations. */
4783 void
4784 start_decl_1 (tree decl, bool initialized)
4786 tree type;
4787 bool complete_p;
4788 bool aggregate_definition_p;
4790 gcc_assert (!processing_template_decl);
4792 if (error_operand_p (decl))
4793 return;
4795 gcc_assert (VAR_P (decl));
4797 type = TREE_TYPE (decl);
4798 complete_p = COMPLETE_TYPE_P (type);
4799 aggregate_definition_p = MAYBE_CLASS_TYPE_P (type) && !DECL_EXTERNAL (decl);
4801 /* If an explicit initializer is present, or if this is a definition
4802 of an aggregate, then we need a complete type at this point.
4803 (Scalars are always complete types, so there is nothing to
4804 check.) This code just sets COMPLETE_P; errors (if necessary)
4805 are issued below. */
4806 if ((initialized || aggregate_definition_p)
4807 && !complete_p
4808 && COMPLETE_TYPE_P (complete_type (type)))
4810 complete_p = true;
4811 /* We will not yet have set TREE_READONLY on DECL if the type
4812 was "const", but incomplete, before this point. But, now, we
4813 have a complete type, so we can try again. */
4814 cp_apply_type_quals_to_decl (cp_type_quals (type), decl);
4817 if (initialized)
4818 /* Is it valid for this decl to have an initializer at all? */
4820 /* Don't allow initializations for incomplete types except for
4821 arrays which might be completed by the initialization. */
4822 if (complete_p)
4823 ; /* A complete type is ok. */
4824 else if (type_uses_auto (type))
4825 ; /* An auto type is ok. */
4826 else if (TREE_CODE (type) != ARRAY_TYPE)
4828 error ("variable %q#D has initializer but incomplete type", decl);
4829 type = TREE_TYPE (decl) = error_mark_node;
4831 else if (!COMPLETE_TYPE_P (complete_type (TREE_TYPE (type))))
4833 if (DECL_LANG_SPECIFIC (decl) && DECL_TEMPLATE_INFO (decl))
4834 error ("elements of array %q#D have incomplete type", decl);
4835 /* else we already gave an error in start_decl. */
4838 else if (aggregate_definition_p && !complete_p)
4840 if (type_uses_auto (type))
4841 error ("declaration of %q#D has no initializer", decl);
4842 else
4843 error ("aggregate %q#D has incomplete type and cannot be defined",
4844 decl);
4845 /* Change the type so that assemble_variable will give
4846 DECL an rtl we can live with: (mem (const_int 0)). */
4847 type = TREE_TYPE (decl) = error_mark_node;
4850 /* Create a new scope to hold this declaration if necessary.
4851 Whether or not a new scope is necessary cannot be determined
4852 until after the type has been completed; if the type is a
4853 specialization of a class template it is not until after
4854 instantiation has occurred that TYPE_HAS_NONTRIVIAL_DESTRUCTOR
4855 will be set correctly. */
4856 maybe_push_cleanup_level (type);
4859 /* Handle initialization of references. DECL, TYPE, and INIT have the
4860 same meaning as in cp_finish_decl. *CLEANUP must be NULL on entry,
4861 but will be set to a new CLEANUP_STMT if a temporary is created
4862 that must be destroyed subsequently.
4864 Returns an initializer expression to use to initialize DECL, or
4865 NULL if the initialization can be performed statically.
4867 Quotes on semantics can be found in ARM 8.4.3. */
4869 static tree
4870 grok_reference_init (tree decl, tree type, tree init, int flags)
4872 if (init == NULL_TREE)
4874 if ((DECL_LANG_SPECIFIC (decl) == 0
4875 || DECL_IN_AGGR_P (decl) == 0)
4876 && ! DECL_THIS_EXTERN (decl))
4877 error ("%qD declared as reference but not initialized", decl);
4878 return NULL_TREE;
4881 if (TREE_CODE (init) == TREE_LIST)
4882 init = build_x_compound_expr_from_list (init, ELK_INIT,
4883 tf_warning_or_error);
4885 if (TREE_CODE (TREE_TYPE (type)) != ARRAY_TYPE
4886 && TREE_CODE (TREE_TYPE (init)) == ARRAY_TYPE)
4887 /* Note: default conversion is only called in very special cases. */
4888 init = decay_conversion (init, tf_warning_or_error);
4890 /* Convert INIT to the reference type TYPE. This may involve the
4891 creation of a temporary, whose lifetime must be the same as that
4892 of the reference. If so, a DECL_EXPR for the temporary will be
4893 added just after the DECL_EXPR for DECL. That's why we don't set
4894 DECL_INITIAL for local references (instead assigning to them
4895 explicitly); we need to allow the temporary to be initialized
4896 first. */
4897 return initialize_reference (type, init, flags,
4898 tf_warning_or_error);
4901 /* Designated initializers in arrays are not supported in GNU C++.
4902 The parser cannot detect this error since it does not know whether
4903 a given brace-enclosed initializer is for a class type or for an
4904 array. This function checks that CE does not use a designated
4905 initializer. If it does, an error is issued. Returns true if CE
4906 is valid, i.e., does not have a designated initializer. */
4908 static bool
4909 check_array_designated_initializer (constructor_elt *ce,
4910 unsigned HOST_WIDE_INT index)
4912 /* Designated initializers for array elements are not supported. */
4913 if (ce->index)
4915 /* The parser only allows identifiers as designated
4916 initializers. */
4917 if (ce->index == error_mark_node)
4919 error ("name used in a GNU-style designated "
4920 "initializer for an array");
4921 return false;
4923 else if (identifier_p (ce->index))
4925 error ("name %qD used in a GNU-style designated "
4926 "initializer for an array", ce->index);
4927 return false;
4930 ce->index = cxx_constant_value (ce->index);
4932 if (TREE_CODE (ce->index) == INTEGER_CST)
4934 /* A C99 designator is OK if it matches the current index. */
4935 if (wi::eq_p (ce->index, index))
4936 return true;
4937 else
4938 sorry ("non-trivial designated initializers not supported");
4940 else
4941 gcc_unreachable ();
4943 return false;
4946 return true;
4949 /* When parsing `int a[] = {1, 2};' we don't know the size of the
4950 array until we finish parsing the initializer. If that's the
4951 situation we're in, update DECL accordingly. */
4953 static void
4954 maybe_deduce_size_from_array_init (tree decl, tree init)
4956 tree type = TREE_TYPE (decl);
4958 if (TREE_CODE (type) == ARRAY_TYPE
4959 && TYPE_DOMAIN (type) == NULL_TREE
4960 && TREE_CODE (decl) != TYPE_DECL)
4962 /* do_default is really a C-ism to deal with tentative definitions.
4963 But let's leave it here to ease the eventual merge. */
4964 int do_default = !DECL_EXTERNAL (decl);
4965 tree initializer = init ? init : DECL_INITIAL (decl);
4966 int failure = 0;
4968 /* Check that there are no designated initializers in INIT, as
4969 those are not supported in GNU C++, and as the middle-end
4970 will crash if presented with a non-numeric designated
4971 initializer. */
4972 if (initializer && BRACE_ENCLOSED_INITIALIZER_P (initializer))
4974 vec<constructor_elt, va_gc> *v = CONSTRUCTOR_ELTS (initializer);
4975 constructor_elt *ce;
4976 HOST_WIDE_INT i;
4977 FOR_EACH_VEC_SAFE_ELT (v, i, ce)
4978 if (!check_array_designated_initializer (ce, i))
4979 failure = 1;
4982 if (!failure)
4984 failure = cp_complete_array_type (&TREE_TYPE (decl), initializer,
4985 do_default);
4986 if (failure == 1)
4988 error ("initializer fails to determine size of %qD", decl);
4990 else if (failure == 2)
4992 if (do_default)
4994 error ("array size missing in %qD", decl);
4996 /* If a `static' var's size isn't known, make it extern as
4997 well as static, so it does not get allocated. If it's not
4998 `static', then don't mark it extern; finish_incomplete_decl
4999 will give it a default size and it will get allocated. */
5000 else if (!pedantic && TREE_STATIC (decl) && !TREE_PUBLIC (decl))
5001 DECL_EXTERNAL (decl) = 1;
5003 else if (failure == 3)
5005 error ("zero-size array %qD", decl);
5009 cp_apply_type_quals_to_decl (cp_type_quals (TREE_TYPE (decl)), decl);
5011 relayout_decl (decl);
5015 /* Set DECL_SIZE, DECL_ALIGN, etc. for DECL (a VAR_DECL), and issue
5016 any appropriate error messages regarding the layout. */
5018 static void
5019 layout_var_decl (tree decl)
5021 tree type;
5023 type = TREE_TYPE (decl);
5024 if (type == error_mark_node)
5025 return;
5027 /* If we haven't already laid out this declaration, do so now.
5028 Note that we must not call complete type for an external object
5029 because it's type might involve templates that we are not
5030 supposed to instantiate yet. (And it's perfectly valid to say
5031 `extern X x' for some incomplete type `X'.) */
5032 if (!DECL_EXTERNAL (decl))
5033 complete_type (type);
5034 if (!DECL_SIZE (decl)
5035 && TREE_TYPE (decl) != error_mark_node
5036 && (COMPLETE_TYPE_P (type)
5037 || (TREE_CODE (type) == ARRAY_TYPE
5038 && !TYPE_DOMAIN (type)
5039 && COMPLETE_TYPE_P (TREE_TYPE (type)))))
5040 layout_decl (decl, 0);
5042 if (!DECL_EXTERNAL (decl) && DECL_SIZE (decl) == NULL_TREE)
5044 /* An automatic variable with an incomplete type: that is an error.
5045 Don't talk about array types here, since we took care of that
5046 message in grokdeclarator. */
5047 error ("storage size of %qD isn%'t known", decl);
5048 TREE_TYPE (decl) = error_mark_node;
5050 #if 0
5051 /* Keep this code around in case we later want to control debug info
5052 based on whether a type is "used". (jason 1999-11-11) */
5054 else if (!DECL_EXTERNAL (decl) && MAYBE_CLASS_TYPE_P (ttype))
5055 /* Let debugger know it should output info for this type. */
5056 note_debug_info_needed (ttype);
5058 if (TREE_STATIC (decl) && DECL_CLASS_SCOPE_P (decl))
5059 note_debug_info_needed (DECL_CONTEXT (decl));
5060 #endif
5062 if ((DECL_EXTERNAL (decl) || TREE_STATIC (decl))
5063 && DECL_SIZE (decl) != NULL_TREE
5064 && ! TREE_CONSTANT (DECL_SIZE (decl)))
5066 if (TREE_CODE (DECL_SIZE (decl)) == INTEGER_CST)
5067 constant_expression_warning (DECL_SIZE (decl));
5068 else
5070 error ("storage size of %qD isn%'t constant", decl);
5071 TREE_TYPE (decl) = error_mark_node;
5076 /* If a local static variable is declared in an inline function, or if
5077 we have a weak definition, we must endeavor to create only one
5078 instance of the variable at link-time. */
5080 void
5081 maybe_commonize_var (tree decl)
5083 /* Static data in a function with comdat linkage also has comdat
5084 linkage. */
5085 if (TREE_STATIC (decl)
5086 /* Don't mess with __FUNCTION__. */
5087 && ! DECL_ARTIFICIAL (decl)
5088 && DECL_FUNCTION_SCOPE_P (decl)
5089 && vague_linkage_p (DECL_CONTEXT (decl)))
5091 if (flag_weak)
5093 /* With weak symbols, we simply make the variable COMDAT;
5094 that will cause copies in multiple translations units to
5095 be merged. */
5096 comdat_linkage (decl);
5098 else
5100 if (DECL_INITIAL (decl) == NULL_TREE
5101 || DECL_INITIAL (decl) == error_mark_node)
5103 /* Without weak symbols, we can use COMMON to merge
5104 uninitialized variables. */
5105 TREE_PUBLIC (decl) = 1;
5106 DECL_COMMON (decl) = 1;
5108 else
5110 /* While for initialized variables, we must use internal
5111 linkage -- which means that multiple copies will not
5112 be merged. */
5113 TREE_PUBLIC (decl) = 0;
5114 DECL_COMMON (decl) = 0;
5115 if (warning_at (DECL_SOURCE_LOCATION (decl), 0,
5116 "sorry: semantics of inline function static "
5117 "data %q#D are wrong (you%'ll wind up "
5118 "with multiple copies)", decl))
5119 inform (DECL_SOURCE_LOCATION (decl),
5120 "you can work around this by removing the initializer");
5126 /* Issue an error message if DECL is an uninitialized const variable. */
5128 static void
5129 check_for_uninitialized_const_var (tree decl)
5131 tree type = strip_array_types (TREE_TYPE (decl));
5133 /* ``Unless explicitly declared extern, a const object does not have
5134 external linkage and must be initialized. ($8.4; $12.1)'' ARM
5135 7.1.6 */
5136 if (VAR_P (decl)
5137 && TREE_CODE (type) != REFERENCE_TYPE
5138 && CP_TYPE_CONST_P (type)
5139 && !DECL_INITIAL (decl))
5141 tree field = default_init_uninitialized_part (type);
5142 if (!field)
5143 return;
5145 permerror (DECL_SOURCE_LOCATION (decl),
5146 "uninitialized const %qD", decl);
5148 if (CLASS_TYPE_P (type))
5150 tree defaulted_ctor;
5152 inform (DECL_SOURCE_LOCATION (TYPE_MAIN_DECL (type)),
5153 "%q#T has no user-provided default constructor", type);
5154 defaulted_ctor = in_class_defaulted_default_constructor (type);
5155 if (defaulted_ctor)
5156 inform (DECL_SOURCE_LOCATION (defaulted_ctor),
5157 "constructor is not user-provided because it is "
5158 "explicitly defaulted in the class body");
5159 inform (0, "and the implicitly-defined constructor does not "
5160 "initialize %q+#D", field);
5165 /* Structure holding the current initializer being processed by reshape_init.
5166 CUR is a pointer to the current element being processed, END is a pointer
5167 after the last element present in the initializer. */
5168 typedef struct reshape_iterator_t
5170 constructor_elt *cur;
5171 constructor_elt *end;
5172 } reshape_iter;
5174 static tree reshape_init_r (tree, reshape_iter *, bool, tsubst_flags_t);
5176 /* FIELD is a FIELD_DECL or NULL. In the former case, the value
5177 returned is the next FIELD_DECL (possibly FIELD itself) that can be
5178 initialized. If there are no more such fields, the return value
5179 will be NULL. */
5181 tree
5182 next_initializable_field (tree field)
5184 while (field
5185 && (TREE_CODE (field) != FIELD_DECL
5186 || (DECL_C_BIT_FIELD (field) && !DECL_NAME (field))
5187 || DECL_ARTIFICIAL (field)))
5188 field = DECL_CHAIN (field);
5190 return field;
5193 /* Subroutine of reshape_init_array and reshape_init_vector, which does
5194 the actual work. ELT_TYPE is the element type of the array. MAX_INDEX is an
5195 INTEGER_CST representing the size of the array minus one (the maximum index),
5196 or NULL_TREE if the array was declared without specifying the size. D is
5197 the iterator within the constructor. */
5199 static tree
5200 reshape_init_array_1 (tree elt_type, tree max_index, reshape_iter *d,
5201 tsubst_flags_t complain)
5203 tree new_init;
5204 bool sized_array_p = (max_index && TREE_CONSTANT (max_index));
5205 unsigned HOST_WIDE_INT max_index_cst = 0;
5206 unsigned HOST_WIDE_INT index;
5208 /* The initializer for an array is always a CONSTRUCTOR. */
5209 new_init = build_constructor (init_list_type_node, NULL);
5211 if (sized_array_p)
5213 /* Minus 1 is used for zero sized arrays. */
5214 if (integer_all_onesp (max_index))
5215 return new_init;
5217 if (tree_fits_uhwi_p (max_index))
5218 max_index_cst = tree_to_uhwi (max_index);
5219 /* sizetype is sign extended, not zero extended. */
5220 else
5221 max_index_cst = tree_to_uhwi (fold_convert (size_type_node, max_index));
5224 /* Loop until there are no more initializers. */
5225 for (index = 0;
5226 d->cur != d->end && (!sized_array_p || index <= max_index_cst);
5227 ++index)
5229 tree elt_init;
5230 constructor_elt *old_cur = d->cur;
5232 check_array_designated_initializer (d->cur, index);
5233 elt_init = reshape_init_r (elt_type, d, /*first_initializer_p=*/false,
5234 complain);
5235 if (elt_init == error_mark_node)
5236 return error_mark_node;
5237 CONSTRUCTOR_APPEND_ELT (CONSTRUCTOR_ELTS (new_init),
5238 size_int (index), elt_init);
5239 if (!TREE_CONSTANT (elt_init))
5240 TREE_CONSTANT (new_init) = false;
5242 /* This can happen with an invalid initializer (c++/54501). */
5243 if (d->cur == old_cur && !sized_array_p)
5244 break;
5247 return new_init;
5250 /* Subroutine of reshape_init_r, processes the initializers for arrays.
5251 Parameters are the same of reshape_init_r. */
5253 static tree
5254 reshape_init_array (tree type, reshape_iter *d, tsubst_flags_t complain)
5256 tree max_index = NULL_TREE;
5258 gcc_assert (TREE_CODE (type) == ARRAY_TYPE);
5260 if (TYPE_DOMAIN (type))
5261 max_index = array_type_nelts (type);
5263 return reshape_init_array_1 (TREE_TYPE (type), max_index, d, complain);
5266 /* Subroutine of reshape_init_r, processes the initializers for vectors.
5267 Parameters are the same of reshape_init_r. */
5269 static tree
5270 reshape_init_vector (tree type, reshape_iter *d, tsubst_flags_t complain)
5272 tree max_index = NULL_TREE;
5274 gcc_assert (TREE_CODE (type) == VECTOR_TYPE);
5276 if (COMPOUND_LITERAL_P (d->cur->value))
5278 tree value = d->cur->value;
5279 if (!same_type_p (TREE_TYPE (value), type))
5281 if (complain & tf_error)
5282 error ("invalid type %qT as initializer for a vector of type %qT",
5283 TREE_TYPE (d->cur->value), type);
5284 value = error_mark_node;
5286 ++d->cur;
5287 return value;
5290 /* For a vector, we initialize it as an array of the appropriate size. */
5291 if (TREE_CODE (type) == VECTOR_TYPE)
5292 max_index = size_int (TYPE_VECTOR_SUBPARTS (type) - 1);
5294 return reshape_init_array_1 (TREE_TYPE (type), max_index, d, complain);
5297 /* Subroutine of reshape_init_r, processes the initializers for classes
5298 or union. Parameters are the same of reshape_init_r. */
5300 static tree
5301 reshape_init_class (tree type, reshape_iter *d, bool first_initializer_p,
5302 tsubst_flags_t complain)
5304 tree field;
5305 tree new_init;
5307 gcc_assert (CLASS_TYPE_P (type));
5309 /* The initializer for a class is always a CONSTRUCTOR. */
5310 new_init = build_constructor (init_list_type_node, NULL);
5311 field = next_initializable_field (TYPE_FIELDS (type));
5313 if (!field)
5315 /* [dcl.init.aggr]
5317 An initializer for an aggregate member that is an
5318 empty class shall have the form of an empty
5319 initializer-list {}. */
5320 if (!first_initializer_p)
5322 if (complain & tf_error)
5323 error ("initializer for %qT must be brace-enclosed", type);
5324 return error_mark_node;
5326 return new_init;
5329 /* Loop through the initializable fields, gathering initializers. */
5330 while (d->cur != d->end)
5332 tree field_init;
5333 constructor_elt *old_cur = d->cur;
5335 /* Handle designated initializers, as an extension. */
5336 if (d->cur->index)
5338 if (d->cur->index == error_mark_node)
5339 return error_mark_node;
5341 if (TREE_CODE (d->cur->index) == FIELD_DECL)
5342 /* We already reshaped this. */
5343 gcc_assert (d->cur->index == field);
5344 else if (TREE_CODE (d->cur->index) == IDENTIFIER_NODE)
5345 field = lookup_field_1 (type, d->cur->index, /*want_type=*/false);
5346 else
5348 if (complain & tf_error)
5349 error ("%<[%E] =%> used in a GNU-style designated initializer"
5350 " for class %qT", d->cur->index, type);
5351 return error_mark_node;
5354 if (!field || TREE_CODE (field) != FIELD_DECL)
5356 if (complain & tf_error)
5357 error ("%qT has no non-static data member named %qD", type,
5358 d->cur->index);
5359 return error_mark_node;
5363 /* If we processed all the member of the class, we are done. */
5364 if (!field)
5365 break;
5367 field_init = reshape_init_r (TREE_TYPE (field), d,
5368 /*first_initializer_p=*/false, complain);
5369 if (field_init == error_mark_node)
5370 return error_mark_node;
5372 if (d->cur == old_cur && d->cur->index)
5374 /* This can happen with an invalid initializer for a flexible
5375 array member (c++/54441). */
5376 if (complain & tf_error)
5377 error ("invalid initializer for %q#D", field);
5378 return error_mark_node;
5381 CONSTRUCTOR_APPEND_ELT (CONSTRUCTOR_ELTS (new_init), field, field_init);
5383 /* [dcl.init.aggr]
5385 When a union is initialized with a brace-enclosed
5386 initializer, the braces shall only contain an
5387 initializer for the first member of the union. */
5388 if (TREE_CODE (type) == UNION_TYPE)
5389 break;
5391 field = next_initializable_field (DECL_CHAIN (field));
5394 return new_init;
5397 /* Subroutine of reshape_init_r. We're in a context where C99 initializer
5398 designators are not valid; either complain or return true to indicate
5399 that reshape_init_r should return error_mark_node. */
5401 static bool
5402 has_designator_problem (reshape_iter *d, tsubst_flags_t complain)
5404 if (d->cur->index)
5406 if (complain & tf_error)
5407 error ("C99 designator %qE outside aggregate initializer",
5408 d->cur->index);
5409 else
5410 return true;
5412 return false;
5415 /* Subroutine of reshape_init, which processes a single initializer (part of
5416 a CONSTRUCTOR). TYPE is the type of the variable being initialized, D is the
5417 iterator within the CONSTRUCTOR which points to the initializer to process.
5418 FIRST_INITIALIZER_P is true if this is the first initializer of the
5419 outermost CONSTRUCTOR node. */
5421 static tree
5422 reshape_init_r (tree type, reshape_iter *d, bool first_initializer_p,
5423 tsubst_flags_t complain)
5425 tree init = d->cur->value;
5427 if (error_operand_p (init))
5428 return error_mark_node;
5430 if (first_initializer_p && !CP_AGGREGATE_TYPE_P (type)
5431 && has_designator_problem (d, complain))
5432 return error_mark_node;
5434 if (TREE_CODE (type) == COMPLEX_TYPE)
5436 /* A complex type can be initialized from one or two initializers,
5437 but braces are not elided. */
5438 d->cur++;
5439 if (BRACE_ENCLOSED_INITIALIZER_P (init))
5441 if (CONSTRUCTOR_NELTS (init) > 2)
5443 if (complain & tf_error)
5444 error ("too many initializers for %qT", type);
5445 else
5446 return error_mark_node;
5449 else if (first_initializer_p && d->cur != d->end)
5451 vec<constructor_elt, va_gc> *v = 0;
5452 CONSTRUCTOR_APPEND_ELT (v, NULL_TREE, init);
5453 CONSTRUCTOR_APPEND_ELT (v, NULL_TREE, d->cur->value);
5454 if (has_designator_problem (d, complain))
5455 return error_mark_node;
5456 d->cur++;
5457 init = build_constructor (init_list_type_node, v);
5459 return init;
5462 /* A non-aggregate type is always initialized with a single
5463 initializer. */
5464 if (!CP_AGGREGATE_TYPE_P (type))
5466 /* It is invalid to initialize a non-aggregate type with a
5467 brace-enclosed initializer before C++0x.
5468 We need to check for BRACE_ENCLOSED_INITIALIZER_P here because
5469 of g++.old-deja/g++.mike/p7626.C: a pointer-to-member constant is
5470 a CONSTRUCTOR (with a record type). */
5471 if (TREE_CODE (init) == CONSTRUCTOR
5472 && BRACE_ENCLOSED_INITIALIZER_P (init)) /* p7626.C */
5474 if (SCALAR_TYPE_P (type))
5476 if (complain & tf_error)
5477 error ("braces around scalar initializer for type %qT", type);
5478 init = error_mark_node;
5480 else
5481 maybe_warn_cpp0x (CPP0X_INITIALIZER_LISTS);
5484 d->cur++;
5485 return init;
5488 /* "If T is a class type and the initializer list has a single element of
5489 type cv U, where U is T or a class derived from T, the object is
5490 initialized from that element." Even if T is an aggregate. */
5491 if (cxx_dialect >= cxx11 && (CLASS_TYPE_P (type) || VECTOR_TYPE_P (type))
5492 && first_initializer_p
5493 && d->end - d->cur == 1
5494 && reference_related_p (type, TREE_TYPE (init)))
5496 d->cur++;
5497 return init;
5500 /* [dcl.init.aggr]
5502 All implicit type conversions (clause _conv_) are considered when
5503 initializing the aggregate member with an initializer from an
5504 initializer-list. If the initializer can initialize a member,
5505 the member is initialized. Otherwise, if the member is itself a
5506 non-empty subaggregate, brace elision is assumed and the
5507 initializer is considered for the initialization of the first
5508 member of the subaggregate. */
5509 if (TREE_CODE (init) != CONSTRUCTOR
5510 /* But don't try this for the first initializer, since that would be
5511 looking through the outermost braces; A a2 = { a1 }; is not a
5512 valid aggregate initialization. */
5513 && !first_initializer_p
5514 && (same_type_ignoring_top_level_qualifiers_p (type, TREE_TYPE (init))
5515 || can_convert_arg (type, TREE_TYPE (init), init, LOOKUP_NORMAL,
5516 complain)))
5518 d->cur++;
5519 return init;
5522 /* [dcl.init.string]
5524 A char array (whether plain char, signed char, or unsigned char)
5525 can be initialized by a string-literal (optionally enclosed in
5526 braces); a wchar_t array can be initialized by a wide
5527 string-literal (optionally enclosed in braces). */
5528 if (TREE_CODE (type) == ARRAY_TYPE
5529 && char_type_p (TYPE_MAIN_VARIANT (TREE_TYPE (type))))
5531 tree str_init = init;
5533 /* Strip one level of braces if and only if they enclose a single
5534 element (as allowed by [dcl.init.string]). */
5535 if (!first_initializer_p
5536 && TREE_CODE (str_init) == CONSTRUCTOR
5537 && vec_safe_length (CONSTRUCTOR_ELTS (str_init)) == 1)
5539 str_init = (*CONSTRUCTOR_ELTS (str_init))[0].value;
5542 /* If it's a string literal, then it's the initializer for the array
5543 as a whole. Otherwise, continue with normal initialization for
5544 array types (one value per array element). */
5545 if (TREE_CODE (str_init) == STRING_CST)
5547 if (has_designator_problem (d, complain))
5548 return error_mark_node;
5549 d->cur++;
5550 return str_init;
5554 /* The following cases are about aggregates. If we are not within a full
5555 initializer already, and there is not a CONSTRUCTOR, it means that there
5556 is a missing set of braces (that is, we are processing the case for
5557 which reshape_init exists). */
5558 if (!first_initializer_p)
5560 if (TREE_CODE (init) == CONSTRUCTOR)
5562 if (TREE_TYPE (init) && TYPE_PTRMEMFUNC_P (TREE_TYPE (init)))
5563 /* There is no need to reshape pointer-to-member function
5564 initializers, as they are always constructed correctly
5565 by the front end. */
5567 else if (COMPOUND_LITERAL_P (init))
5568 /* For a nested compound literal, there is no need to reshape since
5569 brace elision is not allowed. Even if we decided to allow it,
5570 we should add a call to reshape_init in finish_compound_literal,
5571 before calling digest_init, so changing this code would still
5572 not be necessary. */
5573 gcc_assert (!BRACE_ENCLOSED_INITIALIZER_P (init));
5574 else
5576 ++d->cur;
5577 gcc_assert (BRACE_ENCLOSED_INITIALIZER_P (init));
5578 return reshape_init (type, init, complain);
5582 warning (OPT_Wmissing_braces, "missing braces around initializer for %qT",
5583 type);
5586 /* Dispatch to specialized routines. */
5587 if (CLASS_TYPE_P (type))
5588 return reshape_init_class (type, d, first_initializer_p, complain);
5589 else if (TREE_CODE (type) == ARRAY_TYPE)
5590 return reshape_init_array (type, d, complain);
5591 else if (TREE_CODE (type) == VECTOR_TYPE)
5592 return reshape_init_vector (type, d, complain);
5593 else
5594 gcc_unreachable();
5597 /* Undo the brace-elision allowed by [dcl.init.aggr] in a
5598 brace-enclosed aggregate initializer.
5600 INIT is the CONSTRUCTOR containing the list of initializers describing
5601 a brace-enclosed initializer for an entity of the indicated aggregate TYPE.
5602 It may not presently match the shape of the TYPE; for example:
5604 struct S { int a; int b; };
5605 struct S a[] = { 1, 2, 3, 4 };
5607 Here INIT will hold a vector of four elements, rather than a
5608 vector of two elements, each itself a vector of two elements. This
5609 routine transforms INIT from the former form into the latter. The
5610 revised CONSTRUCTOR node is returned. */
5612 tree
5613 reshape_init (tree type, tree init, tsubst_flags_t complain)
5615 vec<constructor_elt, va_gc> *v;
5616 reshape_iter d;
5617 tree new_init;
5619 gcc_assert (BRACE_ENCLOSED_INITIALIZER_P (init));
5621 v = CONSTRUCTOR_ELTS (init);
5623 /* An empty constructor does not need reshaping, and it is always a valid
5624 initializer. */
5625 if (vec_safe_is_empty (v))
5626 return init;
5628 /* Recurse on this CONSTRUCTOR. */
5629 d.cur = &(*v)[0];
5630 d.end = d.cur + v->length ();
5632 new_init = reshape_init_r (type, &d, true, complain);
5633 if (new_init == error_mark_node)
5634 return error_mark_node;
5636 /* Make sure all the element of the constructor were used. Otherwise,
5637 issue an error about exceeding initializers. */
5638 if (d.cur != d.end)
5640 if (complain & tf_error)
5641 error ("too many initializers for %qT", type);
5642 else
5643 return error_mark_node;
5646 return new_init;
5649 /* Verify array initializer. Returns true if errors have been reported. */
5651 bool
5652 check_array_initializer (tree decl, tree type, tree init)
5654 tree element_type = TREE_TYPE (type);
5656 /* The array type itself need not be complete, because the
5657 initializer may tell us how many elements are in the array.
5658 But, the elements of the array must be complete. */
5659 if (!COMPLETE_TYPE_P (complete_type (element_type)))
5661 if (decl)
5662 error ("elements of array %q#D have incomplete type", decl);
5663 else
5664 error ("elements of array %q#T have incomplete type", type);
5665 return true;
5667 /* A compound literal can't have variable size. */
5668 if (init && !decl
5669 && ((COMPLETE_TYPE_P (type) && !TREE_CONSTANT (TYPE_SIZE (type)))
5670 || !TREE_CONSTANT (TYPE_SIZE (element_type))))
5672 error ("variable-sized compound literal");
5673 return true;
5675 return false;
5678 /* Subroutine of check_initializer; args are passed down from that function.
5679 Set stmts_are_full_exprs_p to 1 across a call to build_aggr_init. */
5681 static tree
5682 build_aggr_init_full_exprs (tree decl, tree init, int flags)
5685 gcc_assert (stmts_are_full_exprs_p ());
5686 return build_aggr_init (decl, init, flags, tf_warning_or_error);
5689 /* Verify INIT (the initializer for DECL), and record the
5690 initialization in DECL_INITIAL, if appropriate. CLEANUP is as for
5691 grok_reference_init.
5693 If the return value is non-NULL, it is an expression that must be
5694 evaluated dynamically to initialize DECL. */
5696 static tree
5697 check_initializer (tree decl, tree init, int flags, vec<tree, va_gc> **cleanups)
5699 tree type = TREE_TYPE (decl);
5700 tree init_code = NULL;
5701 tree core_type;
5703 /* Things that are going to be initialized need to have complete
5704 type. */
5705 TREE_TYPE (decl) = type = complete_type (TREE_TYPE (decl));
5707 if (DECL_HAS_VALUE_EXPR_P (decl))
5709 /* A variable with DECL_HAS_VALUE_EXPR_P set is just a placeholder,
5710 it doesn't have storage to be initialized. */
5711 gcc_assert (init == NULL_TREE);
5712 return NULL_TREE;
5715 if (type == error_mark_node)
5716 /* We will have already complained. */
5717 return NULL_TREE;
5719 if (TREE_CODE (type) == ARRAY_TYPE)
5721 if (check_array_initializer (decl, type, init))
5722 return NULL_TREE;
5724 else if (!COMPLETE_TYPE_P (type))
5726 error ("%q#D has incomplete type", decl);
5727 TREE_TYPE (decl) = error_mark_node;
5728 return NULL_TREE;
5730 else
5731 /* There is no way to make a variable-sized class type in GNU C++. */
5732 gcc_assert (TREE_CONSTANT (TYPE_SIZE (type)));
5734 if (init && BRACE_ENCLOSED_INITIALIZER_P (init))
5736 int init_len = vec_safe_length (CONSTRUCTOR_ELTS (init));
5737 if (SCALAR_TYPE_P (type))
5739 if (init_len == 0)
5741 maybe_warn_cpp0x (CPP0X_INITIALIZER_LISTS);
5742 init = build_zero_init (type, NULL_TREE, false);
5744 else if (init_len != 1 && TREE_CODE (type) != COMPLEX_TYPE)
5746 error ("scalar object %qD requires one element in initializer",
5747 decl);
5748 TREE_TYPE (decl) = error_mark_node;
5749 return NULL_TREE;
5754 if (TREE_CODE (decl) == CONST_DECL)
5756 gcc_assert (TREE_CODE (type) != REFERENCE_TYPE);
5758 DECL_INITIAL (decl) = init;
5760 gcc_assert (init != NULL_TREE);
5761 init = NULL_TREE;
5763 else if (!init && DECL_REALLY_EXTERN (decl))
5765 else if (init || type_build_ctor_call (type)
5766 || TREE_CODE (type) == REFERENCE_TYPE)
5768 if (TREE_CODE (type) == REFERENCE_TYPE)
5770 init = grok_reference_init (decl, type, init, flags);
5771 flags |= LOOKUP_ALREADY_DIGESTED;
5773 else if (!init)
5774 check_for_uninitialized_const_var (decl);
5775 /* Do not reshape constructors of vectors (they don't need to be
5776 reshaped. */
5777 else if (BRACE_ENCLOSED_INITIALIZER_P (init))
5779 if (is_std_init_list (type))
5781 init = perform_implicit_conversion (type, init,
5782 tf_warning_or_error);
5783 flags |= LOOKUP_ALREADY_DIGESTED;
5785 else if (TYPE_NON_AGGREGATE_CLASS (type))
5787 /* Don't reshape if the class has constructors. */
5788 if (cxx_dialect == cxx98)
5789 error ("in C++98 %qD must be initialized by constructor, "
5790 "not by %<{...}%>",
5791 decl);
5793 else if (TREE_CODE (type) == VECTOR_TYPE && TYPE_VECTOR_OPAQUE (type))
5795 error ("opaque vector types cannot be initialized");
5796 init = error_mark_node;
5798 else
5800 init = reshape_init (type, init, tf_warning_or_error);
5801 flags |= LOOKUP_NO_NARROWING;
5804 else if (TREE_CODE (init) == TREE_LIST
5805 && TREE_TYPE (init) != unknown_type_node
5806 && !MAYBE_CLASS_TYPE_P (type))
5808 gcc_assert (TREE_CODE (decl) != RESULT_DECL);
5810 /* We get here with code like `int a (2);' */
5811 init = build_x_compound_expr_from_list (init, ELK_INIT,
5812 tf_warning_or_error);
5815 /* If DECL has an array type without a specific bound, deduce the
5816 array size from the initializer. */
5817 maybe_deduce_size_from_array_init (decl, init);
5818 type = TREE_TYPE (decl);
5819 if (type == error_mark_node)
5820 return NULL_TREE;
5822 if ((type_build_ctor_call (type) || CLASS_TYPE_P (type))
5823 && !(flags & LOOKUP_ALREADY_DIGESTED)
5824 && !(init && BRACE_ENCLOSED_INITIALIZER_P (init)
5825 && CP_AGGREGATE_TYPE_P (type)
5826 && (CLASS_TYPE_P (type)
5827 || !TYPE_NEEDS_CONSTRUCTING (type)
5828 || type_has_extended_temps (type))))
5830 init_code = build_aggr_init_full_exprs (decl, init, flags);
5832 /* A constructor call is a non-trivial initializer even if
5833 it isn't explicitly written. */
5834 if (TREE_SIDE_EFFECTS (init_code))
5835 DECL_NONTRIVIALLY_INITIALIZED_P (decl) = true;
5837 /* If this is a constexpr initializer, expand_default_init will
5838 have returned an INIT_EXPR rather than a CALL_EXPR. In that
5839 case, pull the initializer back out and pass it down into
5840 store_init_value. */
5841 while (TREE_CODE (init_code) == EXPR_STMT
5842 || TREE_CODE (init_code) == CONVERT_EXPR)
5843 init_code = TREE_OPERAND (init_code, 0);
5844 if (TREE_CODE (init_code) == INIT_EXPR)
5846 init = TREE_OPERAND (init_code, 1);
5847 init_code = NULL_TREE;
5848 /* Don't call digest_init; it's unnecessary and will complain
5849 about aggregate initialization of non-aggregate classes. */
5850 flags |= LOOKUP_ALREADY_DIGESTED;
5852 else if (DECL_DECLARED_CONSTEXPR_P (decl))
5854 /* Declared constexpr, but no suitable initializer; massage
5855 init appropriately so we can pass it into store_init_value
5856 for the error. */
5857 if (CLASS_TYPE_P (type)
5858 && (!init || TREE_CODE (init) == TREE_LIST))
5860 init = build_functional_cast (type, init, tf_none);
5861 if (TREE_CODE (init) == TARGET_EXPR)
5862 TARGET_EXPR_DIRECT_INIT_P (init) = true;
5864 init_code = NULL_TREE;
5866 else
5867 init = NULL_TREE;
5870 if (init && TREE_CODE (init) != TREE_VEC)
5872 /* In aggregate initialization of a variable, each element
5873 initialization is a full-expression because there is no
5874 enclosing expression. */
5875 gcc_assert (stmts_are_full_exprs_p ());
5877 init_code = store_init_value (decl, init, cleanups, flags);
5879 if (pedantic && TREE_CODE (type) == ARRAY_TYPE
5880 && DECL_INITIAL (decl)
5881 && TREE_CODE (DECL_INITIAL (decl)) == STRING_CST
5882 && PAREN_STRING_LITERAL_P (DECL_INITIAL (decl)))
5883 warning (0, "array %qD initialized by parenthesized string literal %qE",
5884 decl, DECL_INITIAL (decl));
5885 init = NULL;
5888 else
5890 if (CLASS_TYPE_P (core_type = strip_array_types (type))
5891 && (CLASSTYPE_READONLY_FIELDS_NEED_INIT (core_type)
5892 || CLASSTYPE_REF_FIELDS_NEED_INIT (core_type)))
5893 diagnose_uninitialized_cst_or_ref_member (core_type, /*using_new=*/false,
5894 /*complain=*/true);
5896 check_for_uninitialized_const_var (decl);
5899 if (init && init != error_mark_node)
5900 init_code = build2 (INIT_EXPR, type, decl, init);
5902 if (init_code)
5904 /* We might have set these in cp_finish_decl. */
5905 DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P (decl) = false;
5906 TREE_CONSTANT (decl) = false;
5909 if (init_code && DECL_IN_AGGR_P (decl))
5911 static int explained = 0;
5913 if (cxx_dialect < cxx11)
5914 error ("initializer invalid for static member with constructor");
5915 else
5916 error ("non-constant in-class initialization invalid for static "
5917 "member %qD", decl);
5918 if (!explained)
5920 inform (input_location,
5921 "(an out of class initialization is required)");
5922 explained = 1;
5924 return NULL_TREE;
5927 return init_code;
5930 /* If DECL is not a local variable, give it RTL. */
5932 static void
5933 make_rtl_for_nonlocal_decl (tree decl, tree init, const char* asmspec)
5935 int toplev = toplevel_bindings_p ();
5936 int defer_p;
5937 const char *filename;
5939 /* Set the DECL_ASSEMBLER_NAME for the object. */
5940 if (asmspec)
5942 /* The `register' keyword, when used together with an
5943 asm-specification, indicates that the variable should be
5944 placed in a particular register. */
5945 if (VAR_P (decl) && DECL_REGISTER (decl))
5947 set_user_assembler_name (decl, asmspec);
5948 DECL_HARD_REGISTER (decl) = 1;
5950 else
5952 if (TREE_CODE (decl) == FUNCTION_DECL
5953 && DECL_BUILT_IN_CLASS (decl) == BUILT_IN_NORMAL)
5954 set_builtin_user_assembler_name (decl, asmspec);
5955 set_user_assembler_name (decl, asmspec);
5959 /* Handle non-variables up front. */
5960 if (!VAR_P (decl))
5962 rest_of_decl_compilation (decl, toplev, at_eof);
5963 return;
5966 /* If we see a class member here, it should be a static data
5967 member. */
5968 if (DECL_LANG_SPECIFIC (decl) && DECL_IN_AGGR_P (decl))
5970 gcc_assert (TREE_STATIC (decl));
5971 /* An in-class declaration of a static data member should be
5972 external; it is only a declaration, and not a definition. */
5973 if (init == NULL_TREE)
5974 gcc_assert (DECL_EXTERNAL (decl) || !TREE_PUBLIC (decl));
5977 /* We don't create any RTL for local variables. */
5978 if (DECL_FUNCTION_SCOPE_P (decl) && !TREE_STATIC (decl))
5979 return;
5981 /* We defer emission of local statics until the corresponding
5982 DECL_EXPR is expanded. */
5983 defer_p = DECL_FUNCTION_SCOPE_P (decl) || DECL_VIRTUAL_P (decl);
5985 /* We try to defer namespace-scope static constants so that they are
5986 not emitted into the object file unnecessarily. */
5987 filename = LOCATION_FILE (input_location);
5988 if (!DECL_VIRTUAL_P (decl)
5989 && TREE_READONLY (decl)
5990 && DECL_INITIAL (decl) != NULL_TREE
5991 && DECL_INITIAL (decl) != error_mark_node
5992 && filename != NULL
5993 && ! EMPTY_CONSTRUCTOR_P (DECL_INITIAL (decl))
5994 && toplev
5995 && !TREE_PUBLIC (decl))
5997 /* Fool with the linkage of static consts according to #pragma
5998 interface. */
5999 struct c_fileinfo *finfo = get_fileinfo (filename);
6000 if (!finfo->interface_unknown && !TREE_PUBLIC (decl))
6002 TREE_PUBLIC (decl) = 1;
6003 DECL_EXTERNAL (decl) = finfo->interface_only;
6006 defer_p = 1;
6008 /* Likewise for template instantiations. */
6009 else if (DECL_LANG_SPECIFIC (decl)
6010 && DECL_IMPLICIT_INSTANTIATION (decl))
6011 defer_p = 1;
6013 /* If we're not deferring, go ahead and assemble the variable. */
6014 if (!defer_p)
6015 rest_of_decl_compilation (decl, toplev, at_eof);
6018 /* walk_tree helper for wrap_temporary_cleanups, below. */
6020 static tree
6021 wrap_cleanups_r (tree *stmt_p, int *walk_subtrees, void *data)
6023 /* Stop at types or full-expression boundaries. */
6024 if (TYPE_P (*stmt_p)
6025 || TREE_CODE (*stmt_p) == CLEANUP_POINT_EXPR)
6027 *walk_subtrees = 0;
6028 return NULL_TREE;
6031 if (TREE_CODE (*stmt_p) == TARGET_EXPR)
6033 tree guard = (tree)data;
6034 tree tcleanup = TARGET_EXPR_CLEANUP (*stmt_p);
6036 tcleanup = build2 (TRY_CATCH_EXPR, void_type_node, tcleanup, guard);
6037 /* Tell honor_protect_cleanup_actions to handle this as a separate
6038 cleanup. */
6039 TRY_CATCH_IS_CLEANUP (tcleanup) = 1;
6041 TARGET_EXPR_CLEANUP (*stmt_p) = tcleanup;
6044 return NULL_TREE;
6047 /* We're initializing a local variable which has a cleanup GUARD. If there
6048 are any temporaries used in the initializer INIT of this variable, we
6049 need to wrap their cleanups with TRY_CATCH_EXPR (, GUARD) so that the
6050 variable will be cleaned up properly if one of them throws.
6052 Unfortunately, there's no way to express this properly in terms of
6053 nesting, as the regions for the temporaries overlap the region for the
6054 variable itself; if there are two temporaries, the variable needs to be
6055 the first thing destroyed if either of them throws. However, we only
6056 want to run the variable's cleanup if it actually got constructed. So
6057 we need to guard the temporary cleanups with the variable's cleanup if
6058 they are run on the normal path, but not if they are run on the
6059 exceptional path. We implement this by telling
6060 honor_protect_cleanup_actions to strip the variable cleanup from the
6061 exceptional path. */
6063 static void
6064 wrap_temporary_cleanups (tree init, tree guard)
6066 cp_walk_tree_without_duplicates (&init, wrap_cleanups_r, (void *)guard);
6069 /* Generate code to initialize DECL (a local variable). */
6071 static void
6072 initialize_local_var (tree decl, tree init)
6074 tree type = TREE_TYPE (decl);
6075 tree cleanup;
6076 int already_used;
6078 gcc_assert (VAR_P (decl)
6079 || TREE_CODE (decl) == RESULT_DECL);
6080 gcc_assert (!TREE_STATIC (decl));
6082 if (DECL_SIZE (decl) == NULL_TREE)
6084 /* If we used it already as memory, it must stay in memory. */
6085 DECL_INITIAL (decl) = NULL_TREE;
6086 TREE_ADDRESSABLE (decl) = TREE_USED (decl);
6087 return;
6090 if (type == error_mark_node)
6091 return;
6093 /* Compute and store the initial value. */
6094 already_used = TREE_USED (decl) || TREE_USED (type);
6095 if (TREE_USED (type))
6096 DECL_READ_P (decl) = 1;
6098 /* Generate a cleanup, if necessary. */
6099 cleanup = cxx_maybe_build_cleanup (decl, tf_warning_or_error);
6101 /* Perform the initialization. */
6102 if (init)
6104 if (TREE_CODE (init) == INIT_EXPR
6105 && !TREE_SIDE_EFFECTS (TREE_OPERAND (init, 1)))
6107 /* Stick simple initializers in DECL_INITIAL so that
6108 -Wno-init-self works (c++/34772). */
6109 gcc_assert (TREE_OPERAND (init, 0) == decl);
6110 DECL_INITIAL (decl) = TREE_OPERAND (init, 1);
6112 else
6114 int saved_stmts_are_full_exprs_p;
6116 /* If we're only initializing a single object, guard the
6117 destructors of any temporaries used in its initializer with
6118 its destructor. This isn't right for arrays because each
6119 element initialization is a full-expression. */
6120 if (cleanup && TREE_CODE (type) != ARRAY_TYPE)
6121 wrap_temporary_cleanups (init, cleanup);
6123 gcc_assert (building_stmt_list_p ());
6124 saved_stmts_are_full_exprs_p = stmts_are_full_exprs_p ();
6125 current_stmt_tree ()->stmts_are_full_exprs_p = 1;
6126 finish_expr_stmt (init);
6127 current_stmt_tree ()->stmts_are_full_exprs_p =
6128 saved_stmts_are_full_exprs_p;
6132 /* Set this to 0 so we can tell whether an aggregate which was
6133 initialized was ever used. Don't do this if it has a
6134 destructor, so we don't complain about the 'resource
6135 allocation is initialization' idiom. Now set
6136 attribute((unused)) on types so decls of that type will be
6137 marked used. (see TREE_USED, above.) */
6138 if (TYPE_NEEDS_CONSTRUCTING (type)
6139 && ! already_used
6140 && TYPE_HAS_TRIVIAL_DESTRUCTOR (type)
6141 && DECL_NAME (decl))
6142 TREE_USED (decl) = 0;
6143 else if (already_used)
6144 TREE_USED (decl) = 1;
6146 if (cleanup)
6147 finish_decl_cleanup (decl, cleanup);
6150 /* DECL is a VAR_DECL for a compiler-generated variable with static
6151 storage duration (like a virtual table) whose initializer is a
6152 compile-time constant. Initialize the variable and provide it to the
6153 back end. */
6155 void
6156 initialize_artificial_var (tree decl, vec<constructor_elt, va_gc> *v)
6158 tree init;
6159 gcc_assert (DECL_ARTIFICIAL (decl));
6160 init = build_constructor (TREE_TYPE (decl), v);
6161 gcc_assert (TREE_CODE (init) == CONSTRUCTOR);
6162 DECL_INITIAL (decl) = init;
6163 DECL_INITIALIZED_P (decl) = 1;
6164 determine_visibility (decl);
6165 layout_var_decl (decl);
6166 maybe_commonize_var (decl);
6167 make_rtl_for_nonlocal_decl (decl, init, /*asmspec=*/NULL);
6170 /* INIT is the initializer for a variable, as represented by the
6171 parser. Returns true iff INIT is type-dependent. */
6173 static bool
6174 type_dependent_init_p (tree init)
6176 if (TREE_CODE (init) == TREE_LIST)
6177 /* A parenthesized initializer, e.g.: int i (3, 2); ? */
6178 return any_type_dependent_elements_p (init);
6179 else if (TREE_CODE (init) == CONSTRUCTOR)
6180 /* A brace-enclosed initializer, e.g.: int i = { 3 }; ? */
6182 vec<constructor_elt, va_gc> *elts;
6183 size_t nelts;
6184 size_t i;
6186 elts = CONSTRUCTOR_ELTS (init);
6187 nelts = vec_safe_length (elts);
6188 for (i = 0; i < nelts; ++i)
6189 if (type_dependent_init_p ((*elts)[i].value))
6190 return true;
6192 else
6193 /* It must be a simple expression, e.g., int i = 3; */
6194 return type_dependent_expression_p (init);
6196 return false;
6199 /* INIT is the initializer for a variable, as represented by the
6200 parser. Returns true iff INIT is value-dependent. */
6202 static bool
6203 value_dependent_init_p (tree init)
6205 if (TREE_CODE (init) == TREE_LIST)
6206 /* A parenthesized initializer, e.g.: int i (3, 2); ? */
6207 return any_value_dependent_elements_p (init);
6208 else if (TREE_CODE (init) == CONSTRUCTOR)
6209 /* A brace-enclosed initializer, e.g.: int i = { 3 }; ? */
6211 vec<constructor_elt, va_gc> *elts;
6212 size_t nelts;
6213 size_t i;
6215 elts = CONSTRUCTOR_ELTS (init);
6216 nelts = vec_safe_length (elts);
6217 for (i = 0; i < nelts; ++i)
6218 if (value_dependent_init_p ((*elts)[i].value))
6219 return true;
6221 else
6222 /* It must be a simple expression, e.g., int i = 3; */
6223 return value_dependent_expression_p (init);
6225 return false;
6228 /* Finish processing of a declaration;
6229 install its line number and initial value.
6230 If the length of an array type is not known before,
6231 it must be determined now, from the initial value, or it is an error.
6233 INIT is the initializer (if any) for DECL. If INIT_CONST_EXPR_P is
6234 true, then INIT is an integral constant expression.
6236 FLAGS is LOOKUP_ONLYCONVERTING if the = init syntax was used, else 0
6237 if the (init) syntax was used. */
6239 void
6240 cp_finish_decl (tree decl, tree init, bool init_const_expr_p,
6241 tree asmspec_tree, int flags)
6243 tree type;
6244 vec<tree, va_gc> *cleanups = NULL;
6245 const char *asmspec = NULL;
6246 int was_readonly = 0;
6247 bool var_definition_p = false;
6248 tree auto_node;
6250 if (decl == error_mark_node)
6251 return;
6252 else if (! decl)
6254 if (init)
6255 error ("assignment (not initialization) in declaration");
6256 return;
6259 gcc_assert (TREE_CODE (decl) != RESULT_DECL);
6260 /* Parameters are handled by store_parm_decls, not cp_finish_decl. */
6261 gcc_assert (TREE_CODE (decl) != PARM_DECL);
6263 type = TREE_TYPE (decl);
6264 if (type == error_mark_node)
6265 return;
6267 /* If a name was specified, get the string. */
6268 if (at_namespace_scope_p ())
6269 asmspec_tree = maybe_apply_renaming_pragma (decl, asmspec_tree);
6270 if (asmspec_tree && asmspec_tree != error_mark_node)
6271 asmspec = TREE_STRING_POINTER (asmspec_tree);
6273 if (current_class_type
6274 && CP_DECL_CONTEXT (decl) == current_class_type
6275 && TYPE_BEING_DEFINED (current_class_type)
6276 && !CLASSTYPE_TEMPLATE_INSTANTIATION (current_class_type)
6277 && (DECL_INITIAL (decl) || init))
6278 DECL_INITIALIZED_IN_CLASS_P (decl) = 1;
6280 if (TREE_CODE (decl) != FUNCTION_DECL
6281 && (auto_node = type_uses_auto (type)))
6283 tree d_init;
6284 if (init == NULL_TREE)
6286 if (DECL_LANG_SPECIFIC (decl)
6287 && DECL_TEMPLATE_INSTANTIATION (decl)
6288 && !DECL_TEMPLATE_INSTANTIATED (decl))
6290 /* init is null because we're deferring instantiating the
6291 initializer until we need it. Well, we need it now. */
6292 instantiate_decl (decl, /*defer_ok*/true, /*expl*/false);
6293 return;
6296 error ("declaration of %q#D has no initializer", decl);
6297 TREE_TYPE (decl) = error_mark_node;
6298 return;
6300 d_init = init;
6301 if (TREE_CODE (d_init) == TREE_LIST)
6302 d_init = build_x_compound_expr_from_list (d_init, ELK_INIT,
6303 tf_warning_or_error);
6304 d_init = resolve_nondeduced_context (d_init);
6305 type = TREE_TYPE (decl) = do_auto_deduction (type, d_init,
6306 auto_node);
6307 if (type == error_mark_node)
6308 return;
6309 cp_apply_type_quals_to_decl (cp_type_quals (type), decl);
6312 if (!ensure_literal_type_for_constexpr_object (decl))
6313 DECL_DECLARED_CONSTEXPR_P (decl) = 0;
6315 if (VAR_P (decl)
6316 && DECL_CLASS_SCOPE_P (decl)
6317 && DECL_INITIALIZED_IN_CLASS_P (decl))
6318 check_static_variable_definition (decl, type);
6320 if (init && TREE_CODE (decl) == FUNCTION_DECL)
6322 tree clone;
6323 if (init == ridpointers[(int)RID_DELETE])
6325 /* FIXME check this is 1st decl. */
6326 DECL_DELETED_FN (decl) = 1;
6327 DECL_DECLARED_INLINE_P (decl) = 1;
6328 DECL_INITIAL (decl) = error_mark_node;
6329 FOR_EACH_CLONE (clone, decl)
6331 DECL_DELETED_FN (clone) = 1;
6332 DECL_DECLARED_INLINE_P (clone) = 1;
6333 DECL_INITIAL (clone) = error_mark_node;
6335 init = NULL_TREE;
6337 else if (init == ridpointers[(int)RID_DEFAULT])
6339 if (defaultable_fn_check (decl))
6340 DECL_DEFAULTED_FN (decl) = 1;
6341 else
6342 DECL_INITIAL (decl) = NULL_TREE;
6346 if (init && VAR_P (decl))
6348 DECL_NONTRIVIALLY_INITIALIZED_P (decl) = 1;
6349 /* If DECL is a reference, then we want to know whether init is a
6350 reference constant; init_const_expr_p as passed tells us whether
6351 it's an rvalue constant. */
6352 if (TREE_CODE (type) == REFERENCE_TYPE)
6353 init_const_expr_p = potential_constant_expression (init);
6354 if (init_const_expr_p)
6356 /* Set these flags now for templates. We'll update the flags in
6357 store_init_value for instantiations. */
6358 DECL_INITIALIZED_BY_CONSTANT_EXPRESSION_P (decl) = 1;
6359 if (decl_maybe_constant_var_p (decl))
6360 TREE_CONSTANT (decl) = 1;
6364 if (processing_template_decl)
6366 bool type_dependent_p;
6368 /* Add this declaration to the statement-tree. */
6369 if (at_function_scope_p ())
6370 add_decl_expr (decl);
6372 type_dependent_p = dependent_type_p (type);
6374 if (check_for_bare_parameter_packs (init))
6376 init = NULL_TREE;
6377 DECL_INITIAL (decl) = NULL_TREE;
6380 /* Generally, initializers in templates are expanded when the
6381 template is instantiated. But, if DECL is a variable constant
6382 then it can be used in future constant expressions, so its value
6383 must be available. */
6385 if (!VAR_P (decl) || dependent_type_p (type))
6386 /* We can't do anything if the decl has dependent type. */;
6387 else if (init
6388 && init_const_expr_p
6389 && !type_dependent_p
6390 && decl_maybe_constant_var_p (decl)
6391 && !type_dependent_init_p (init)
6392 && !value_dependent_init_p (init))
6394 /* This variable seems to be a non-dependent constant, so process
6395 its initializer. If check_initializer returns non-null the
6396 initialization wasn't constant after all. */
6397 tree init_code;
6398 cleanups = make_tree_vector ();
6399 init_code = check_initializer (decl, init, flags, &cleanups);
6400 if (init_code == NULL_TREE)
6401 init = NULL_TREE;
6402 release_tree_vector (cleanups);
6404 else if (!DECL_PRETTY_FUNCTION_P (decl))
6406 /* Deduce array size even if the initializer is dependent. */
6407 maybe_deduce_size_from_array_init (decl, init);
6408 /* And complain about multiple initializers. */
6409 if (init && TREE_CODE (init) == TREE_LIST && TREE_CHAIN (init)
6410 && !MAYBE_CLASS_TYPE_P (type))
6411 init = build_x_compound_expr_from_list (init, ELK_INIT,
6412 tf_warning_or_error);
6415 if (init)
6416 DECL_INITIAL (decl) = init;
6417 return;
6420 /* Just store non-static data member initializers for later. */
6421 if (init && TREE_CODE (decl) == FIELD_DECL)
6422 DECL_INITIAL (decl) = init;
6424 /* Take care of TYPE_DECLs up front. */
6425 if (TREE_CODE (decl) == TYPE_DECL)
6427 if (type != error_mark_node
6428 && MAYBE_CLASS_TYPE_P (type) && DECL_NAME (decl))
6430 if (TREE_TYPE (DECL_NAME (decl)) && TREE_TYPE (decl) != type)
6431 warning (0, "shadowing previous type declaration of %q#D", decl);
6432 set_identifier_type_value (DECL_NAME (decl), decl);
6435 /* If we have installed this as the canonical typedef for this
6436 type, and that type has not been defined yet, delay emitting
6437 the debug information for it, as we will emit it later. */
6438 if (TYPE_MAIN_DECL (TREE_TYPE (decl)) == decl
6439 && !COMPLETE_TYPE_P (TREE_TYPE (decl)))
6440 TYPE_DECL_SUPPRESS_DEBUG (decl) = 1;
6442 rest_of_decl_compilation (decl, DECL_FILE_SCOPE_P (decl),
6443 at_eof);
6444 return;
6447 /* A reference will be modified here, as it is initialized. */
6448 if (! DECL_EXTERNAL (decl)
6449 && TREE_READONLY (decl)
6450 && TREE_CODE (type) == REFERENCE_TYPE)
6452 was_readonly = 1;
6453 TREE_READONLY (decl) = 0;
6456 if (VAR_P (decl))
6458 /* If this is a local variable that will need a mangled name,
6459 register it now. We must do this before processing the
6460 initializer for the variable, since the initialization might
6461 require a guard variable, and since the mangled name of the
6462 guard variable will depend on the mangled name of this
6463 variable. */
6464 if (DECL_FUNCTION_SCOPE_P (decl)
6465 && TREE_STATIC (decl)
6466 && !DECL_ARTIFICIAL (decl))
6468 push_local_name (decl);
6469 if (DECL_CONSTRUCTOR_P (current_function_decl)
6470 || DECL_DESTRUCTOR_P (current_function_decl))
6471 /* Normally local_decls is populated during GIMPLE lowering,
6472 but [cd]tors are never actually compiled directly. We need
6473 to put statics on the list so we can deal with the label
6474 address extension. FIXME. */
6475 add_local_decl (cfun, decl);
6478 /* Convert the initializer to the type of DECL, if we have not
6479 already initialized DECL. */
6480 if (!DECL_INITIALIZED_P (decl)
6481 /* If !DECL_EXTERNAL then DECL is being defined. In the
6482 case of a static data member initialized inside the
6483 class-specifier, there can be an initializer even if DECL
6484 is *not* defined. */
6485 && (!DECL_EXTERNAL (decl) || init))
6487 if (TYPE_FOR_JAVA (type) && MAYBE_CLASS_TYPE_P (type))
6489 tree jclass
6490 = IDENTIFIER_GLOBAL_VALUE (get_identifier ("jclass"));
6491 /* Allow libjava/prims.cc define primitive classes. */
6492 if (init != NULL_TREE
6493 || jclass == NULL_TREE
6494 || TREE_CODE (jclass) != TYPE_DECL
6495 || !POINTER_TYPE_P (TREE_TYPE (jclass))
6496 || !same_type_ignoring_top_level_qualifiers_p
6497 (type, TREE_TYPE (TREE_TYPE (jclass))))
6498 error ("Java object %qD not allocated with %<new%>", decl);
6499 init = NULL_TREE;
6501 cleanups = make_tree_vector ();
6502 init = check_initializer (decl, init, flags, &cleanups);
6504 /* Handle:
6506 [dcl.init]
6508 The memory occupied by any object of static storage
6509 duration is zero-initialized at program startup before
6510 any other initialization takes place.
6512 We cannot create an appropriate initializer until after
6513 the type of DECL is finalized. If DECL_INITIAL is set,
6514 then the DECL is statically initialized, and any
6515 necessary zero-initialization has already been performed. */
6516 if (TREE_STATIC (decl) && !DECL_INITIAL (decl))
6517 DECL_INITIAL (decl) = build_zero_init (TREE_TYPE (decl),
6518 /*nelts=*/NULL_TREE,
6519 /*static_storage_p=*/true);
6520 /* Remember that the initialization for this variable has
6521 taken place. */
6522 DECL_INITIALIZED_P (decl) = 1;
6523 /* This declaration is the definition of this variable,
6524 unless we are initializing a static data member within
6525 the class specifier. */
6526 if (!DECL_EXTERNAL (decl))
6527 var_definition_p = true;
6529 /* If the variable has an array type, lay out the type, even if
6530 there is no initializer. It is valid to index through the
6531 array, and we must get TYPE_ALIGN set correctly on the array
6532 type. */
6533 else if (TREE_CODE (type) == ARRAY_TYPE)
6534 layout_type (type);
6536 if (TREE_STATIC (decl)
6537 && !at_function_scope_p ()
6538 && current_function_decl == NULL)
6539 /* So decl is a global variable or a static member of a
6540 non local class. Record the types it uses
6541 so that we can decide later to emit debug info for them. */
6542 record_types_used_by_current_var_decl (decl);
6544 else if (TREE_CODE (decl) == FIELD_DECL
6545 && TYPE_FOR_JAVA (type) && MAYBE_CLASS_TYPE_P (type))
6546 error ("non-static data member %qD has Java class type", decl);
6548 /* Add this declaration to the statement-tree. This needs to happen
6549 after the call to check_initializer so that the DECL_EXPR for a
6550 reference temp is added before the DECL_EXPR for the reference itself. */
6551 if (DECL_FUNCTION_SCOPE_P (decl))
6553 /* If we're building a variable sized type, and we might be
6554 reachable other than via the top of the current binding
6555 level, then create a new BIND_EXPR so that we deallocate
6556 the object at the right time. */
6557 if (VAR_P (decl)
6558 && DECL_SIZE (decl)
6559 && !TREE_CONSTANT (DECL_SIZE (decl))
6560 && STATEMENT_LIST_HAS_LABEL (cur_stmt_list))
6562 tree bind;
6563 bind = build3 (BIND_EXPR, void_type_node, NULL, NULL, NULL);
6564 TREE_SIDE_EFFECTS (bind) = 1;
6565 add_stmt (bind);
6566 BIND_EXPR_BODY (bind) = push_stmt_list ();
6568 add_decl_expr (decl);
6571 /* Let the middle end know about variables and functions -- but not
6572 static data members in uninstantiated class templates. */
6573 if (VAR_OR_FUNCTION_DECL_P (decl))
6575 if (VAR_P (decl))
6577 layout_var_decl (decl);
6578 maybe_commonize_var (decl);
6581 /* This needs to happen after the linkage is set. */
6582 determine_visibility (decl);
6584 if (var_definition_p && TREE_STATIC (decl))
6586 /* If a TREE_READONLY variable needs initialization
6587 at runtime, it is no longer readonly and we need to
6588 avoid MEM_READONLY_P being set on RTL created for it. */
6589 if (init)
6591 if (TREE_READONLY (decl))
6592 TREE_READONLY (decl) = 0;
6593 was_readonly = 0;
6595 else if (was_readonly)
6596 TREE_READONLY (decl) = 1;
6598 /* Likewise if it needs destruction. */
6599 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type))
6600 TREE_READONLY (decl) = 0;
6603 make_rtl_for_nonlocal_decl (decl, init, asmspec);
6605 /* Check for abstractness of the type. Notice that there is no
6606 need to strip array types here since the check for those types
6607 is already done within create_array_type_for_decl. */
6608 abstract_virtuals_error (decl, type);
6610 if (TREE_TYPE (decl) == error_mark_node)
6611 /* No initialization required. */
6613 else if (TREE_CODE (decl) == FUNCTION_DECL)
6615 if (init)
6617 if (init == ridpointers[(int)RID_DEFAULT])
6619 /* An out-of-class default definition is defined at
6620 the point where it is explicitly defaulted. */
6621 if (DECL_DELETED_FN (decl))
6622 maybe_explain_implicit_delete (decl);
6623 else if (DECL_INITIAL (decl) == error_mark_node)
6624 synthesize_method (decl);
6626 else
6627 error ("function %q#D is initialized like a variable", decl);
6629 /* else no initialization required. */
6631 else if (DECL_EXTERNAL (decl)
6632 && ! (DECL_LANG_SPECIFIC (decl)
6633 && DECL_NOT_REALLY_EXTERN (decl)))
6635 if (init)
6636 DECL_INITIAL (decl) = init;
6638 /* A variable definition. */
6639 else if (DECL_FUNCTION_SCOPE_P (decl) && !TREE_STATIC (decl))
6640 /* Initialize the local variable. */
6641 initialize_local_var (decl, init);
6643 /* If a variable is defined, and then a subsequent
6644 definition with external linkage is encountered, we will
6645 get here twice for the same variable. We want to avoid
6646 calling expand_static_init more than once. For variables
6647 that are not static data members, we can call
6648 expand_static_init only when we actually process the
6649 initializer. It is not legal to redeclare a static data
6650 member, so this issue does not arise in that case. */
6651 else if (var_definition_p && TREE_STATIC (decl))
6652 expand_static_init (decl, init);
6655 /* If a CLEANUP_STMT was created to destroy a temporary bound to a
6656 reference, insert it in the statement-tree now. */
6657 if (cleanups)
6659 unsigned i; tree t;
6660 FOR_EACH_VEC_ELT (*cleanups, i, t)
6661 push_cleanup (decl, t, false);
6662 release_tree_vector (cleanups);
6665 if (was_readonly)
6666 TREE_READONLY (decl) = 1;
6668 invoke_plugin_callbacks (PLUGIN_FINISH_DECL, decl);
6671 /* Returns a declaration for a VAR_DECL as if:
6673 extern "C" TYPE NAME;
6675 had been seen. Used to create compiler-generated global
6676 variables. */
6678 static tree
6679 declare_global_var (tree name, tree type)
6681 tree decl;
6683 push_to_top_level ();
6684 decl = build_decl (input_location, VAR_DECL, name, type);
6685 TREE_PUBLIC (decl) = 1;
6686 DECL_EXTERNAL (decl) = 1;
6687 DECL_ARTIFICIAL (decl) = 1;
6688 /* If the user has explicitly declared this variable (perhaps
6689 because the code we are compiling is part of a low-level runtime
6690 library), then it is possible that our declaration will be merged
6691 with theirs by pushdecl. */
6692 decl = pushdecl (decl);
6693 cp_finish_decl (decl, NULL_TREE, false, NULL_TREE, 0);
6694 pop_from_top_level ();
6696 return decl;
6699 /* Returns the type for the argument to "__cxa_atexit" (or "atexit",
6700 if "__cxa_atexit" is not being used) corresponding to the function
6701 to be called when the program exits. */
6703 static tree
6704 get_atexit_fn_ptr_type (void)
6706 tree fn_type;
6708 if (!atexit_fn_ptr_type_node)
6710 tree arg_type;
6711 if (flag_use_cxa_atexit
6712 && !targetm.cxx.use_atexit_for_cxa_atexit ())
6713 /* The parameter to "__cxa_atexit" is "void (*)(void *)". */
6714 arg_type = ptr_type_node;
6715 else
6716 /* The parameter to "atexit" is "void (*)(void)". */
6717 arg_type = NULL_TREE;
6719 fn_type = build_function_type_list (void_type_node,
6720 arg_type, NULL_TREE);
6721 atexit_fn_ptr_type_node = build_pointer_type (fn_type);
6724 return atexit_fn_ptr_type_node;
6727 /* Returns a pointer to the `atexit' function. Note that if
6728 FLAG_USE_CXA_ATEXIT is nonzero, then this will actually be the new
6729 `__cxa_atexit' function specified in the IA64 C++ ABI. */
6731 static tree
6732 get_atexit_node (void)
6734 tree atexit_fndecl;
6735 tree fn_type;
6736 tree fn_ptr_type;
6737 const char *name;
6738 bool use_aeabi_atexit;
6740 if (atexit_node)
6741 return atexit_node;
6743 if (flag_use_cxa_atexit && !targetm.cxx.use_atexit_for_cxa_atexit ())
6745 /* The declaration for `__cxa_atexit' is:
6747 int __cxa_atexit (void (*)(void *), void *, void *)
6749 We build up the argument types and then the function type
6750 itself. */
6751 tree argtype0, argtype1, argtype2;
6753 use_aeabi_atexit = targetm.cxx.use_aeabi_atexit ();
6754 /* First, build the pointer-to-function type for the first
6755 argument. */
6756 fn_ptr_type = get_atexit_fn_ptr_type ();
6757 /* Then, build the rest of the argument types. */
6758 argtype2 = ptr_type_node;
6759 if (use_aeabi_atexit)
6761 argtype1 = fn_ptr_type;
6762 argtype0 = ptr_type_node;
6764 else
6766 argtype1 = ptr_type_node;
6767 argtype0 = fn_ptr_type;
6769 /* And the final __cxa_atexit type. */
6770 fn_type = build_function_type_list (integer_type_node,
6771 argtype0, argtype1, argtype2,
6772 NULL_TREE);
6773 if (use_aeabi_atexit)
6774 name = "__aeabi_atexit";
6775 else
6776 name = "__cxa_atexit";
6778 else
6780 /* The declaration for `atexit' is:
6782 int atexit (void (*)());
6784 We build up the argument types and then the function type
6785 itself. */
6786 fn_ptr_type = get_atexit_fn_ptr_type ();
6787 /* Build the final atexit type. */
6788 fn_type = build_function_type_list (integer_type_node,
6789 fn_ptr_type, NULL_TREE);
6790 name = "atexit";
6793 /* Now, build the function declaration. */
6794 push_lang_context (lang_name_c);
6795 atexit_fndecl = build_library_fn_ptr (name, fn_type, ECF_LEAF | ECF_NOTHROW);
6796 mark_used (atexit_fndecl);
6797 pop_lang_context ();
6798 atexit_node = decay_conversion (atexit_fndecl, tf_warning_or_error);
6800 return atexit_node;
6803 /* Like get_atexit_node, but for thread-local cleanups. */
6805 static tree
6806 get_thread_atexit_node (void)
6808 /* The declaration for `__cxa_thread_atexit' is:
6810 int __cxa_thread_atexit (void (*)(void *), void *, void *) */
6811 tree fn_type = build_function_type_list (integer_type_node,
6812 get_atexit_fn_ptr_type (),
6813 ptr_type_node, ptr_type_node,
6814 NULL_TREE);
6816 /* Now, build the function declaration. */
6817 tree atexit_fndecl = build_library_fn_ptr ("__cxa_thread_atexit", fn_type,
6818 ECF_LEAF | ECF_NOTHROW);
6819 return decay_conversion (atexit_fndecl, tf_warning_or_error);
6822 /* Returns the __dso_handle VAR_DECL. */
6824 static tree
6825 get_dso_handle_node (void)
6827 if (dso_handle_node)
6828 return dso_handle_node;
6830 /* Declare the variable. */
6831 dso_handle_node = declare_global_var (get_identifier ("__dso_handle"),
6832 ptr_type_node);
6834 #ifdef HAVE_GAS_HIDDEN
6835 if (dso_handle_node != error_mark_node)
6837 DECL_VISIBILITY (dso_handle_node) = VISIBILITY_HIDDEN;
6838 DECL_VISIBILITY_SPECIFIED (dso_handle_node) = 1;
6840 #endif
6842 return dso_handle_node;
6845 /* Begin a new function with internal linkage whose job will be simply
6846 to destroy some particular variable. */
6848 static GTY(()) int start_cleanup_cnt;
6850 static tree
6851 start_cleanup_fn (void)
6853 char name[32];
6854 tree fntype;
6855 tree fndecl;
6856 bool use_cxa_atexit = flag_use_cxa_atexit
6857 && !targetm.cxx.use_atexit_for_cxa_atexit ();
6859 push_to_top_level ();
6861 /* No need to mangle this. */
6862 push_lang_context (lang_name_c);
6864 /* Build the name of the function. */
6865 sprintf (name, "__tcf_%d", start_cleanup_cnt++);
6866 /* Build the function declaration. */
6867 fntype = TREE_TYPE (get_atexit_fn_ptr_type ());
6868 fndecl = build_lang_decl (FUNCTION_DECL, get_identifier (name), fntype);
6869 /* It's a function with internal linkage, generated by the
6870 compiler. */
6871 TREE_PUBLIC (fndecl) = 0;
6872 DECL_ARTIFICIAL (fndecl) = 1;
6873 /* Make the function `inline' so that it is only emitted if it is
6874 actually needed. It is unlikely that it will be inlined, since
6875 it is only called via a function pointer, but we avoid unnecessary
6876 emissions this way. */
6877 DECL_DECLARED_INLINE_P (fndecl) = 1;
6878 DECL_INTERFACE_KNOWN (fndecl) = 1;
6879 /* Build the parameter. */
6880 if (use_cxa_atexit)
6882 tree parmdecl;
6884 parmdecl = cp_build_parm_decl (NULL_TREE, ptr_type_node);
6885 DECL_CONTEXT (parmdecl) = fndecl;
6886 TREE_USED (parmdecl) = 1;
6887 DECL_READ_P (parmdecl) = 1;
6888 DECL_ARGUMENTS (fndecl) = parmdecl;
6891 pushdecl (fndecl);
6892 start_preparsed_function (fndecl, NULL_TREE, SF_PRE_PARSED);
6894 pop_lang_context ();
6896 return current_function_decl;
6899 /* Finish the cleanup function begun by start_cleanup_fn. */
6901 static void
6902 end_cleanup_fn (void)
6904 expand_or_defer_fn (finish_function (0));
6906 pop_from_top_level ();
6909 /* Generate code to handle the destruction of DECL, an object with
6910 static storage duration. */
6912 tree
6913 register_dtor_fn (tree decl)
6915 tree cleanup;
6916 tree addr;
6917 tree compound_stmt;
6918 tree fcall;
6919 tree type;
6920 bool ob_parm, dso_parm, use_dtor;
6921 tree arg0, arg1, arg2;
6922 tree atex_node;
6924 type = TREE_TYPE (decl);
6925 if (TYPE_HAS_TRIVIAL_DESTRUCTOR (type))
6926 return void_node;
6928 /* If we're using "__cxa_atexit" (or "__cxa_thread_atexit" or
6929 "__aeabi_atexit"), and DECL is a class object, we can just pass the
6930 destructor to "__cxa_atexit"; we don't have to build a temporary
6931 function to do the cleanup. */
6932 dso_parm = (flag_use_cxa_atexit
6933 && !targetm.cxx.use_atexit_for_cxa_atexit ());
6934 ob_parm = (DECL_THREAD_LOCAL_P (decl) || dso_parm);
6935 use_dtor = ob_parm && CLASS_TYPE_P (type);
6936 if (use_dtor)
6938 int idx;
6940 /* Find the destructor. */
6941 idx = lookup_fnfields_1 (type, complete_dtor_identifier);
6942 gcc_assert (idx >= 0);
6943 cleanup = (*CLASSTYPE_METHOD_VEC (type))[idx];
6944 /* Make sure it is accessible. */
6945 perform_or_defer_access_check (TYPE_BINFO (type), cleanup, cleanup,
6946 tf_warning_or_error);
6948 else
6950 /* Call build_cleanup before we enter the anonymous function so
6951 that any access checks will be done relative to the current
6952 scope, rather than the scope of the anonymous function. */
6953 build_cleanup (decl);
6955 /* Now start the function. */
6956 cleanup = start_cleanup_fn ();
6958 /* Now, recompute the cleanup. It may contain SAVE_EXPRs that refer
6959 to the original function, rather than the anonymous one. That
6960 will make the back end think that nested functions are in use,
6961 which causes confusion. */
6962 push_deferring_access_checks (dk_no_check);
6963 fcall = build_cleanup (decl);
6964 pop_deferring_access_checks ();
6966 /* Create the body of the anonymous function. */
6967 compound_stmt = begin_compound_stmt (BCS_FN_BODY);
6968 finish_expr_stmt (fcall);
6969 finish_compound_stmt (compound_stmt);
6970 end_cleanup_fn ();
6973 /* Call atexit with the cleanup function. */
6974 mark_used (cleanup);
6975 cleanup = build_address (cleanup);
6977 if (DECL_THREAD_LOCAL_P (decl))
6978 atex_node = get_thread_atexit_node ();
6979 else
6980 atex_node = get_atexit_node ();
6982 if (use_dtor)
6984 /* We must convert CLEANUP to the type that "__cxa_atexit"
6985 expects. */
6986 cleanup = build_nop (get_atexit_fn_ptr_type (), cleanup);
6987 /* "__cxa_atexit" will pass the address of DECL to the
6988 cleanup function. */
6989 mark_used (decl);
6990 addr = build_address (decl);
6991 /* The declared type of the parameter to "__cxa_atexit" is
6992 "void *". For plain "T*", we could just let the
6993 machinery in cp_build_function_call convert it -- but if the
6994 type is "cv-qualified T *", then we need to convert it
6995 before passing it in, to avoid spurious errors. */
6996 addr = build_nop (ptr_type_node, addr);
6998 else
6999 /* Since the cleanup functions we build ignore the address
7000 they're given, there's no reason to pass the actual address
7001 in, and, in general, it's cheaper to pass NULL than any
7002 other value. */
7003 addr = null_pointer_node;
7005 if (dso_parm)
7006 arg2 = cp_build_addr_expr (get_dso_handle_node (),
7007 tf_warning_or_error);
7008 else if (ob_parm)
7009 /* Just pass NULL to the dso handle parm if we don't actually
7010 have a DSO handle on this target. */
7011 arg2 = null_pointer_node;
7012 else
7013 arg2 = NULL_TREE;
7015 if (ob_parm)
7017 if (!DECL_THREAD_LOCAL_P (decl)
7018 && targetm.cxx.use_aeabi_atexit ())
7020 arg1 = cleanup;
7021 arg0 = addr;
7023 else
7025 arg1 = addr;
7026 arg0 = cleanup;
7029 else
7031 arg0 = cleanup;
7032 arg1 = NULL_TREE;
7034 return cp_build_function_call_nary (atex_node, tf_warning_or_error,
7035 arg0, arg1, arg2, NULL_TREE);
7038 /* DECL is a VAR_DECL with static storage duration. INIT, if present,
7039 is its initializer. Generate code to handle the construction
7040 and destruction of DECL. */
7042 static void
7043 expand_static_init (tree decl, tree init)
7045 gcc_assert (VAR_P (decl));
7046 gcc_assert (TREE_STATIC (decl));
7048 /* Some variables require no dynamic initialization. */
7049 if (!init
7050 && TYPE_HAS_TRIVIAL_DESTRUCTOR (TREE_TYPE (decl)))
7052 /* Make sure the destructor is callable. */
7053 cxx_maybe_build_cleanup (decl, tf_warning_or_error);
7054 return;
7057 if (DECL_THREAD_LOCAL_P (decl) && DECL_GNU_TLS_P (decl)
7058 && !DECL_FUNCTION_SCOPE_P (decl))
7060 if (init)
7061 error ("non-local variable %qD declared %<__thread%> "
7062 "needs dynamic initialization", decl);
7063 else
7064 error ("non-local variable %qD declared %<__thread%> "
7065 "has a non-trivial destructor", decl);
7066 static bool informed;
7067 if (!informed)
7069 inform (DECL_SOURCE_LOCATION (decl),
7070 "C++11 %<thread_local%> allows dynamic initialization "
7071 "and destruction");
7072 informed = true;
7074 return;
7077 if (DECL_FUNCTION_SCOPE_P (decl))
7079 /* Emit code to perform this initialization but once. */
7080 tree if_stmt = NULL_TREE, inner_if_stmt = NULL_TREE;
7081 tree then_clause = NULL_TREE, inner_then_clause = NULL_TREE;
7082 tree guard, guard_addr;
7083 tree flag, begin;
7084 /* We don't need thread-safety code for thread-local vars. */
7085 bool thread_guard = (flag_threadsafe_statics
7086 && !DECL_THREAD_LOCAL_P (decl));
7088 /* Emit code to perform this initialization but once. This code
7089 looks like:
7091 static <type> guard;
7092 if (!guard.first_byte) {
7093 if (__cxa_guard_acquire (&guard)) {
7094 bool flag = false;
7095 try {
7096 // Do initialization.
7097 flag = true; __cxa_guard_release (&guard);
7098 // Register variable for destruction at end of program.
7099 } catch {
7100 if (!flag) __cxa_guard_abort (&guard);
7104 Note that the `flag' variable is only set to 1 *after* the
7105 initialization is complete. This ensures that an exception,
7106 thrown during the construction, will cause the variable to
7107 reinitialized when we pass through this code again, as per:
7109 [stmt.dcl]
7111 If the initialization exits by throwing an exception, the
7112 initialization is not complete, so it will be tried again
7113 the next time control enters the declaration.
7115 This process should be thread-safe, too; multiple threads
7116 should not be able to initialize the variable more than
7117 once. */
7119 /* Create the guard variable. */
7120 guard = get_guard (decl);
7122 /* This optimization isn't safe on targets with relaxed memory
7123 consistency. On such targets we force synchronization in
7124 __cxa_guard_acquire. */
7125 if (!targetm.relaxed_ordering || !thread_guard)
7127 /* Begin the conditional initialization. */
7128 if_stmt = begin_if_stmt ();
7129 finish_if_stmt_cond (get_guard_cond (guard), if_stmt);
7130 then_clause = begin_compound_stmt (BCS_NO_SCOPE);
7133 if (thread_guard)
7135 tree vfntype = NULL_TREE;
7136 tree acquire_name, release_name, abort_name;
7137 tree acquire_fn, release_fn, abort_fn;
7138 guard_addr = build_address (guard);
7140 acquire_name = get_identifier ("__cxa_guard_acquire");
7141 release_name = get_identifier ("__cxa_guard_release");
7142 abort_name = get_identifier ("__cxa_guard_abort");
7143 acquire_fn = identifier_global_value (acquire_name);
7144 release_fn = identifier_global_value (release_name);
7145 abort_fn = identifier_global_value (abort_name);
7146 if (!acquire_fn)
7147 acquire_fn = push_library_fn
7148 (acquire_name, build_function_type_list (integer_type_node,
7149 TREE_TYPE (guard_addr),
7150 NULL_TREE),
7151 NULL_TREE, ECF_NOTHROW | ECF_LEAF);
7152 if (!release_fn || !abort_fn)
7153 vfntype = build_function_type_list (void_type_node,
7154 TREE_TYPE (guard_addr),
7155 NULL_TREE);
7156 if (!release_fn)
7157 release_fn = push_library_fn (release_name, vfntype, NULL_TREE,
7158 ECF_NOTHROW | ECF_LEAF);
7159 if (!abort_fn)
7160 abort_fn = push_library_fn (abort_name, vfntype, NULL_TREE,
7161 ECF_NOTHROW | ECF_LEAF);
7163 inner_if_stmt = begin_if_stmt ();
7164 finish_if_stmt_cond (build_call_n (acquire_fn, 1, guard_addr),
7165 inner_if_stmt);
7167 inner_then_clause = begin_compound_stmt (BCS_NO_SCOPE);
7168 begin = get_target_expr (boolean_false_node);
7169 flag = TARGET_EXPR_SLOT (begin);
7171 TARGET_EXPR_CLEANUP (begin)
7172 = build3 (COND_EXPR, void_type_node, flag,
7173 void_node,
7174 build_call_n (abort_fn, 1, guard_addr));
7175 CLEANUP_EH_ONLY (begin) = 1;
7177 /* Do the initialization itself. */
7178 init = add_stmt_to_compound (begin, init);
7179 init = add_stmt_to_compound
7180 (init, build2 (MODIFY_EXPR, void_type_node, flag, boolean_true_node));
7181 init = add_stmt_to_compound
7182 (init, build_call_n (release_fn, 1, guard_addr));
7184 else
7185 init = add_stmt_to_compound (init, set_guard (guard));
7187 /* Use atexit to register a function for destroying this static
7188 variable. */
7189 init = add_stmt_to_compound (init, register_dtor_fn (decl));
7191 finish_expr_stmt (init);
7193 if (thread_guard)
7195 finish_compound_stmt (inner_then_clause);
7196 finish_then_clause (inner_if_stmt);
7197 finish_if_stmt (inner_if_stmt);
7200 if (!targetm.relaxed_ordering || !thread_guard)
7202 finish_compound_stmt (then_clause);
7203 finish_then_clause (if_stmt);
7204 finish_if_stmt (if_stmt);
7207 else if (DECL_THREAD_LOCAL_P (decl))
7208 tls_aggregates = tree_cons (init, decl, tls_aggregates);
7209 else
7210 static_aggregates = tree_cons (init, decl, static_aggregates);
7214 /* Make TYPE a complete type based on INITIAL_VALUE.
7215 Return 0 if successful, 1 if INITIAL_VALUE can't be deciphered,
7216 2 if there was no information (in which case assume 0 if DO_DEFAULT),
7217 3 if the initializer list is empty (in pedantic mode). */
7220 cp_complete_array_type (tree *ptype, tree initial_value, bool do_default)
7222 int failure;
7223 tree type, elt_type;
7225 /* Don't get confused by a CONSTRUCTOR for some other type. */
7226 if (initial_value && TREE_CODE (initial_value) == CONSTRUCTOR
7227 && !BRACE_ENCLOSED_INITIALIZER_P (initial_value))
7228 return 1;
7230 if (initial_value)
7232 unsigned HOST_WIDE_INT i;
7233 tree value;
7235 /* An array of character type can be initialized from a
7236 brace-enclosed string constant.
7238 FIXME: this code is duplicated from reshape_init. Probably
7239 we should just call reshape_init here? */
7240 if (char_type_p (TYPE_MAIN_VARIANT (TREE_TYPE (*ptype)))
7241 && TREE_CODE (initial_value) == CONSTRUCTOR
7242 && !vec_safe_is_empty (CONSTRUCTOR_ELTS (initial_value)))
7244 vec<constructor_elt, va_gc> *v = CONSTRUCTOR_ELTS (initial_value);
7245 tree value = (*v)[0].value;
7247 if (TREE_CODE (value) == STRING_CST
7248 && v->length () == 1)
7249 initial_value = value;
7252 /* If any of the elements are parameter packs, we can't actually
7253 complete this type now because the array size is dependent. */
7254 if (TREE_CODE (initial_value) == CONSTRUCTOR)
7256 FOR_EACH_CONSTRUCTOR_VALUE (CONSTRUCTOR_ELTS (initial_value),
7257 i, value)
7259 if (PACK_EXPANSION_P (value))
7260 return 0;
7265 failure = complete_array_type (ptype, initial_value, do_default);
7267 /* We can create the array before the element type is complete, which
7268 means that we didn't have these two bits set in the original type
7269 either. In completing the type, we are expected to propagate these
7270 bits. See also complete_type which does the same thing for arrays
7271 of fixed size. */
7272 type = *ptype;
7273 if (TYPE_DOMAIN (type))
7275 elt_type = TREE_TYPE (type);
7276 TYPE_NEEDS_CONSTRUCTING (type) = TYPE_NEEDS_CONSTRUCTING (elt_type);
7277 TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type)
7278 = TYPE_HAS_NONTRIVIAL_DESTRUCTOR (elt_type);
7281 return failure;
7284 /* As above, but either give an error or reject zero-size arrays, depending
7285 on COMPLAIN. */
7288 cp_complete_array_type_or_error (tree *ptype, tree initial_value,
7289 bool do_default, tsubst_flags_t complain)
7291 int failure;
7292 bool sfinae = !(complain & tf_error);
7293 /* In SFINAE context we can't be lenient about zero-size arrays. */
7294 if (sfinae)
7295 ++pedantic;
7296 failure = cp_complete_array_type (ptype, initial_value, do_default);
7297 if (sfinae)
7298 --pedantic;
7299 if (failure)
7301 if (sfinae)
7302 /* Not an error. */;
7303 else if (failure == 1)
7304 error ("initializer fails to determine size of %qT", *ptype);
7305 else if (failure == 2)
7307 if (do_default)
7308 error ("array size missing in %qT", *ptype);
7310 else if (failure == 3)
7311 error ("zero-size array %qT", *ptype);
7312 *ptype = error_mark_node;
7314 return failure;
7317 /* Return zero if something is declared to be a member of type
7318 CTYPE when in the context of CUR_TYPE. STRING is the error
7319 message to print in that case. Otherwise, quietly return 1. */
7321 static int
7322 member_function_or_else (tree ctype, tree cur_type, enum overload_flags flags)
7324 if (ctype && ctype != cur_type)
7326 if (flags == DTOR_FLAG)
7327 error ("destructor for alien class %qT cannot be a member", ctype);
7328 else
7329 error ("constructor for alien class %qT cannot be a member", ctype);
7330 return 0;
7332 return 1;
7335 /* Subroutine of `grokdeclarator'. */
7337 /* Generate errors possibly applicable for a given set of specifiers.
7338 This is for ARM $7.1.2. */
7340 static void
7341 bad_specifiers (tree object,
7342 enum bad_spec_place type,
7343 int virtualp,
7344 int quals,
7345 int inlinep,
7346 int friendp,
7347 int raises)
7349 switch (type)
7351 case BSP_VAR:
7352 if (virtualp)
7353 error ("%qD declared as a %<virtual%> variable", object);
7354 if (inlinep)
7355 error ("%qD declared as an %<inline%> variable", object);
7356 if (quals)
7357 error ("%<const%> and %<volatile%> function specifiers on "
7358 "%qD invalid in variable declaration", object);
7359 break;
7360 case BSP_PARM:
7361 if (virtualp)
7362 error ("%qD declared as a %<virtual%> parameter", object);
7363 if (inlinep)
7364 error ("%qD declared as an %<inline%> parameter", object);
7365 if (quals)
7366 error ("%<const%> and %<volatile%> function specifiers on "
7367 "%qD invalid in parameter declaration", object);
7368 break;
7369 case BSP_TYPE:
7370 if (virtualp)
7371 error ("%qD declared as a %<virtual%> type", object);
7372 if (inlinep)
7373 error ("%qD declared as an %<inline%> type", object);
7374 if (quals)
7375 error ("%<const%> and %<volatile%> function specifiers on "
7376 "%qD invalid in type declaration", object);
7377 break;
7378 case BSP_FIELD:
7379 if (virtualp)
7380 error ("%qD declared as a %<virtual%> field", object);
7381 if (inlinep)
7382 error ("%qD declared as an %<inline%> field", object);
7383 if (quals)
7384 error ("%<const%> and %<volatile%> function specifiers on "
7385 "%qD invalid in field declaration", object);
7386 break;
7387 default:
7388 gcc_unreachable();
7390 if (friendp)
7391 error ("%q+D declared as a friend", object);
7392 if (raises
7393 && (TREE_CODE (object) == TYPE_DECL
7394 || (!TYPE_PTRFN_P (TREE_TYPE (object))
7395 && !TYPE_REFFN_P (TREE_TYPE (object))
7396 && !TYPE_PTRMEMFUNC_P (TREE_TYPE (object)))))
7397 error ("%q+D declared with an exception specification", object);
7400 /* DECL is a member function or static data member and is presently
7401 being defined. Check that the definition is taking place in a
7402 valid namespace. */
7404 static void
7405 check_class_member_definition_namespace (tree decl)
7407 /* These checks only apply to member functions and static data
7408 members. */
7409 gcc_assert (VAR_OR_FUNCTION_DECL_P (decl));
7410 /* We check for problems with specializations in pt.c in
7411 check_specialization_namespace, where we can issue better
7412 diagnostics. */
7413 if (processing_specialization)
7414 return;
7415 /* There are no restrictions on the placement of
7416 explicit instantiations. */
7417 if (processing_explicit_instantiation)
7418 return;
7419 /* [class.mfct]
7421 A member function definition that appears outside of the
7422 class definition shall appear in a namespace scope enclosing
7423 the class definition.
7425 [class.static.data]
7427 The definition for a static data member shall appear in a
7428 namespace scope enclosing the member's class definition. */
7429 if (!is_ancestor (current_namespace, DECL_CONTEXT (decl)))
7430 permerror (input_location, "definition of %qD is not in namespace enclosing %qT",
7431 decl, DECL_CONTEXT (decl));
7434 /* Build a PARM_DECL for the "this" parameter. TYPE is the
7435 METHOD_TYPE for a non-static member function; QUALS are the
7436 cv-qualifiers that apply to the function. */
7438 tree
7439 build_this_parm (tree type, cp_cv_quals quals)
7441 tree this_type;
7442 tree qual_type;
7443 tree parm;
7444 cp_cv_quals this_quals;
7446 if (CLASS_TYPE_P (type))
7448 this_type
7449 = cp_build_qualified_type (type, quals & ~TYPE_QUAL_RESTRICT);
7450 this_type = build_pointer_type (this_type);
7452 else
7453 this_type = type_of_this_parm (type);
7454 /* The `this' parameter is implicitly `const'; it cannot be
7455 assigned to. */
7456 this_quals = (quals & TYPE_QUAL_RESTRICT) | TYPE_QUAL_CONST;
7457 qual_type = cp_build_qualified_type (this_type, this_quals);
7458 parm = build_artificial_parm (this_identifier, qual_type);
7459 cp_apply_type_quals_to_decl (this_quals, parm);
7460 return parm;
7463 /* DECL is a static member function. Complain if it was declared
7464 with function-cv-quals. */
7466 static void
7467 check_static_quals (tree decl, cp_cv_quals quals)
7469 if (quals != TYPE_UNQUALIFIED)
7470 error ("static member function %q#D declared with type qualifiers",
7471 decl);
7474 /* Helper function. Replace the temporary this parameter injected
7475 during cp_finish_omp_declare_simd with the real this parameter. */
7477 static tree
7478 declare_simd_adjust_this (tree *tp, int *walk_subtrees, void *data)
7480 tree this_parm = (tree) data;
7481 if (TREE_CODE (*tp) == PARM_DECL
7482 && DECL_NAME (*tp) == this_identifier
7483 && *tp != this_parm)
7484 *tp = this_parm;
7485 else if (TYPE_P (*tp))
7486 *walk_subtrees = 0;
7487 return NULL_TREE;
7490 /* CTYPE is class type, or null if non-class.
7491 TYPE is type this FUNCTION_DECL should have, either FUNCTION_TYPE
7492 or METHOD_TYPE.
7493 DECLARATOR is the function's name.
7494 PARMS is a chain of PARM_DECLs for the function.
7495 VIRTUALP is truthvalue of whether the function is virtual or not.
7496 FLAGS are to be passed through to `grokclassfn'.
7497 QUALS are qualifiers indicating whether the function is `const'
7498 or `volatile'.
7499 RAISES is a list of exceptions that this function can raise.
7500 CHECK is 1 if we must find this method in CTYPE, 0 if we should
7501 not look, and -1 if we should not call `grokclassfn' at all.
7503 SFK is the kind of special function (if any) for the new function.
7505 Returns `NULL_TREE' if something goes wrong, after issuing
7506 applicable error messages. */
7508 static tree
7509 grokfndecl (tree ctype,
7510 tree type,
7511 tree declarator,
7512 tree parms,
7513 tree orig_declarator,
7514 int virtualp,
7515 enum overload_flags flags,
7516 cp_cv_quals quals,
7517 cp_ref_qualifier rqual,
7518 tree raises,
7519 int check,
7520 int friendp,
7521 int publicp,
7522 int inlinep,
7523 special_function_kind sfk,
7524 bool funcdef_flag,
7525 int template_count,
7526 tree in_namespace,
7527 tree* attrlist,
7528 location_t location)
7530 tree decl;
7531 int staticp = ctype && TREE_CODE (type) == FUNCTION_TYPE;
7532 tree t;
7534 if (rqual)
7535 type = build_ref_qualified_type (type, rqual);
7536 if (raises)
7537 type = build_exception_variant (type, raises);
7539 decl = build_lang_decl (FUNCTION_DECL, declarator, type);
7541 /* If we have an explicit location, use it, otherwise use whatever
7542 build_lang_decl used (probably input_location). */
7543 if (location != UNKNOWN_LOCATION)
7544 DECL_SOURCE_LOCATION (decl) = location;
7546 if (TREE_CODE (type) == METHOD_TYPE)
7548 tree parm;
7549 parm = build_this_parm (type, quals);
7550 DECL_CHAIN (parm) = parms;
7551 parms = parm;
7553 DECL_ARGUMENTS (decl) = parms;
7554 for (t = parms; t; t = DECL_CHAIN (t))
7555 DECL_CONTEXT (t) = decl;
7556 /* Propagate volatile out from type to decl. */
7557 if (TYPE_VOLATILE (type))
7558 TREE_THIS_VOLATILE (decl) = 1;
7560 /* Setup decl according to sfk. */
7561 switch (sfk)
7563 case sfk_constructor:
7564 case sfk_copy_constructor:
7565 case sfk_move_constructor:
7566 DECL_CONSTRUCTOR_P (decl) = 1;
7567 break;
7568 case sfk_destructor:
7569 DECL_DESTRUCTOR_P (decl) = 1;
7570 break;
7571 default:
7572 break;
7575 /* If pointers to member functions use the least significant bit to
7576 indicate whether a function is virtual, ensure a pointer
7577 to this function will have that bit clear. */
7578 if (TARGET_PTRMEMFUNC_VBIT_LOCATION == ptrmemfunc_vbit_in_pfn
7579 && TREE_CODE (type) == METHOD_TYPE
7580 && DECL_ALIGN (decl) < 2 * BITS_PER_UNIT)
7581 DECL_ALIGN (decl) = 2 * BITS_PER_UNIT;
7583 if (friendp
7584 && TREE_CODE (orig_declarator) == TEMPLATE_ID_EXPR)
7586 if (funcdef_flag)
7587 error
7588 ("defining explicit specialization %qD in friend declaration",
7589 orig_declarator);
7590 else
7592 tree fns = TREE_OPERAND (orig_declarator, 0);
7593 tree args = TREE_OPERAND (orig_declarator, 1);
7595 if (PROCESSING_REAL_TEMPLATE_DECL_P ())
7597 /* Something like `template <class T> friend void f<T>()'. */
7598 error ("invalid use of template-id %qD in declaration "
7599 "of primary template",
7600 orig_declarator);
7601 return NULL_TREE;
7605 /* A friend declaration of the form friend void f<>(). Record
7606 the information in the TEMPLATE_ID_EXPR. */
7607 SET_DECL_IMPLICIT_INSTANTIATION (decl);
7609 gcc_assert (identifier_p (fns) || TREE_CODE (fns) == OVERLOAD);
7610 DECL_TEMPLATE_INFO (decl) = build_template_info (fns, args);
7612 for (t = TYPE_ARG_TYPES (TREE_TYPE (decl)); t; t = TREE_CHAIN (t))
7613 if (TREE_PURPOSE (t)
7614 && TREE_CODE (TREE_PURPOSE (t)) == DEFAULT_ARG)
7616 error ("default arguments are not allowed in declaration "
7617 "of friend template specialization %qD",
7618 decl);
7619 return NULL_TREE;
7622 if (inlinep & 1)
7623 error ("%<inline%> is not allowed in declaration of friend "
7624 "template specialization %qD",
7625 decl);
7626 if (inlinep & 2)
7627 error ("%<constexpr%> is not allowed in declaration of friend "
7628 "template specialization %qD",
7629 decl);
7630 if (inlinep)
7631 return NULL_TREE;
7635 /* If this decl has namespace scope, set that up. */
7636 if (in_namespace)
7637 set_decl_namespace (decl, in_namespace, friendp);
7638 else if (!ctype)
7639 DECL_CONTEXT (decl) = FROB_CONTEXT (current_decl_namespace ());
7641 /* `main' and builtins have implicit 'C' linkage. */
7642 if ((MAIN_NAME_P (declarator)
7643 || (IDENTIFIER_LENGTH (declarator) > 10
7644 && IDENTIFIER_POINTER (declarator)[0] == '_'
7645 && IDENTIFIER_POINTER (declarator)[1] == '_'
7646 && strncmp (IDENTIFIER_POINTER (declarator)+2, "builtin_", 8) == 0)
7647 || (targetcm.cxx_implicit_extern_c
7648 && targetcm.cxx_implicit_extern_c(IDENTIFIER_POINTER (declarator))))
7649 && current_lang_name == lang_name_cplusplus
7650 && ctype == NULL_TREE
7651 && DECL_FILE_SCOPE_P (decl))
7652 SET_DECL_LANGUAGE (decl, lang_c);
7654 /* Should probably propagate const out from type to decl I bet (mrs). */
7655 if (staticp)
7657 DECL_STATIC_FUNCTION_P (decl) = 1;
7658 DECL_CONTEXT (decl) = ctype;
7661 if (ctype)
7663 DECL_CONTEXT (decl) = ctype;
7664 if (funcdef_flag)
7665 check_class_member_definition_namespace (decl);
7668 if (ctype == NULL_TREE && DECL_MAIN_P (decl))
7670 if (PROCESSING_REAL_TEMPLATE_DECL_P())
7671 error ("cannot declare %<::main%> to be a template");
7672 if (inlinep & 1)
7673 error ("cannot declare %<::main%> to be inline");
7674 if (inlinep & 2)
7675 error ("cannot declare %<::main%> to be constexpr");
7676 if (!publicp)
7677 error ("cannot declare %<::main%> to be static");
7678 inlinep = 0;
7679 publicp = 1;
7682 /* Members of anonymous types and local classes have no linkage; make
7683 them internal. If a typedef is made later, this will be changed. */
7684 if (ctype && (TYPE_ANONYMOUS_P (ctype)
7685 || decl_function_context (TYPE_MAIN_DECL (ctype))))
7686 publicp = 0;
7688 if (publicp && cxx_dialect == cxx98)
7690 /* [basic.link]: A name with no linkage (notably, the name of a class
7691 or enumeration declared in a local scope) shall not be used to
7692 declare an entity with linkage.
7694 DR 757 relaxes this restriction for C++0x. */
7695 no_linkage_error (decl);
7698 TREE_PUBLIC (decl) = publicp;
7699 if (! publicp)
7701 DECL_INTERFACE_KNOWN (decl) = 1;
7702 DECL_NOT_REALLY_EXTERN (decl) = 1;
7705 /* If the declaration was declared inline, mark it as such. */
7706 if (inlinep)
7708 DECL_DECLARED_INLINE_P (decl) = 1;
7709 if (publicp)
7710 DECL_COMDAT (decl) = 1;
7712 if (inlinep & 2)
7713 DECL_DECLARED_CONSTEXPR_P (decl) = true;
7715 DECL_EXTERNAL (decl) = 1;
7716 if (TREE_CODE (type) == FUNCTION_TYPE)
7718 if (quals)
7720 error (ctype
7721 ? G_("static member function %qD cannot have cv-qualifier")
7722 : G_("non-member function %qD cannot have cv-qualifier"),
7723 decl);
7724 quals = TYPE_UNQUALIFIED;
7727 if (rqual)
7729 error (ctype
7730 ? G_("static member function %qD cannot have ref-qualifier")
7731 : G_("non-member function %qD cannot have ref-qualifier"),
7732 decl);
7733 rqual = REF_QUAL_NONE;
7737 if (IDENTIFIER_OPNAME_P (DECL_NAME (decl))
7738 && !grok_op_properties (decl, /*complain=*/true))
7739 return NULL_TREE;
7740 else if (UDLIT_OPER_P (DECL_NAME (decl)))
7742 bool long_long_unsigned_p;
7743 bool long_double_p;
7744 const char *suffix = NULL;
7745 /* [over.literal]/6: Literal operators shall not have C linkage. */
7746 if (DECL_LANGUAGE (decl) == lang_c)
7748 error ("literal operator with C linkage");
7749 return NULL_TREE;
7752 if (DECL_NAMESPACE_SCOPE_P (decl))
7754 if (!check_literal_operator_args (decl, &long_long_unsigned_p,
7755 &long_double_p))
7757 error ("%qD has invalid argument list", decl);
7758 return NULL_TREE;
7761 suffix = UDLIT_OP_SUFFIX (DECL_NAME (decl));
7762 if (long_long_unsigned_p)
7764 if (cpp_interpret_int_suffix (parse_in, suffix, strlen (suffix)))
7765 warning (0, "integer suffix %<%s%>"
7766 " shadowed by implementation", suffix);
7768 else if (long_double_p)
7770 if (cpp_interpret_float_suffix (parse_in, suffix, strlen (suffix)))
7771 warning (0, "floating point suffix %<%s%>"
7772 " shadowed by implementation", suffix);
7775 else
7777 error ("%qD must be a non-member function", decl);
7778 return NULL_TREE;
7782 if (funcdef_flag)
7783 /* Make the init_value nonzero so pushdecl knows this is not
7784 tentative. error_mark_node is replaced later with the BLOCK. */
7785 DECL_INITIAL (decl) = error_mark_node;
7787 if (TYPE_NOTHROW_P (type) || nothrow_libfn_p (decl))
7788 TREE_NOTHROW (decl) = 1;
7790 if (flag_openmp || flag_cilkplus)
7792 /* Adjust "omp declare simd" attributes. */
7793 tree ods = lookup_attribute ("omp declare simd", *attrlist);
7794 if (ods)
7796 tree attr;
7797 for (attr = ods; attr;
7798 attr = lookup_attribute ("omp declare simd", TREE_CHAIN (attr)))
7800 if (TREE_CODE (type) == METHOD_TYPE)
7801 walk_tree (&TREE_VALUE (attr), declare_simd_adjust_this,
7802 DECL_ARGUMENTS (decl), NULL);
7803 if (TREE_VALUE (attr) != NULL_TREE)
7805 tree cl = TREE_VALUE (TREE_VALUE (attr));
7806 cl = c_omp_declare_simd_clauses_to_numbers
7807 (DECL_ARGUMENTS (decl), cl);
7808 if (cl)
7809 TREE_VALUE (TREE_VALUE (attr)) = cl;
7810 else
7811 TREE_VALUE (attr) = NULL_TREE;
7817 /* Caller will do the rest of this. */
7818 if (check < 0)
7819 return decl;
7821 if (ctype != NULL_TREE)
7822 grokclassfn (ctype, decl, flags);
7824 /* 12.4/3 */
7825 if (cxx_dialect >= cxx11
7826 && DECL_DESTRUCTOR_P (decl)
7827 && !TYPE_BEING_DEFINED (DECL_CONTEXT (decl))
7828 && !processing_template_decl)
7829 deduce_noexcept_on_destructor (decl);
7831 decl = check_explicit_specialization (orig_declarator, decl,
7832 template_count,
7833 2 * funcdef_flag +
7834 4 * (friendp != 0));
7835 if (decl == error_mark_node)
7836 return NULL_TREE;
7838 if (DECL_STATIC_FUNCTION_P (decl))
7839 check_static_quals (decl, quals);
7841 if (attrlist)
7843 cplus_decl_attributes (&decl, *attrlist, 0);
7844 *attrlist = NULL_TREE;
7847 /* Check main's type after attributes have been applied. */
7848 if (ctype == NULL_TREE && DECL_MAIN_P (decl))
7850 if (!same_type_p (TREE_TYPE (TREE_TYPE (decl)),
7851 integer_type_node))
7853 tree oldtypeargs = TYPE_ARG_TYPES (TREE_TYPE (decl));
7854 tree newtype;
7855 error ("%<::main%> must return %<int%>");
7856 newtype = build_function_type (integer_type_node, oldtypeargs);
7857 TREE_TYPE (decl) = newtype;
7859 if (warn_main)
7860 check_main_parameter_types (decl);
7863 if (ctype != NULL_TREE
7864 && (! TYPE_FOR_JAVA (ctype) || check_java_method (decl))
7865 && check)
7867 tree old_decl = check_classfn (ctype, decl,
7868 (processing_template_decl
7869 > template_class_depth (ctype))
7870 ? current_template_parms
7871 : NULL_TREE);
7873 if (old_decl == error_mark_node)
7874 return NULL_TREE;
7876 if (old_decl)
7878 tree ok;
7879 tree pushed_scope;
7881 if (TREE_CODE (old_decl) == TEMPLATE_DECL)
7882 /* Because grokfndecl is always supposed to return a
7883 FUNCTION_DECL, we pull out the DECL_TEMPLATE_RESULT
7884 here. We depend on our callers to figure out that its
7885 really a template that's being returned. */
7886 old_decl = DECL_TEMPLATE_RESULT (old_decl);
7888 if (DECL_STATIC_FUNCTION_P (old_decl)
7889 && TREE_CODE (TREE_TYPE (decl)) == METHOD_TYPE)
7891 /* Remove the `this' parm added by grokclassfn. */
7892 revert_static_member_fn (decl);
7893 check_static_quals (decl, quals);
7895 if (DECL_ARTIFICIAL (old_decl))
7897 error ("definition of implicitly-declared %qD", old_decl);
7898 return NULL_TREE;
7900 else if (DECL_DEFAULTED_FN (old_decl))
7902 error ("definition of explicitly-defaulted %q+D", decl);
7903 error ("%q+#D explicitly defaulted here", old_decl);
7904 return NULL_TREE;
7907 /* Since we've smashed OLD_DECL to its
7908 DECL_TEMPLATE_RESULT, we must do the same to DECL. */
7909 if (TREE_CODE (decl) == TEMPLATE_DECL)
7910 decl = DECL_TEMPLATE_RESULT (decl);
7912 /* Attempt to merge the declarations. This can fail, in
7913 the case of some invalid specialization declarations. */
7914 pushed_scope = push_scope (ctype);
7915 ok = duplicate_decls (decl, old_decl, friendp);
7916 if (pushed_scope)
7917 pop_scope (pushed_scope);
7918 if (!ok)
7920 error ("no %q#D member function declared in class %qT",
7921 decl, ctype);
7922 return NULL_TREE;
7924 if (ok == error_mark_node)
7925 return NULL_TREE;
7926 return old_decl;
7930 if (DECL_CONSTRUCTOR_P (decl) && !grok_ctor_properties (ctype, decl))
7931 return NULL_TREE;
7933 if (ctype == NULL_TREE || check)
7934 return decl;
7936 if (virtualp)
7937 DECL_VIRTUAL_P (decl) = 1;
7939 return decl;
7942 /* decl is a FUNCTION_DECL.
7943 specifiers are the parsed virt-specifiers.
7945 Set flags to reflect the virt-specifiers.
7947 Returns decl. */
7949 static tree
7950 set_virt_specifiers (tree decl, cp_virt_specifiers specifiers)
7952 if (decl == NULL_TREE)
7953 return decl;
7954 if (specifiers & VIRT_SPEC_OVERRIDE)
7955 DECL_OVERRIDE_P (decl) = 1;
7956 if (specifiers & VIRT_SPEC_FINAL)
7957 DECL_FINAL_P (decl) = 1;
7958 return decl;
7961 /* DECL is a VAR_DECL for a static data member. Set flags to reflect
7962 the linkage that DECL will receive in the object file. */
7964 static void
7965 set_linkage_for_static_data_member (tree decl)
7967 /* A static data member always has static storage duration and
7968 external linkage. Note that static data members are forbidden in
7969 local classes -- the only situation in which a class has
7970 non-external linkage. */
7971 TREE_PUBLIC (decl) = 1;
7972 TREE_STATIC (decl) = 1;
7973 /* For non-template classes, static data members are always put
7974 out in exactly those files where they are defined, just as
7975 with ordinary namespace-scope variables. */
7976 if (!processing_template_decl)
7977 DECL_INTERFACE_KNOWN (decl) = 1;
7980 /* Create a VAR_DECL named NAME with the indicated TYPE.
7982 If SCOPE is non-NULL, it is the class type or namespace containing
7983 the variable. If SCOPE is NULL, the variable should is created in
7984 the innermost enclosing scope. */
7986 static tree
7987 grokvardecl (tree type,
7988 tree name,
7989 tree orig_declarator,
7990 const cp_decl_specifier_seq *declspecs,
7991 int initialized,
7992 int constp,
7993 int template_count,
7994 tree scope)
7996 tree decl;
7997 tree explicit_scope;
7999 gcc_assert (!name || identifier_p (name));
8001 /* Compute the scope in which to place the variable, but remember
8002 whether or not that scope was explicitly specified by the user. */
8003 explicit_scope = scope;
8004 if (!scope)
8006 /* An explicit "extern" specifier indicates a namespace-scope
8007 variable. */
8008 if (declspecs->storage_class == sc_extern)
8009 scope = current_decl_namespace ();
8010 else if (!at_function_scope_p ())
8011 scope = current_scope ();
8014 if (scope
8015 && (/* If the variable is a namespace-scope variable declared in a
8016 template, we need DECL_LANG_SPECIFIC. */
8017 (TREE_CODE (scope) == NAMESPACE_DECL && processing_template_decl)
8018 /* Similarly for namespace-scope variables with language linkage
8019 other than C++. */
8020 || (TREE_CODE (scope) == NAMESPACE_DECL
8021 && current_lang_name != lang_name_cplusplus)
8022 /* Similarly for static data members. */
8023 || TYPE_P (scope)
8024 /* Similarly for explicit specializations. */
8025 || (orig_declarator
8026 && TREE_CODE (orig_declarator) == TEMPLATE_ID_EXPR)))
8027 decl = build_lang_decl (VAR_DECL, name, type);
8028 else
8029 decl = build_decl (input_location, VAR_DECL, name, type);
8031 if (explicit_scope && TREE_CODE (explicit_scope) == NAMESPACE_DECL)
8032 set_decl_namespace (decl, explicit_scope, 0);
8033 else
8034 DECL_CONTEXT (decl) = FROB_CONTEXT (scope);
8036 if (declspecs->storage_class == sc_extern)
8038 DECL_THIS_EXTERN (decl) = 1;
8039 DECL_EXTERNAL (decl) = !initialized;
8042 if (DECL_CLASS_SCOPE_P (decl))
8044 set_linkage_for_static_data_member (decl);
8045 /* This function is only called with out-of-class definitions. */
8046 DECL_EXTERNAL (decl) = 0;
8047 check_class_member_definition_namespace (decl);
8049 /* At top level, either `static' or no s.c. makes a definition
8050 (perhaps tentative), and absence of `static' makes it public. */
8051 else if (toplevel_bindings_p ())
8053 TREE_PUBLIC (decl) = (declspecs->storage_class != sc_static
8054 && (DECL_THIS_EXTERN (decl) || ! constp));
8055 TREE_STATIC (decl) = ! DECL_EXTERNAL (decl);
8057 /* Not at top level, only `static' makes a static definition. */
8058 else
8060 TREE_STATIC (decl) = declspecs->storage_class == sc_static;
8061 TREE_PUBLIC (decl) = DECL_EXTERNAL (decl);
8064 if (decl_spec_seq_has_spec_p (declspecs, ds_thread))
8066 if (DECL_EXTERNAL (decl) || TREE_STATIC (decl))
8067 set_decl_tls_model (decl, decl_default_tls_model (decl));
8068 if (declspecs->gnu_thread_keyword_p)
8069 DECL_GNU_TLS_P (decl) = true;
8072 /* If the type of the decl has no linkage, make sure that we'll
8073 notice that in mark_used. */
8074 if (cxx_dialect > cxx98
8075 && decl_linkage (decl) != lk_none
8076 && DECL_LANG_SPECIFIC (decl) == NULL
8077 && !DECL_EXTERN_C_P (decl)
8078 && no_linkage_check (TREE_TYPE (decl), /*relaxed_p=*/false))
8079 retrofit_lang_decl (decl);
8081 if (TREE_PUBLIC (decl))
8083 /* [basic.link]: A name with no linkage (notably, the name of a class
8084 or enumeration declared in a local scope) shall not be used to
8085 declare an entity with linkage.
8087 DR 757 relaxes this restriction for C++0x. */
8088 if (cxx_dialect < cxx11)
8089 no_linkage_error (decl);
8091 else
8092 DECL_INTERFACE_KNOWN (decl) = 1;
8094 // Handle explicit specializations and instantiations of variable templates.
8095 if (orig_declarator)
8096 decl = check_explicit_specialization (orig_declarator, decl,
8097 template_count, 0);
8099 return decl != error_mark_node ? decl : NULL_TREE;
8102 /* Create and return a canonical pointer to member function type, for
8103 TYPE, which is a POINTER_TYPE to a METHOD_TYPE. */
8105 tree
8106 build_ptrmemfunc_type (tree type)
8108 tree field, fields;
8109 tree t;
8110 tree unqualified_variant = NULL_TREE;
8112 if (type == error_mark_node)
8113 return type;
8115 /* If a canonical type already exists for this type, use it. We use
8116 this method instead of type_hash_canon, because it only does a
8117 simple equality check on the list of field members. */
8119 if ((t = TYPE_GET_PTRMEMFUNC_TYPE (type)))
8120 return t;
8122 /* Make sure that we always have the unqualified pointer-to-member
8123 type first. */
8124 if (cp_type_quals (type) != TYPE_UNQUALIFIED)
8125 unqualified_variant
8126 = build_ptrmemfunc_type (TYPE_MAIN_VARIANT (type));
8128 t = make_node (RECORD_TYPE);
8130 /* Let the front end know this is a pointer to member function. */
8131 TYPE_PTRMEMFUNC_FLAG (t) = 1;
8133 field = build_decl (input_location, FIELD_DECL, pfn_identifier, type);
8134 fields = field;
8136 field = build_decl (input_location, FIELD_DECL, delta_identifier,
8137 delta_type_node);
8138 DECL_CHAIN (field) = fields;
8139 fields = field;
8141 finish_builtin_struct (t, "__ptrmemfunc_type", fields, ptr_type_node);
8143 /* Zap out the name so that the back end will give us the debugging
8144 information for this anonymous RECORD_TYPE. */
8145 TYPE_NAME (t) = NULL_TREE;
8147 /* If this is not the unqualified form of this pointer-to-member
8148 type, set the TYPE_MAIN_VARIANT for this type to be the
8149 unqualified type. Since they are actually RECORD_TYPEs that are
8150 not variants of each other, we must do this manually.
8151 As we just built a new type there is no need to do yet another copy. */
8152 if (cp_type_quals (type) != TYPE_UNQUALIFIED)
8154 int type_quals = cp_type_quals (type);
8155 TYPE_READONLY (t) = (type_quals & TYPE_QUAL_CONST) != 0;
8156 TYPE_VOLATILE (t) = (type_quals & TYPE_QUAL_VOLATILE) != 0;
8157 TYPE_RESTRICT (t) = (type_quals & TYPE_QUAL_RESTRICT) != 0;
8158 TYPE_MAIN_VARIANT (t) = unqualified_variant;
8159 TYPE_NEXT_VARIANT (t) = TYPE_NEXT_VARIANT (unqualified_variant);
8160 TYPE_NEXT_VARIANT (unqualified_variant) = t;
8163 /* Cache this pointer-to-member type so that we can find it again
8164 later. */
8165 TYPE_SET_PTRMEMFUNC_TYPE (type, t);
8167 if (TYPE_STRUCTURAL_EQUALITY_P (type))
8168 SET_TYPE_STRUCTURAL_EQUALITY (t);
8169 else if (TYPE_CANONICAL (type) != type)
8170 TYPE_CANONICAL (t) = build_ptrmemfunc_type (TYPE_CANONICAL (type));
8172 return t;
8175 /* Create and return a pointer to data member type. */
8177 tree
8178 build_ptrmem_type (tree class_type, tree member_type)
8180 if (TREE_CODE (member_type) == METHOD_TYPE)
8182 cp_cv_quals quals = type_memfn_quals (member_type);
8183 cp_ref_qualifier rqual = type_memfn_rqual (member_type);
8184 member_type = build_memfn_type (member_type, class_type, quals, rqual);
8185 return build_ptrmemfunc_type (build_pointer_type (member_type));
8187 else
8189 gcc_assert (TREE_CODE (member_type) != FUNCTION_TYPE);
8190 return build_offset_type (class_type, member_type);
8194 /* DECL is a VAR_DECL defined in-class, whose TYPE is also given.
8195 Check to see that the definition is valid. Issue appropriate error
8196 messages. Return 1 if the definition is particularly bad, or 0
8197 otherwise. */
8199 static int
8200 check_static_variable_definition (tree decl, tree type)
8202 /* Can't check yet if we don't know the type. */
8203 if (dependent_type_p (type))
8204 return 0;
8205 /* If DECL is declared constexpr, we'll do the appropriate checks
8206 in check_initializer. */
8207 if (DECL_P (decl) && DECL_DECLARED_CONSTEXPR_P (decl))
8208 return 0;
8209 else if (cxx_dialect >= cxx11 && !INTEGRAL_OR_ENUMERATION_TYPE_P (type))
8211 if (!COMPLETE_TYPE_P (type))
8212 error ("in-class initialization of static data member %q#D of "
8213 "incomplete type", decl);
8214 else if (literal_type_p (type))
8215 permerror (input_location,
8216 "%<constexpr%> needed for in-class initialization of "
8217 "static data member %q#D of non-integral type", decl);
8218 else
8219 error ("in-class initialization of static data member %q#D of "
8220 "non-literal type", decl);
8221 return 1;
8224 /* Motion 10 at San Diego: If a static const integral data member is
8225 initialized with an integral constant expression, the initializer
8226 may appear either in the declaration (within the class), or in
8227 the definition, but not both. If it appears in the class, the
8228 member is a member constant. The file-scope definition is always
8229 required. */
8230 if (!ARITHMETIC_TYPE_P (type) && TREE_CODE (type) != ENUMERAL_TYPE)
8232 error ("invalid in-class initialization of static data member "
8233 "of non-integral type %qT",
8234 type);
8235 return 1;
8237 else if (!CP_TYPE_CONST_P (type))
8238 error ("ISO C++ forbids in-class initialization of non-const "
8239 "static member %qD",
8240 decl);
8241 else if (!INTEGRAL_OR_ENUMERATION_TYPE_P (type))
8242 pedwarn (input_location, OPT_Wpedantic, "ISO C++ forbids initialization of member constant "
8243 "%qD of non-integral type %qT", decl, type);
8245 return 0;
8248 /* *expr_p is part of the TYPE_SIZE of a variably-sized array. If any
8249 SAVE_EXPRs in *expr_p wrap expressions with side-effects, break those
8250 expressions out into temporary variables so that walk_tree doesn't
8251 step into them (c++/15764). */
8253 static tree
8254 stabilize_save_expr_r (tree *expr_p, int *walk_subtrees, void *data)
8256 hash_set<tree> *pset = (hash_set<tree> *)data;
8257 tree expr = *expr_p;
8258 if (TREE_CODE (expr) == SAVE_EXPR)
8260 tree op = TREE_OPERAND (expr, 0);
8261 cp_walk_tree (&op, stabilize_save_expr_r, data, pset);
8262 if (TREE_SIDE_EFFECTS (op))
8263 TREE_OPERAND (expr, 0) = get_temp_regvar (TREE_TYPE (op), op);
8264 *walk_subtrees = 0;
8266 else if (!EXPR_P (expr) || !TREE_SIDE_EFFECTS (expr))
8267 *walk_subtrees = 0;
8268 return NULL;
8271 /* Entry point for the above. */
8273 static void
8274 stabilize_vla_size (tree size)
8276 hash_set<tree> pset;
8277 /* Break out any function calls into temporary variables. */
8278 cp_walk_tree (&size, stabilize_save_expr_r, &pset, &pset);
8281 /* Helper function for compute_array_index_type. Look for SIZEOF_EXPR
8282 not inside of SAVE_EXPR and fold them. */
8284 static tree
8285 fold_sizeof_expr_r (tree *expr_p, int *walk_subtrees, void *data)
8287 tree expr = *expr_p;
8288 if (TREE_CODE (expr) == SAVE_EXPR || TYPE_P (expr))
8289 *walk_subtrees = 0;
8290 else if (TREE_CODE (expr) == SIZEOF_EXPR)
8292 *(bool *)data = true;
8293 if (SIZEOF_EXPR_TYPE_P (expr))
8294 expr = cxx_sizeof_or_alignof_type (TREE_TYPE (TREE_OPERAND (expr, 0)),
8295 SIZEOF_EXPR, false);
8296 else if (TYPE_P (TREE_OPERAND (expr, 0)))
8297 expr = cxx_sizeof_or_alignof_type (TREE_OPERAND (expr, 0), SIZEOF_EXPR,
8298 false);
8299 else
8300 expr = cxx_sizeof_or_alignof_expr (TREE_OPERAND (expr, 0), SIZEOF_EXPR,
8301 false);
8302 if (expr == error_mark_node)
8303 expr = size_one_node;
8304 *expr_p = expr;
8305 *walk_subtrees = 0;
8307 return NULL;
8310 /* Given the SIZE (i.e., number of elements) in an array, compute an
8311 appropriate index type for the array. If non-NULL, NAME is the
8312 name of the thing being declared. */
8314 tree
8315 compute_array_index_type (tree name, tree size, tsubst_flags_t complain)
8317 tree itype;
8318 tree osize = size;
8320 if (error_operand_p (size))
8321 return error_mark_node;
8323 if (!type_dependent_expression_p (size))
8325 tree type = TREE_TYPE (size);
8327 mark_rvalue_use (size);
8329 if (cxx_dialect < cxx11 && TREE_CODE (size) == NOP_EXPR
8330 && TREE_SIDE_EFFECTS (size))
8331 /* In C++98, we mark a non-constant array bound with a magic
8332 NOP_EXPR with TREE_SIDE_EFFECTS; don't fold in that case. */;
8333 else
8335 size = fold_non_dependent_expr_sfinae (size, complain);
8337 if (CLASS_TYPE_P (type)
8338 && CLASSTYPE_LITERAL_P (type))
8340 size = build_expr_type_conversion (WANT_INT, size, true);
8341 if (!size)
8343 if (!(complain & tf_error))
8344 return error_mark_node;
8345 if (name)
8346 error ("size of array %qD has non-integral type %qT",
8347 name, type);
8348 else
8349 error ("size of array has non-integral type %qT", type);
8350 size = integer_one_node;
8352 if (size == error_mark_node)
8353 return error_mark_node;
8354 type = TREE_TYPE (size);
8357 if (INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type))
8358 size = maybe_constant_value (size);
8360 if (!TREE_CONSTANT (size))
8361 size = osize;
8364 if (error_operand_p (size))
8365 return error_mark_node;
8367 /* The array bound must be an integer type. */
8368 if (!INTEGRAL_OR_UNSCOPED_ENUMERATION_TYPE_P (type))
8370 if (!(complain & tf_error))
8371 return error_mark_node;
8372 if (name)
8373 error ("size of array %qD has non-integral type %qT", name, type);
8374 else
8375 error ("size of array has non-integral type %qT", type);
8376 size = integer_one_node;
8377 type = TREE_TYPE (size);
8381 /* A type is dependent if it is...an array type constructed from any
8382 dependent type or whose size is specified by a constant expression
8383 that is value-dependent. */
8384 /* We can only call value_dependent_expression_p on integral constant
8385 expressions; treat non-constant expressions as dependent, too. */
8386 if (processing_template_decl
8387 && (type_dependent_expression_p (size)
8388 || !TREE_CONSTANT (size) || value_dependent_expression_p (size)))
8390 /* We cannot do any checking for a SIZE that isn't known to be
8391 constant. Just build the index type and mark that it requires
8392 structural equality checks. */
8393 itype = build_index_type (build_min (MINUS_EXPR, sizetype,
8394 size, size_one_node));
8395 TYPE_DEPENDENT_P (itype) = 1;
8396 TYPE_DEPENDENT_P_VALID (itype) = 1;
8397 SET_TYPE_STRUCTURAL_EQUALITY (itype);
8398 return itype;
8401 /* Normally, the array-bound will be a constant. */
8402 if (TREE_CODE (size) == INTEGER_CST)
8404 /* Check to see if the array bound overflowed. Make that an
8405 error, no matter how generous we're being. */
8406 constant_expression_error (size);
8408 /* An array must have a positive number of elements. */
8409 if (tree_int_cst_lt (size, integer_zero_node))
8411 if (!(complain & tf_error))
8412 return error_mark_node;
8413 if (name)
8414 error ("size of array %qD is negative", name);
8415 else
8416 error ("size of array is negative");
8417 size = integer_one_node;
8419 /* As an extension we allow zero-sized arrays. */
8420 else if (integer_zerop (size))
8422 if (!(complain & tf_error))
8423 /* We must fail if performing argument deduction (as
8424 indicated by the state of complain), so that
8425 another substitution can be found. */
8426 return error_mark_node;
8427 else if (in_system_header_at (input_location))
8428 /* Allow them in system headers because glibc uses them. */;
8429 else if (name)
8430 pedwarn (input_location, OPT_Wpedantic, "ISO C++ forbids zero-size array %qD", name);
8431 else
8432 pedwarn (input_location, OPT_Wpedantic, "ISO C++ forbids zero-size array");
8435 else if (TREE_CONSTANT (size)
8436 /* We don't allow VLAs at non-function scopes, or during
8437 tentative template substitution. */
8438 || !at_function_scope_p ()
8439 || (cxx_dialect < cxx14 && !(complain & tf_error)))
8441 if (!(complain & tf_error))
8442 return error_mark_node;
8443 /* `(int) &fn' is not a valid array bound. */
8444 if (name)
8445 error ("size of array %qD is not an integral constant-expression",
8446 name);
8447 else
8448 error ("size of array is not an integral constant-expression");
8449 size = integer_one_node;
8451 else if (cxx_dialect < cxx14 && pedantic && warn_vla != 0)
8453 if (name)
8454 pedwarn (input_location, OPT_Wvla, "ISO C++ forbids variable length array %qD", name);
8455 else
8456 pedwarn (input_location, OPT_Wvla, "ISO C++ forbids variable length array");
8458 else if (warn_vla > 0)
8460 if (name)
8461 warning (OPT_Wvla,
8462 "variable length array %qD is used", name);
8463 else
8464 warning (OPT_Wvla,
8465 "variable length array is used");
8468 if (processing_template_decl && !TREE_CONSTANT (size))
8469 /* A variable sized array. */
8470 itype = build_min (MINUS_EXPR, sizetype, size, integer_one_node);
8471 else
8473 HOST_WIDE_INT saved_processing_template_decl;
8475 /* Compute the index of the largest element in the array. It is
8476 one less than the number of elements in the array. We save
8477 and restore PROCESSING_TEMPLATE_DECL so that computations in
8478 cp_build_binary_op will be appropriately folded. */
8479 saved_processing_template_decl = processing_template_decl;
8480 processing_template_decl = 0;
8481 itype = cp_build_binary_op (input_location,
8482 MINUS_EXPR,
8483 cp_convert (ssizetype, size, complain),
8484 cp_convert (ssizetype, integer_one_node,
8485 complain),
8486 complain);
8487 itype = fold (itype);
8488 processing_template_decl = saved_processing_template_decl;
8490 if (!TREE_CONSTANT (itype))
8492 /* A variable sized array. */
8493 itype = variable_size (itype);
8495 if (TREE_CODE (itype) != SAVE_EXPR)
8497 /* Look for SIZEOF_EXPRs in itype and fold them, otherwise
8498 they might survive till gimplification. */
8499 tree newitype = itype;
8500 bool found = false;
8501 cp_walk_tree_without_duplicates (&newitype,
8502 fold_sizeof_expr_r, &found);
8503 if (found)
8504 itype = variable_size (fold (newitype));
8507 stabilize_vla_size (itype);
8509 if (cxx_dialect >= cxx14 && flag_exceptions)
8511 /* If the VLA bound is larger than half the address space,
8512 or less than zero, throw std::bad_array_length. */
8513 tree comp = build2 (LT_EXPR, boolean_type_node, itype,
8514 ssize_int (-1));
8515 comp = build3 (COND_EXPR, void_type_node, comp,
8516 throw_bad_array_length (), void_node);
8517 finish_expr_stmt (comp);
8519 else if (flag_sanitize & SANITIZE_VLA
8520 && current_function_decl != NULL_TREE
8521 && !lookup_attribute ("no_sanitize_undefined",
8522 DECL_ATTRIBUTES
8523 (current_function_decl)))
8525 /* From C++14 onwards, we throw an exception on a negative
8526 length size of an array; see above. */
8528 /* We have to add 1 -- in the ubsan routine we generate
8529 LE_EXPR rather than LT_EXPR. */
8530 tree t = fold_build2 (PLUS_EXPR, TREE_TYPE (itype), itype,
8531 build_one_cst (TREE_TYPE (itype)));
8532 t = ubsan_instrument_vla (input_location, t);
8533 finish_expr_stmt (t);
8536 /* Make sure that there was no overflow when creating to a signed
8537 index type. (For example, on a 32-bit machine, an array with
8538 size 2^32 - 1 is too big.) */
8539 else if (TREE_CODE (itype) == INTEGER_CST
8540 && TREE_OVERFLOW (itype))
8542 if (!(complain & tf_error))
8543 return error_mark_node;
8544 error ("overflow in array dimension");
8545 TREE_OVERFLOW (itype) = 0;
8549 /* Create and return the appropriate index type. */
8550 itype = build_index_type (itype);
8552 /* If the index type were dependent, we would have returned early, so
8553 remember that it isn't. */
8554 TYPE_DEPENDENT_P (itype) = 0;
8555 TYPE_DEPENDENT_P_VALID (itype) = 1;
8556 return itype;
8559 /* Returns the scope (if any) in which the entity declared by
8560 DECLARATOR will be located. If the entity was declared with an
8561 unqualified name, NULL_TREE is returned. */
8563 tree
8564 get_scope_of_declarator (const cp_declarator *declarator)
8566 while (declarator && declarator->kind != cdk_id)
8567 declarator = declarator->declarator;
8569 /* If the declarator-id is a SCOPE_REF, the scope in which the
8570 declaration occurs is the first operand. */
8571 if (declarator
8572 && declarator->u.id.qualifying_scope)
8573 return declarator->u.id.qualifying_scope;
8575 /* Otherwise, the declarator is not a qualified name; the entity will
8576 be declared in the current scope. */
8577 return NULL_TREE;
8580 /* Returns an ARRAY_TYPE for an array with SIZE elements of the
8581 indicated TYPE. If non-NULL, NAME is the NAME of the declaration
8582 with this type. */
8584 static tree
8585 create_array_type_for_decl (tree name, tree type, tree size)
8587 tree itype = NULL_TREE;
8589 /* If things have already gone awry, bail now. */
8590 if (type == error_mark_node || size == error_mark_node)
8591 return error_mark_node;
8593 /* 8.3.4/1: If the type of the identifier of D contains the auto
8594 type-specifier, the program is ill-formed. */
8595 if (type_uses_auto (type))
8597 error ("%qD declared as array of %qT", name, type);
8598 return error_mark_node;
8601 /* If there are some types which cannot be array elements,
8602 issue an error-message and return. */
8603 switch (TREE_CODE (type))
8605 case VOID_TYPE:
8606 if (name)
8607 error ("declaration of %qD as array of void", name);
8608 else
8609 error ("creating array of void");
8610 return error_mark_node;
8612 case FUNCTION_TYPE:
8613 if (name)
8614 error ("declaration of %qD as array of functions", name);
8615 else
8616 error ("creating array of functions");
8617 return error_mark_node;
8619 case REFERENCE_TYPE:
8620 if (name)
8621 error ("declaration of %qD as array of references", name);
8622 else
8623 error ("creating array of references");
8624 return error_mark_node;
8626 case METHOD_TYPE:
8627 if (name)
8628 error ("declaration of %qD as array of function members", name);
8629 else
8630 error ("creating array of function members");
8631 return error_mark_node;
8633 default:
8634 break;
8637 /* [dcl.array]
8639 The constant expressions that specify the bounds of the arrays
8640 can be omitted only for the first member of the sequence. */
8641 if (TREE_CODE (type) == ARRAY_TYPE && !TYPE_DOMAIN (type))
8643 if (name)
8644 error ("declaration of %qD as multidimensional array must "
8645 "have bounds for all dimensions except the first",
8646 name);
8647 else
8648 error ("multidimensional array must have bounds for all "
8649 "dimensions except the first");
8651 return error_mark_node;
8654 if (cxx_dialect >= cxx14 && array_of_runtime_bound_p (type)
8655 && (flag_iso || warn_vla > 0))
8656 pedwarn (input_location, OPT_Wvla, "array of array of runtime bound");
8658 /* Figure out the index type for the array. */
8659 if (size)
8660 itype = compute_array_index_type (name, size, tf_warning_or_error);
8662 /* [dcl.array]
8663 T is called the array element type; this type shall not be [...] an
8664 abstract class type. */
8665 abstract_virtuals_error (name, type);
8667 return build_cplus_array_type (type, itype);
8670 /* Check that it's OK to declare a function with the indicated TYPE.
8671 SFK indicates the kind of special function (if any) that this
8672 function is. OPTYPE is the type given in a conversion operator
8673 declaration, or the class type for a constructor/destructor.
8674 Returns the actual return type of the function; that
8675 may be different than TYPE if an error occurs, or for certain
8676 special functions. */
8678 static tree
8679 check_special_function_return_type (special_function_kind sfk,
8680 tree type,
8681 tree optype)
8683 switch (sfk)
8685 case sfk_constructor:
8686 if (type)
8687 error ("return type specification for constructor invalid");
8689 if (targetm.cxx.cdtor_returns_this () && !TYPE_FOR_JAVA (optype))
8690 type = build_pointer_type (optype);
8691 else
8692 type = void_type_node;
8693 break;
8695 case sfk_destructor:
8696 if (type)
8697 error ("return type specification for destructor invalid");
8698 /* We can't use the proper return type here because we run into
8699 problems with ambiguous bases and covariant returns.
8700 Java classes are left unchanged because (void *) isn't a valid
8701 Java type, and we don't want to change the Java ABI. */
8702 if (targetm.cxx.cdtor_returns_this () && !TYPE_FOR_JAVA (optype))
8703 type = build_pointer_type (void_type_node);
8704 else
8705 type = void_type_node;
8706 break;
8708 case sfk_conversion:
8709 if (type)
8710 error ("return type specified for %<operator %T%>", optype);
8711 type = optype;
8712 break;
8714 default:
8715 gcc_unreachable ();
8718 return type;
8721 /* A variable or data member (whose unqualified name is IDENTIFIER)
8722 has been declared with the indicated TYPE. If the TYPE is not
8723 acceptable, issue an error message and return a type to use for
8724 error-recovery purposes. */
8726 tree
8727 check_var_type (tree identifier, tree type)
8729 if (VOID_TYPE_P (type))
8731 if (!identifier)
8732 error ("unnamed variable or field declared void");
8733 else if (identifier_p (identifier))
8735 gcc_assert (!IDENTIFIER_OPNAME_P (identifier));
8736 error ("variable or field %qE declared void", identifier);
8738 else
8739 error ("variable or field declared void");
8740 type = error_mark_node;
8743 return type;
8746 /* Given declspecs and a declarator (abstract or otherwise), determine
8747 the name and type of the object declared and construct a DECL node
8748 for it.
8750 DECLSPECS points to the representation of declaration-specifier
8751 sequence that precedes declarator.
8753 DECL_CONTEXT says which syntactic context this declaration is in:
8754 NORMAL for most contexts. Make a VAR_DECL or FUNCTION_DECL or TYPE_DECL.
8755 FUNCDEF for a function definition. Like NORMAL but a few different
8756 error messages in each case. Return value may be zero meaning
8757 this definition is too screwy to try to parse.
8758 MEMFUNCDEF for a function definition. Like FUNCDEF but prepares to
8759 handle member functions (which have FIELD context).
8760 Return value may be zero meaning this definition is too screwy to
8761 try to parse.
8762 PARM for a parameter declaration (either within a function prototype
8763 or before a function body). Make a PARM_DECL, or return void_type_node.
8764 TPARM for a template parameter declaration.
8765 CATCHPARM for a parameter declaration before a catch clause.
8766 TYPENAME if for a typename (in a cast or sizeof).
8767 Don't make a DECL node; just return the ..._TYPE node.
8768 FIELD for a struct or union field; make a FIELD_DECL.
8769 BITFIELD for a field with specified width.
8771 INITIALIZED is as for start_decl.
8773 ATTRLIST is a pointer to the list of attributes, which may be NULL
8774 if there are none; *ATTRLIST may be modified if attributes from inside
8775 the declarator should be applied to the declaration.
8777 When this function is called, scoping variables (such as
8778 CURRENT_CLASS_TYPE) should reflect the scope in which the
8779 declaration occurs, not the scope in which the new declaration will
8780 be placed. For example, on:
8782 void S::f() { ... }
8784 when grokdeclarator is called for `S::f', the CURRENT_CLASS_TYPE
8785 should not be `S'.
8787 Returns a DECL (if a declarator is present), a TYPE (if there is no
8788 declarator, in cases like "struct S;"), or the ERROR_MARK_NODE if an
8789 error occurs. */
8791 tree
8792 grokdeclarator (const cp_declarator *declarator,
8793 cp_decl_specifier_seq *declspecs,
8794 enum decl_context decl_context,
8795 int initialized,
8796 tree* attrlist)
8798 tree type = NULL_TREE;
8799 int longlong = 0;
8800 int explicit_int128 = 0;
8801 int virtualp, explicitp, friendp, inlinep, staticp;
8802 int explicit_int = 0;
8803 int explicit_char = 0;
8804 int defaulted_int = 0;
8806 tree typedef_decl = NULL_TREE;
8807 const char *name = NULL;
8808 tree typedef_type = NULL_TREE;
8809 /* True if this declarator is a function definition. */
8810 bool funcdef_flag = false;
8811 cp_declarator_kind innermost_code = cdk_error;
8812 int bitfield = 0;
8813 #if 0
8814 /* See the code below that used this. */
8815 tree decl_attr = NULL_TREE;
8816 #endif
8818 /* Keep track of what sort of function is being processed
8819 so that we can warn about default return values, or explicit
8820 return values which do not match prescribed defaults. */
8821 special_function_kind sfk = sfk_none;
8823 tree dname = NULL_TREE;
8824 tree ctor_return_type = NULL_TREE;
8825 enum overload_flags flags = NO_SPECIAL;
8826 /* cv-qualifiers that apply to the declarator, for a declaration of
8827 a member function. */
8828 cp_cv_quals memfn_quals = TYPE_UNQUALIFIED;
8829 /* virt-specifiers that apply to the declarator, for a declaration of
8830 a member function. */
8831 cp_virt_specifiers virt_specifiers = VIRT_SPEC_UNSPECIFIED;
8832 /* ref-qualifier that applies to the declarator, for a declaration of
8833 a member function. */
8834 cp_ref_qualifier rqual = REF_QUAL_NONE;
8835 /* cv-qualifiers that apply to the type specified by the DECLSPECS. */
8836 int type_quals;
8837 tree raises = NULL_TREE;
8838 int template_count = 0;
8839 tree returned_attrs = NULL_TREE;
8840 tree parms = NULL_TREE;
8841 const cp_declarator *id_declarator;
8842 /* The unqualified name of the declarator; either an
8843 IDENTIFIER_NODE, BIT_NOT_EXPR, or TEMPLATE_ID_EXPR. */
8844 tree unqualified_id;
8845 /* The class type, if any, in which this entity is located,
8846 or NULL_TREE if none. Note that this value may be different from
8847 the current class type; for example if an attempt is made to declare
8848 "A::f" inside "B", this value will be "A". */
8849 tree ctype = current_class_type;
8850 /* The NAMESPACE_DECL for the namespace in which this entity is
8851 located. If an unqualified name is used to declare the entity,
8852 this value will be NULL_TREE, even if the entity is located at
8853 namespace scope. */
8854 tree in_namespace = NULL_TREE;
8855 cp_storage_class storage_class;
8856 bool unsigned_p, signed_p, short_p, long_p, thread_p;
8857 bool type_was_error_mark_node = false;
8858 bool parameter_pack_p = declarator? declarator->parameter_pack_p : false;
8859 bool template_type_arg = false;
8860 bool template_parm_flag = false;
8861 bool typedef_p = decl_spec_seq_has_spec_p (declspecs, ds_typedef);
8862 bool constexpr_p = decl_spec_seq_has_spec_p (declspecs, ds_constexpr);
8863 bool late_return_type_p = false;
8864 bool array_parameter_p = false;
8865 source_location saved_loc = input_location;
8866 const char *errmsg;
8868 signed_p = decl_spec_seq_has_spec_p (declspecs, ds_signed);
8869 unsigned_p = decl_spec_seq_has_spec_p (declspecs, ds_unsigned);
8870 short_p = decl_spec_seq_has_spec_p (declspecs, ds_short);
8871 long_p = decl_spec_seq_has_spec_p (declspecs, ds_long);
8872 longlong = decl_spec_seq_has_spec_p (declspecs, ds_long_long);
8873 explicit_int128 = declspecs->explicit_int128_p;
8874 thread_p = decl_spec_seq_has_spec_p (declspecs, ds_thread);
8876 if (decl_context == FUNCDEF)
8877 funcdef_flag = true, decl_context = NORMAL;
8878 else if (decl_context == MEMFUNCDEF)
8879 funcdef_flag = true, decl_context = FIELD;
8880 else if (decl_context == BITFIELD)
8881 bitfield = 1, decl_context = FIELD;
8882 else if (decl_context == TEMPLATE_TYPE_ARG)
8883 template_type_arg = true, decl_context = TYPENAME;
8884 else if (decl_context == TPARM)
8885 template_parm_flag = true, decl_context = PARM;
8887 if (initialized > 1)
8888 funcdef_flag = true;
8890 /* Look inside a declarator for the name being declared
8891 and get it as a string, for an error message. */
8892 for (id_declarator = declarator;
8893 id_declarator;
8894 id_declarator = id_declarator->declarator)
8896 if (id_declarator->kind != cdk_id)
8897 innermost_code = id_declarator->kind;
8899 switch (id_declarator->kind)
8901 case cdk_function:
8902 if (id_declarator->declarator
8903 && id_declarator->declarator->kind == cdk_id)
8905 sfk = id_declarator->declarator->u.id.sfk;
8906 if (sfk == sfk_destructor)
8907 flags = DTOR_FLAG;
8909 break;
8911 case cdk_id:
8913 tree qualifying_scope = id_declarator->u.id.qualifying_scope;
8914 tree decl = id_declarator->u.id.unqualified_name;
8915 if (!decl)
8916 break;
8917 if (qualifying_scope)
8919 if (at_function_scope_p ())
8921 /* [dcl.meaning]
8923 A declarator-id shall not be qualified except
8924 for ...
8926 None of the cases are permitted in block
8927 scope. */
8928 if (qualifying_scope == global_namespace)
8929 error ("invalid use of qualified-name %<::%D%>",
8930 decl);
8931 else if (TYPE_P (qualifying_scope))
8932 error ("invalid use of qualified-name %<%T::%D%>",
8933 qualifying_scope, decl);
8934 else
8935 error ("invalid use of qualified-name %<%D::%D%>",
8936 qualifying_scope, decl);
8937 return error_mark_node;
8939 else if (TYPE_P (qualifying_scope))
8941 ctype = qualifying_scope;
8942 if (!MAYBE_CLASS_TYPE_P (ctype))
8944 error ("%q#T is not a class or a namespace", ctype);
8945 ctype = NULL_TREE;
8947 else if (innermost_code != cdk_function
8948 && current_class_type
8949 && !uniquely_derived_from_p (ctype,
8950 current_class_type))
8952 error ("invalid use of qualified-name %<%T::%D%>",
8953 qualifying_scope, decl);
8954 return error_mark_node;
8957 else if (TREE_CODE (qualifying_scope) == NAMESPACE_DECL)
8958 in_namespace = qualifying_scope;
8960 switch (TREE_CODE (decl))
8962 case BIT_NOT_EXPR:
8964 tree type;
8966 if (innermost_code != cdk_function)
8968 error ("declaration of %qD as non-function", decl);
8969 return error_mark_node;
8971 else if (!qualifying_scope
8972 && !(current_class_type && at_class_scope_p ()))
8974 error ("declaration of %qD as non-member", decl);
8975 return error_mark_node;
8978 type = TREE_OPERAND (decl, 0);
8979 if (TYPE_P (type))
8980 type = constructor_name (type);
8981 name = identifier_to_locale (IDENTIFIER_POINTER (type));
8982 dname = decl;
8984 break;
8986 case TEMPLATE_ID_EXPR:
8988 tree fns = TREE_OPERAND (decl, 0);
8990 dname = fns;
8991 if (!identifier_p (dname))
8993 if (variable_template_p (dname))
8994 dname = DECL_NAME (dname);
8995 else
8997 gcc_assert (is_overloaded_fn (dname));
8998 dname = DECL_NAME (get_first_fn (dname));
9002 /* Fall through. */
9004 case IDENTIFIER_NODE:
9005 if (identifier_p (decl))
9006 dname = decl;
9008 if (C_IS_RESERVED_WORD (dname))
9010 error ("declarator-id missing; using reserved word %qD",
9011 dname);
9012 name = identifier_to_locale (IDENTIFIER_POINTER (dname));
9014 else if (!IDENTIFIER_TYPENAME_P (dname))
9015 name = identifier_to_locale (IDENTIFIER_POINTER (dname));
9016 else
9018 gcc_assert (flags == NO_SPECIAL);
9019 flags = TYPENAME_FLAG;
9020 ctor_return_type = TREE_TYPE (dname);
9021 sfk = sfk_conversion;
9022 if (is_typename_at_global_scope (dname))
9023 name = identifier_to_locale (IDENTIFIER_POINTER (dname));
9024 else
9025 name = "<invalid operator>";
9027 break;
9029 default:
9030 gcc_unreachable ();
9032 break;
9035 case cdk_array:
9036 case cdk_pointer:
9037 case cdk_reference:
9038 case cdk_ptrmem:
9039 break;
9041 case cdk_error:
9042 return error_mark_node;
9044 default:
9045 gcc_unreachable ();
9047 if (id_declarator->kind == cdk_id)
9048 break;
9051 /* [dcl.fct.edf]
9053 The declarator in a function-definition shall have the form
9054 D1 ( parameter-declaration-clause) ... */
9055 if (funcdef_flag && innermost_code != cdk_function)
9057 error ("function definition does not declare parameters");
9058 return error_mark_node;
9061 if (flags == TYPENAME_FLAG
9062 && innermost_code != cdk_function
9063 && ! (ctype && !declspecs->any_specifiers_p))
9065 error ("declaration of %qD as non-function", dname);
9066 return error_mark_node;
9069 if (dname
9070 && identifier_p (dname)
9071 && UDLIT_OPER_P (dname)
9072 && innermost_code != cdk_function)
9074 error ("declaration of %qD as non-function", dname);
9075 return error_mark_node;
9078 if (dname && IDENTIFIER_OPNAME_P (dname))
9080 if (typedef_p)
9082 error ("declaration of %qD as %<typedef%>", dname);
9083 return error_mark_node;
9085 else if (decl_context == PARM || decl_context == CATCHPARM)
9087 error ("declaration of %qD as parameter", dname);
9088 return error_mark_node;
9092 /* Anything declared one level down from the top level
9093 must be one of the parameters of a function
9094 (because the body is at least two levels down). */
9096 /* This heuristic cannot be applied to C++ nodes! Fixed, however,
9097 by not allowing C++ class definitions to specify their parameters
9098 with xdecls (must be spec.d in the parmlist).
9100 Since we now wait to push a class scope until we are sure that
9101 we are in a legitimate method context, we must set oldcname
9102 explicitly (since current_class_name is not yet alive).
9104 We also want to avoid calling this a PARM if it is in a namespace. */
9106 if (decl_context == NORMAL && !toplevel_bindings_p ())
9108 cp_binding_level *b = current_binding_level;
9109 current_binding_level = b->level_chain;
9110 if (current_binding_level != 0 && toplevel_bindings_p ())
9111 decl_context = PARM;
9112 current_binding_level = b;
9115 if (name == NULL)
9116 name = decl_context == PARM ? "parameter" : "type name";
9118 if (constexpr_p && typedef_p)
9120 error ("%<constexpr%> cannot appear in a typedef declaration");
9121 return error_mark_node;
9124 /* If there were multiple types specified in the decl-specifier-seq,
9125 issue an error message. */
9126 if (declspecs->multiple_types_p)
9128 error ("two or more data types in declaration of %qs", name);
9129 return error_mark_node;
9132 if (declspecs->conflicting_specifiers_p)
9134 error ("conflicting specifiers in declaration of %qs", name);
9135 return error_mark_node;
9138 /* Extract the basic type from the decl-specifier-seq. */
9139 type = declspecs->type;
9140 if (type == error_mark_node)
9142 type = NULL_TREE;
9143 type_was_error_mark_node = true;
9145 /* If the entire declaration is itself tagged as deprecated then
9146 suppress reports of deprecated items. */
9147 if (type && TREE_DEPRECATED (type)
9148 && deprecated_state != DEPRECATED_SUPPRESS)
9149 warn_deprecated_use (type, NULL_TREE);
9150 if (type && TREE_CODE (type) == TYPE_DECL)
9152 typedef_decl = type;
9153 type = TREE_TYPE (typedef_decl);
9154 if (TREE_DEPRECATED (type)
9155 && DECL_ARTIFICIAL (typedef_decl)
9156 && deprecated_state != DEPRECATED_SUPPRESS)
9157 warn_deprecated_use (type, NULL_TREE);
9159 /* No type at all: default to `int', and set DEFAULTED_INT
9160 because it was not a user-defined typedef. */
9161 if (type == NULL_TREE && (signed_p || unsigned_p || long_p || short_p))
9163 /* These imply 'int'. */
9164 type = integer_type_node;
9165 defaulted_int = 1;
9167 /* Gather flags. */
9168 explicit_int = declspecs->explicit_int_p;
9169 explicit_char = declspecs->explicit_char_p;
9171 #if 0
9172 /* See the code below that used this. */
9173 if (typedef_decl)
9174 decl_attr = DECL_ATTRIBUTES (typedef_decl);
9175 #endif
9176 typedef_type = type;
9179 if (sfk != sfk_conversion)
9180 ctor_return_type = ctype;
9182 if (sfk != sfk_none)
9183 type = check_special_function_return_type (sfk, type,
9184 ctor_return_type);
9185 else if (type == NULL_TREE)
9187 int is_main;
9189 explicit_int = -1;
9191 /* We handle `main' specially here, because 'main () { }' is so
9192 common. With no options, it is allowed. With -Wreturn-type,
9193 it is a warning. It is only an error with -pedantic-errors. */
9194 is_main = (funcdef_flag
9195 && dname && identifier_p (dname)
9196 && MAIN_NAME_P (dname)
9197 && ctype == NULL_TREE
9198 && in_namespace == NULL_TREE
9199 && current_namespace == global_namespace);
9201 if (type_was_error_mark_node)
9202 /* We've already issued an error, don't complain more. */;
9203 else if (in_system_header_at (input_location) || flag_ms_extensions)
9204 /* Allow it, sigh. */;
9205 else if (! is_main)
9206 permerror (input_location, "ISO C++ forbids declaration of %qs with no type", name);
9207 else if (pedantic)
9208 pedwarn (input_location, OPT_Wpedantic,
9209 "ISO C++ forbids declaration of %qs with no type", name);
9210 else
9211 warning (OPT_Wreturn_type,
9212 "ISO C++ forbids declaration of %qs with no type", name);
9214 type = integer_type_node;
9217 ctype = NULL_TREE;
9219 if (explicit_int128)
9221 if (int128_integer_type_node == NULL_TREE)
9223 error ("%<__int128%> is not supported by this target");
9224 explicit_int128 = false;
9226 else if (pedantic && ! in_system_header_at (input_location))
9227 pedwarn (input_location, OPT_Wpedantic,
9228 "ISO C++ does not support %<__int128%> for %qs", name);
9231 /* Now process the modifiers that were specified
9232 and check for invalid combinations. */
9234 /* Long double is a special combination. */
9235 if (long_p && !longlong && TYPE_MAIN_VARIANT (type) == double_type_node)
9237 long_p = false;
9238 type = cp_build_qualified_type (long_double_type_node,
9239 cp_type_quals (type));
9242 /* Check all other uses of type modifiers. */
9244 if (unsigned_p || signed_p || long_p || short_p)
9246 int ok = 0;
9248 if ((signed_p || unsigned_p) && TREE_CODE (type) != INTEGER_TYPE)
9249 error ("%<signed%> or %<unsigned%> invalid for %qs", name);
9250 else if (signed_p && unsigned_p)
9251 error ("%<signed%> and %<unsigned%> specified together for %qs", name);
9252 else if (longlong && TREE_CODE (type) != INTEGER_TYPE)
9253 error ("%<long long%> invalid for %qs", name);
9254 else if (long_p && TREE_CODE (type) == REAL_TYPE)
9255 error ("%<long%> invalid for %qs", name);
9256 else if (short_p && TREE_CODE (type) == REAL_TYPE)
9257 error ("%<short%> invalid for %qs", name);
9258 else if ((long_p || short_p) && TREE_CODE (type) != INTEGER_TYPE)
9259 error ("%<long%> or %<short%> invalid for %qs", name);
9260 else if ((long_p || short_p || explicit_char || explicit_int) && explicit_int128)
9261 error ("%<long%>, %<int%>, %<short%>, or %<char%> invalid for %qs", name);
9262 else if ((long_p || short_p) && explicit_char)
9263 error ("%<long%> or %<short%> specified with char for %qs", name);
9264 else if (long_p && short_p)
9265 error ("%<long%> and %<short%> specified together for %qs", name);
9266 else if (type == char16_type_node || type == char32_type_node)
9268 if (signed_p || unsigned_p)
9269 error ("%<signed%> or %<unsigned%> invalid for %qs", name);
9270 else if (short_p || long_p)
9271 error ("%<short%> or %<long%> invalid for %qs", name);
9273 else
9275 ok = 1;
9276 if (!explicit_int && !defaulted_int && !explicit_char && !explicit_int128 && pedantic)
9278 pedwarn (input_location, OPT_Wpedantic,
9279 "long, short, signed or unsigned used invalidly for %qs",
9280 name);
9281 if (flag_pedantic_errors)
9282 ok = 0;
9286 /* Discard the type modifiers if they are invalid. */
9287 if (! ok)
9289 unsigned_p = false;
9290 signed_p = false;
9291 long_p = false;
9292 short_p = false;
9293 longlong = 0;
9297 /* Decide whether an integer type is signed or not.
9298 Optionally treat bitfields as signed by default. */
9299 if (unsigned_p
9300 /* [class.bit]
9302 It is implementation-defined whether a plain (neither
9303 explicitly signed or unsigned) char, short, int, or long
9304 bit-field is signed or unsigned.
9306 Naturally, we extend this to long long as well. Note that
9307 this does not include wchar_t. */
9308 || (bitfield && !flag_signed_bitfields
9309 && !signed_p
9310 /* A typedef for plain `int' without `signed' can be
9311 controlled just like plain `int', but a typedef for
9312 `signed int' cannot be so controlled. */
9313 && !(typedef_decl
9314 && C_TYPEDEF_EXPLICITLY_SIGNED (typedef_decl))
9315 && TREE_CODE (type) == INTEGER_TYPE
9316 && !same_type_p (TYPE_MAIN_VARIANT (type), wchar_type_node)))
9318 if (explicit_int128)
9319 type = int128_unsigned_type_node;
9320 else if (longlong)
9321 type = long_long_unsigned_type_node;
9322 else if (long_p)
9323 type = long_unsigned_type_node;
9324 else if (short_p)
9325 type = short_unsigned_type_node;
9326 else if (type == char_type_node)
9327 type = unsigned_char_type_node;
9328 else if (typedef_decl)
9329 type = unsigned_type_for (type);
9330 else
9331 type = unsigned_type_node;
9333 else if (signed_p && type == char_type_node)
9334 type = signed_char_type_node;
9335 else if (explicit_int128)
9336 type = int128_integer_type_node;
9337 else if (longlong)
9338 type = long_long_integer_type_node;
9339 else if (long_p)
9340 type = long_integer_type_node;
9341 else if (short_p)
9342 type = short_integer_type_node;
9344 if (decl_spec_seq_has_spec_p (declspecs, ds_complex))
9346 if (TREE_CODE (type) != INTEGER_TYPE && TREE_CODE (type) != REAL_TYPE)
9347 error ("complex invalid for %qs", name);
9348 /* If we just have "complex", it is equivalent to
9349 "complex double", but if any modifiers at all are specified it is
9350 the complex form of TYPE. E.g, "complex short" is
9351 "complex short int". */
9352 else if (defaulted_int && ! longlong && ! explicit_int128
9353 && ! (long_p || short_p || signed_p || unsigned_p))
9354 type = complex_double_type_node;
9355 else if (type == integer_type_node)
9356 type = complex_integer_type_node;
9357 else if (type == float_type_node)
9358 type = complex_float_type_node;
9359 else if (type == double_type_node)
9360 type = complex_double_type_node;
9361 else if (type == long_double_type_node)
9362 type = complex_long_double_type_node;
9363 else
9364 type = build_complex_type (type);
9367 type_quals = TYPE_UNQUALIFIED;
9368 if (decl_spec_seq_has_spec_p (declspecs, ds_const))
9369 type_quals |= TYPE_QUAL_CONST;
9370 if (decl_spec_seq_has_spec_p (declspecs, ds_volatile))
9371 type_quals |= TYPE_QUAL_VOLATILE;
9372 if (decl_spec_seq_has_spec_p (declspecs, ds_restrict))
9373 type_quals |= TYPE_QUAL_RESTRICT;
9374 if (sfk == sfk_conversion && type_quals != TYPE_UNQUALIFIED)
9375 error ("qualifiers are not allowed on declaration of %<operator %T%>",
9376 ctor_return_type);
9378 /* If we're using the injected-class-name to form a compound type or a
9379 declaration, replace it with the underlying class so we don't get
9380 redundant typedefs in the debug output. But if we are returning the
9381 type unchanged, leave it alone so that it's available to
9382 maybe_get_template_decl_from_type_decl. */
9383 if (CLASS_TYPE_P (type)
9384 && DECL_SELF_REFERENCE_P (TYPE_NAME (type))
9385 && type == TREE_TYPE (TYPE_NAME (type))
9386 && (declarator || type_quals))
9387 type = DECL_ORIGINAL_TYPE (TYPE_NAME (type));
9389 type_quals |= cp_type_quals (type);
9390 type = cp_build_qualified_type_real
9391 (type, type_quals, ((typedef_decl && !DECL_ARTIFICIAL (typedef_decl)
9392 ? tf_ignore_bad_quals : 0) | tf_warning_or_error));
9393 /* We might have ignored or rejected some of the qualifiers. */
9394 type_quals = cp_type_quals (type);
9396 staticp = 0;
9397 inlinep = decl_spec_seq_has_spec_p (declspecs, ds_inline);
9398 virtualp = decl_spec_seq_has_spec_p (declspecs, ds_virtual);
9399 explicitp = decl_spec_seq_has_spec_p (declspecs, ds_explicit);
9401 storage_class = declspecs->storage_class;
9402 if (storage_class == sc_static)
9403 staticp = 1 + (decl_context == FIELD);
9405 if (virtualp && staticp == 2)
9407 error ("member %qD cannot be declared both virtual and static", dname);
9408 storage_class = sc_none;
9409 staticp = 0;
9411 friendp = decl_spec_seq_has_spec_p (declspecs, ds_friend);
9413 /* Issue errors about use of storage classes for parameters. */
9414 if (decl_context == PARM)
9416 if (typedef_p)
9418 error ("typedef declaration invalid in parameter declaration");
9419 return error_mark_node;
9421 else if (template_parm_flag && storage_class != sc_none)
9423 error ("storage class specified for template parameter %qs", name);
9424 return error_mark_node;
9426 else if (storage_class == sc_static
9427 || storage_class == sc_extern
9428 || thread_p)
9429 error ("storage class specifiers invalid in parameter declarations");
9431 /* Function parameters cannot be constexpr. If we saw one, moan
9432 and pretend it wasn't there. */
9433 if (constexpr_p)
9435 error ("a parameter cannot be declared %<constexpr%>");
9436 constexpr_p = 0;
9440 /* Give error if `virtual' is used outside of class declaration. */
9441 if (virtualp
9442 && (current_class_name == NULL_TREE || decl_context != FIELD))
9444 error ("%<virtual%> outside class declaration");
9445 virtualp = 0;
9448 /* Static anonymous unions are dealt with here. */
9449 if (staticp && decl_context == TYPENAME
9450 && declspecs->type
9451 && ANON_AGGR_TYPE_P (declspecs->type))
9452 decl_context = FIELD;
9454 /* Warn about storage classes that are invalid for certain
9455 kinds of declarations (parameters, typenames, etc.). */
9456 if (thread_p
9457 && ((storage_class
9458 && storage_class != sc_extern
9459 && storage_class != sc_static)
9460 || typedef_p))
9462 error ("multiple storage classes in declaration of %qs", name);
9463 thread_p = false;
9465 if (decl_context != NORMAL
9466 && ((storage_class != sc_none
9467 && storage_class != sc_mutable)
9468 || thread_p))
9470 if ((decl_context == PARM || decl_context == CATCHPARM)
9471 && (storage_class == sc_register
9472 || storage_class == sc_auto))
9474 else if (typedef_p)
9476 else if (decl_context == FIELD
9477 /* C++ allows static class elements. */
9478 && storage_class == sc_static)
9479 /* C++ also allows inlines and signed and unsigned elements,
9480 but in those cases we don't come in here. */
9482 else
9484 if (decl_context == FIELD)
9485 error ("storage class specified for %qs", name);
9486 else
9488 if (decl_context == PARM || decl_context == CATCHPARM)
9489 error ("storage class specified for parameter %qs", name);
9490 else
9491 error ("storage class specified for typename");
9493 if (storage_class == sc_register
9494 || storage_class == sc_auto
9495 || storage_class == sc_extern
9496 || thread_p)
9497 storage_class = sc_none;
9500 else if (storage_class == sc_extern && funcdef_flag
9501 && ! toplevel_bindings_p ())
9502 error ("nested function %qs declared %<extern%>", name);
9503 else if (toplevel_bindings_p ())
9505 if (storage_class == sc_auto)
9506 error ("top-level declaration of %qs specifies %<auto%>", name);
9508 else if (thread_p
9509 && storage_class != sc_extern
9510 && storage_class != sc_static)
9512 if (declspecs->gnu_thread_keyword_p)
9513 pedwarn (input_location, 0, "function-scope %qs implicitly auto and "
9514 "declared %<__thread%>", name);
9516 /* When thread_local is applied to a variable of block scope the
9517 storage-class-specifier static is implied if it does not appear
9518 explicitly. */
9519 storage_class = declspecs->storage_class = sc_static;
9520 staticp = 1;
9523 if (storage_class && friendp)
9525 error ("storage class specifiers invalid in friend function declarations");
9526 storage_class = sc_none;
9527 staticp = 0;
9530 if (!id_declarator)
9531 unqualified_id = NULL_TREE;
9532 else
9534 unqualified_id = id_declarator->u.id.unqualified_name;
9535 switch (TREE_CODE (unqualified_id))
9537 case BIT_NOT_EXPR:
9538 unqualified_id = TREE_OPERAND (unqualified_id, 0);
9539 if (TYPE_P (unqualified_id))
9540 unqualified_id = constructor_name (unqualified_id);
9541 break;
9543 case IDENTIFIER_NODE:
9544 case TEMPLATE_ID_EXPR:
9545 break;
9547 default:
9548 gcc_unreachable ();
9552 if (declspecs->std_attributes)
9554 /* Apply the c++11 attributes to the type preceding them. */
9555 input_location = declspecs->locations[ds_std_attribute];
9556 decl_attributes (&type, declspecs->std_attributes, 0);
9557 input_location = saved_loc;
9560 /* Determine the type of the entity declared by recurring on the
9561 declarator. */
9562 for (; declarator; declarator = declarator->declarator)
9564 const cp_declarator *inner_declarator;
9565 tree attrs;
9567 if (type == error_mark_node)
9568 return error_mark_node;
9570 attrs = declarator->attributes;
9571 if (attrs)
9573 int attr_flags;
9575 attr_flags = 0;
9576 if (declarator == NULL || declarator->kind == cdk_id)
9577 attr_flags |= (int) ATTR_FLAG_DECL_NEXT;
9578 if (declarator->kind == cdk_function)
9579 attr_flags |= (int) ATTR_FLAG_FUNCTION_NEXT;
9580 if (declarator->kind == cdk_array)
9581 attr_flags |= (int) ATTR_FLAG_ARRAY_NEXT;
9582 returned_attrs = decl_attributes (&type,
9583 chainon (returned_attrs, attrs),
9584 attr_flags);
9587 if (declarator->kind == cdk_id)
9588 break;
9590 inner_declarator = declarator->declarator;
9592 switch (declarator->kind)
9594 case cdk_array:
9595 type = create_array_type_for_decl (dname, type,
9596 declarator->u.array.bounds);
9597 if (declarator->std_attributes)
9598 /* [dcl.array]/1:
9600 The optional attribute-specifier-seq appertains to the
9601 array. */
9602 returned_attrs = chainon (returned_attrs,
9603 declarator->std_attributes);
9604 break;
9606 case cdk_function:
9608 tree arg_types;
9609 int funcdecl_p;
9611 /* Declaring a function type.
9612 Make sure we have a valid type for the function to return. */
9614 if (type_quals != TYPE_UNQUALIFIED)
9616 if (SCALAR_TYPE_P (type) || VOID_TYPE_P (type))
9617 warning (OPT_Wignored_qualifiers,
9618 "type qualifiers ignored on function return type");
9619 /* We now know that the TYPE_QUALS don't apply to the
9620 decl, but to its return type. */
9621 type_quals = TYPE_UNQUALIFIED;
9623 errmsg = targetm.invalid_return_type (type);
9624 if (errmsg)
9626 error (errmsg);
9627 type = integer_type_node;
9630 /* Error about some types functions can't return. */
9632 if (TREE_CODE (type) == FUNCTION_TYPE)
9634 error ("%qs declared as function returning a function", name);
9635 return error_mark_node;
9637 if (TREE_CODE (type) == ARRAY_TYPE)
9639 error ("%qs declared as function returning an array", name);
9640 return error_mark_node;
9643 input_location = declspecs->locations[ds_type_spec];
9644 abstract_virtuals_error (ACU_RETURN, type);
9645 input_location = saved_loc;
9647 /* Pick up type qualifiers which should be applied to `this'. */
9648 memfn_quals = declarator->u.function.qualifiers;
9649 /* Pick up virt-specifiers. */
9650 virt_specifiers = declarator->u.function.virt_specifiers;
9651 /* And ref-qualifier, too */
9652 rqual = declarator->u.function.ref_qualifier;
9653 /* Pick up the exception specifications. */
9654 raises = declarator->u.function.exception_specification;
9655 /* If the exception-specification is ill-formed, let's pretend
9656 there wasn't one. */
9657 if (raises == error_mark_node)
9658 raises = NULL_TREE;
9660 /* Say it's a definition only for the CALL_EXPR
9661 closest to the identifier. */
9662 funcdecl_p = inner_declarator && inner_declarator->kind == cdk_id;
9664 /* Handle a late-specified return type. */
9665 if (funcdecl_p)
9667 if (type_uses_auto (type))
9669 if (!declarator->u.function.late_return_type)
9671 if (current_class_type
9672 && LAMBDA_TYPE_P (current_class_type))
9673 /* OK for C++11 lambdas. */;
9674 else if (cxx_dialect < cxx14)
9676 error ("%qs function uses "
9677 "%<auto%> type specifier without trailing "
9678 "return type", name);
9679 inform (input_location, "deduced return type "
9680 "only available with -std=c++14 or "
9681 "-std=gnu++14");
9683 else if (virtualp)
9685 error ("virtual function cannot "
9686 "have deduced return type");
9687 virtualp = false;
9690 else if (!is_auto (type))
9692 error ("%qs function with trailing return type has"
9693 " %qT as its type rather than plain %<auto%>",
9694 name, type);
9695 return error_mark_node;
9698 else if (declarator->u.function.late_return_type)
9700 if (cxx_dialect < cxx11)
9701 /* Not using maybe_warn_cpp0x because this should
9702 always be an error. */
9703 error ("trailing return type only available with "
9704 "-std=c++11 or -std=gnu++11");
9705 else
9706 error ("%qs function with trailing return type not "
9707 "declared with %<auto%> type specifier", name);
9708 return error_mark_node;
9711 type = splice_late_return_type
9712 (type, declarator->u.function.late_return_type);
9713 if (type == error_mark_node)
9714 return error_mark_node;
9716 if (declarator->u.function.late_return_type)
9717 late_return_type_p = true;
9719 if (ctype == NULL_TREE
9720 && decl_context == FIELD
9721 && funcdecl_p
9722 && friendp == 0)
9723 ctype = current_class_type;
9725 if (ctype && (sfk == sfk_constructor
9726 || sfk == sfk_destructor))
9728 /* We are within a class's scope. If our declarator name
9729 is the same as the class name, and we are defining
9730 a function, then it is a constructor/destructor, and
9731 therefore returns a void type. */
9733 /* ISO C++ 12.4/2. A destructor may not be declared
9734 const or volatile. A destructor may not be static.
9735 A destructor may not be declared with ref-qualifier.
9737 ISO C++ 12.1. A constructor may not be declared
9738 const or volatile. A constructor may not be
9739 virtual. A constructor may not be static.
9740 A constructor may not be declared with ref-qualifier. */
9741 if (staticp == 2)
9742 error ((flags == DTOR_FLAG)
9743 ? G_("destructor cannot be static member function")
9744 : G_("constructor cannot be static member function"));
9745 if (memfn_quals)
9747 error ((flags == DTOR_FLAG)
9748 ? G_("destructors may not be cv-qualified")
9749 : G_("constructors may not be cv-qualified"));
9750 memfn_quals = TYPE_UNQUALIFIED;
9753 if (rqual)
9755 maybe_warn_cpp0x (CPP0X_REF_QUALIFIER);
9756 error ((flags == DTOR_FLAG)
9757 ? "destructors may not be ref-qualified"
9758 : "constructors may not be ref-qualified");
9759 rqual = REF_QUAL_NONE;
9762 if (decl_context == FIELD
9763 && !member_function_or_else (ctype,
9764 current_class_type,
9765 flags))
9766 return error_mark_node;
9768 if (flags != DTOR_FLAG)
9770 /* It's a constructor. */
9771 if (explicitp == 1)
9772 explicitp = 2;
9773 if (virtualp)
9775 permerror (input_location, "constructors cannot be declared virtual");
9776 virtualp = 0;
9778 if (decl_context == FIELD
9779 && sfk != sfk_constructor)
9780 return error_mark_node;
9782 if (decl_context == FIELD)
9783 staticp = 0;
9785 else if (friendp)
9787 if (virtualp)
9789 /* Cannot be both friend and virtual. */
9790 error ("virtual functions cannot be friends");
9791 friendp = 0;
9793 if (decl_context == NORMAL)
9794 error ("friend declaration not in class definition");
9795 if (current_function_decl && funcdef_flag)
9796 error ("can%'t define friend function %qs in a local "
9797 "class definition",
9798 name);
9800 else if (ctype && sfk == sfk_conversion)
9802 if (explicitp == 1)
9804 maybe_warn_cpp0x (CPP0X_EXPLICIT_CONVERSION);
9805 explicitp = 2;
9809 arg_types = grokparms (declarator->u.function.parameters,
9810 &parms);
9812 if (inner_declarator
9813 && inner_declarator->kind == cdk_id
9814 && inner_declarator->u.id.sfk == sfk_destructor
9815 && arg_types != void_list_node)
9817 error ("destructors may not have parameters");
9818 arg_types = void_list_node;
9819 parms = NULL_TREE;
9822 type = build_function_type (type, arg_types);
9823 if (declarator->std_attributes)
9824 /* [dcl.fct]/2:
9826 The optional attribute-specifier-seq appertains to
9827 the function type. */
9828 decl_attributes (&type, declarator->std_attributes,
9831 break;
9833 case cdk_pointer:
9834 case cdk_reference:
9835 case cdk_ptrmem:
9836 /* Filter out pointers-to-references and references-to-references.
9837 We can get these if a TYPE_DECL is used. */
9839 if (TREE_CODE (type) == REFERENCE_TYPE)
9841 if (declarator->kind != cdk_reference)
9843 error ("cannot declare pointer to %q#T", type);
9844 type = TREE_TYPE (type);
9847 /* In C++0x, we allow reference to reference declarations
9848 that occur indirectly through typedefs [7.1.3/8 dcl.typedef]
9849 and template type arguments [14.3.1/4 temp.arg.type]. The
9850 check for direct reference to reference declarations, which
9851 are still forbidden, occurs below. Reasoning behind the change
9852 can be found in DR106, DR540, and the rvalue reference
9853 proposals. */
9854 else if (cxx_dialect == cxx98)
9856 error ("cannot declare reference to %q#T", type);
9857 type = TREE_TYPE (type);
9860 else if (VOID_TYPE_P (type))
9862 if (declarator->kind == cdk_reference)
9863 error ("cannot declare reference to %q#T", type);
9864 else if (declarator->kind == cdk_ptrmem)
9865 error ("cannot declare pointer to %q#T member", type);
9868 /* We now know that the TYPE_QUALS don't apply to the decl,
9869 but to the target of the pointer. */
9870 type_quals = TYPE_UNQUALIFIED;
9872 /* This code used to handle METHOD_TYPE, but I don't think it's
9873 possible to get it here anymore. */
9874 gcc_assert (TREE_CODE (type) != METHOD_TYPE);
9875 if (declarator->kind == cdk_ptrmem
9876 && TREE_CODE (type) == FUNCTION_TYPE)
9878 memfn_quals |= type_memfn_quals (type);
9879 type = build_memfn_type (type,
9880 declarator->u.pointer.class_type,
9881 memfn_quals,
9882 rqual);
9883 if (type == error_mark_node)
9884 return error_mark_node;
9886 rqual = REF_QUAL_NONE;
9887 memfn_quals = TYPE_UNQUALIFIED;
9890 if (TREE_CODE (type) == FUNCTION_TYPE
9891 && (type_memfn_quals (type) != TYPE_UNQUALIFIED
9892 || type_memfn_rqual (type) != REF_QUAL_NONE))
9893 error (declarator->kind == cdk_reference
9894 ? G_("cannot declare reference to qualified function type %qT")
9895 : G_("cannot declare pointer to qualified function type %qT"),
9896 type);
9898 if (cxx_dialect >= cxx14 && array_of_runtime_bound_p (type)
9899 && (flag_iso || warn_vla > 0))
9900 pedwarn (input_location, OPT_Wvla,
9901 declarator->kind == cdk_reference
9902 ? G_("reference to array of runtime bound")
9903 : G_("pointer to array of runtime bound"));
9905 /* When the pointed-to type involves components of variable size,
9906 care must be taken to ensure that the size evaluation code is
9907 emitted early enough to dominate all the possible later uses
9908 and late enough for the variables on which it depends to have
9909 been assigned.
9911 This is expected to happen automatically when the pointed-to
9912 type has a name/declaration of it's own, but special attention
9913 is required if the type is anonymous.
9915 We handle the NORMAL and FIELD contexts here by inserting a
9916 dummy statement that just evaluates the size at a safe point
9917 and ensures it is not deferred until e.g. within a deeper
9918 conditional context (c++/43555).
9920 We expect nothing to be needed here for PARM or TYPENAME.
9921 Evaluating the size at this point for TYPENAME would
9922 actually be incorrect, as we might be in the middle of an
9923 expression with side effects on the pointed-to type size
9924 "arguments" prior to the pointer declaration point and the
9925 size evaluation could end up prior to the side effects. */
9927 if (!TYPE_NAME (type)
9928 && (decl_context == NORMAL || decl_context == FIELD)
9929 && at_function_scope_p ()
9930 && variably_modified_type_p (type, NULL_TREE))
9931 /* Force evaluation of the SAVE_EXPR. */
9932 finish_expr_stmt (TYPE_SIZE (type));
9934 if (declarator->kind == cdk_reference)
9936 /* In C++0x, the type we are creating a reference to might be
9937 a typedef which is itself a reference type. In that case,
9938 we follow the reference collapsing rules in
9939 [7.1.3/8 dcl.typedef] to create the final reference type:
9941 "If a typedef TD names a type that is a reference to a type
9942 T, an attempt to create the type 'lvalue reference to cv TD'
9943 creates the type 'lvalue reference to T,' while an attempt
9944 to create the type "rvalue reference to cv TD' creates the
9945 type TD."
9947 if (VOID_TYPE_P (type))
9948 /* We already gave an error. */;
9949 else if (TREE_CODE (type) == REFERENCE_TYPE)
9951 if (declarator->u.reference.rvalue_ref)
9952 /* Leave type alone. */;
9953 else
9954 type = cp_build_reference_type (TREE_TYPE (type), false);
9956 else
9957 type = cp_build_reference_type
9958 (type, declarator->u.reference.rvalue_ref);
9960 /* In C++0x, we need this check for direct reference to
9961 reference declarations, which are forbidden by
9962 [8.3.2/5 dcl.ref]. Reference to reference declarations
9963 are only allowed indirectly through typedefs and template
9964 type arguments. Example:
9966 void foo(int & &); // invalid ref-to-ref decl
9968 typedef int & int_ref;
9969 void foo(int_ref &); // valid ref-to-ref decl
9971 if (inner_declarator && inner_declarator->kind == cdk_reference)
9972 error ("cannot declare reference to %q#T, which is not "
9973 "a typedef or a template type argument", type);
9975 else if (TREE_CODE (type) == METHOD_TYPE)
9976 type = build_ptrmemfunc_type (build_pointer_type (type));
9977 else if (declarator->kind == cdk_ptrmem)
9979 gcc_assert (TREE_CODE (declarator->u.pointer.class_type)
9980 != NAMESPACE_DECL);
9981 if (declarator->u.pointer.class_type == error_mark_node)
9982 /* We will already have complained. */
9983 type = error_mark_node;
9984 else
9985 type = build_ptrmem_type (declarator->u.pointer.class_type,
9986 type);
9988 else
9989 type = build_pointer_type (type);
9991 /* Process a list of type modifier keywords (such as
9992 const or volatile) that were given inside the `*' or `&'. */
9994 if (declarator->u.pointer.qualifiers)
9996 type
9997 = cp_build_qualified_type (type,
9998 declarator->u.pointer.qualifiers);
9999 type_quals = cp_type_quals (type);
10002 /* Apply C++11 attributes to the pointer, and not to the
10003 type pointed to. This is unlike what is done for GNU
10004 attributes above. It is to comply with [dcl.ptr]/1:
10006 [the optional attribute-specifier-seq (7.6.1) appertains
10007 to the pointer and not to the object pointed to]. */
10008 if (declarator->std_attributes)
10009 decl_attributes (&type, declarator->std_attributes,
10012 ctype = NULL_TREE;
10013 break;
10015 case cdk_error:
10016 break;
10018 default:
10019 gcc_unreachable ();
10023 /* A `constexpr' specifier used in an object declaration declares
10024 the object as `const'. */
10025 if (constexpr_p && innermost_code != cdk_function)
10027 if (type_quals & TYPE_QUAL_VOLATILE)
10028 error ("both %<volatile%> and %<constexpr%> cannot be used here");
10029 if (TREE_CODE (type) != REFERENCE_TYPE)
10031 type_quals |= TYPE_QUAL_CONST;
10032 type = cp_build_qualified_type (type, type_quals);
10036 if (unqualified_id && TREE_CODE (unqualified_id) == TEMPLATE_ID_EXPR
10037 && TREE_CODE (type) != FUNCTION_TYPE
10038 && TREE_CODE (type) != METHOD_TYPE
10039 && !variable_template_p (TREE_OPERAND (unqualified_id, 0)))
10041 error ("template-id %qD used as a declarator",
10042 unqualified_id);
10043 unqualified_id = dname;
10046 /* If TYPE is a FUNCTION_TYPE, but the function name was explicitly
10047 qualified with a class-name, turn it into a METHOD_TYPE, unless
10048 we know that the function is static. We take advantage of this
10049 opportunity to do other processing that pertains to entities
10050 explicitly declared to be class members. Note that if DECLARATOR
10051 is non-NULL, we know it is a cdk_id declarator; otherwise, we
10052 would not have exited the loop above. */
10053 if (declarator
10054 && declarator->u.id.qualifying_scope
10055 && MAYBE_CLASS_TYPE_P (declarator->u.id.qualifying_scope))
10057 ctype = declarator->u.id.qualifying_scope;
10058 ctype = TYPE_MAIN_VARIANT (ctype);
10059 template_count = num_template_headers_for_class (ctype);
10061 if (ctype == current_class_type)
10063 if (friendp)
10065 permerror (input_location, "member functions are implicitly friends of their class");
10066 friendp = 0;
10068 else
10069 permerror (declarator->id_loc,
10070 "extra qualification %<%T::%> on member %qs",
10071 ctype, name);
10073 else if (/* If the qualifying type is already complete, then we
10074 can skip the following checks. */
10075 !COMPLETE_TYPE_P (ctype)
10076 && (/* If the function is being defined, then
10077 qualifying type must certainly be complete. */
10078 funcdef_flag
10079 /* A friend declaration of "T::f" is OK, even if
10080 "T" is a template parameter. But, if this
10081 function is not a friend, the qualifying type
10082 must be a class. */
10083 || (!friendp && !CLASS_TYPE_P (ctype))
10084 /* For a declaration, the type need not be
10085 complete, if either it is dependent (since there
10086 is no meaningful definition of complete in that
10087 case) or the qualifying class is currently being
10088 defined. */
10089 || !(dependent_type_p (ctype)
10090 || currently_open_class (ctype)))
10091 /* Check that the qualifying type is complete. */
10092 && !complete_type_or_else (ctype, NULL_TREE))
10093 return error_mark_node;
10094 else if (TREE_CODE (type) == FUNCTION_TYPE)
10096 if (current_class_type
10097 && (!friendp || funcdef_flag))
10099 error (funcdef_flag
10100 ? G_("cannot define member function %<%T::%s%> "
10101 "within %<%T%>")
10102 : G_("cannot declare member function %<%T::%s%> "
10103 "within %<%T%>"),
10104 ctype, name, current_class_type);
10105 return error_mark_node;
10108 else if (typedef_p && current_class_type)
10110 error ("cannot declare member %<%T::%s%> within %qT",
10111 ctype, name, current_class_type);
10112 return error_mark_node;
10116 if (ctype == NULL_TREE && decl_context == FIELD && friendp == 0)
10117 ctype = current_class_type;
10119 /* Now TYPE has the actual type. */
10121 if (returned_attrs)
10123 if (attrlist)
10124 *attrlist = chainon (returned_attrs, *attrlist);
10125 else
10126 attrlist = &returned_attrs;
10129 if (declarator
10130 && declarator->kind == cdk_id
10131 && declarator->std_attributes)
10132 /* [dcl.meaning]/1: The optional attribute-specifier-seq following
10133 a declarator-id appertains to the entity that is declared. */
10134 *attrlist = chainon (*attrlist, declarator->std_attributes);
10136 /* Handle parameter packs. */
10137 if (parameter_pack_p)
10139 if (decl_context == PARM)
10140 /* Turn the type into a pack expansion.*/
10141 type = make_pack_expansion (type);
10142 else
10143 error ("non-parameter %qs cannot be a parameter pack", name);
10146 /* Did array size calculations overflow or does the array cover more
10147 than half of the address-space? */
10148 if (TREE_CODE (type) == ARRAY_TYPE
10149 && COMPLETE_TYPE_P (type)
10150 && TREE_CODE (TYPE_SIZE_UNIT (type)) == INTEGER_CST
10151 && ! valid_constant_size_p (TYPE_SIZE_UNIT (type)))
10153 error ("size of array %qs is too large", name);
10154 /* If we proceed with the array type as it is, we'll eventually
10155 crash in tree_to_[su]hwi(). */
10156 type = error_mark_node;
10159 if ((decl_context == FIELD || decl_context == PARM)
10160 && !processing_template_decl
10161 && variably_modified_type_p (type, NULL_TREE))
10163 if (decl_context == FIELD)
10164 error ("data member may not have variably modified type %qT", type);
10165 else
10166 error ("parameter may not have variably modified type %qT", type);
10167 type = error_mark_node;
10170 if (explicitp == 1 || (explicitp && friendp))
10172 /* [dcl.fct.spec] (C++11) The explicit specifier shall be used only
10173 in the declaration of a constructor or conversion function within
10174 a class definition. */
10175 if (!current_class_type)
10176 error ("%<explicit%> outside class declaration");
10177 else if (friendp)
10178 error ("%<explicit%> in friend declaration");
10179 else
10180 error ("only declarations of constructors and conversion operators "
10181 "can be %<explicit%>");
10182 explicitp = 0;
10185 if (storage_class == sc_mutable)
10187 if (decl_context != FIELD || friendp)
10189 error ("non-member %qs cannot be declared %<mutable%>", name);
10190 storage_class = sc_none;
10192 else if (decl_context == TYPENAME || typedef_p)
10194 error ("non-object member %qs cannot be declared %<mutable%>", name);
10195 storage_class = sc_none;
10197 else if (TREE_CODE (type) == FUNCTION_TYPE
10198 || TREE_CODE (type) == METHOD_TYPE)
10200 error ("function %qs cannot be declared %<mutable%>", name);
10201 storage_class = sc_none;
10203 else if (staticp)
10205 error ("static %qs cannot be declared %<mutable%>", name);
10206 storage_class = sc_none;
10208 else if (type_quals & TYPE_QUAL_CONST)
10210 error ("const %qs cannot be declared %<mutable%>", name);
10211 storage_class = sc_none;
10213 else if (TREE_CODE (type) == REFERENCE_TYPE)
10215 permerror (input_location, "reference %qs cannot be declared "
10216 "%<mutable%>", name);
10217 storage_class = sc_none;
10221 /* If this is declaring a typedef name, return a TYPE_DECL. */
10222 if (typedef_p && decl_context != TYPENAME)
10224 tree decl;
10226 /* Note that the grammar rejects storage classes
10227 in typenames, fields or parameters. */
10228 if (current_lang_name == lang_name_java)
10229 TYPE_FOR_JAVA (type) = 1;
10231 /* This declaration:
10233 typedef void f(int) const;
10235 declares a function type which is not a member of any
10236 particular class, but which is cv-qualified; for
10237 example "f S::*" declares a pointer to a const-qualified
10238 member function of S. We record the cv-qualification in the
10239 function type. */
10240 if ((rqual || memfn_quals) && TREE_CODE (type) == FUNCTION_TYPE)
10242 type = apply_memfn_quals (type, memfn_quals, rqual);
10244 /* We have now dealt with these qualifiers. */
10245 memfn_quals = TYPE_UNQUALIFIED;
10246 rqual = REF_QUAL_NONE;
10249 if (type_uses_auto (type))
10251 error ("typedef declared %<auto%>");
10252 type = error_mark_node;
10255 if (cxx_dialect >= cxx14 && array_of_runtime_bound_p (type)
10256 && (flag_iso || warn_vla > 0))
10257 pedwarn (input_location, OPT_Wvla,
10258 "typedef naming array of runtime bound");
10260 if (decl_context == FIELD)
10261 decl = build_lang_decl (TYPE_DECL, unqualified_id, type);
10262 else
10263 decl = build_decl (input_location, TYPE_DECL, unqualified_id, type);
10264 if (id_declarator && declarator->u.id.qualifying_scope) {
10265 error_at (DECL_SOURCE_LOCATION (decl),
10266 "typedef name may not be a nested-name-specifier");
10267 TREE_TYPE (decl) = error_mark_node;
10270 if (decl_context != FIELD)
10272 if (!current_function_decl)
10273 DECL_CONTEXT (decl) = FROB_CONTEXT (current_namespace);
10274 else if (DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P (current_function_decl)
10275 || (DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P
10276 (current_function_decl)))
10277 /* The TYPE_DECL is "abstract" because there will be
10278 clones of this constructor/destructor, and there will
10279 be copies of this TYPE_DECL generated in those
10280 clones. The decloning optimization (for space) may
10281 revert this subsequently if it determines that
10282 the clones should share a common implementation. */
10283 DECL_ABSTRACT (decl) = 1;
10285 else if (current_class_type
10286 && constructor_name_p (unqualified_id, current_class_type))
10287 permerror (input_location, "ISO C++ forbids nested type %qD with same name "
10288 "as enclosing class",
10289 unqualified_id);
10291 /* If the user declares "typedef struct {...} foo" then the
10292 struct will have an anonymous name. Fill that name in now.
10293 Nothing can refer to it, so nothing needs know about the name
10294 change. */
10295 if (type != error_mark_node
10296 && unqualified_id
10297 && TYPE_NAME (type)
10298 && TREE_CODE (TYPE_NAME (type)) == TYPE_DECL
10299 && TYPE_ANONYMOUS_P (type)
10300 && declspecs->type_definition_p
10301 && attributes_naming_typedef_ok (*attrlist)
10302 && cp_type_quals (type) == TYPE_UNQUALIFIED)
10304 tree t;
10306 /* Replace the anonymous name with the real name everywhere. */
10307 for (t = TYPE_MAIN_VARIANT (type); t; t = TYPE_NEXT_VARIANT (t))
10309 if (ANON_AGGRNAME_P (TYPE_IDENTIFIER (t)))
10310 /* We do not rename the debug info representing the
10311 anonymous tagged type because the standard says in
10312 [dcl.typedef] that the naming applies only for
10313 linkage purposes. */
10314 /*debug_hooks->set_name (t, decl);*/
10315 TYPE_NAME (t) = decl;
10318 if (TYPE_LANG_SPECIFIC (type))
10319 TYPE_WAS_ANONYMOUS (type) = 1;
10321 /* If this is a typedef within a template class, the nested
10322 type is a (non-primary) template. The name for the
10323 template needs updating as well. */
10324 if (TYPE_LANG_SPECIFIC (type) && CLASSTYPE_TEMPLATE_INFO (type))
10325 DECL_NAME (CLASSTYPE_TI_TEMPLATE (type))
10326 = TYPE_IDENTIFIER (type);
10328 /* Adjust linkage now that we aren't anonymous anymore. */
10329 reset_type_linkage (type);
10331 /* FIXME remangle member functions; member functions of a
10332 type with external linkage have external linkage. */
10335 if (signed_p
10336 || (typedef_decl && C_TYPEDEF_EXPLICITLY_SIGNED (typedef_decl)))
10337 C_TYPEDEF_EXPLICITLY_SIGNED (decl) = 1;
10339 bad_specifiers (decl, BSP_TYPE, virtualp,
10340 memfn_quals != TYPE_UNQUALIFIED,
10341 inlinep, friendp, raises != NULL_TREE);
10343 if (decl_spec_seq_has_spec_p (declspecs, ds_alias))
10344 /* Acknowledge that this was written:
10345 `using analias = atype;'. */
10346 TYPE_DECL_ALIAS_P (decl) = 1;
10348 return decl;
10351 /* Detect the case of an array type of unspecified size
10352 which came, as such, direct from a typedef name.
10353 We must copy the type, so that the array's domain can be
10354 individually set by the object's initializer. */
10356 if (type && typedef_type
10357 && TREE_CODE (type) == ARRAY_TYPE && !TYPE_DOMAIN (type)
10358 && TYPE_MAIN_VARIANT (type) == TYPE_MAIN_VARIANT (typedef_type))
10359 type = build_cplus_array_type (TREE_TYPE (type), NULL_TREE);
10361 /* Detect where we're using a typedef of function type to declare a
10362 function. PARMS will not be set, so we must create it now. */
10364 if (type == typedef_type && TREE_CODE (type) == FUNCTION_TYPE)
10366 tree decls = NULL_TREE;
10367 tree args;
10369 for (args = TYPE_ARG_TYPES (type);
10370 args && args != void_list_node;
10371 args = TREE_CHAIN (args))
10373 tree decl = cp_build_parm_decl (NULL_TREE, TREE_VALUE (args));
10375 DECL_CHAIN (decl) = decls;
10376 decls = decl;
10379 parms = nreverse (decls);
10381 if (decl_context != TYPENAME)
10383 /* The qualifiers on the function type become the qualifiers on
10384 the non-static member function. */
10385 memfn_quals |= type_memfn_quals (type);
10386 rqual = type_memfn_rqual (type);
10387 type_quals = TYPE_UNQUALIFIED;
10391 /* If this is a type name (such as, in a cast or sizeof),
10392 compute the type and return it now. */
10394 if (decl_context == TYPENAME)
10396 /* Note that the grammar rejects storage classes
10397 in typenames, fields or parameters. */
10398 if (type_quals != TYPE_UNQUALIFIED)
10399 type_quals = TYPE_UNQUALIFIED;
10401 /* Special case: "friend class foo" looks like a TYPENAME context. */
10402 if (friendp)
10404 if (type_quals != TYPE_UNQUALIFIED)
10406 error ("type qualifiers specified for friend class declaration");
10407 type_quals = TYPE_UNQUALIFIED;
10409 if (inlinep)
10411 error ("%<inline%> specified for friend class declaration");
10412 inlinep = 0;
10415 if (!current_aggr)
10417 /* Don't allow friend declaration without a class-key. */
10418 if (TREE_CODE (type) == TEMPLATE_TYPE_PARM)
10419 permerror (input_location, "template parameters cannot be friends");
10420 else if (TREE_CODE (type) == TYPENAME_TYPE)
10421 permerror (input_location, "friend declaration requires class-key, "
10422 "i.e. %<friend class %T::%D%>",
10423 TYPE_CONTEXT (type), TYPENAME_TYPE_FULLNAME (type));
10424 else
10425 permerror (input_location, "friend declaration requires class-key, "
10426 "i.e. %<friend %#T%>",
10427 type);
10430 /* Only try to do this stuff if we didn't already give up. */
10431 if (type != integer_type_node)
10433 /* A friendly class? */
10434 if (current_class_type)
10435 make_friend_class (current_class_type, TYPE_MAIN_VARIANT (type),
10436 /*complain=*/true);
10437 else
10438 error ("trying to make class %qT a friend of global scope",
10439 type);
10441 type = void_type_node;
10444 else if (memfn_quals || rqual)
10446 if (ctype == NULL_TREE
10447 && TREE_CODE (type) == METHOD_TYPE)
10448 ctype = TYPE_METHOD_BASETYPE (type);
10450 if (ctype)
10451 type = build_memfn_type (type, ctype, memfn_quals, rqual);
10452 /* Core issue #547: need to allow this in template type args.
10453 Allow it in general in C++11 for alias-declarations. */
10454 else if ((template_type_arg || cxx_dialect >= cxx11)
10455 && TREE_CODE (type) == FUNCTION_TYPE)
10456 type = apply_memfn_quals (type, memfn_quals, rqual);
10457 else
10458 error ("invalid qualifiers on non-member function type");
10461 return type;
10463 else if (unqualified_id == NULL_TREE && decl_context != PARM
10464 && decl_context != CATCHPARM
10465 && TREE_CODE (type) != UNION_TYPE
10466 && ! bitfield)
10468 error ("abstract declarator %qT used as declaration", type);
10469 return error_mark_node;
10472 /* Only functions may be declared using an operator-function-id. */
10473 if (unqualified_id
10474 && IDENTIFIER_OPNAME_P (unqualified_id)
10475 && TREE_CODE (type) != FUNCTION_TYPE
10476 && TREE_CODE (type) != METHOD_TYPE)
10478 error ("declaration of %qD as non-function", unqualified_id);
10479 return error_mark_node;
10482 /* We don't check parameter types here because we can emit a better
10483 error message later. */
10484 if (decl_context != PARM)
10486 type = check_var_type (unqualified_id, type);
10487 if (type == error_mark_node)
10488 return error_mark_node;
10491 /* Now create the decl, which may be a VAR_DECL, a PARM_DECL
10492 or a FUNCTION_DECL, depending on DECL_CONTEXT and TYPE. */
10494 if (decl_context == PARM || decl_context == CATCHPARM)
10496 if (ctype || in_namespace)
10497 error ("cannot use %<::%> in parameter declaration");
10499 if (type_uses_auto (type))
10501 if (cxx_dialect >= cxx14)
10502 error ("%<auto%> parameter not permitted in this context");
10503 else
10504 error ("parameter declared %<auto%>");
10505 type = error_mark_node;
10508 /* A parameter declared as an array of T is really a pointer to T.
10509 One declared as a function is really a pointer to a function.
10510 One declared as a member is really a pointer to member. */
10512 if (TREE_CODE (type) == ARRAY_TYPE)
10514 /* Transfer const-ness of array into that of type pointed to. */
10515 type = build_pointer_type (TREE_TYPE (type));
10516 type_quals = TYPE_UNQUALIFIED;
10517 array_parameter_p = true;
10519 else if (TREE_CODE (type) == FUNCTION_TYPE)
10520 type = build_pointer_type (type);
10523 if (ctype && TREE_CODE (type) == FUNCTION_TYPE && staticp < 2
10524 && !NEW_DELETE_OPNAME_P (unqualified_id))
10526 cp_cv_quals real_quals = memfn_quals;
10527 if (constexpr_p && sfk != sfk_constructor && sfk != sfk_destructor)
10528 real_quals |= TYPE_QUAL_CONST;
10529 type = build_memfn_type (type, ctype, real_quals, rqual);
10533 tree decl;
10535 if (decl_context == PARM)
10537 decl = cp_build_parm_decl (unqualified_id, type);
10538 DECL_ARRAY_PARAMETER_P (decl) = array_parameter_p;
10540 bad_specifiers (decl, BSP_PARM, virtualp,
10541 memfn_quals != TYPE_UNQUALIFIED,
10542 inlinep, friendp, raises != NULL_TREE);
10544 else if (decl_context == FIELD)
10546 if (!staticp && TREE_CODE (type) != METHOD_TYPE
10547 && type_uses_auto (type))
10549 error ("non-static data member declared %<auto%>");
10550 type = error_mark_node;
10553 /* The C99 flexible array extension. */
10554 if (!staticp && TREE_CODE (type) == ARRAY_TYPE
10555 && TYPE_DOMAIN (type) == NULL_TREE)
10557 tree itype = compute_array_index_type (dname, integer_zero_node,
10558 tf_warning_or_error);
10559 type = build_cplus_array_type (TREE_TYPE (type), itype);
10562 if (type == error_mark_node)
10564 /* Happens when declaring arrays of sizes which
10565 are error_mark_node, for example. */
10566 decl = NULL_TREE;
10568 else if (in_namespace && !friendp)
10570 /* Something like struct S { int N::j; }; */
10571 error ("invalid use of %<::%>");
10572 return error_mark_node;
10574 else if (TREE_CODE (type) == FUNCTION_TYPE
10575 || TREE_CODE (type) == METHOD_TYPE)
10577 int publicp = 0;
10578 tree function_context;
10580 if (friendp == 0)
10582 /* This should never happen in pure C++ (the check
10583 could be an assert). It could happen in
10584 Objective-C++ if someone writes invalid code that
10585 uses a function declaration for an instance
10586 variable or property (instance variables and
10587 properties are parsed as FIELD_DECLs, but they are
10588 part of an Objective-C class, not a C++ class).
10589 That code is invalid and is caught by this
10590 check. */
10591 if (!ctype)
10593 error ("declaration of function %qD in invalid context",
10594 unqualified_id);
10595 return error_mark_node;
10598 /* ``A union may [ ... ] not [ have ] virtual functions.''
10599 ARM 9.5 */
10600 if (virtualp && TREE_CODE (ctype) == UNION_TYPE)
10602 error ("function %qD declared virtual inside a union",
10603 unqualified_id);
10604 return error_mark_node;
10607 if (NEW_DELETE_OPNAME_P (unqualified_id))
10609 if (virtualp)
10611 error ("%qD cannot be declared virtual, since it "
10612 "is always static",
10613 unqualified_id);
10614 virtualp = 0;
10619 /* Check that the name used for a destructor makes sense. */
10620 if (sfk == sfk_destructor)
10622 tree uqname = id_declarator->u.id.unqualified_name;
10624 if (!ctype)
10626 gcc_assert (friendp);
10627 error ("expected qualified name in friend declaration "
10628 "for destructor %qD", uqname);
10629 return error_mark_node;
10632 if (!check_dtor_name (ctype, TREE_OPERAND (uqname, 0)))
10634 error ("declaration of %qD as member of %qT",
10635 uqname, ctype);
10636 return error_mark_node;
10638 if (constexpr_p)
10640 error ("a destructor cannot be %<constexpr%>");
10641 return error_mark_node;
10644 else if (sfk == sfk_constructor && friendp && !ctype)
10646 error ("expected qualified name in friend declaration "
10647 "for constructor %qD",
10648 id_declarator->u.id.unqualified_name);
10649 return error_mark_node;
10652 /* Tell grokfndecl if it needs to set TREE_PUBLIC on the node. */
10653 function_context = (ctype != NULL_TREE) ?
10654 decl_function_context (TYPE_MAIN_DECL (ctype)) : NULL_TREE;
10655 publicp = (! friendp || ! staticp)
10656 && function_context == NULL_TREE;
10658 if (late_return_type_p)
10659 TYPE_HAS_LATE_RETURN_TYPE (type) = 1;
10661 decl = grokfndecl (ctype, type,
10662 TREE_CODE (unqualified_id) != TEMPLATE_ID_EXPR
10663 ? unqualified_id : dname,
10664 parms,
10665 unqualified_id,
10666 virtualp, flags, memfn_quals, rqual, raises,
10667 friendp ? -1 : 0, friendp, publicp,
10668 inlinep | (2 * constexpr_p),
10669 sfk,
10670 funcdef_flag, template_count, in_namespace,
10671 attrlist, declarator->id_loc);
10672 decl = set_virt_specifiers (decl, virt_specifiers);
10673 if (decl == NULL_TREE)
10674 return error_mark_node;
10675 #if 0
10676 /* This clobbers the attrs stored in `decl' from `attrlist'. */
10677 /* The decl and setting of decl_attr is also turned off. */
10678 decl = build_decl_attribute_variant (decl, decl_attr);
10679 #endif
10681 /* [class.conv.ctor]
10683 A constructor declared without the function-specifier
10684 explicit that can be called with a single parameter
10685 specifies a conversion from the type of its first
10686 parameter to the type of its class. Such a constructor
10687 is called a converting constructor. */
10688 if (explicitp == 2)
10689 DECL_NONCONVERTING_P (decl) = 1;
10691 else if (!staticp && !dependent_type_p (type)
10692 && !COMPLETE_TYPE_P (complete_type (type))
10693 && (TREE_CODE (type) != ARRAY_TYPE
10694 || !COMPLETE_TYPE_P (TREE_TYPE (type))
10695 || initialized == 0))
10697 if (unqualified_id)
10699 error ("field %qD has incomplete type %qT",
10700 unqualified_id, type);
10701 cxx_incomplete_type_inform (strip_array_types (type));
10703 else
10704 error ("name %qT has incomplete type", type);
10706 type = error_mark_node;
10707 decl = NULL_TREE;
10709 else
10711 if (friendp)
10713 error ("%qE is neither function nor member function; "
10714 "cannot be declared friend", unqualified_id);
10715 friendp = 0;
10717 decl = NULL_TREE;
10720 if (friendp)
10722 /* Friends are treated specially. */
10723 if (ctype == current_class_type)
10724 ; /* We already issued a permerror. */
10725 else if (decl && DECL_NAME (decl))
10727 if (template_class_depth (current_class_type) == 0)
10729 decl = check_explicit_specialization
10730 (unqualified_id, decl, template_count,
10731 2 * funcdef_flag + 4);
10732 if (decl == error_mark_node)
10733 return error_mark_node;
10736 decl = do_friend (ctype, unqualified_id, decl,
10737 *attrlist, flags,
10738 funcdef_flag);
10739 return decl;
10741 else
10742 return error_mark_node;
10745 /* Structure field. It may not be a function, except for C++. */
10747 if (decl == NULL_TREE)
10749 if (staticp)
10751 /* C++ allows static class members. All other work
10752 for this is done by grokfield. */
10753 decl = build_lang_decl_loc (declarator
10754 ? declarator->id_loc
10755 : input_location,
10756 VAR_DECL, unqualified_id, type);
10757 set_linkage_for_static_data_member (decl);
10758 /* Even if there is an in-class initialization, DECL
10759 is considered undefined until an out-of-class
10760 definition is provided. */
10761 DECL_EXTERNAL (decl) = 1;
10763 if (thread_p)
10765 set_decl_tls_model (decl, decl_default_tls_model (decl));
10766 if (declspecs->gnu_thread_keyword_p)
10767 DECL_GNU_TLS_P (decl) = true;
10770 if (constexpr_p && !initialized)
10772 error ("constexpr static data member %qD must have an "
10773 "initializer", decl);
10774 constexpr_p = false;
10777 else
10779 if (constexpr_p)
10781 error ("non-static data member %qE declared %<constexpr%>",
10782 unqualified_id);
10783 constexpr_p = false;
10785 decl = build_decl (input_location,
10786 FIELD_DECL, unqualified_id, type);
10787 DECL_NONADDRESSABLE_P (decl) = bitfield;
10788 if (bitfield && !unqualified_id)
10789 TREE_NO_WARNING (decl) = 1;
10791 if (storage_class == sc_mutable)
10793 DECL_MUTABLE_P (decl) = 1;
10794 storage_class = sc_none;
10797 if (initialized)
10799 /* An attempt is being made to initialize a non-static
10800 member. This is new in C++11. */
10801 maybe_warn_cpp0x (CPP0X_NSDMI);
10803 /* If this has been parsed with static storage class, but
10804 errors forced staticp to be cleared, ensure NSDMI is
10805 not present. */
10806 if (declspecs->storage_class == sc_static)
10807 DECL_INITIAL (decl) = error_mark_node;
10811 bad_specifiers (decl, BSP_FIELD, virtualp,
10812 memfn_quals != TYPE_UNQUALIFIED,
10813 inlinep, friendp, raises != NULL_TREE);
10816 else if (TREE_CODE (type) == FUNCTION_TYPE
10817 || TREE_CODE (type) == METHOD_TYPE)
10819 tree original_name;
10820 int publicp = 0;
10822 if (!unqualified_id)
10823 return error_mark_node;
10825 if (TREE_CODE (unqualified_id) == TEMPLATE_ID_EXPR)
10826 original_name = dname;
10827 else
10828 original_name = unqualified_id;
10830 if (storage_class == sc_auto)
10831 error ("storage class %<auto%> invalid for function %qs", name);
10832 else if (storage_class == sc_register)
10833 error ("storage class %<register%> invalid for function %qs", name);
10834 else if (thread_p)
10836 if (declspecs->gnu_thread_keyword_p)
10837 error ("storage class %<__thread%> invalid for function %qs",
10838 name);
10839 else
10840 error ("storage class %<thread_local%> invalid for function %qs",
10841 name);
10844 if (virt_specifiers)
10845 error ("virt-specifiers in %qs not allowed outside a class definition", name);
10846 /* Function declaration not at top level.
10847 Storage classes other than `extern' are not allowed
10848 and `extern' makes no difference. */
10849 if (! toplevel_bindings_p ()
10850 && (storage_class == sc_static
10851 || decl_spec_seq_has_spec_p (declspecs, ds_inline))
10852 && pedantic)
10854 if (storage_class == sc_static)
10855 pedwarn (input_location, OPT_Wpedantic,
10856 "%<static%> specified invalid for function %qs "
10857 "declared out of global scope", name);
10858 else
10859 pedwarn (input_location, OPT_Wpedantic,
10860 "%<inline%> specifier invalid for function %qs "
10861 "declared out of global scope", name);
10864 if (ctype == NULL_TREE)
10866 if (virtualp)
10868 error ("virtual non-class function %qs", name);
10869 virtualp = 0;
10871 else if (sfk == sfk_constructor
10872 || sfk == sfk_destructor)
10874 error (funcdef_flag
10875 ? G_("%qs defined in a non-class scope")
10876 : G_("%qs declared in a non-class scope"), name);
10877 sfk = sfk_none;
10881 /* Record whether the function is public. */
10882 publicp = (ctype != NULL_TREE
10883 || storage_class != sc_static);
10885 if (late_return_type_p)
10886 TYPE_HAS_LATE_RETURN_TYPE (type) = 1;
10888 decl = grokfndecl (ctype, type, original_name, parms, unqualified_id,
10889 virtualp, flags, memfn_quals, rqual, raises,
10890 1, friendp,
10891 publicp, inlinep | (2 * constexpr_p), sfk,
10892 funcdef_flag,
10893 template_count, in_namespace, attrlist,
10894 declarator->id_loc);
10895 if (decl == NULL_TREE)
10896 return error_mark_node;
10898 if (staticp == 1)
10900 int invalid_static = 0;
10902 /* Don't allow a static member function in a class, and forbid
10903 declaring main to be static. */
10904 if (TREE_CODE (type) == METHOD_TYPE)
10906 permerror (input_location, "cannot declare member function %qD to have "
10907 "static linkage", decl);
10908 invalid_static = 1;
10910 else if (current_function_decl)
10912 /* FIXME need arm citation */
10913 error ("cannot declare static function inside another function");
10914 invalid_static = 1;
10917 if (invalid_static)
10919 staticp = 0;
10920 storage_class = sc_none;
10924 else
10926 /* It's a variable. */
10928 /* An uninitialized decl with `extern' is a reference. */
10929 decl = grokvardecl (type, dname, unqualified_id,
10930 declspecs,
10931 initialized,
10932 (type_quals & TYPE_QUAL_CONST) != 0,
10933 template_count,
10934 ctype ? ctype : in_namespace);
10935 if (decl == NULL_TREE)
10936 return error_mark_node;
10938 bad_specifiers (decl, BSP_VAR, virtualp,
10939 memfn_quals != TYPE_UNQUALIFIED,
10940 inlinep, friendp, raises != NULL_TREE);
10942 if (ctype)
10944 DECL_CONTEXT (decl) = ctype;
10945 if (staticp == 1)
10947 permerror (input_location, "%<static%> may not be used when defining "
10948 "(as opposed to declaring) a static data member");
10949 staticp = 0;
10950 storage_class = sc_none;
10952 if (storage_class == sc_register && TREE_STATIC (decl))
10954 error ("static member %qD declared %<register%>", decl);
10955 storage_class = sc_none;
10957 if (storage_class == sc_extern && pedantic)
10959 pedwarn (input_location, OPT_Wpedantic,
10960 "cannot explicitly declare member %q#D to have "
10961 "extern linkage", decl);
10962 storage_class = sc_none;
10965 else if (constexpr_p && DECL_EXTERNAL (decl))
10967 error ("declaration of constexpr variable %qD is not a definition",
10968 decl);
10969 constexpr_p = false;
10973 if (storage_class == sc_extern && initialized && !funcdef_flag)
10975 if (toplevel_bindings_p ())
10977 /* It's common practice (and completely valid) to have a const
10978 be initialized and declared extern. */
10979 if (!(type_quals & TYPE_QUAL_CONST))
10980 warning (0, "%qs initialized and declared %<extern%>", name);
10982 else
10984 error ("%qs has both %<extern%> and initializer", name);
10985 return error_mark_node;
10989 /* Record `register' declaration for warnings on &
10990 and in case doing stupid register allocation. */
10992 if (storage_class == sc_register)
10993 DECL_REGISTER (decl) = 1;
10994 else if (storage_class == sc_extern)
10995 DECL_THIS_EXTERN (decl) = 1;
10996 else if (storage_class == sc_static)
10997 DECL_THIS_STATIC (decl) = 1;
10999 /* Set constexpr flag on vars (functions got it in grokfndecl). */
11000 if (constexpr_p && VAR_P (decl))
11001 DECL_DECLARED_CONSTEXPR_P (decl) = true;
11003 /* Record constancy and volatility on the DECL itself . There's
11004 no need to do this when processing a template; we'll do this
11005 for the instantiated declaration based on the type of DECL. */
11006 if (!processing_template_decl)
11007 cp_apply_type_quals_to_decl (type_quals, decl);
11009 return decl;
11013 /* Subroutine of start_function. Ensure that each of the parameter
11014 types (as listed in PARMS) is complete, as is required for a
11015 function definition. */
11017 static void
11018 require_complete_types_for_parms (tree parms)
11020 for (; parms; parms = DECL_CHAIN (parms))
11022 if (dependent_type_p (TREE_TYPE (parms)))
11023 continue;
11024 if (!VOID_TYPE_P (TREE_TYPE (parms))
11025 && complete_type_or_else (TREE_TYPE (parms), parms))
11027 relayout_decl (parms);
11028 DECL_ARG_TYPE (parms) = type_passed_as (TREE_TYPE (parms));
11030 else
11031 /* grokparms or complete_type_or_else will have already issued
11032 an error. */
11033 TREE_TYPE (parms) = error_mark_node;
11037 /* Returns nonzero if T is a local variable. */
11040 local_variable_p (const_tree t)
11042 if ((VAR_P (t)
11043 /* A VAR_DECL with a context that is a _TYPE is a static data
11044 member. */
11045 && !TYPE_P (CP_DECL_CONTEXT (t))
11046 /* Any other non-local variable must be at namespace scope. */
11047 && !DECL_NAMESPACE_SCOPE_P (t))
11048 || (TREE_CODE (t) == PARM_DECL))
11049 return 1;
11051 return 0;
11054 /* Like local_variable_p, but suitable for use as a tree-walking
11055 function. */
11057 static tree
11058 local_variable_p_walkfn (tree *tp, int *walk_subtrees,
11059 void * /*data*/)
11061 if (local_variable_p (*tp)
11062 && (!DECL_ARTIFICIAL (*tp) || DECL_NAME (*tp) == this_identifier))
11063 return *tp;
11064 else if (TYPE_P (*tp))
11065 *walk_subtrees = 0;
11067 return NULL_TREE;
11070 /* Check that ARG, which is a default-argument expression for a
11071 parameter DECL, is valid. Returns ARG, or ERROR_MARK_NODE, if
11072 something goes wrong. DECL may also be a _TYPE node, rather than a
11073 DECL, if there is no DECL available. */
11075 tree
11076 check_default_argument (tree decl, tree arg, tsubst_flags_t complain)
11078 tree var;
11079 tree decl_type;
11081 if (TREE_CODE (arg) == DEFAULT_ARG)
11082 /* We get a DEFAULT_ARG when looking at an in-class declaration
11083 with a default argument. Ignore the argument for now; we'll
11084 deal with it after the class is complete. */
11085 return arg;
11087 if (TYPE_P (decl))
11089 decl_type = decl;
11090 decl = NULL_TREE;
11092 else
11093 decl_type = TREE_TYPE (decl);
11095 if (arg == error_mark_node
11096 || decl == error_mark_node
11097 || TREE_TYPE (arg) == error_mark_node
11098 || decl_type == error_mark_node)
11099 /* Something already went wrong. There's no need to check
11100 further. */
11101 return error_mark_node;
11103 /* [dcl.fct.default]
11105 A default argument expression is implicitly converted to the
11106 parameter type. */
11107 ++cp_unevaluated_operand;
11108 perform_implicit_conversion_flags (decl_type, arg, complain,
11109 LOOKUP_IMPLICIT);
11110 --cp_unevaluated_operand;
11112 if (warn_zero_as_null_pointer_constant
11113 && TYPE_PTR_OR_PTRMEM_P (decl_type)
11114 && null_ptr_cst_p (arg)
11115 && (complain & tf_warning)
11116 && maybe_warn_zero_as_null_pointer_constant (arg, input_location))
11117 return nullptr_node;
11119 /* [dcl.fct.default]
11121 Local variables shall not be used in default argument
11122 expressions.
11124 The keyword `this' shall not be used in a default argument of a
11125 member function. */
11126 var = cp_walk_tree_without_duplicates (&arg, local_variable_p_walkfn, NULL);
11127 if (var)
11129 if (complain & tf_warning_or_error)
11131 if (DECL_NAME (var) == this_identifier)
11132 permerror (input_location, "default argument %qE uses %qD",
11133 arg, var);
11134 else
11135 error ("default argument %qE uses local variable %qD", arg, var);
11137 return error_mark_node;
11140 /* All is well. */
11141 return arg;
11144 /* Returns a deprecated type used within TYPE, or NULL_TREE if none. */
11146 static tree
11147 type_is_deprecated (tree type)
11149 enum tree_code code;
11150 if (TREE_DEPRECATED (type))
11151 return type;
11152 if (TYPE_NAME (type)
11153 && TREE_DEPRECATED (TYPE_NAME (type)))
11154 return type;
11156 /* Do warn about using typedefs to a deprecated class. */
11157 if (OVERLOAD_TYPE_P (type) && type != TYPE_MAIN_VARIANT (type))
11158 return type_is_deprecated (TYPE_MAIN_VARIANT (type));
11160 code = TREE_CODE (type);
11162 if (code == POINTER_TYPE || code == REFERENCE_TYPE
11163 || code == OFFSET_TYPE || code == FUNCTION_TYPE
11164 || code == METHOD_TYPE || code == ARRAY_TYPE)
11165 return type_is_deprecated (TREE_TYPE (type));
11167 if (TYPE_PTRMEMFUNC_P (type))
11168 return type_is_deprecated
11169 (TREE_TYPE (TREE_TYPE (TYPE_PTRMEMFUNC_FN_TYPE (type))));
11171 return NULL_TREE;
11174 /* Decode the list of parameter types for a function type.
11175 Given the list of things declared inside the parens,
11176 return a list of types.
11178 If this parameter does not end with an ellipsis, we append
11179 void_list_node.
11181 *PARMS is set to the chain of PARM_DECLs created. */
11183 static tree
11184 grokparms (tree parmlist, tree *parms)
11186 tree result = NULL_TREE;
11187 tree decls = NULL_TREE;
11188 tree parm;
11189 int any_error = 0;
11191 for (parm = parmlist; parm != NULL_TREE; parm = TREE_CHAIN (parm))
11193 tree type = NULL_TREE;
11194 tree init = TREE_PURPOSE (parm);
11195 tree decl = TREE_VALUE (parm);
11196 const char *errmsg;
11198 if (parm == void_list_node)
11199 break;
11201 if (! decl || TREE_TYPE (decl) == error_mark_node)
11202 continue;
11204 type = TREE_TYPE (decl);
11205 if (VOID_TYPE_P (type))
11207 if (same_type_p (type, void_type_node)
11208 && !init
11209 && !DECL_NAME (decl) && !result
11210 && TREE_CHAIN (parm) == void_list_node)
11211 /* DR 577: A parameter list consisting of a single
11212 unnamed parameter of non-dependent type 'void'. */
11213 break;
11214 else if (cv_qualified_p (type))
11215 error_at (DECL_SOURCE_LOCATION (decl),
11216 "invalid use of cv-qualified type %qT in "
11217 "parameter declaration", type);
11218 else
11219 error_at (DECL_SOURCE_LOCATION (decl),
11220 "invalid use of type %<void%> in parameter "
11221 "declaration");
11222 /* It's not a good idea to actually create parameters of
11223 type `void'; other parts of the compiler assume that a
11224 void type terminates the parameter list. */
11225 type = error_mark_node;
11226 TREE_TYPE (decl) = error_mark_node;
11229 if (type != error_mark_node
11230 && TYPE_FOR_JAVA (type)
11231 && MAYBE_CLASS_TYPE_P (type))
11233 error ("parameter %qD has Java class type", decl);
11234 type = error_mark_node;
11235 TREE_TYPE (decl) = error_mark_node;
11236 init = NULL_TREE;
11239 if (type != error_mark_node
11240 && (errmsg = targetm.invalid_parameter_type (type)))
11242 error (errmsg);
11243 type = error_mark_node;
11244 TREE_TYPE (decl) = error_mark_node;
11247 if (type != error_mark_node)
11249 if (deprecated_state != DEPRECATED_SUPPRESS)
11251 tree deptype = type_is_deprecated (type);
11252 if (deptype)
11253 warn_deprecated_use (deptype, NULL_TREE);
11256 /* Top-level qualifiers on the parameters are
11257 ignored for function types. */
11258 type = cp_build_qualified_type (type, 0);
11259 if (TREE_CODE (type) == METHOD_TYPE)
11261 error ("parameter %qD invalidly declared method type", decl);
11262 type = build_pointer_type (type);
11263 TREE_TYPE (decl) = type;
11265 else if (abstract_virtuals_error (decl, type))
11266 any_error = 1; /* Seems like a good idea. */
11267 else if (POINTER_TYPE_P (type))
11269 /* [dcl.fct]/6, parameter types cannot contain pointers
11270 (references) to arrays of unknown bound. */
11271 tree t = TREE_TYPE (type);
11272 int ptr = TYPE_PTR_P (type);
11274 while (1)
11276 if (TYPE_PTR_P (t))
11277 ptr = 1;
11278 else if (TREE_CODE (t) != ARRAY_TYPE)
11279 break;
11280 else if (!TYPE_DOMAIN (t))
11281 break;
11282 t = TREE_TYPE (t);
11284 if (TREE_CODE (t) == ARRAY_TYPE)
11285 error (ptr
11286 ? G_("parameter %qD includes pointer to array of "
11287 "unknown bound %qT")
11288 : G_("parameter %qD includes reference to array of "
11289 "unknown bound %qT"),
11290 decl, t);
11293 if (any_error)
11294 init = NULL_TREE;
11295 else if (init && !processing_template_decl)
11296 init = check_default_argument (decl, init, tf_warning_or_error);
11299 DECL_CHAIN (decl) = decls;
11300 decls = decl;
11301 result = tree_cons (init, type, result);
11303 decls = nreverse (decls);
11304 result = nreverse (result);
11305 if (parm)
11306 result = chainon (result, void_list_node);
11307 *parms = decls;
11309 return result;
11313 /* D is a constructor or overloaded `operator='.
11315 Let T be the class in which D is declared. Then, this function
11316 returns:
11318 -1 if D's is an ill-formed constructor or copy assignment operator
11319 whose first parameter is of type `T'.
11320 0 if D is not a copy constructor or copy assignment
11321 operator.
11322 1 if D is a copy constructor or copy assignment operator whose
11323 first parameter is a reference to non-const qualified T.
11324 2 if D is a copy constructor or copy assignment operator whose
11325 first parameter is a reference to const qualified T.
11327 This function can be used as a predicate. Positive values indicate
11328 a copy constructor and nonzero values indicate a copy assignment
11329 operator. */
11332 copy_fn_p (const_tree d)
11334 tree args;
11335 tree arg_type;
11336 int result = 1;
11338 gcc_assert (DECL_FUNCTION_MEMBER_P (d));
11340 if (TREE_CODE (d) == TEMPLATE_DECL
11341 || (DECL_TEMPLATE_INFO (d)
11342 && DECL_MEMBER_TEMPLATE_P (DECL_TI_TEMPLATE (d))))
11343 /* Instantiations of template member functions are never copy
11344 functions. Note that member functions of templated classes are
11345 represented as template functions internally, and we must
11346 accept those as copy functions. */
11347 return 0;
11349 args = FUNCTION_FIRST_USER_PARMTYPE (d);
11350 if (!args)
11351 return 0;
11353 arg_type = TREE_VALUE (args);
11354 if (arg_type == error_mark_node)
11355 return 0;
11357 if (TYPE_MAIN_VARIANT (arg_type) == DECL_CONTEXT (d))
11359 /* Pass by value copy assignment operator. */
11360 result = -1;
11362 else if (TREE_CODE (arg_type) == REFERENCE_TYPE
11363 && !TYPE_REF_IS_RVALUE (arg_type)
11364 && TYPE_MAIN_VARIANT (TREE_TYPE (arg_type)) == DECL_CONTEXT (d))
11366 if (CP_TYPE_CONST_P (TREE_TYPE (arg_type)))
11367 result = 2;
11369 else
11370 return 0;
11372 args = TREE_CHAIN (args);
11374 if (args && args != void_list_node && !TREE_PURPOSE (args))
11375 /* There are more non-optional args. */
11376 return 0;
11378 return result;
11381 /* D is a constructor or overloaded `operator='.
11383 Let T be the class in which D is declared. Then, this function
11384 returns true when D is a move constructor or move assignment
11385 operator, false otherwise. */
11387 bool
11388 move_fn_p (const_tree d)
11390 gcc_assert (DECL_FUNCTION_MEMBER_P (d));
11392 if (cxx_dialect == cxx98)
11393 /* There are no move constructors if we are in C++98 mode. */
11394 return false;
11396 if (TREE_CODE (d) == TEMPLATE_DECL
11397 || (DECL_TEMPLATE_INFO (d)
11398 && DECL_MEMBER_TEMPLATE_P (DECL_TI_TEMPLATE (d))))
11399 /* Instantiations of template member functions are never move
11400 functions. Note that member functions of templated classes are
11401 represented as template functions internally, and we must
11402 accept those as move functions. */
11403 return 0;
11405 return move_signature_fn_p (d);
11408 /* D is a constructor or overloaded `operator='.
11410 Then, this function returns true when D has the same signature as a move
11411 constructor or move assignment operator (because either it is such a
11412 ctor/op= or it is a template specialization with the same signature),
11413 false otherwise. */
11415 bool
11416 move_signature_fn_p (const_tree d)
11418 tree args;
11419 tree arg_type;
11420 bool result = false;
11422 args = FUNCTION_FIRST_USER_PARMTYPE (d);
11423 if (!args)
11424 return 0;
11426 arg_type = TREE_VALUE (args);
11427 if (arg_type == error_mark_node)
11428 return 0;
11430 if (TREE_CODE (arg_type) == REFERENCE_TYPE
11431 && TYPE_REF_IS_RVALUE (arg_type)
11432 && same_type_p (TYPE_MAIN_VARIANT (TREE_TYPE (arg_type)),
11433 DECL_CONTEXT (d)))
11434 result = true;
11436 args = TREE_CHAIN (args);
11438 if (args && args != void_list_node && !TREE_PURPOSE (args))
11439 /* There are more non-optional args. */
11440 return false;
11442 return result;
11445 /* Remember any special properties of member function DECL. */
11447 void
11448 grok_special_member_properties (tree decl)
11450 tree class_type;
11452 if (!DECL_NONSTATIC_MEMBER_FUNCTION_P (decl))
11453 return;
11455 class_type = DECL_CONTEXT (decl);
11456 if (DECL_CONSTRUCTOR_P (decl))
11458 int ctor = copy_fn_p (decl);
11460 if (!DECL_ARTIFICIAL (decl))
11461 TYPE_HAS_USER_CONSTRUCTOR (class_type) = 1;
11463 if (ctor > 0)
11465 /* [class.copy]
11467 A non-template constructor for class X is a copy
11468 constructor if its first parameter is of type X&, const
11469 X&, volatile X& or const volatile X&, and either there
11470 are no other parameters or else all other parameters have
11471 default arguments. */
11472 TYPE_HAS_COPY_CTOR (class_type) = 1;
11473 if (user_provided_p (decl))
11474 TYPE_HAS_COMPLEX_COPY_CTOR (class_type) = 1;
11475 if (ctor > 1)
11476 TYPE_HAS_CONST_COPY_CTOR (class_type) = 1;
11478 else if (sufficient_parms_p (FUNCTION_FIRST_USER_PARMTYPE (decl)))
11480 TYPE_HAS_DEFAULT_CONSTRUCTOR (class_type) = 1;
11481 if (user_provided_p (decl))
11482 TYPE_HAS_COMPLEX_DFLT (class_type) = 1;
11484 else if (move_fn_p (decl) && user_provided_p (decl))
11485 TYPE_HAS_COMPLEX_MOVE_CTOR (class_type) = 1;
11486 else if (is_list_ctor (decl))
11487 TYPE_HAS_LIST_CTOR (class_type) = 1;
11489 if (DECL_DECLARED_CONSTEXPR_P (decl)
11490 && !copy_fn_p (decl) && !move_fn_p (decl))
11491 TYPE_HAS_CONSTEXPR_CTOR (class_type) = 1;
11493 else if (DECL_OVERLOADED_OPERATOR_P (decl) == NOP_EXPR)
11495 /* [class.copy]
11497 A non-template assignment operator for class X is a copy
11498 assignment operator if its parameter is of type X, X&, const
11499 X&, volatile X& or const volatile X&. */
11501 int assop = copy_fn_p (decl);
11503 if (assop)
11505 TYPE_HAS_COPY_ASSIGN (class_type) = 1;
11506 if (user_provided_p (decl))
11507 TYPE_HAS_COMPLEX_COPY_ASSIGN (class_type) = 1;
11508 if (assop != 1)
11509 TYPE_HAS_CONST_COPY_ASSIGN (class_type) = 1;
11511 else if (move_fn_p (decl) && user_provided_p (decl))
11512 TYPE_HAS_COMPLEX_MOVE_ASSIGN (class_type) = 1;
11514 /* Destructors are handled in check_methods. */
11517 /* Check a constructor DECL has the correct form. Complains
11518 if the class has a constructor of the form X(X). */
11521 grok_ctor_properties (const_tree ctype, const_tree decl)
11523 int ctor_parm = copy_fn_p (decl);
11525 if (ctor_parm < 0)
11527 /* [class.copy]
11529 A declaration of a constructor for a class X is ill-formed if
11530 its first parameter is of type (optionally cv-qualified) X
11531 and either there are no other parameters or else all other
11532 parameters have default arguments.
11534 We *don't* complain about member template instantiations that
11535 have this form, though; they can occur as we try to decide
11536 what constructor to use during overload resolution. Since
11537 overload resolution will never prefer such a constructor to
11538 the non-template copy constructor (which is either explicitly
11539 or implicitly defined), there's no need to worry about their
11540 existence. Theoretically, they should never even be
11541 instantiated, but that's hard to forestall. */
11542 error ("invalid constructor; you probably meant %<%T (const %T&)%>",
11543 ctype, ctype);
11544 return 0;
11547 return 1;
11550 /* An operator with this code is unary, but can also be binary. */
11552 static int
11553 ambi_op_p (enum tree_code code)
11555 return (code == INDIRECT_REF
11556 || code == ADDR_EXPR
11557 || code == UNARY_PLUS_EXPR
11558 || code == NEGATE_EXPR
11559 || code == PREINCREMENT_EXPR
11560 || code == PREDECREMENT_EXPR);
11563 /* An operator with this name can only be unary. */
11565 static int
11566 unary_op_p (enum tree_code code)
11568 return (code == TRUTH_NOT_EXPR
11569 || code == BIT_NOT_EXPR
11570 || code == COMPONENT_REF
11571 || code == TYPE_EXPR);
11574 /* DECL is a declaration for an overloaded operator. If COMPLAIN is true,
11575 errors are issued for invalid declarations. */
11577 bool
11578 grok_op_properties (tree decl, bool complain)
11580 tree argtypes = TYPE_ARG_TYPES (TREE_TYPE (decl));
11581 tree argtype;
11582 int methodp = (TREE_CODE (TREE_TYPE (decl)) == METHOD_TYPE);
11583 tree name = DECL_NAME (decl);
11584 enum tree_code operator_code;
11585 int arity;
11586 bool ellipsis_p;
11587 tree class_type;
11589 /* Count the number of arguments and check for ellipsis. */
11590 for (argtype = argtypes, arity = 0;
11591 argtype && argtype != void_list_node;
11592 argtype = TREE_CHAIN (argtype))
11593 ++arity;
11594 ellipsis_p = !argtype;
11596 class_type = DECL_CONTEXT (decl);
11597 if (class_type && !CLASS_TYPE_P (class_type))
11598 class_type = NULL_TREE;
11600 if (DECL_CONV_FN_P (decl))
11601 operator_code = TYPE_EXPR;
11602 else
11605 #define DEF_OPERATOR(NAME, CODE, MANGLING, ARITY, ASSN_P) \
11606 if (ansi_opname (CODE) == name) \
11608 operator_code = (CODE); \
11609 break; \
11611 else if (ansi_assopname (CODE) == name) \
11613 operator_code = (CODE); \
11614 DECL_ASSIGNMENT_OPERATOR_P (decl) = 1; \
11615 break; \
11618 #include "operators.def"
11619 #undef DEF_OPERATOR
11621 gcc_unreachable ();
11623 while (0);
11624 gcc_assert (operator_code != MAX_TREE_CODES);
11625 SET_OVERLOADED_OPERATOR_CODE (decl, operator_code);
11627 if (class_type)
11628 switch (operator_code)
11630 case NEW_EXPR:
11631 TYPE_HAS_NEW_OPERATOR (class_type) = 1;
11632 break;
11634 case DELETE_EXPR:
11635 TYPE_GETS_DELETE (class_type) |= 1;
11636 break;
11638 case VEC_NEW_EXPR:
11639 TYPE_HAS_ARRAY_NEW_OPERATOR (class_type) = 1;
11640 break;
11642 case VEC_DELETE_EXPR:
11643 TYPE_GETS_DELETE (class_type) |= 2;
11644 break;
11646 default:
11647 break;
11650 /* [basic.std.dynamic.allocation]/1:
11652 A program is ill-formed if an allocation function is declared
11653 in a namespace scope other than global scope or declared static
11654 in global scope.
11656 The same also holds true for deallocation functions. */
11657 if (operator_code == NEW_EXPR || operator_code == VEC_NEW_EXPR
11658 || operator_code == DELETE_EXPR || operator_code == VEC_DELETE_EXPR)
11660 if (DECL_NAMESPACE_SCOPE_P (decl))
11662 if (CP_DECL_CONTEXT (decl) != global_namespace)
11664 error ("%qD may not be declared within a namespace", decl);
11665 return false;
11667 else if (!TREE_PUBLIC (decl))
11669 error ("%qD may not be declared as static", decl);
11670 return false;
11675 if (operator_code == NEW_EXPR || operator_code == VEC_NEW_EXPR)
11677 TREE_TYPE (decl) = coerce_new_type (TREE_TYPE (decl));
11678 DECL_IS_OPERATOR_NEW (decl) = 1;
11680 else if (operator_code == DELETE_EXPR || operator_code == VEC_DELETE_EXPR)
11681 TREE_TYPE (decl) = coerce_delete_type (TREE_TYPE (decl));
11682 else
11684 /* An operator function must either be a non-static member function
11685 or have at least one parameter of a class, a reference to a class,
11686 an enumeration, or a reference to an enumeration. 13.4.0.6 */
11687 if (! methodp || DECL_STATIC_FUNCTION_P (decl))
11689 if (operator_code == TYPE_EXPR
11690 || operator_code == CALL_EXPR
11691 || operator_code == COMPONENT_REF
11692 || operator_code == ARRAY_REF
11693 || operator_code == NOP_EXPR)
11695 error ("%qD must be a nonstatic member function", decl);
11696 return false;
11698 else
11700 tree p;
11702 if (DECL_STATIC_FUNCTION_P (decl))
11704 error ("%qD must be either a non-static member "
11705 "function or a non-member function", decl);
11706 return false;
11709 for (p = argtypes; p && p != void_list_node; p = TREE_CHAIN (p))
11711 tree arg = non_reference (TREE_VALUE (p));
11712 if (arg == error_mark_node)
11713 return false;
11715 /* MAYBE_CLASS_TYPE_P, rather than CLASS_TYPE_P, is used
11716 because these checks are performed even on
11717 template functions. */
11718 if (MAYBE_CLASS_TYPE_P (arg)
11719 || TREE_CODE (arg) == ENUMERAL_TYPE)
11720 break;
11723 if (!p || p == void_list_node)
11725 if (complain)
11726 error ("%qD must have an argument of class or "
11727 "enumerated type", decl);
11728 return false;
11733 /* There are no restrictions on the arguments to an overloaded
11734 "operator ()". */
11735 if (operator_code == CALL_EXPR)
11736 return true;
11738 /* Warn about conversion operators that will never be used. */
11739 if (IDENTIFIER_TYPENAME_P (name)
11740 && ! DECL_TEMPLATE_INFO (decl)
11741 && warn_conversion
11742 /* Warn only declaring the function; there is no need to
11743 warn again about out-of-class definitions. */
11744 && class_type == current_class_type)
11746 tree t = TREE_TYPE (name);
11747 int ref = (TREE_CODE (t) == REFERENCE_TYPE);
11749 if (ref)
11750 t = TYPE_MAIN_VARIANT (TREE_TYPE (t));
11752 if (VOID_TYPE_P (t))
11753 warning (OPT_Wconversion,
11755 ? G_("conversion to a reference to void "
11756 "will never use a type conversion operator")
11757 : G_("conversion to void "
11758 "will never use a type conversion operator"));
11759 else if (class_type)
11761 if (t == class_type)
11762 warning (OPT_Wconversion,
11764 ? G_("conversion to a reference to the same type "
11765 "will never use a type conversion operator")
11766 : G_("conversion to the same type "
11767 "will never use a type conversion operator"));
11768 /* Don't force t to be complete here. */
11769 else if (MAYBE_CLASS_TYPE_P (t)
11770 && COMPLETE_TYPE_P (t)
11771 && DERIVED_FROM_P (t, class_type))
11772 warning (OPT_Wconversion,
11774 ? G_("conversion to a reference to a base class "
11775 "will never use a type conversion operator")
11776 : G_("conversion to a base class "
11777 "will never use a type conversion operator"));
11782 if (operator_code == COND_EXPR)
11784 /* 13.4.0.3 */
11785 error ("ISO C++ prohibits overloading operator ?:");
11786 return false;
11788 else if (ellipsis_p)
11790 error ("%qD must not have variable number of arguments", decl);
11791 return false;
11793 else if (ambi_op_p (operator_code))
11795 if (arity == 1)
11796 /* We pick the one-argument operator codes by default, so
11797 we don't have to change anything. */
11799 else if (arity == 2)
11801 /* If we thought this was a unary operator, we now know
11802 it to be a binary operator. */
11803 switch (operator_code)
11805 case INDIRECT_REF:
11806 operator_code = MULT_EXPR;
11807 break;
11809 case ADDR_EXPR:
11810 operator_code = BIT_AND_EXPR;
11811 break;
11813 case UNARY_PLUS_EXPR:
11814 operator_code = PLUS_EXPR;
11815 break;
11817 case NEGATE_EXPR:
11818 operator_code = MINUS_EXPR;
11819 break;
11821 case PREINCREMENT_EXPR:
11822 operator_code = POSTINCREMENT_EXPR;
11823 break;
11825 case PREDECREMENT_EXPR:
11826 operator_code = POSTDECREMENT_EXPR;
11827 break;
11829 default:
11830 gcc_unreachable ();
11833 SET_OVERLOADED_OPERATOR_CODE (decl, operator_code);
11835 if ((operator_code == POSTINCREMENT_EXPR
11836 || operator_code == POSTDECREMENT_EXPR)
11837 && ! processing_template_decl
11838 && ! same_type_p (TREE_VALUE (TREE_CHAIN (argtypes)), integer_type_node))
11840 if (methodp)
11841 error ("postfix %qD must take %<int%> as its argument",
11842 decl);
11843 else
11844 error ("postfix %qD must take %<int%> as its second "
11845 "argument", decl);
11846 return false;
11849 else
11851 if (methodp)
11852 error ("%qD must take either zero or one argument", decl);
11853 else
11854 error ("%qD must take either one or two arguments", decl);
11855 return false;
11858 /* More Effective C++ rule 6. */
11859 if (warn_ecpp
11860 && (operator_code == POSTINCREMENT_EXPR
11861 || operator_code == POSTDECREMENT_EXPR
11862 || operator_code == PREINCREMENT_EXPR
11863 || operator_code == PREDECREMENT_EXPR))
11865 tree arg = TREE_VALUE (argtypes);
11866 tree ret = TREE_TYPE (TREE_TYPE (decl));
11867 if (methodp || TREE_CODE (arg) == REFERENCE_TYPE)
11868 arg = TREE_TYPE (arg);
11869 arg = TYPE_MAIN_VARIANT (arg);
11870 if (operator_code == PREINCREMENT_EXPR
11871 || operator_code == PREDECREMENT_EXPR)
11873 if (TREE_CODE (ret) != REFERENCE_TYPE
11874 || !same_type_p (TYPE_MAIN_VARIANT (TREE_TYPE (ret)),
11875 arg))
11876 warning (OPT_Weffc__, "prefix %qD should return %qT", decl,
11877 build_reference_type (arg));
11879 else
11881 if (!same_type_p (TYPE_MAIN_VARIANT (ret), arg))
11882 warning (OPT_Weffc__, "postfix %qD should return %qT", decl, arg);
11886 else if (unary_op_p (operator_code))
11888 if (arity != 1)
11890 if (methodp)
11891 error ("%qD must take %<void%>", decl);
11892 else
11893 error ("%qD must take exactly one argument", decl);
11894 return false;
11897 else /* if (binary_op_p (operator_code)) */
11899 if (arity != 2)
11901 if (methodp)
11902 error ("%qD must take exactly one argument", decl);
11903 else
11904 error ("%qD must take exactly two arguments", decl);
11905 return false;
11908 /* More Effective C++ rule 7. */
11909 if (warn_ecpp
11910 && (operator_code == TRUTH_ANDIF_EXPR
11911 || operator_code == TRUTH_ORIF_EXPR
11912 || operator_code == COMPOUND_EXPR))
11913 warning (OPT_Weffc__, "user-defined %qD always evaluates both arguments",
11914 decl);
11917 /* Effective C++ rule 23. */
11918 if (warn_ecpp
11919 && arity == 2
11920 && !DECL_ASSIGNMENT_OPERATOR_P (decl)
11921 && (operator_code == PLUS_EXPR
11922 || operator_code == MINUS_EXPR
11923 || operator_code == TRUNC_DIV_EXPR
11924 || operator_code == MULT_EXPR
11925 || operator_code == TRUNC_MOD_EXPR)
11926 && TREE_CODE (TREE_TYPE (TREE_TYPE (decl))) == REFERENCE_TYPE)
11927 warning (OPT_Weffc__, "%qD should return by value", decl);
11929 /* [over.oper]/8 */
11930 for (; argtypes && argtypes != void_list_node;
11931 argtypes = TREE_CHAIN (argtypes))
11932 if (TREE_PURPOSE (argtypes))
11934 TREE_PURPOSE (argtypes) = NULL_TREE;
11935 if (operator_code == POSTINCREMENT_EXPR
11936 || operator_code == POSTDECREMENT_EXPR)
11938 pedwarn (input_location, OPT_Wpedantic, "%qD cannot have default arguments",
11939 decl);
11941 else
11943 error ("%qD cannot have default arguments", decl);
11944 return false;
11948 return true;
11951 /* Return a string giving the keyword associate with CODE. */
11953 static const char *
11954 tag_name (enum tag_types code)
11956 switch (code)
11958 case record_type:
11959 return "struct";
11960 case class_type:
11961 return "class";
11962 case union_type:
11963 return "union";
11964 case enum_type:
11965 return "enum";
11966 case typename_type:
11967 return "typename";
11968 default:
11969 gcc_unreachable ();
11973 /* Name lookup in an elaborated-type-specifier (after the keyword
11974 indicated by TAG_CODE) has found the TYPE_DECL DECL. If the
11975 elaborated-type-specifier is invalid, issue a diagnostic and return
11976 error_mark_node; otherwise, return the *_TYPE to which it referred.
11977 If ALLOW_TEMPLATE_P is true, TYPE may be a class template. */
11979 tree
11980 check_elaborated_type_specifier (enum tag_types tag_code,
11981 tree decl,
11982 bool allow_template_p)
11984 tree type;
11986 /* In the case of:
11988 struct S { struct S *p; };
11990 name lookup will find the TYPE_DECL for the implicit "S::S"
11991 typedef. Adjust for that here. */
11992 if (DECL_SELF_REFERENCE_P (decl))
11993 decl = TYPE_NAME (TREE_TYPE (decl));
11995 type = TREE_TYPE (decl);
11997 /* Check TEMPLATE_TYPE_PARM first because DECL_IMPLICIT_TYPEDEF_P
11998 is false for this case as well. */
11999 if (TREE_CODE (type) == TEMPLATE_TYPE_PARM)
12001 error ("using template type parameter %qT after %qs",
12002 type, tag_name (tag_code));
12003 return error_mark_node;
12005 /* Accept template template parameters. */
12006 else if (allow_template_p
12007 && (TREE_CODE (type) == BOUND_TEMPLATE_TEMPLATE_PARM
12008 || TREE_CODE (type) == TEMPLATE_TEMPLATE_PARM))
12010 /* [dcl.type.elab]
12012 If the identifier resolves to a typedef-name or the
12013 simple-template-id resolves to an alias template
12014 specialization, the elaborated-type-specifier is ill-formed.
12016 In other words, the only legitimate declaration to use in the
12017 elaborated type specifier is the implicit typedef created when
12018 the type is declared. */
12019 else if (!DECL_IMPLICIT_TYPEDEF_P (decl)
12020 && !DECL_SELF_REFERENCE_P (decl)
12021 && tag_code != typename_type)
12023 if (alias_template_specialization_p (type))
12024 error ("using alias template specialization %qT after %qs",
12025 type, tag_name (tag_code));
12026 else
12027 error ("using typedef-name %qD after %qs", decl, tag_name (tag_code));
12028 inform (DECL_SOURCE_LOCATION (decl),
12029 "%qD has a previous declaration here", decl);
12030 return error_mark_node;
12032 else if (TREE_CODE (type) != RECORD_TYPE
12033 && TREE_CODE (type) != UNION_TYPE
12034 && tag_code != enum_type
12035 && tag_code != typename_type)
12037 error ("%qT referred to as %qs", type, tag_name (tag_code));
12038 inform (input_location, "%q+T has a previous declaration here", type);
12039 return error_mark_node;
12041 else if (TREE_CODE (type) != ENUMERAL_TYPE
12042 && tag_code == enum_type)
12044 error ("%qT referred to as enum", type);
12045 inform (input_location, "%q+T has a previous declaration here", type);
12046 return error_mark_node;
12048 else if (!allow_template_p
12049 && TREE_CODE (type) == RECORD_TYPE
12050 && CLASSTYPE_IS_TEMPLATE (type))
12052 /* If a class template appears as elaborated type specifier
12053 without a template header such as:
12055 template <class T> class C {};
12056 void f(class C); // No template header here
12058 then the required template argument is missing. */
12059 error ("template argument required for %<%s %T%>",
12060 tag_name (tag_code),
12061 DECL_NAME (CLASSTYPE_TI_TEMPLATE (type)));
12062 return error_mark_node;
12065 return type;
12068 /* Lookup NAME in elaborate type specifier in scope according to
12069 SCOPE and issue diagnostics if necessary.
12070 Return *_TYPE node upon success, NULL_TREE when the NAME is not
12071 found, and ERROR_MARK_NODE for type error. */
12073 static tree
12074 lookup_and_check_tag (enum tag_types tag_code, tree name,
12075 tag_scope scope, bool template_header_p)
12077 tree t;
12078 tree decl;
12079 if (scope == ts_global)
12081 /* First try ordinary name lookup, ignoring hidden class name
12082 injected via friend declaration. */
12083 decl = lookup_name_prefer_type (name, 2);
12084 /* If that fails, the name will be placed in the smallest
12085 non-class, non-function-prototype scope according to 3.3.1/5.
12086 We may already have a hidden name declared as friend in this
12087 scope. So lookup again but not ignoring hidden names.
12088 If we find one, that name will be made visible rather than
12089 creating a new tag. */
12090 if (!decl)
12091 decl = lookup_type_scope (name, ts_within_enclosing_non_class);
12093 else
12094 decl = lookup_type_scope (name, scope);
12096 if (decl
12097 && (DECL_CLASS_TEMPLATE_P (decl)
12098 /* If scope is ts_current we're defining a class, so ignore a
12099 template template parameter. */
12100 || (scope != ts_current
12101 && DECL_TEMPLATE_TEMPLATE_PARM_P (decl))))
12102 decl = DECL_TEMPLATE_RESULT (decl);
12104 if (decl && TREE_CODE (decl) == TYPE_DECL)
12106 /* Look for invalid nested type:
12107 class C {
12108 class C {};
12109 }; */
12110 if (scope == ts_current && DECL_SELF_REFERENCE_P (decl))
12112 error ("%qD has the same name as the class in which it is "
12113 "declared",
12114 decl);
12115 return error_mark_node;
12118 /* Two cases we need to consider when deciding if a class
12119 template is allowed as an elaborated type specifier:
12120 1. It is a self reference to its own class.
12121 2. It comes with a template header.
12123 For example:
12125 template <class T> class C {
12126 class C *c1; // DECL_SELF_REFERENCE_P is true
12127 class D;
12129 template <class U> class C; // template_header_p is true
12130 template <class T> class C<T>::D {
12131 class C *c2; // DECL_SELF_REFERENCE_P is true
12132 }; */
12134 t = check_elaborated_type_specifier (tag_code,
12135 decl,
12136 template_header_p
12137 | DECL_SELF_REFERENCE_P (decl));
12138 return t;
12140 else if (decl && TREE_CODE (decl) == TREE_LIST)
12142 error ("reference to %qD is ambiguous", name);
12143 print_candidates (decl);
12144 return error_mark_node;
12146 else
12147 return NULL_TREE;
12150 /* Get the struct, enum or union (TAG_CODE says which) with tag NAME.
12151 Define the tag as a forward-reference if it is not defined.
12153 If a declaration is given, process it here, and report an error if
12154 multiple declarations are not identical.
12156 SCOPE is TS_CURRENT when this is also a definition. Only look in
12157 the current frame for the name (since C++ allows new names in any
12158 scope.) It is TS_WITHIN_ENCLOSING_NON_CLASS if this is a friend
12159 declaration. Only look beginning from the current scope outward up
12160 till the nearest non-class scope. Otherwise it is TS_GLOBAL.
12162 TEMPLATE_HEADER_P is true when this declaration is preceded by
12163 a set of template parameters. */
12165 static tree
12166 xref_tag_1 (enum tag_types tag_code, tree name,
12167 tag_scope orig_scope, bool template_header_p)
12169 enum tree_code code;
12170 tree t;
12171 tree context = NULL_TREE;
12172 tag_scope scope;
12174 gcc_assert (identifier_p (name));
12176 switch (tag_code)
12178 case record_type:
12179 case class_type:
12180 code = RECORD_TYPE;
12181 break;
12182 case union_type:
12183 code = UNION_TYPE;
12184 break;
12185 case enum_type:
12186 code = ENUMERAL_TYPE;
12187 break;
12188 default:
12189 gcc_unreachable ();
12192 if (orig_scope == ts_lambda)
12193 scope = ts_current;
12194 else
12195 scope = orig_scope;
12197 /* In case of anonymous name, xref_tag is only called to
12198 make type node and push name. Name lookup is not required. */
12199 if (ANON_AGGRNAME_P (name))
12200 t = NULL_TREE;
12201 else
12202 t = lookup_and_check_tag (tag_code, name,
12203 scope, template_header_p);
12205 if (t == error_mark_node)
12206 return error_mark_node;
12208 if (scope != ts_current && t && current_class_type
12209 && template_class_depth (current_class_type)
12210 && template_header_p)
12212 if (TREE_CODE (t) == TEMPLATE_TEMPLATE_PARM)
12213 return t;
12215 /* Since SCOPE is not TS_CURRENT, we are not looking at a
12216 definition of this tag. Since, in addition, we are currently
12217 processing a (member) template declaration of a template
12218 class, we must be very careful; consider:
12220 template <class X>
12221 struct S1
12223 template <class U>
12224 struct S2
12225 { template <class V>
12226 friend struct S1; };
12228 Here, the S2::S1 declaration should not be confused with the
12229 outer declaration. In particular, the inner version should
12230 have a template parameter of level 2, not level 1. This
12231 would be particularly important if the member declaration
12232 were instead:
12234 template <class V = U> friend struct S1;
12236 say, when we should tsubst into `U' when instantiating
12237 S2. On the other hand, when presented with:
12239 template <class T>
12240 struct S1 {
12241 template <class U>
12242 struct S2 {};
12243 template <class U>
12244 friend struct S2;
12247 we must find the inner binding eventually. We
12248 accomplish this by making sure that the new type we
12249 create to represent this declaration has the right
12250 TYPE_CONTEXT. */
12251 context = TYPE_CONTEXT (t);
12252 t = NULL_TREE;
12255 if (! t)
12257 /* If no such tag is yet defined, create a forward-reference node
12258 and record it as the "definition".
12259 When a real declaration of this type is found,
12260 the forward-reference will be altered into a real type. */
12261 if (code == ENUMERAL_TYPE)
12263 error ("use of enum %q#D without previous declaration", name);
12264 return error_mark_node;
12266 else
12268 t = make_class_type (code);
12269 TYPE_CONTEXT (t) = context;
12270 if (orig_scope == ts_lambda)
12271 /* Remember that we're declaring a lambda to avoid bogus errors
12272 in push_template_decl. */
12273 CLASSTYPE_LAMBDA_EXPR (t) = error_mark_node;
12274 t = pushtag (name, t, scope);
12277 else
12279 if (template_header_p && MAYBE_CLASS_TYPE_P (t))
12281 if (!redeclare_class_template (t, current_template_parms))
12282 return error_mark_node;
12284 else if (!processing_template_decl
12285 && CLASS_TYPE_P (t)
12286 && CLASSTYPE_IS_TEMPLATE (t))
12288 error ("redeclaration of %qT as a non-template", t);
12289 error ("previous declaration %q+D", t);
12290 return error_mark_node;
12293 /* Make injected friend class visible. */
12294 if (scope != ts_within_enclosing_non_class
12295 && hidden_name_p (TYPE_NAME (t)))
12297 DECL_ANTICIPATED (TYPE_NAME (t)) = 0;
12298 DECL_FRIEND_P (TYPE_NAME (t)) = 0;
12300 if (TYPE_TEMPLATE_INFO (t))
12302 DECL_ANTICIPATED (TYPE_TI_TEMPLATE (t)) = 0;
12303 DECL_FRIEND_P (TYPE_TI_TEMPLATE (t)) = 0;
12308 return t;
12311 /* Wrapper for xref_tag_1. */
12313 tree
12314 xref_tag (enum tag_types tag_code, tree name,
12315 tag_scope scope, bool template_header_p)
12317 tree ret;
12318 bool subtime;
12319 subtime = timevar_cond_start (TV_NAME_LOOKUP);
12320 ret = xref_tag_1 (tag_code, name, scope, template_header_p);
12321 timevar_cond_stop (TV_NAME_LOOKUP, subtime);
12322 return ret;
12326 tree
12327 xref_tag_from_type (tree old, tree id, tag_scope scope)
12329 enum tag_types tag_kind;
12331 if (TREE_CODE (old) == RECORD_TYPE)
12332 tag_kind = (CLASSTYPE_DECLARED_CLASS (old) ? class_type : record_type);
12333 else
12334 tag_kind = union_type;
12336 if (id == NULL_TREE)
12337 id = TYPE_IDENTIFIER (old);
12339 return xref_tag (tag_kind, id, scope, false);
12342 /* Create the binfo hierarchy for REF with (possibly NULL) base list
12343 BASE_LIST. For each element on BASE_LIST the TREE_PURPOSE is an
12344 access_* node, and the TREE_VALUE is the type of the base-class.
12345 Non-NULL TREE_TYPE indicates virtual inheritance.
12347 Returns true if the binfo hierarchy was successfully created,
12348 false if an error was detected. */
12350 bool
12351 xref_basetypes (tree ref, tree base_list)
12353 tree *basep;
12354 tree binfo, base_binfo;
12355 unsigned max_vbases = 0; /* Maximum direct & indirect virtual bases. */
12356 unsigned max_bases = 0; /* Maximum direct bases. */
12357 int i;
12358 tree default_access;
12359 tree igo_prev; /* Track Inheritance Graph Order. */
12361 if (ref == error_mark_node)
12362 return false;
12364 /* The base of a derived class is private by default, all others are
12365 public. */
12366 default_access = (TREE_CODE (ref) == RECORD_TYPE
12367 && CLASSTYPE_DECLARED_CLASS (ref)
12368 ? access_private_node : access_public_node);
12370 /* First, make sure that any templates in base-classes are
12371 instantiated. This ensures that if we call ourselves recursively
12372 we do not get confused about which classes are marked and which
12373 are not. */
12374 basep = &base_list;
12375 while (*basep)
12377 tree basetype = TREE_VALUE (*basep);
12379 /* The dependent_type_p call below should really be dependent_scope_p
12380 so that we give a hard error about using an incomplete type as a
12381 base, but we allow it with a pedwarn for backward
12382 compatibility. */
12383 if (processing_template_decl
12384 && CLASS_TYPE_P (basetype) && TYPE_BEING_DEFINED (basetype))
12385 cxx_incomplete_type_diagnostic (NULL_TREE, basetype, DK_PEDWARN);
12386 if (!dependent_type_p (basetype)
12387 && !complete_type_or_else (basetype, NULL))
12388 /* An incomplete type. Remove it from the list. */
12389 *basep = TREE_CHAIN (*basep);
12390 else
12392 max_bases++;
12393 if (TREE_TYPE (*basep))
12394 max_vbases++;
12395 if (CLASS_TYPE_P (basetype))
12396 max_vbases += vec_safe_length (CLASSTYPE_VBASECLASSES (basetype));
12397 basep = &TREE_CHAIN (*basep);
12401 TYPE_MARKED_P (ref) = 1;
12403 /* The binfo slot should be empty, unless this is an (ill-formed)
12404 redefinition. */
12405 if (TYPE_BINFO (ref) && !TYPE_SIZE (ref))
12407 error ("redefinition of %q#T", ref);
12408 return false;
12411 gcc_assert (TYPE_MAIN_VARIANT (ref) == ref);
12413 binfo = make_tree_binfo (max_bases);
12415 TYPE_BINFO (ref) = binfo;
12416 BINFO_OFFSET (binfo) = size_zero_node;
12417 BINFO_TYPE (binfo) = ref;
12419 /* Apply base-class info set up to the variants of this type. */
12420 fixup_type_variants (ref);
12422 if (max_bases)
12424 vec_alloc (BINFO_BASE_ACCESSES (binfo), max_bases);
12425 /* An aggregate cannot have baseclasses. */
12426 CLASSTYPE_NON_AGGREGATE (ref) = 1;
12428 if (TREE_CODE (ref) == UNION_TYPE)
12430 error ("derived union %qT invalid", ref);
12431 return false;
12435 if (max_bases > 1)
12437 if (TYPE_FOR_JAVA (ref))
12439 error ("Java class %qT cannot have multiple bases", ref);
12440 return false;
12444 if (max_vbases)
12446 vec_alloc (CLASSTYPE_VBASECLASSES (ref), max_vbases);
12448 if (TYPE_FOR_JAVA (ref))
12450 error ("Java class %qT cannot have virtual bases", ref);
12451 return false;
12455 for (igo_prev = binfo; base_list; base_list = TREE_CHAIN (base_list))
12457 tree access = TREE_PURPOSE (base_list);
12458 int via_virtual = TREE_TYPE (base_list) != NULL_TREE;
12459 tree basetype = TREE_VALUE (base_list);
12461 if (access == access_default_node)
12462 access = default_access;
12464 if (PACK_EXPANSION_P (basetype))
12465 basetype = PACK_EXPANSION_PATTERN (basetype);
12466 if (TREE_CODE (basetype) == TYPE_DECL)
12467 basetype = TREE_TYPE (basetype);
12468 if (!MAYBE_CLASS_TYPE_P (basetype) || TREE_CODE (basetype) == UNION_TYPE)
12470 error ("base type %qT fails to be a struct or class type",
12471 basetype);
12472 return false;
12475 if (TYPE_FOR_JAVA (basetype) && (current_lang_depth () == 0))
12476 TYPE_FOR_JAVA (ref) = 1;
12478 base_binfo = NULL_TREE;
12479 if (CLASS_TYPE_P (basetype) && !dependent_scope_p (basetype))
12481 base_binfo = TYPE_BINFO (basetype);
12482 /* The original basetype could have been a typedef'd type. */
12483 basetype = BINFO_TYPE (base_binfo);
12485 /* Inherit flags from the base. */
12486 TYPE_HAS_NEW_OPERATOR (ref)
12487 |= TYPE_HAS_NEW_OPERATOR (basetype);
12488 TYPE_HAS_ARRAY_NEW_OPERATOR (ref)
12489 |= TYPE_HAS_ARRAY_NEW_OPERATOR (basetype);
12490 TYPE_GETS_DELETE (ref) |= TYPE_GETS_DELETE (basetype);
12491 TYPE_HAS_CONVERSION (ref) |= TYPE_HAS_CONVERSION (basetype);
12492 CLASSTYPE_DIAMOND_SHAPED_P (ref)
12493 |= CLASSTYPE_DIAMOND_SHAPED_P (basetype);
12494 CLASSTYPE_REPEATED_BASE_P (ref)
12495 |= CLASSTYPE_REPEATED_BASE_P (basetype);
12498 /* We must do this test after we've seen through a typedef
12499 type. */
12500 if (TYPE_MARKED_P (basetype))
12502 if (basetype == ref)
12503 error ("recursive type %qT undefined", basetype);
12504 else
12505 error ("duplicate base type %qT invalid", basetype);
12506 return false;
12509 if (PACK_EXPANSION_P (TREE_VALUE (base_list)))
12510 /* Regenerate the pack expansion for the bases. */
12511 basetype = make_pack_expansion (basetype);
12513 TYPE_MARKED_P (basetype) = 1;
12515 base_binfo = copy_binfo (base_binfo, basetype, ref,
12516 &igo_prev, via_virtual);
12517 if (!BINFO_INHERITANCE_CHAIN (base_binfo))
12518 BINFO_INHERITANCE_CHAIN (base_binfo) = binfo;
12520 BINFO_BASE_APPEND (binfo, base_binfo);
12521 BINFO_BASE_ACCESS_APPEND (binfo, access);
12524 if (vec_safe_length (CLASSTYPE_VBASECLASSES (ref)) < max_vbases)
12525 /* If we didn't get max_vbases vbases, we must have shared at
12526 least one of them, and are therefore diamond shaped. */
12527 CLASSTYPE_DIAMOND_SHAPED_P (ref) = 1;
12529 /* Unmark all the types. */
12530 for (i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); i++)
12531 TYPE_MARKED_P (BINFO_TYPE (base_binfo)) = 0;
12532 TYPE_MARKED_P (ref) = 0;
12534 /* Now see if we have a repeated base type. */
12535 if (!CLASSTYPE_REPEATED_BASE_P (ref))
12537 for (base_binfo = binfo; base_binfo;
12538 base_binfo = TREE_CHAIN (base_binfo))
12540 if (TYPE_MARKED_P (BINFO_TYPE (base_binfo)))
12542 CLASSTYPE_REPEATED_BASE_P (ref) = 1;
12543 break;
12545 TYPE_MARKED_P (BINFO_TYPE (base_binfo)) = 1;
12547 for (base_binfo = binfo; base_binfo;
12548 base_binfo = TREE_CHAIN (base_binfo))
12549 if (TYPE_MARKED_P (BINFO_TYPE (base_binfo)))
12550 TYPE_MARKED_P (BINFO_TYPE (base_binfo)) = 0;
12551 else
12552 break;
12555 return true;
12559 /* Copies the enum-related properties from type SRC to type DST.
12560 Used with the underlying type of an enum and the enum itself. */
12561 static void
12562 copy_type_enum (tree dst, tree src)
12564 tree t;
12565 for (t = dst; t; t = TYPE_NEXT_VARIANT (t))
12567 TYPE_MIN_VALUE (t) = TYPE_MIN_VALUE (src);
12568 TYPE_MAX_VALUE (t) = TYPE_MAX_VALUE (src);
12569 TYPE_SIZE (t) = TYPE_SIZE (src);
12570 TYPE_SIZE_UNIT (t) = TYPE_SIZE_UNIT (src);
12571 SET_TYPE_MODE (dst, TYPE_MODE (src));
12572 TYPE_PRECISION (t) = TYPE_PRECISION (src);
12573 TYPE_ALIGN (t) = TYPE_ALIGN (src);
12574 TYPE_USER_ALIGN (t) = TYPE_USER_ALIGN (src);
12575 TYPE_UNSIGNED (t) = TYPE_UNSIGNED (src);
12579 /* Begin compiling the definition of an enumeration type.
12580 NAME is its name,
12582 if ENUMTYPE is not NULL_TREE then the type has alredy been found.
12584 UNDERLYING_TYPE is the type that will be used as the storage for
12585 the enumeration type. This should be NULL_TREE if no storage type
12586 was specified.
12588 SCOPED_ENUM_P is true if this is a scoped enumeration type.
12590 if IS_NEW is not NULL, gets TRUE iff a new type is created.
12592 Returns the type object, as yet incomplete.
12593 Also records info about it so that build_enumerator
12594 may be used to declare the individual values as they are read. */
12596 tree
12597 start_enum (tree name, tree enumtype, tree underlying_type,
12598 bool scoped_enum_p, bool *is_new)
12600 tree prevtype = NULL_TREE;
12601 gcc_assert (identifier_p (name));
12603 if (is_new)
12604 *is_new = false;
12605 /* [C++0x dcl.enum]p5:
12607 If not explicitly specified, the underlying type of a scoped
12608 enumeration type is int. */
12609 if (!underlying_type && scoped_enum_p)
12610 underlying_type = integer_type_node;
12612 if (underlying_type)
12613 underlying_type = cv_unqualified (underlying_type);
12615 /* If this is the real definition for a previous forward reference,
12616 fill in the contents in the same object that used to be the
12617 forward reference. */
12618 if (!enumtype)
12619 enumtype = lookup_and_check_tag (enum_type, name,
12620 /*tag_scope=*/ts_current,
12621 /*template_header_p=*/false);
12623 /* In case of a template_decl, the only check that should be deferred
12624 to instantiation time is the comparison of underlying types. */
12625 if (enumtype && TREE_CODE (enumtype) == ENUMERAL_TYPE)
12627 if (scoped_enum_p != SCOPED_ENUM_P (enumtype))
12629 error_at (input_location, "scoped/unscoped mismatch "
12630 "in enum %q#T", enumtype);
12631 error_at (DECL_SOURCE_LOCATION (TYPE_MAIN_DECL (enumtype)),
12632 "previous definition here");
12633 enumtype = error_mark_node;
12635 else if (ENUM_FIXED_UNDERLYING_TYPE_P (enumtype) != !! underlying_type)
12637 error_at (input_location, "underlying type mismatch "
12638 "in enum %q#T", enumtype);
12639 error_at (DECL_SOURCE_LOCATION (TYPE_MAIN_DECL (enumtype)),
12640 "previous definition here");
12641 enumtype = error_mark_node;
12643 else if (underlying_type && ENUM_UNDERLYING_TYPE (enumtype)
12644 && !dependent_type_p (underlying_type)
12645 && !dependent_type_p (ENUM_UNDERLYING_TYPE (enumtype))
12646 && !same_type_p (underlying_type,
12647 ENUM_UNDERLYING_TYPE (enumtype)))
12649 error_at (input_location, "different underlying type "
12650 "in enum %q#T", enumtype);
12651 error_at (DECL_SOURCE_LOCATION (TYPE_MAIN_DECL (enumtype)),
12652 "previous definition here");
12653 underlying_type = NULL_TREE;
12657 if (!enumtype || TREE_CODE (enumtype) != ENUMERAL_TYPE
12658 || processing_template_decl)
12660 /* In case of error, make a dummy enum to allow parsing to
12661 continue. */
12662 if (enumtype == error_mark_node)
12664 name = make_anon_name ();
12665 enumtype = NULL_TREE;
12668 /* enumtype may be an ENUMERAL_TYPE if this is a redefinition
12669 of an opaque enum, or an opaque enum of an already defined
12670 enumeration (C++0x only).
12671 In any other case, it'll be NULL_TREE. */
12672 if (!enumtype)
12674 if (is_new)
12675 *is_new = true;
12677 prevtype = enumtype;
12679 /* Do not push the decl more than once, unless we need to
12680 compare underlying types at instantiation time */
12681 if (!enumtype
12682 || TREE_CODE (enumtype) != ENUMERAL_TYPE
12683 || (underlying_type
12684 && dependent_type_p (underlying_type))
12685 || (ENUM_UNDERLYING_TYPE (enumtype)
12686 && dependent_type_p (ENUM_UNDERLYING_TYPE (enumtype))))
12688 enumtype = cxx_make_type (ENUMERAL_TYPE);
12689 enumtype = pushtag (name, enumtype, /*tag_scope=*/ts_current);
12691 else
12692 enumtype = xref_tag (enum_type, name, /*tag_scope=*/ts_current,
12693 false);
12695 if (enumtype == error_mark_node)
12696 return error_mark_node;
12698 /* The enum is considered opaque until the opening '{' of the
12699 enumerator list. */
12700 SET_OPAQUE_ENUM_P (enumtype, true);
12701 ENUM_FIXED_UNDERLYING_TYPE_P (enumtype) = !! underlying_type;
12704 SET_SCOPED_ENUM_P (enumtype, scoped_enum_p);
12706 if (underlying_type)
12708 if (CP_INTEGRAL_TYPE_P (underlying_type))
12710 copy_type_enum (enumtype, underlying_type);
12711 ENUM_UNDERLYING_TYPE (enumtype) = underlying_type;
12713 else if (dependent_type_p (underlying_type))
12714 ENUM_UNDERLYING_TYPE (enumtype) = underlying_type;
12715 else
12716 error ("underlying type %<%T%> of %<%T%> must be an integral type",
12717 underlying_type, enumtype);
12720 /* If into a template class, the returned enum is always the first
12721 declaration (opaque or not) seen. This way all the references to
12722 this type will be to the same declaration. The following ones are used
12723 only to check for definition errors. */
12724 if (prevtype && processing_template_decl)
12725 return prevtype;
12726 else
12727 return enumtype;
12730 /* After processing and defining all the values of an enumeration type,
12731 install their decls in the enumeration type.
12732 ENUMTYPE is the type object. */
12734 void
12735 finish_enum_value_list (tree enumtype)
12737 tree values;
12738 tree underlying_type;
12739 tree decl;
12740 tree value;
12741 tree minnode, maxnode;
12742 tree t;
12744 bool fixed_underlying_type_p
12745 = ENUM_UNDERLYING_TYPE (enumtype) != NULL_TREE;
12747 /* We built up the VALUES in reverse order. */
12748 TYPE_VALUES (enumtype) = nreverse (TYPE_VALUES (enumtype));
12750 /* For an enum defined in a template, just set the type of the values;
12751 all further processing is postponed until the template is
12752 instantiated. We need to set the type so that tsubst of a CONST_DECL
12753 works. */
12754 if (processing_template_decl)
12756 for (values = TYPE_VALUES (enumtype);
12757 values;
12758 values = TREE_CHAIN (values))
12759 TREE_TYPE (TREE_VALUE (values)) = enumtype;
12760 return;
12763 /* Determine the minimum and maximum values of the enumerators. */
12764 if (TYPE_VALUES (enumtype))
12766 minnode = maxnode = NULL_TREE;
12768 for (values = TYPE_VALUES (enumtype);
12769 values;
12770 values = TREE_CHAIN (values))
12772 decl = TREE_VALUE (values);
12774 /* [dcl.enum]: Following the closing brace of an enum-specifier,
12775 each enumerator has the type of its enumeration. Prior to the
12776 closing brace, the type of each enumerator is the type of its
12777 initializing value. */
12778 TREE_TYPE (decl) = enumtype;
12780 /* Update the minimum and maximum values, if appropriate. */
12781 value = DECL_INITIAL (decl);
12782 if (value == error_mark_node)
12783 value = integer_zero_node;
12784 /* Figure out what the minimum and maximum values of the
12785 enumerators are. */
12786 if (!minnode)
12787 minnode = maxnode = value;
12788 else if (tree_int_cst_lt (maxnode, value))
12789 maxnode = value;
12790 else if (tree_int_cst_lt (value, minnode))
12791 minnode = value;
12794 else
12795 /* [dcl.enum]
12797 If the enumerator-list is empty, the underlying type is as if
12798 the enumeration had a single enumerator with value 0. */
12799 minnode = maxnode = integer_zero_node;
12801 if (!fixed_underlying_type_p)
12803 /* Compute the number of bits require to represent all values of the
12804 enumeration. We must do this before the type of MINNODE and
12805 MAXNODE are transformed, since tree_int_cst_min_precision relies
12806 on the TREE_TYPE of the value it is passed. */
12807 signop sgn = tree_int_cst_sgn (minnode) >= 0 ? UNSIGNED : SIGNED;
12808 int lowprec = tree_int_cst_min_precision (minnode, sgn);
12809 int highprec = tree_int_cst_min_precision (maxnode, sgn);
12810 int precision = MAX (lowprec, highprec);
12811 unsigned int itk;
12812 bool use_short_enum;
12814 /* Determine the underlying type of the enumeration.
12816 [dcl.enum]
12818 The underlying type of an enumeration is an integral type that
12819 can represent all the enumerator values defined in the
12820 enumeration. It is implementation-defined which integral type is
12821 used as the underlying type for an enumeration except that the
12822 underlying type shall not be larger than int unless the value of
12823 an enumerator cannot fit in an int or unsigned int.
12825 We use "int" or an "unsigned int" as the underlying type, even if
12826 a smaller integral type would work, unless the user has
12827 explicitly requested that we use the smallest possible type. The
12828 user can request that for all enumerations with a command line
12829 flag, or for just one enumeration with an attribute. */
12831 use_short_enum = flag_short_enums
12832 || lookup_attribute ("packed", TYPE_ATTRIBUTES (enumtype));
12834 for (itk = (use_short_enum ? itk_char : itk_int);
12835 itk != itk_none;
12836 itk++)
12838 underlying_type = integer_types[itk];
12839 if (underlying_type != NULL_TREE
12840 && TYPE_PRECISION (underlying_type) >= precision
12841 && TYPE_SIGN (underlying_type) == sgn)
12842 break;
12844 if (itk == itk_none)
12846 /* DR 377
12848 IF no integral type can represent all the enumerator values, the
12849 enumeration is ill-formed. */
12850 error ("no integral type can represent all of the enumerator values "
12851 "for %qT", enumtype);
12852 precision = TYPE_PRECISION (long_long_integer_type_node);
12853 underlying_type = integer_types[itk_unsigned_long_long];
12856 /* [dcl.enum]
12858 The value of sizeof() applied to an enumeration type, an object
12859 of an enumeration type, or an enumerator, is the value of sizeof()
12860 applied to the underlying type. */
12861 copy_type_enum (enumtype, underlying_type);
12863 /* Compute the minimum and maximum values for the type.
12865 [dcl.enum]
12867 For an enumeration where emin is the smallest enumerator and emax
12868 is the largest, the values of the enumeration are the values of the
12869 underlying type in the range bmin to bmax, where bmin and bmax are,
12870 respectively, the smallest and largest values of the smallest bit-
12871 field that can store emin and emax. */
12873 /* The middle-end currently assumes that types with TYPE_PRECISION
12874 narrower than their underlying type are suitably zero or sign
12875 extended to fill their mode. Similarly, it assumes that the front
12876 end assures that a value of a particular type must be within
12877 TYPE_MIN_VALUE and TYPE_MAX_VALUE.
12879 We used to set these fields based on bmin and bmax, but that led
12880 to invalid assumptions like optimizing away bounds checking. So
12881 now we just set the TYPE_PRECISION, TYPE_MIN_VALUE, and
12882 TYPE_MAX_VALUE to the values for the mode above and only restrict
12883 the ENUM_UNDERLYING_TYPE for the benefit of diagnostics. */
12884 ENUM_UNDERLYING_TYPE (enumtype)
12885 = build_distinct_type_copy (underlying_type);
12886 TYPE_PRECISION (ENUM_UNDERLYING_TYPE (enumtype)) = precision;
12887 set_min_and_max_values_for_integral_type
12888 (ENUM_UNDERLYING_TYPE (enumtype), precision, sgn);
12890 /* If -fstrict-enums, still constrain TYPE_MIN/MAX_VALUE. */
12891 if (flag_strict_enums)
12892 set_min_and_max_values_for_integral_type (enumtype, precision, sgn);
12894 else
12895 underlying_type = ENUM_UNDERLYING_TYPE (enumtype);
12897 /* Convert each of the enumerators to the type of the underlying
12898 type of the enumeration. */
12899 for (values = TYPE_VALUES (enumtype); values; values = TREE_CHAIN (values))
12901 location_t saved_location;
12903 decl = TREE_VALUE (values);
12904 saved_location = input_location;
12905 input_location = DECL_SOURCE_LOCATION (decl);
12906 if (fixed_underlying_type_p)
12907 /* If the enumeration type has a fixed underlying type, we
12908 already checked all of the enumerator values. */
12909 value = DECL_INITIAL (decl);
12910 else
12911 value = perform_implicit_conversion (underlying_type,
12912 DECL_INITIAL (decl),
12913 tf_warning_or_error);
12914 input_location = saved_location;
12916 /* Do not clobber shared ints. */
12917 value = copy_node (value);
12919 TREE_TYPE (value) = enumtype;
12920 DECL_INITIAL (decl) = value;
12923 /* Fix up all variant types of this enum type. */
12924 for (t = TYPE_MAIN_VARIANT (enumtype); t; t = TYPE_NEXT_VARIANT (t))
12925 TYPE_VALUES (t) = TYPE_VALUES (enumtype);
12927 if (at_class_scope_p ()
12928 && COMPLETE_TYPE_P (current_class_type)
12929 && UNSCOPED_ENUM_P (enumtype))
12930 insert_late_enum_def_into_classtype_sorted_fields (enumtype,
12931 current_class_type);
12933 /* Finish debugging output for this type. */
12934 rest_of_type_compilation (enumtype, namespace_bindings_p ());
12937 /* Finishes the enum type. This is called only the first time an
12938 enumeration is seen, be it opaque or odinary.
12939 ENUMTYPE is the type object. */
12941 void
12942 finish_enum (tree enumtype)
12944 if (processing_template_decl)
12946 if (at_function_scope_p ())
12947 add_stmt (build_min (TAG_DEFN, enumtype));
12948 return;
12951 /* If this is a forward declaration, there should not be any variants,
12952 though we can get a variant in the middle of an enum-specifier with
12953 wacky code like 'enum E { e = sizeof(const E*) };' */
12954 gcc_assert (enumtype == TYPE_MAIN_VARIANT (enumtype)
12955 && (TYPE_VALUES (enumtype)
12956 || !TYPE_NEXT_VARIANT (enumtype)));
12959 /* Build and install a CONST_DECL for an enumeration constant of the
12960 enumeration type ENUMTYPE whose NAME and VALUE (if any) are provided.
12961 LOC is the location of NAME.
12962 Assignment of sequential values by default is handled here. */
12964 void
12965 build_enumerator (tree name, tree value, tree enumtype, location_t loc)
12967 tree decl;
12968 tree context;
12969 tree type;
12971 /* If the VALUE was erroneous, pretend it wasn't there; that will
12972 result in the enum being assigned the next value in sequence. */
12973 if (value == error_mark_node)
12974 value = NULL_TREE;
12976 /* Remove no-op casts from the value. */
12977 if (value)
12978 STRIP_TYPE_NOPS (value);
12980 if (! processing_template_decl)
12982 /* Validate and default VALUE. */
12983 if (value != NULL_TREE)
12985 if (!ENUM_UNDERLYING_TYPE (enumtype))
12987 tree tmp_value = build_expr_type_conversion (WANT_INT | WANT_ENUM,
12988 value, true);
12989 if (tmp_value)
12990 value = tmp_value;
12992 else if (! INTEGRAL_OR_ENUMERATION_TYPE_P (TREE_TYPE (value)))
12993 value = perform_implicit_conversion_flags
12994 (ENUM_UNDERLYING_TYPE (enumtype), value, tf_warning_or_error,
12995 LOOKUP_IMPLICIT | LOOKUP_NO_NARROWING);
12997 if (value == error_mark_node)
12998 value = NULL_TREE;
13000 if (value != NULL_TREE)
13002 value = cxx_constant_value (value);
13004 if (TREE_CODE (value) != INTEGER_CST
13005 || ! INTEGRAL_OR_ENUMERATION_TYPE_P (TREE_TYPE (value)))
13007 error ("enumerator value for %qD is not an integer constant",
13008 name);
13009 value = NULL_TREE;
13014 /* Default based on previous value. */
13015 if (value == NULL_TREE)
13017 if (TYPE_VALUES (enumtype))
13019 tree prev_value;
13020 bool overflowed;
13022 /* C++03 7.2/4: If no initializer is specified for the first
13023 enumerator, the type is an unspecified integral
13024 type. Otherwise the type is the same as the type of the
13025 initializing value of the preceding enumerator unless the
13026 incremented value is not representable in that type, in
13027 which case the type is an unspecified integral type
13028 sufficient to contain the incremented value. */
13029 prev_value = DECL_INITIAL (TREE_VALUE (TYPE_VALUES (enumtype)));
13030 if (error_operand_p (prev_value))
13031 value = error_mark_node;
13032 else
13034 tree type = TREE_TYPE (prev_value);
13035 signop sgn = TYPE_SIGN (type);
13036 widest_int wi = wi::add (wi::to_widest (prev_value), 1, sgn,
13037 &overflowed);
13038 if (!overflowed)
13040 bool pos = !wi::neg_p (wi, sgn);
13041 if (!wi::fits_to_tree_p (wi, type))
13043 unsigned int itk;
13044 for (itk = itk_int; itk != itk_none; itk++)
13046 type = integer_types[itk];
13047 if (type != NULL_TREE
13048 && (pos || !TYPE_UNSIGNED (type))
13049 && wi::fits_to_tree_p (wi, type))
13050 break;
13052 if (type && cxx_dialect < cxx11
13053 && itk > itk_unsigned_long)
13054 pedwarn (input_location, OPT_Wlong_long, pos ? "\
13055 incremented enumerator value is too large for %<unsigned long%>" : "\
13056 incremented enumerator value is too large for %<long%>");
13058 if (type == NULL_TREE)
13059 overflowed = true;
13060 else
13061 value = wide_int_to_tree (type, wi);
13064 if (overflowed)
13066 error ("overflow in enumeration values at %qD", name);
13067 value = error_mark_node;
13071 else
13072 value = integer_zero_node;
13075 /* Remove no-op casts from the value. */
13076 STRIP_TYPE_NOPS (value);
13078 /* If the underlying type of the enum is fixed, check whether
13079 the enumerator values fits in the underlying type. If it
13080 does not fit, the program is ill-formed [C++0x dcl.enum]. */
13081 if (ENUM_UNDERLYING_TYPE (enumtype)
13082 && value
13083 && TREE_CODE (value) == INTEGER_CST)
13085 if (!int_fits_type_p (value, ENUM_UNDERLYING_TYPE (enumtype)))
13086 error ("enumerator value %E is outside the range of underlying "
13087 "type %<%T%>", value, ENUM_UNDERLYING_TYPE (enumtype));
13089 /* Convert the value to the appropriate type. */
13090 value = convert (ENUM_UNDERLYING_TYPE (enumtype), value);
13094 /* C++ associates enums with global, function, or class declarations. */
13095 context = current_scope ();
13097 /* Build the actual enumeration constant. Note that the enumeration
13098 constants have the underlying type of the enum (if it is fixed)
13099 or the type of their initializer (if the underlying type of the
13100 enum is not fixed):
13102 [ C++0x dcl.enum ]
13104 If the underlying type is fixed, the type of each enumerator
13105 prior to the closing brace is the underlying type; if the
13106 initializing value of an enumerator cannot be represented by
13107 the underlying type, the program is ill-formed. If the
13108 underlying type is not fixed, the type of each enumerator is
13109 the type of its initializing value.
13111 If the underlying type is not fixed, it will be computed by
13112 finish_enum and we will reset the type of this enumerator. Of
13113 course, if we're processing a template, there may be no value. */
13114 type = value ? TREE_TYPE (value) : NULL_TREE;
13116 decl = build_decl (loc, CONST_DECL, name, type);
13118 DECL_CONTEXT (decl) = enumtype;
13119 TREE_CONSTANT (decl) = 1;
13120 TREE_READONLY (decl) = 1;
13121 DECL_INITIAL (decl) = value;
13123 if (context && context == current_class_type && !SCOPED_ENUM_P (enumtype))
13124 /* In something like `struct S { enum E { i = 7 }; };' we put `i'
13125 on the TYPE_FIELDS list for `S'. (That's so that you can say
13126 things like `S::i' later.) */
13127 finish_member_declaration (decl);
13128 else
13129 pushdecl (decl);
13131 /* Add this enumeration constant to the list for this type. */
13132 TYPE_VALUES (enumtype) = tree_cons (name, decl, TYPE_VALUES (enumtype));
13135 /* Look for an enumerator with the given NAME within the enumeration
13136 type ENUMTYPE. This routine is used primarily for qualified name
13137 lookup into an enumerator in C++0x, e.g.,
13139 enum class Color { Red, Green, Blue };
13141 Color color = Color::Red;
13143 Returns the value corresponding to the enumerator, or
13144 NULL_TREE if no such enumerator was found. */
13145 tree
13146 lookup_enumerator (tree enumtype, tree name)
13148 tree e;
13149 gcc_assert (enumtype && TREE_CODE (enumtype) == ENUMERAL_TYPE);
13151 e = purpose_member (name, TYPE_VALUES (enumtype));
13152 return e? TREE_VALUE (e) : NULL_TREE;
13156 /* We're defining DECL. Make sure that its type is OK. */
13158 static void
13159 check_function_type (tree decl, tree current_function_parms)
13161 tree fntype = TREE_TYPE (decl);
13162 tree return_type = complete_type (TREE_TYPE (fntype));
13164 /* In a function definition, arg types must be complete. */
13165 require_complete_types_for_parms (current_function_parms);
13167 if (dependent_type_p (return_type)
13168 || type_uses_auto (return_type))
13169 return;
13170 if (!COMPLETE_OR_VOID_TYPE_P (return_type)
13171 || (TYPE_FOR_JAVA (return_type) && MAYBE_CLASS_TYPE_P (return_type)))
13173 tree args = TYPE_ARG_TYPES (fntype);
13175 if (!COMPLETE_OR_VOID_TYPE_P (return_type))
13176 error ("return type %q#T is incomplete", return_type);
13177 else
13178 error ("return type has Java class type %q#T", return_type);
13180 /* Make it return void instead. */
13181 if (TREE_CODE (fntype) == METHOD_TYPE)
13182 fntype = build_method_type_directly (TREE_TYPE (TREE_VALUE (args)),
13183 void_type_node,
13184 TREE_CHAIN (args));
13185 else
13186 fntype = build_function_type (void_type_node, args);
13187 fntype
13188 = build_exception_variant (fntype,
13189 TYPE_RAISES_EXCEPTIONS (TREE_TYPE (decl)));
13190 fntype = (cp_build_type_attribute_variant
13191 (fntype, TYPE_ATTRIBUTES (TREE_TYPE (decl))));
13192 TREE_TYPE (decl) = fntype;
13194 else
13195 abstract_virtuals_error (decl, TREE_TYPE (fntype));
13198 /* Create the FUNCTION_DECL for a function definition.
13199 DECLSPECS and DECLARATOR are the parts of the declaration;
13200 they describe the function's name and the type it returns,
13201 but twisted together in a fashion that parallels the syntax of C.
13203 FLAGS is a bitwise or of SF_PRE_PARSED (indicating that the
13204 DECLARATOR is really the DECL for the function we are about to
13205 process and that DECLSPECS should be ignored), SF_INCLASS_INLINE
13206 indicating that the function is an inline defined in-class.
13208 This function creates a binding context for the function body
13209 as well as setting up the FUNCTION_DECL in current_function_decl.
13211 For C++, we must first check whether that datum makes any sense.
13212 For example, "class A local_a(1,2);" means that variable local_a
13213 is an aggregate of type A, which should have a constructor
13214 applied to it with the argument list [1, 2].
13216 On entry, DECL_INITIAL (decl1) should be NULL_TREE or error_mark_node,
13217 or may be a BLOCK if the function has been defined previously
13218 in this translation unit. On exit, DECL_INITIAL (decl1) will be
13219 error_mark_node if the function has never been defined, or
13220 a BLOCK if the function has been defined somewhere. */
13222 bool
13223 start_preparsed_function (tree decl1, tree attrs, int flags)
13225 tree ctype = NULL_TREE;
13226 tree fntype;
13227 tree restype;
13228 int doing_friend = 0;
13229 cp_binding_level *bl;
13230 tree current_function_parms;
13231 struct c_fileinfo *finfo
13232 = get_fileinfo (LOCATION_FILE (DECL_SOURCE_LOCATION (decl1)));
13233 bool honor_interface;
13235 /* Sanity check. */
13236 gcc_assert (VOID_TYPE_P (TREE_VALUE (void_list_node)));
13237 gcc_assert (TREE_CHAIN (void_list_node) == NULL_TREE);
13239 fntype = TREE_TYPE (decl1);
13240 if (TREE_CODE (fntype) == METHOD_TYPE)
13241 ctype = TYPE_METHOD_BASETYPE (fntype);
13243 /* ISO C++ 11.4/5. A friend function defined in a class is in
13244 the (lexical) scope of the class in which it is defined. */
13245 if (!ctype && DECL_FRIEND_P (decl1))
13247 ctype = DECL_FRIEND_CONTEXT (decl1);
13249 /* CTYPE could be null here if we're dealing with a template;
13250 for example, `inline friend float foo()' inside a template
13251 will have no CTYPE set. */
13252 if (ctype && TREE_CODE (ctype) != RECORD_TYPE)
13253 ctype = NULL_TREE;
13254 else
13255 doing_friend = 1;
13258 if (DECL_DECLARED_INLINE_P (decl1)
13259 && lookup_attribute ("noinline", attrs))
13260 warning (0, "inline function %q+D given attribute noinline", decl1);
13262 /* Handle gnu_inline attribute. */
13263 if (GNU_INLINE_P (decl1))
13265 DECL_EXTERNAL (decl1) = 1;
13266 DECL_NOT_REALLY_EXTERN (decl1) = 0;
13267 DECL_INTERFACE_KNOWN (decl1) = 1;
13268 DECL_DISREGARD_INLINE_LIMITS (decl1) = 1;
13271 if (DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P (decl1))
13272 /* This is a constructor, we must ensure that any default args
13273 introduced by this definition are propagated to the clones
13274 now. The clones are used directly in overload resolution. */
13275 adjust_clone_args (decl1);
13277 /* Sometimes we don't notice that a function is a static member, and
13278 build a METHOD_TYPE for it. Fix that up now. */
13279 gcc_assert (!(ctype != NULL_TREE && DECL_STATIC_FUNCTION_P (decl1)
13280 && TREE_CODE (TREE_TYPE (decl1)) == METHOD_TYPE));
13282 /* Set up current_class_type, and enter the scope of the class, if
13283 appropriate. */
13284 if (ctype)
13285 push_nested_class (ctype);
13286 else if (DECL_STATIC_FUNCTION_P (decl1))
13287 push_nested_class (DECL_CONTEXT (decl1));
13289 /* Now that we have entered the scope of the class, we must restore
13290 the bindings for any template parameters surrounding DECL1, if it
13291 is an inline member template. (Order is important; consider the
13292 case where a template parameter has the same name as a field of
13293 the class.) It is not until after this point that
13294 PROCESSING_TEMPLATE_DECL is guaranteed to be set up correctly. */
13295 if (flags & SF_INCLASS_INLINE)
13296 maybe_begin_member_template_processing (decl1);
13298 /* Effective C++ rule 15. */
13299 if (warn_ecpp
13300 && DECL_OVERLOADED_OPERATOR_P (decl1) == NOP_EXPR
13301 && VOID_TYPE_P (TREE_TYPE (fntype)))
13302 warning (OPT_Weffc__, "%<operator=%> should return a reference to %<*this%>");
13304 /* Make the init_value nonzero so pushdecl knows this is not tentative.
13305 error_mark_node is replaced below (in poplevel) with the BLOCK. */
13306 if (!DECL_INITIAL (decl1))
13307 DECL_INITIAL (decl1) = error_mark_node;
13309 /* This function exists in static storage.
13310 (This does not mean `static' in the C sense!) */
13311 TREE_STATIC (decl1) = 1;
13313 /* We must call push_template_decl after current_class_type is set
13314 up. (If we are processing inline definitions after exiting a
13315 class scope, current_class_type will be NULL_TREE until set above
13316 by push_nested_class.) */
13317 if (processing_template_decl)
13319 tree newdecl1 = push_template_decl (decl1);
13320 if (newdecl1 == error_mark_node)
13322 if (ctype || DECL_STATIC_FUNCTION_P (decl1))
13323 pop_nested_class ();
13324 return false;
13326 decl1 = newdecl1;
13329 /* We are now in the scope of the function being defined. */
13330 current_function_decl = decl1;
13332 /* Save the parm names or decls from this function's declarator
13333 where store_parm_decls will find them. */
13334 current_function_parms = DECL_ARGUMENTS (decl1);
13336 /* Make sure the parameter and return types are reasonable. When
13337 you declare a function, these types can be incomplete, but they
13338 must be complete when you define the function. */
13339 check_function_type (decl1, current_function_parms);
13341 /* Build the return declaration for the function. */
13342 restype = TREE_TYPE (fntype);
13344 if (DECL_RESULT (decl1) == NULL_TREE)
13346 tree resdecl;
13348 resdecl = build_decl (input_location, RESULT_DECL, 0, restype);
13349 DECL_ARTIFICIAL (resdecl) = 1;
13350 DECL_IGNORED_P (resdecl) = 1;
13351 DECL_RESULT (decl1) = resdecl;
13353 cp_apply_type_quals_to_decl (cp_type_quals (restype), resdecl);
13356 /* Let the user know we're compiling this function. */
13357 announce_function (decl1);
13359 /* Record the decl so that the function name is defined.
13360 If we already have a decl for this name, and it is a FUNCTION_DECL,
13361 use the old decl. */
13362 if (!processing_template_decl && !(flags & SF_PRE_PARSED))
13364 /* A specialization is not used to guide overload resolution. */
13365 if (!DECL_FUNCTION_MEMBER_P (decl1)
13366 && !(DECL_USE_TEMPLATE (decl1) &&
13367 PRIMARY_TEMPLATE_P (DECL_TI_TEMPLATE (decl1))))
13369 tree olddecl = pushdecl (decl1);
13371 if (olddecl == error_mark_node)
13372 /* If something went wrong when registering the declaration,
13373 use DECL1; we have to have a FUNCTION_DECL to use when
13374 parsing the body of the function. */
13376 else
13378 /* Otherwise, OLDDECL is either a previous declaration
13379 of the same function or DECL1 itself. */
13381 if (warn_missing_declarations
13382 && olddecl == decl1
13383 && !DECL_MAIN_P (decl1)
13384 && TREE_PUBLIC (decl1)
13385 && !DECL_DECLARED_INLINE_P (decl1))
13387 tree context;
13389 /* Check whether DECL1 is in an anonymous
13390 namespace. */
13391 for (context = DECL_CONTEXT (decl1);
13392 context;
13393 context = DECL_CONTEXT (context))
13395 if (TREE_CODE (context) == NAMESPACE_DECL
13396 && DECL_NAME (context) == NULL_TREE)
13397 break;
13400 if (context == NULL)
13401 warning (OPT_Wmissing_declarations,
13402 "no previous declaration for %q+D", decl1);
13405 decl1 = olddecl;
13408 else
13410 /* We need to set the DECL_CONTEXT. */
13411 if (!DECL_CONTEXT (decl1) && DECL_TEMPLATE_INFO (decl1))
13412 DECL_CONTEXT (decl1) = DECL_CONTEXT (DECL_TI_TEMPLATE (decl1));
13414 fntype = TREE_TYPE (decl1);
13415 restype = TREE_TYPE (fntype);
13417 /* If #pragma weak applies, mark the decl appropriately now.
13418 The pragma only applies to global functions. Because
13419 determining whether or not the #pragma applies involves
13420 computing the mangled name for the declaration, we cannot
13421 apply the pragma until after we have merged this declaration
13422 with any previous declarations; if the original declaration
13423 has a linkage specification, that specification applies to
13424 the definition as well, and may affect the mangled name. */
13425 if (DECL_FILE_SCOPE_P (decl1))
13426 maybe_apply_pragma_weak (decl1);
13429 /* Reset this in case the call to pushdecl changed it. */
13430 current_function_decl = decl1;
13432 gcc_assert (DECL_INITIAL (decl1));
13434 /* This function may already have been parsed, in which case just
13435 return; our caller will skip over the body without parsing. */
13436 if (DECL_INITIAL (decl1) != error_mark_node)
13437 return true;
13439 /* Initialize RTL machinery. We cannot do this until
13440 CURRENT_FUNCTION_DECL and DECL_RESULT are set up. We do this
13441 even when processing a template; this is how we get
13442 CFUN set up, and our per-function variables initialized.
13443 FIXME factor out the non-RTL stuff. */
13444 bl = current_binding_level;
13445 allocate_struct_function (decl1, processing_template_decl);
13447 /* Initialize the language data structures. Whenever we start
13448 a new function, we destroy temporaries in the usual way. */
13449 cfun->language = ggc_cleared_alloc<language_function> ();
13450 current_stmt_tree ()->stmts_are_full_exprs_p = 1;
13451 current_binding_level = bl;
13453 if (!processing_template_decl && type_uses_auto (restype))
13455 FNDECL_USED_AUTO (decl1) = true;
13456 current_function_auto_return_pattern = restype;
13459 /* Start the statement-tree, start the tree now. */
13460 DECL_SAVED_TREE (decl1) = push_stmt_list ();
13462 /* If we are (erroneously) defining a function that we have already
13463 defined before, wipe out what we knew before. */
13464 if (!DECL_PENDING_INLINE_P (decl1))
13465 DECL_SAVED_FUNCTION_DATA (decl1) = NULL;
13467 if (ctype && !doing_friend && !DECL_STATIC_FUNCTION_P (decl1))
13469 /* We know that this was set up by `grokclassfn'. We do not
13470 wait until `store_parm_decls', since evil parse errors may
13471 never get us to that point. Here we keep the consistency
13472 between `current_class_type' and `current_class_ptr'. */
13473 tree t = DECL_ARGUMENTS (decl1);
13475 gcc_assert (t != NULL_TREE && TREE_CODE (t) == PARM_DECL);
13476 gcc_assert (TYPE_PTR_P (TREE_TYPE (t)));
13478 cp_function_chain->x_current_class_ref
13479 = cp_build_indirect_ref (t, RO_NULL, tf_warning_or_error);
13480 /* Set this second to avoid shortcut in cp_build_indirect_ref. */
13481 cp_function_chain->x_current_class_ptr = t;
13483 /* Constructors and destructors need to know whether they're "in
13484 charge" of initializing virtual base classes. */
13485 t = DECL_CHAIN (t);
13486 if (DECL_HAS_IN_CHARGE_PARM_P (decl1))
13488 current_in_charge_parm = t;
13489 t = DECL_CHAIN (t);
13491 if (DECL_HAS_VTT_PARM_P (decl1))
13493 gcc_assert (DECL_NAME (t) == vtt_parm_identifier);
13494 current_vtt_parm = t;
13498 honor_interface = (!DECL_TEMPLATE_INSTANTIATION (decl1)
13499 /* Implicitly-defined methods (like the
13500 destructor for a class in which no destructor
13501 is explicitly declared) must not be defined
13502 until their definition is needed. So, we
13503 ignore interface specifications for
13504 compiler-generated functions. */
13505 && !DECL_ARTIFICIAL (decl1));
13507 if (processing_template_decl)
13508 /* Don't mess with interface flags. */;
13509 else if (DECL_INTERFACE_KNOWN (decl1))
13511 tree ctx = decl_function_context (decl1);
13513 if (DECL_NOT_REALLY_EXTERN (decl1))
13514 DECL_EXTERNAL (decl1) = 0;
13516 if (ctx != NULL_TREE && vague_linkage_p (ctx))
13517 /* This is a function in a local class in an extern inline
13518 or template function. */
13519 comdat_linkage (decl1);
13521 /* If this function belongs to an interface, it is public.
13522 If it belongs to someone else's interface, it is also external.
13523 This only affects inlines and template instantiations. */
13524 else if (!finfo->interface_unknown && honor_interface)
13526 if (DECL_DECLARED_INLINE_P (decl1)
13527 || DECL_TEMPLATE_INSTANTIATION (decl1))
13529 DECL_EXTERNAL (decl1)
13530 = (finfo->interface_only
13531 || (DECL_DECLARED_INLINE_P (decl1)
13532 && ! flag_implement_inlines
13533 && !DECL_VINDEX (decl1)));
13535 /* For WIN32 we also want to put these in linkonce sections. */
13536 maybe_make_one_only (decl1);
13538 else
13539 DECL_EXTERNAL (decl1) = 0;
13540 DECL_INTERFACE_KNOWN (decl1) = 1;
13541 /* If this function is in an interface implemented in this file,
13542 make sure that the back end knows to emit this function
13543 here. */
13544 if (!DECL_EXTERNAL (decl1))
13545 mark_needed (decl1);
13547 else if (finfo->interface_unknown && finfo->interface_only
13548 && honor_interface)
13550 /* If MULTIPLE_SYMBOL_SPACES is defined and we saw a #pragma
13551 interface, we will have both finfo->interface_unknown and
13552 finfo->interface_only set. In that case, we don't want to
13553 use the normal heuristics because someone will supply a
13554 #pragma implementation elsewhere, and deducing it here would
13555 produce a conflict. */
13556 comdat_linkage (decl1);
13557 DECL_EXTERNAL (decl1) = 0;
13558 DECL_INTERFACE_KNOWN (decl1) = 1;
13559 DECL_DEFER_OUTPUT (decl1) = 1;
13561 else
13563 /* This is a definition, not a reference.
13564 So clear DECL_EXTERNAL, unless this is a GNU extern inline. */
13565 if (!GNU_INLINE_P (decl1))
13566 DECL_EXTERNAL (decl1) = 0;
13568 if ((DECL_DECLARED_INLINE_P (decl1)
13569 || DECL_TEMPLATE_INSTANTIATION (decl1))
13570 && ! DECL_INTERFACE_KNOWN (decl1))
13571 DECL_DEFER_OUTPUT (decl1) = 1;
13572 else
13573 DECL_INTERFACE_KNOWN (decl1) = 1;
13576 /* Determine the ELF visibility attribute for the function. We must not
13577 do this before calling "pushdecl", as we must allow "duplicate_decls"
13578 to merge any attributes appropriately. We also need to wait until
13579 linkage is set. */
13580 if (!DECL_CLONED_FUNCTION_P (decl1))
13581 determine_visibility (decl1);
13583 if (!processing_template_decl)
13584 maybe_instantiate_noexcept (decl1);
13586 begin_scope (sk_function_parms, decl1);
13588 ++function_depth;
13590 if (DECL_DESTRUCTOR_P (decl1)
13591 || (DECL_CONSTRUCTOR_P (decl1)
13592 && targetm.cxx.cdtor_returns_this ()))
13594 cdtor_label = build_decl (input_location,
13595 LABEL_DECL, NULL_TREE, NULL_TREE);
13596 DECL_CONTEXT (cdtor_label) = current_function_decl;
13599 start_fname_decls ();
13601 store_parm_decls (current_function_parms);
13603 return true;
13607 /* Like start_preparsed_function, except that instead of a
13608 FUNCTION_DECL, this function takes DECLSPECS and DECLARATOR.
13610 Returns true on success. If the DECLARATOR is not suitable
13611 for a function, we return false, which tells the parser to
13612 skip the entire function. */
13614 bool
13615 start_function (cp_decl_specifier_seq *declspecs,
13616 const cp_declarator *declarator,
13617 tree attrs)
13619 tree decl1;
13621 decl1 = grokdeclarator (declarator, declspecs, FUNCDEF, 1, &attrs);
13622 if (decl1 == error_mark_node)
13623 return false;
13624 /* If the declarator is not suitable for a function definition,
13625 cause a syntax error. */
13626 if (decl1 == NULL_TREE || TREE_CODE (decl1) != FUNCTION_DECL)
13628 error ("invalid function declaration");
13629 return false;
13632 if (DECL_MAIN_P (decl1))
13633 /* main must return int. grokfndecl should have corrected it
13634 (and issued a diagnostic) if the user got it wrong. */
13635 gcc_assert (same_type_p (TREE_TYPE (TREE_TYPE (decl1)),
13636 integer_type_node));
13638 return start_preparsed_function (decl1, attrs, /*flags=*/SF_DEFAULT);
13641 /* Returns true iff an EH_SPEC_BLOCK should be created in the body of
13642 FN. */
13644 static bool
13645 use_eh_spec_block (tree fn)
13647 return (flag_exceptions && flag_enforce_eh_specs
13648 && !processing_template_decl
13649 && !type_throw_all_p (TREE_TYPE (fn))
13650 /* We insert the EH_SPEC_BLOCK only in the original
13651 function; then, it is copied automatically to the
13652 clones. */
13653 && !DECL_CLONED_FUNCTION_P (fn)
13654 /* Implicitly-generated constructors and destructors have
13655 exception specifications. However, those specifications
13656 are the union of the possible exceptions specified by the
13657 constructors/destructors for bases and members, so no
13658 unallowed exception will ever reach this function. By
13659 not creating the EH_SPEC_BLOCK we save a little memory,
13660 and we avoid spurious warnings about unreachable
13661 code. */
13662 && !DECL_DEFAULTED_FN (fn));
13665 /* Store the parameter declarations into the current function declaration.
13666 This is called after parsing the parameter declarations, before
13667 digesting the body of the function.
13669 Also install to binding contour return value identifier, if any. */
13671 static void
13672 store_parm_decls (tree current_function_parms)
13674 tree fndecl = current_function_decl;
13675 tree parm;
13677 /* This is a chain of any other decls that came in among the parm
13678 declarations. If a parm is declared with enum {foo, bar} x;
13679 then CONST_DECLs for foo and bar are put here. */
13680 tree nonparms = NULL_TREE;
13682 if (current_function_parms)
13684 /* This case is when the function was defined with an ANSI prototype.
13685 The parms already have decls, so we need not do anything here
13686 except record them as in effect
13687 and complain if any redundant old-style parm decls were written. */
13689 tree specparms = current_function_parms;
13690 tree next;
13692 /* Must clear this because it might contain TYPE_DECLs declared
13693 at class level. */
13694 current_binding_level->names = NULL;
13696 /* If we're doing semantic analysis, then we'll call pushdecl
13697 for each of these. We must do them in reverse order so that
13698 they end in the correct forward order. */
13699 specparms = nreverse (specparms);
13701 for (parm = specparms; parm; parm = next)
13703 next = DECL_CHAIN (parm);
13704 if (TREE_CODE (parm) == PARM_DECL)
13706 if (DECL_NAME (parm) == NULL_TREE
13707 || !VOID_TYPE_P (parm))
13708 pushdecl (parm);
13709 else
13710 error ("parameter %qD declared void", parm);
13712 else
13714 /* If we find an enum constant or a type tag,
13715 put it aside for the moment. */
13716 TREE_CHAIN (parm) = NULL_TREE;
13717 nonparms = chainon (nonparms, parm);
13721 /* Get the decls in their original chain order and record in the
13722 function. This is all and only the PARM_DECLs that were
13723 pushed into scope by the loop above. */
13724 DECL_ARGUMENTS (fndecl) = getdecls ();
13726 else
13727 DECL_ARGUMENTS (fndecl) = NULL_TREE;
13729 /* Now store the final chain of decls for the arguments
13730 as the decl-chain of the current lexical scope.
13731 Put the enumerators in as well, at the front so that
13732 DECL_ARGUMENTS is not modified. */
13733 current_binding_level->names = chainon (nonparms, DECL_ARGUMENTS (fndecl));
13735 if (use_eh_spec_block (current_function_decl))
13736 current_eh_spec_block = begin_eh_spec_block ();
13740 /* We have finished doing semantic analysis on DECL, but have not yet
13741 generated RTL for its body. Save away our current state, so that
13742 when we want to generate RTL later we know what to do. */
13744 static void
13745 save_function_data (tree decl)
13747 struct language_function *f;
13749 /* Save the language-specific per-function data so that we can
13750 get it back when we really expand this function. */
13751 gcc_assert (!DECL_PENDING_INLINE_P (decl));
13753 /* Make a copy. */
13754 f = ggc_alloc<language_function> ();
13755 memcpy (f, cp_function_chain, sizeof (struct language_function));
13756 DECL_SAVED_FUNCTION_DATA (decl) = f;
13758 /* Clear out the bits we don't need. */
13759 f->base.x_stmt_tree.x_cur_stmt_list = NULL;
13760 f->bindings = NULL;
13761 f->x_local_names = NULL;
13762 f->base.local_typedefs = NULL;
13766 /* Set the return value of the constructor (if present). */
13768 static void
13769 finish_constructor_body (void)
13771 tree val;
13772 tree exprstmt;
13774 if (targetm.cxx.cdtor_returns_this ()
13775 && (! TYPE_FOR_JAVA (current_class_type)))
13777 /* Any return from a constructor will end up here. */
13778 add_stmt (build_stmt (input_location, LABEL_EXPR, cdtor_label));
13780 val = DECL_ARGUMENTS (current_function_decl);
13781 val = build2 (MODIFY_EXPR, TREE_TYPE (val),
13782 DECL_RESULT (current_function_decl), val);
13783 /* Return the address of the object. */
13784 exprstmt = build_stmt (input_location, RETURN_EXPR, val);
13785 add_stmt (exprstmt);
13789 /* Do all the processing for the beginning of a destructor; set up the
13790 vtable pointers and cleanups for bases and members. */
13792 static void
13793 begin_destructor_body (void)
13795 tree compound_stmt;
13797 /* If the CURRENT_CLASS_TYPE is incomplete, we will have already
13798 issued an error message. We still want to try to process the
13799 body of the function, but initialize_vtbl_ptrs will crash if
13800 TYPE_BINFO is NULL. */
13801 if (COMPLETE_TYPE_P (current_class_type))
13803 compound_stmt = begin_compound_stmt (0);
13804 /* Make all virtual function table pointers in non-virtual base
13805 classes point to CURRENT_CLASS_TYPE's virtual function
13806 tables. */
13807 initialize_vtbl_ptrs (current_class_ptr);
13808 finish_compound_stmt (compound_stmt);
13810 /* Insert a cleanup to let the back end know that the object is dead
13811 when we exit the destructor, either normally or via exception. */
13812 tree btype = CLASSTYPE_AS_BASE (current_class_type);
13813 tree clobber = build_constructor (btype, NULL);
13814 TREE_THIS_VOLATILE (clobber) = true;
13815 tree bref = build_nop (build_reference_type (btype), current_class_ptr);
13816 bref = convert_from_reference (bref);
13817 tree exprstmt = build2 (MODIFY_EXPR, btype, bref, clobber);
13818 finish_decl_cleanup (NULL_TREE, exprstmt);
13820 /* And insert cleanups for our bases and members so that they
13821 will be properly destroyed if we throw. */
13822 push_base_cleanups ();
13826 /* At the end of every destructor we generate code to delete the object if
13827 necessary. Do that now. */
13829 static void
13830 finish_destructor_body (void)
13832 tree exprstmt;
13834 /* Any return from a destructor will end up here; that way all base
13835 and member cleanups will be run when the function returns. */
13836 add_stmt (build_stmt (input_location, LABEL_EXPR, cdtor_label));
13838 /* In a virtual destructor, we must call delete. */
13839 if (DECL_VIRTUAL_P (current_function_decl))
13841 tree if_stmt;
13842 tree virtual_size = cxx_sizeof (current_class_type);
13844 /* [class.dtor]
13846 At the point of definition of a virtual destructor (including
13847 an implicit definition), non-placement operator delete shall
13848 be looked up in the scope of the destructor's class and if
13849 found shall be accessible and unambiguous. */
13850 exprstmt = build_op_delete_call (DELETE_EXPR, current_class_ptr,
13851 virtual_size,
13852 /*global_p=*/false,
13853 /*placement=*/NULL_TREE,
13854 /*alloc_fn=*/NULL_TREE,
13855 tf_warning_or_error);
13857 if_stmt = begin_if_stmt ();
13858 finish_if_stmt_cond (build2 (BIT_AND_EXPR, integer_type_node,
13859 current_in_charge_parm,
13860 integer_one_node),
13861 if_stmt);
13862 finish_expr_stmt (exprstmt);
13863 finish_then_clause (if_stmt);
13864 finish_if_stmt (if_stmt);
13867 if (targetm.cxx.cdtor_returns_this ())
13869 tree val;
13871 val = DECL_ARGUMENTS (current_function_decl);
13872 val = build2 (MODIFY_EXPR, TREE_TYPE (val),
13873 DECL_RESULT (current_function_decl), val);
13874 /* Return the address of the object. */
13875 exprstmt = build_stmt (input_location, RETURN_EXPR, val);
13876 add_stmt (exprstmt);
13880 /* Do the necessary processing for the beginning of a function body, which
13881 in this case includes member-initializers, but not the catch clauses of
13882 a function-try-block. Currently, this means opening a binding level
13883 for the member-initializers (in a ctor), member cleanups (in a dtor),
13884 and capture proxies (in a lambda operator()). */
13886 tree
13887 begin_function_body (void)
13889 tree stmt;
13891 if (! FUNCTION_NEEDS_BODY_BLOCK (current_function_decl))
13892 return NULL_TREE;
13894 if (processing_template_decl)
13895 /* Do nothing now. */;
13896 else
13897 /* Always keep the BLOCK node associated with the outermost pair of
13898 curly braces of a function. These are needed for correct
13899 operation of dwarfout.c. */
13900 keep_next_level (true);
13902 stmt = begin_compound_stmt (BCS_FN_BODY);
13904 if (processing_template_decl)
13905 /* Do nothing now. */;
13906 else if (DECL_DESTRUCTOR_P (current_function_decl))
13907 begin_destructor_body ();
13909 return stmt;
13912 /* Do the processing for the end of a function body. Currently, this means
13913 closing out the cleanups for fully-constructed bases and members, and in
13914 the case of the destructor, deleting the object if desired. Again, this
13915 is only meaningful for [cd]tors, since they are the only functions where
13916 there is a significant distinction between the main body and any
13917 function catch clauses. Handling, say, main() return semantics here
13918 would be wrong, as flowing off the end of a function catch clause for
13919 main() would also need to return 0. */
13921 void
13922 finish_function_body (tree compstmt)
13924 if (compstmt == NULL_TREE)
13925 return;
13927 /* Close the block. */
13928 finish_compound_stmt (compstmt);
13930 if (processing_template_decl)
13931 /* Do nothing now. */;
13932 else if (DECL_CONSTRUCTOR_P (current_function_decl))
13933 finish_constructor_body ();
13934 else if (DECL_DESTRUCTOR_P (current_function_decl))
13935 finish_destructor_body ();
13938 /* Given a function, returns the BLOCK corresponding to the outermost level
13939 of curly braces, skipping the artificial block created for constructor
13940 initializers. */
13942 tree
13943 outer_curly_brace_block (tree fndecl)
13945 tree block = BLOCK_SUBBLOCKS (DECL_INITIAL (fndecl));
13946 if (FUNCTION_NEEDS_BODY_BLOCK (current_function_decl))
13947 /* Skip the artificial function body block. */
13948 block = BLOCK_SUBBLOCKS (block);
13949 return block;
13952 /* If FNDECL is a class's key method, add the class to the list of
13953 keyed classes that should be emitted. */
13955 static void
13956 record_key_method_defined (tree fndecl)
13958 if (DECL_NONSTATIC_MEMBER_FUNCTION_P (fndecl)
13959 && DECL_VIRTUAL_P (fndecl)
13960 && !processing_template_decl)
13962 tree fnclass = DECL_CONTEXT (fndecl);
13963 if (fndecl == CLASSTYPE_KEY_METHOD (fnclass))
13964 keyed_classes = tree_cons (NULL_TREE, fnclass, keyed_classes);
13968 /* Subroutine of finish_function.
13969 Save the body of constexpr functions for possible
13970 future compile time evaluation. */
13972 static void
13973 maybe_save_function_definition (tree fun)
13975 if (!processing_template_decl
13976 && DECL_DECLARED_CONSTEXPR_P (fun)
13977 && !DECL_CLONED_FUNCTION_P (fun))
13978 register_constexpr_fundef (fun, DECL_SAVED_TREE (fun));
13981 /* Finish up a function declaration and compile that function
13982 all the way to assembler language output. The free the storage
13983 for the function definition.
13985 FLAGS is a bitwise or of the following values:
13986 2 - INCLASS_INLINE
13987 We just finished processing the body of an in-class inline
13988 function definition. (This processing will have taken place
13989 after the class definition is complete.) */
13991 tree
13992 finish_function (int flags)
13994 tree fndecl = current_function_decl;
13995 tree fntype, ctype = NULL_TREE;
13996 int inclass_inline = (flags & 2) != 0;
13998 /* When we get some parse errors, we can end up without a
13999 current_function_decl, so cope. */
14000 if (fndecl == NULL_TREE)
14001 return error_mark_node;
14003 if (c_dialect_objc ())
14004 objc_finish_function ();
14006 gcc_assert (!defer_mark_used_calls);
14007 defer_mark_used_calls = true;
14009 record_key_method_defined (fndecl);
14011 fntype = TREE_TYPE (fndecl);
14013 /* TREE_READONLY (fndecl) = 1;
14014 This caused &foo to be of type ptr-to-const-function
14015 which then got a warning when stored in a ptr-to-function variable. */
14017 gcc_assert (building_stmt_list_p ());
14018 /* The current function is being defined, so its DECL_INITIAL should
14019 be set, and unless there's a multiple definition, it should be
14020 error_mark_node. */
14021 gcc_assert (DECL_INITIAL (fndecl) == error_mark_node);
14023 /* For a cloned function, we've already got all the code we need;
14024 there's no need to add any extra bits. */
14025 if (!DECL_CLONED_FUNCTION_P (fndecl))
14027 /* Make it so that `main' always returns 0 by default. */
14028 if (DECL_MAIN_P (current_function_decl))
14029 finish_return_stmt (integer_zero_node);
14031 if (use_eh_spec_block (current_function_decl))
14032 finish_eh_spec_block (TYPE_RAISES_EXCEPTIONS
14033 (TREE_TYPE (current_function_decl)),
14034 current_eh_spec_block);
14037 /* If we're saving up tree structure, tie off the function now. */
14038 DECL_SAVED_TREE (fndecl) = pop_stmt_list (DECL_SAVED_TREE (fndecl));
14040 if (fn_contains_cilk_spawn_p (cfun) && !processing_template_decl)
14041 cfun->cilk_frame_decl = insert_cilk_frame (fndecl);
14043 finish_fname_decls ();
14045 /* If this function can't throw any exceptions, remember that. */
14046 if (!processing_template_decl
14047 && !cp_function_chain->can_throw
14048 && !flag_non_call_exceptions
14049 && !decl_replaceable_p (fndecl))
14050 TREE_NOTHROW (fndecl) = 1;
14052 /* This must come after expand_function_end because cleanups might
14053 have declarations (from inline functions) that need to go into
14054 this function's blocks. */
14056 /* If the current binding level isn't the outermost binding level
14057 for this function, either there is a bug, or we have experienced
14058 syntax errors and the statement tree is malformed. */
14059 if (current_binding_level->kind != sk_function_parms)
14061 /* Make sure we have already experienced errors. */
14062 gcc_assert (errorcount);
14064 /* Throw away the broken statement tree and extra binding
14065 levels. */
14066 DECL_SAVED_TREE (fndecl) = alloc_stmt_list ();
14068 while (current_binding_level->kind != sk_function_parms)
14070 if (current_binding_level->kind == sk_class)
14071 pop_nested_class ();
14072 else
14073 poplevel (0, 0, 0);
14076 poplevel (1, 0, 1);
14078 /* Statements should always be full-expressions at the outermost set
14079 of curly braces for a function. */
14080 gcc_assert (stmts_are_full_exprs_p ());
14082 /* If there are no return statements in a function with auto return type,
14083 the return type is void. But if the declared type is something like
14084 auto*, this is an error. */
14085 if (!processing_template_decl && FNDECL_USED_AUTO (fndecl)
14086 && TREE_TYPE (fntype) == current_function_auto_return_pattern)
14088 if (!is_auto (current_function_auto_return_pattern)
14089 && !current_function_returns_value && !current_function_returns_null)
14091 error ("no return statements in function returning %qT",
14092 current_function_auto_return_pattern);
14093 inform (input_location, "only plain %<auto%> return type can be "
14094 "deduced to %<void%>");
14096 apply_deduced_return_type (fndecl, void_type_node);
14097 fntype = TREE_TYPE (fndecl);
14100 /* Save constexpr function body before it gets munged by
14101 the NRV transformation. */
14102 maybe_save_function_definition (fndecl);
14104 /* Set up the named return value optimization, if we can. Candidate
14105 variables are selected in check_return_expr. */
14106 if (current_function_return_value)
14108 tree r = current_function_return_value;
14109 tree outer;
14111 if (r != error_mark_node
14112 /* This is only worth doing for fns that return in memory--and
14113 simpler, since we don't have to worry about promoted modes. */
14114 && aggregate_value_p (TREE_TYPE (TREE_TYPE (fndecl)), fndecl)
14115 /* Only allow this for variables declared in the outer scope of
14116 the function so we know that their lifetime always ends with a
14117 return; see g++.dg/opt/nrv6.C. We could be more flexible if
14118 we were to do this optimization in tree-ssa. */
14119 && (outer = outer_curly_brace_block (fndecl))
14120 && chain_member (r, BLOCK_VARS (outer)))
14121 finalize_nrv (&DECL_SAVED_TREE (fndecl), r, DECL_RESULT (fndecl));
14123 current_function_return_value = NULL_TREE;
14126 /* Remember that we were in class scope. */
14127 if (current_class_name)
14128 ctype = current_class_type;
14130 /* Must mark the RESULT_DECL as being in this function. */
14131 DECL_CONTEXT (DECL_RESULT (fndecl)) = fndecl;
14133 /* Set the BLOCK_SUPERCONTEXT of the outermost function scope to point
14134 to the FUNCTION_DECL node itself. */
14135 BLOCK_SUPERCONTEXT (DECL_INITIAL (fndecl)) = fndecl;
14137 /* Save away current state, if appropriate. */
14138 if (!processing_template_decl)
14139 save_function_data (fndecl);
14141 /* Complain if there's just no return statement. */
14142 if (warn_return_type
14143 && !VOID_TYPE_P (TREE_TYPE (fntype))
14144 && !dependent_type_p (TREE_TYPE (fntype))
14145 && !current_function_returns_value && !current_function_returns_null
14146 /* Don't complain if we abort or throw. */
14147 && !current_function_returns_abnormally
14148 /* Don't complain if there's an infinite loop. */
14149 && !current_function_infinite_loop
14150 /* Don't complain if we are declared noreturn. */
14151 && !TREE_THIS_VOLATILE (fndecl)
14152 && !DECL_NAME (DECL_RESULT (fndecl))
14153 && !TREE_NO_WARNING (fndecl)
14154 /* Structor return values (if any) are set by the compiler. */
14155 && !DECL_CONSTRUCTOR_P (fndecl)
14156 && !DECL_DESTRUCTOR_P (fndecl)
14157 && targetm.warn_func_return (fndecl))
14159 warning (OPT_Wreturn_type,
14160 "no return statement in function returning non-void");
14161 TREE_NO_WARNING (fndecl) = 1;
14164 /* Store the end of the function, so that we get good line number
14165 info for the epilogue. */
14166 cfun->function_end_locus = input_location;
14168 /* Complain about parameters that are only set, but never otherwise used. */
14169 if (warn_unused_but_set_parameter
14170 && !processing_template_decl
14171 && errorcount == unused_but_set_errorcount
14172 && !DECL_CLONED_FUNCTION_P (fndecl))
14174 tree decl;
14176 for (decl = DECL_ARGUMENTS (fndecl);
14177 decl;
14178 decl = DECL_CHAIN (decl))
14179 if (TREE_USED (decl)
14180 && TREE_CODE (decl) == PARM_DECL
14181 && !DECL_READ_P (decl)
14182 && DECL_NAME (decl)
14183 && !DECL_ARTIFICIAL (decl)
14184 && !TREE_NO_WARNING (decl)
14185 && !DECL_IN_SYSTEM_HEADER (decl)
14186 && TREE_TYPE (decl) != error_mark_node
14187 && TREE_CODE (TREE_TYPE (decl)) != REFERENCE_TYPE
14188 && (!CLASS_TYPE_P (TREE_TYPE (decl))
14189 || !TYPE_HAS_NONTRIVIAL_DESTRUCTOR (TREE_TYPE (decl))))
14190 warning (OPT_Wunused_but_set_parameter,
14191 "parameter %q+D set but not used", decl);
14192 unused_but_set_errorcount = errorcount;
14195 /* Complain about locally defined typedefs that are not used in this
14196 function. */
14197 maybe_warn_unused_local_typedefs ();
14199 /* Genericize before inlining. */
14200 if (!processing_template_decl)
14202 struct language_function *f = DECL_SAVED_FUNCTION_DATA (fndecl);
14203 invoke_plugin_callbacks (PLUGIN_PRE_GENERICIZE, fndecl);
14204 cp_genericize (fndecl);
14205 /* Clear out the bits we don't need. */
14206 f->x_current_class_ptr = NULL;
14207 f->x_current_class_ref = NULL;
14208 f->x_eh_spec_block = NULL;
14209 f->x_in_charge_parm = NULL;
14210 f->x_vtt_parm = NULL;
14211 f->x_return_value = NULL;
14212 f->bindings = NULL;
14213 f->extern_decl_map = NULL;
14214 f->infinite_loops = NULL;
14216 /* Clear out the bits we don't need. */
14217 local_names = NULL;
14219 /* We're leaving the context of this function, so zap cfun. It's still in
14220 DECL_STRUCT_FUNCTION, and we'll restore it in tree_rest_of_compilation. */
14221 set_cfun (NULL);
14222 current_function_decl = NULL;
14224 /* If this is an in-class inline definition, we may have to pop the
14225 bindings for the template parameters that we added in
14226 maybe_begin_member_template_processing when start_function was
14227 called. */
14228 if (inclass_inline)
14229 maybe_end_member_template_processing ();
14231 /* Leave the scope of the class. */
14232 if (ctype)
14233 pop_nested_class ();
14235 --function_depth;
14237 /* Clean up. */
14238 current_function_decl = NULL_TREE;
14240 defer_mark_used_calls = false;
14241 if (deferred_mark_used_calls)
14243 unsigned int i;
14244 tree decl;
14246 FOR_EACH_VEC_SAFE_ELT (deferred_mark_used_calls, i, decl)
14247 mark_used (decl);
14248 vec_free (deferred_mark_used_calls);
14251 return fndecl;
14254 /* Create the FUNCTION_DECL for a function definition.
14255 DECLSPECS and DECLARATOR are the parts of the declaration;
14256 they describe the return type and the name of the function,
14257 but twisted together in a fashion that parallels the syntax of C.
14259 This function creates a binding context for the function body
14260 as well as setting up the FUNCTION_DECL in current_function_decl.
14262 Returns a FUNCTION_DECL on success.
14264 If the DECLARATOR is not suitable for a function (it defines a datum
14265 instead), we return 0, which tells yyparse to report a parse error.
14267 May return void_type_node indicating that this method is actually
14268 a friend. See grokfield for more details.
14270 Came here with a `.pushlevel' .
14272 DO NOT MAKE ANY CHANGES TO THIS CODE WITHOUT MAKING CORRESPONDING
14273 CHANGES TO CODE IN `grokfield'. */
14275 tree
14276 grokmethod (cp_decl_specifier_seq *declspecs,
14277 const cp_declarator *declarator, tree attrlist)
14279 tree fndecl = grokdeclarator (declarator, declspecs, MEMFUNCDEF, 0,
14280 &attrlist);
14282 if (fndecl == error_mark_node)
14283 return error_mark_node;
14285 if (fndecl == NULL || TREE_CODE (fndecl) != FUNCTION_DECL)
14287 error ("invalid member function declaration");
14288 return error_mark_node;
14291 if (attrlist)
14292 cplus_decl_attributes (&fndecl, attrlist, 0);
14294 /* Pass friends other than inline friend functions back. */
14295 if (fndecl == void_type_node)
14296 return fndecl;
14298 if (DECL_IN_AGGR_P (fndecl))
14300 if (DECL_CLASS_SCOPE_P (fndecl))
14301 error ("%qD is already defined in class %qT", fndecl,
14302 DECL_CONTEXT (fndecl));
14303 return error_mark_node;
14306 check_template_shadow (fndecl);
14308 DECL_COMDAT (fndecl) = 1;
14309 DECL_DECLARED_INLINE_P (fndecl) = 1;
14310 DECL_NO_INLINE_WARNING_P (fndecl) = 1;
14312 /* We process method specializations in finish_struct_1. */
14313 if (processing_template_decl && !DECL_TEMPLATE_SPECIALIZATION (fndecl))
14315 fndecl = push_template_decl (fndecl);
14316 if (fndecl == error_mark_node)
14317 return fndecl;
14320 if (! DECL_FRIEND_P (fndecl))
14322 if (DECL_CHAIN (fndecl))
14324 fndecl = copy_node (fndecl);
14325 TREE_CHAIN (fndecl) = NULL_TREE;
14329 cp_finish_decl (fndecl, NULL_TREE, false, NULL_TREE, 0);
14331 DECL_IN_AGGR_P (fndecl) = 1;
14332 return fndecl;
14336 /* VAR is a VAR_DECL. If its type is incomplete, remember VAR so that
14337 we can lay it out later, when and if its type becomes complete.
14339 Also handle constexpr variables where the initializer involves
14340 an unlowered PTRMEM_CST because the class isn't complete yet. */
14342 void
14343 maybe_register_incomplete_var (tree var)
14345 gcc_assert (VAR_P (var));
14347 /* Keep track of variables with incomplete types. */
14348 if (!processing_template_decl && TREE_TYPE (var) != error_mark_node
14349 && DECL_EXTERNAL (var))
14351 tree inner_type = TREE_TYPE (var);
14353 while (TREE_CODE (inner_type) == ARRAY_TYPE)
14354 inner_type = TREE_TYPE (inner_type);
14355 inner_type = TYPE_MAIN_VARIANT (inner_type);
14357 if ((!COMPLETE_TYPE_P (inner_type) && CLASS_TYPE_P (inner_type))
14358 /* RTTI TD entries are created while defining the type_info. */
14359 || (TYPE_LANG_SPECIFIC (inner_type)
14360 && TYPE_BEING_DEFINED (inner_type)))
14362 incomplete_var iv = {var, inner_type};
14363 vec_safe_push (incomplete_vars, iv);
14365 else if (!(DECL_LANG_SPECIFIC (var) && DECL_TEMPLATE_INFO (var))
14366 && decl_constant_var_p (var)
14367 && (TYPE_PTRMEM_P (inner_type) || CLASS_TYPE_P (inner_type)))
14369 /* When the outermost open class is complete we can resolve any
14370 pointers-to-members. */
14371 tree context = outermost_open_class ();
14372 incomplete_var iv = {var, context};
14373 vec_safe_push (incomplete_vars, iv);
14378 /* Called when a class type (given by TYPE) is defined. If there are
14379 any existing VAR_DECLs whose type has been completed by this
14380 declaration, update them now. */
14382 void
14383 complete_vars (tree type)
14385 unsigned ix;
14386 incomplete_var *iv;
14388 for (ix = 0; vec_safe_iterate (incomplete_vars, ix, &iv); )
14390 if (same_type_p (type, iv->incomplete_type))
14392 tree var = iv->decl;
14393 tree type = TREE_TYPE (var);
14395 if (TYPE_MAIN_VARIANT (strip_array_types (type))
14396 == iv->incomplete_type)
14398 /* Complete the type of the variable. The VAR_DECL itself
14399 will be laid out in expand_expr. */
14400 complete_type (type);
14401 cp_apply_type_quals_to_decl (cp_type_quals (type), var);
14404 if (DECL_INITIAL (var)
14405 && decl_constant_var_p (var))
14406 DECL_INITIAL (var) = cplus_expand_constant (DECL_INITIAL (var));
14408 /* Remove this entry from the list. */
14409 incomplete_vars->unordered_remove (ix);
14411 else
14412 ix++;
14415 /* Check for pending declarations which may have abstract type. */
14416 complete_type_check_abstract (type);
14419 /* If DECL is of a type which needs a cleanup, build and return an
14420 expression to perform that cleanup here. Return NULL_TREE if no
14421 cleanup need be done. */
14423 tree
14424 cxx_maybe_build_cleanup (tree decl, tsubst_flags_t complain)
14426 tree type;
14427 tree attr;
14428 tree cleanup;
14430 /* Assume no cleanup is required. */
14431 cleanup = NULL_TREE;
14433 if (error_operand_p (decl))
14434 return cleanup;
14436 /* Handle "__attribute__((cleanup))". We run the cleanup function
14437 before the destructor since the destructor is what actually
14438 terminates the lifetime of the object. */
14439 attr = lookup_attribute ("cleanup", DECL_ATTRIBUTES (decl));
14440 if (attr)
14442 tree id;
14443 tree fn;
14444 tree arg;
14446 /* Get the name specified by the user for the cleanup function. */
14447 id = TREE_VALUE (TREE_VALUE (attr));
14448 /* Look up the name to find the cleanup function to call. It is
14449 important to use lookup_name here because that is what is
14450 used in c-common.c:handle_cleanup_attribute when performing
14451 initial checks on the attribute. Note that those checks
14452 include ensuring that the function found is not an overloaded
14453 function, or an object with an overloaded call operator,
14454 etc.; we can rely on the fact that the function found is an
14455 ordinary FUNCTION_DECL. */
14456 fn = lookup_name (id);
14457 arg = build_address (decl);
14458 mark_used (decl);
14459 cleanup = cp_build_function_call_nary (fn, complain, arg, NULL_TREE);
14460 if (cleanup == error_mark_node)
14461 return error_mark_node;
14463 /* Handle ordinary C++ destructors. */
14464 type = TREE_TYPE (decl);
14465 if (type_build_dtor_call (type))
14467 int flags = LOOKUP_NORMAL|LOOKUP_NONVIRTUAL|LOOKUP_DESTRUCTOR;
14468 tree addr;
14469 tree call;
14471 if (TREE_CODE (type) == ARRAY_TYPE)
14472 addr = decl;
14473 else
14474 addr = build_address (decl);
14476 call = build_delete (TREE_TYPE (addr), addr,
14477 sfk_complete_destructor, flags, 0, complain);
14478 if (call == error_mark_node)
14479 cleanup = error_mark_node;
14480 else if (TYPE_HAS_TRIVIAL_DESTRUCTOR (type))
14481 /* Discard the call. */;
14482 else if (cleanup)
14483 cleanup = cp_build_compound_expr (cleanup, call, complain);
14484 else
14485 cleanup = call;
14488 /* build_delete sets the location of the destructor call to the
14489 current location, even though the destructor is going to be
14490 called later, at the end of the current scope. This can lead to
14491 a "jumpy" behaviour for users of debuggers when they step around
14492 the end of the block. So let's unset the location of the
14493 destructor call instead. */
14494 if (cleanup != NULL && EXPR_P (cleanup))
14495 SET_EXPR_LOCATION (cleanup, UNKNOWN_LOCATION);
14497 if (cleanup
14498 && !lookup_attribute ("warn_unused", TYPE_ATTRIBUTES (TREE_TYPE (decl))))
14499 /* Treat objects with destructors as used; the destructor may do
14500 something substantive. */
14501 mark_used (decl);
14503 return cleanup;
14507 /* Return the FUNCTION_TYPE that corresponds to MEMFNTYPE, which can be a
14508 FUNCTION_DECL, METHOD_TYPE, FUNCTION_TYPE, pointer or reference to
14509 METHOD_TYPE or FUNCTION_TYPE, or pointer to member function. */
14511 tree
14512 static_fn_type (tree memfntype)
14514 tree fntype;
14515 tree args;
14517 if (TYPE_PTRMEMFUNC_P (memfntype))
14518 memfntype = TYPE_PTRMEMFUNC_FN_TYPE (memfntype);
14519 if (POINTER_TYPE_P (memfntype)
14520 || TREE_CODE (memfntype) == FUNCTION_DECL)
14521 memfntype = TREE_TYPE (memfntype);
14522 if (TREE_CODE (memfntype) == FUNCTION_TYPE)
14523 return memfntype;
14524 gcc_assert (TREE_CODE (memfntype) == METHOD_TYPE);
14525 args = TYPE_ARG_TYPES (memfntype);
14526 cp_ref_qualifier rqual = type_memfn_rqual (memfntype);
14527 fntype = build_function_type (TREE_TYPE (memfntype), TREE_CHAIN (args));
14528 fntype = apply_memfn_quals (fntype, type_memfn_quals (memfntype), rqual);
14529 fntype = (cp_build_type_attribute_variant
14530 (fntype, TYPE_ATTRIBUTES (memfntype)));
14531 fntype = (build_exception_variant
14532 (fntype, TYPE_RAISES_EXCEPTIONS (memfntype)));
14533 if (TYPE_HAS_LATE_RETURN_TYPE (memfntype))
14534 TYPE_HAS_LATE_RETURN_TYPE (fntype) = 1;
14535 return fntype;
14538 /* DECL was originally constructed as a non-static member function,
14539 but turned out to be static. Update it accordingly. */
14541 void
14542 revert_static_member_fn (tree decl)
14544 tree stype = static_fn_type (decl);
14545 cp_cv_quals quals = type_memfn_quals (stype);
14546 cp_ref_qualifier rqual = type_memfn_rqual (stype);
14548 if (quals != TYPE_UNQUALIFIED || rqual != REF_QUAL_NONE)
14549 stype = apply_memfn_quals (stype, TYPE_UNQUALIFIED, REF_QUAL_NONE);
14551 TREE_TYPE (decl) = stype;
14553 if (DECL_ARGUMENTS (decl))
14554 DECL_ARGUMENTS (decl) = DECL_CHAIN (DECL_ARGUMENTS (decl));
14555 DECL_STATIC_FUNCTION_P (decl) = 1;
14558 /* Return which tree structure is used by T, or TS_CP_GENERIC if T is
14559 one of the language-independent trees. */
14561 enum cp_tree_node_structure_enum
14562 cp_tree_node_structure (union lang_tree_node * t)
14564 switch (TREE_CODE (&t->generic))
14566 case DEFAULT_ARG: return TS_CP_DEFAULT_ARG;
14567 case DEFERRED_NOEXCEPT: return TS_CP_DEFERRED_NOEXCEPT;
14568 case IDENTIFIER_NODE: return TS_CP_IDENTIFIER;
14569 case OVERLOAD: return TS_CP_OVERLOAD;
14570 case TEMPLATE_PARM_INDEX: return TS_CP_TPI;
14571 case PTRMEM_CST: return TS_CP_PTRMEM;
14572 case BASELINK: return TS_CP_BASELINK;
14573 case TEMPLATE_DECL: return TS_CP_TEMPLATE_DECL;
14574 case STATIC_ASSERT: return TS_CP_STATIC_ASSERT;
14575 case ARGUMENT_PACK_SELECT: return TS_CP_ARGUMENT_PACK_SELECT;
14576 case TRAIT_EXPR: return TS_CP_TRAIT_EXPR;
14577 case LAMBDA_EXPR: return TS_CP_LAMBDA_EXPR;
14578 case TEMPLATE_INFO: return TS_CP_TEMPLATE_INFO;
14579 case USERDEF_LITERAL: return TS_CP_USERDEF_LITERAL;
14580 default: return TS_CP_GENERIC;
14584 /* Build the void_list_node (void_type_node having been created). */
14585 tree
14586 build_void_list_node (void)
14588 tree t = build_tree_list (NULL_TREE, void_type_node);
14589 return t;
14592 bool
14593 cp_missing_noreturn_ok_p (tree decl)
14595 /* A missing noreturn is ok for the `main' function. */
14596 return DECL_MAIN_P (decl);
14599 /* Return the decl used to identify the COMDAT group into which DECL should
14600 be placed. */
14602 tree
14603 cxx_comdat_group (tree decl)
14605 /* Virtual tables, construction virtual tables, and virtual table
14606 tables all go in a single COMDAT group, named after the primary
14607 virtual table. */
14608 if (VAR_P (decl) && DECL_VTABLE_OR_VTT_P (decl))
14609 decl = CLASSTYPE_VTABLES (DECL_CONTEXT (decl));
14610 /* For all other DECLs, the COMDAT group is the mangled name of the
14611 declaration itself. */
14612 else
14614 while (DECL_THUNK_P (decl))
14616 /* If TARGET_USE_LOCAL_THUNK_ALIAS_P, use_thunk puts the thunk
14617 into the same section as the target function. In that case
14618 we must return target's name. */
14619 tree target = THUNK_TARGET (decl);
14620 if (TARGET_USE_LOCAL_THUNK_ALIAS_P (target)
14621 && DECL_SECTION_NAME (target) != NULL
14622 && DECL_ONE_ONLY (target))
14623 decl = target;
14624 else
14625 break;
14629 return decl;
14632 /* Returns the return type for FN as written by the user, which may include
14633 a placeholder for a deduced return type. */
14635 tree
14636 fndecl_declared_return_type (tree fn)
14638 fn = STRIP_TEMPLATE (fn);
14639 if (FNDECL_USED_AUTO (fn))
14641 struct language_function *f = NULL;
14642 if (DECL_STRUCT_FUNCTION (fn))
14643 f = DECL_STRUCT_FUNCTION (fn)->language;
14644 if (f == NULL)
14645 f = DECL_SAVED_FUNCTION_DATA (fn);
14646 return f->x_auto_return_pattern;
14648 return TREE_TYPE (TREE_TYPE (fn));
14651 /* Returns true iff DECL was declared with an auto return type and it has
14652 not yet been deduced to a real type. */
14654 bool
14655 undeduced_auto_decl (tree decl)
14657 if (cxx_dialect < cxx14)
14658 return false;
14659 return type_uses_auto (TREE_TYPE (decl));
14662 /* Complain if DECL has an undeduced return type. */
14664 void
14665 require_deduced_type (tree decl)
14667 if (undeduced_auto_decl (decl))
14668 error ("use of %qD before deduction of %<auto%>", decl);
14671 #include "gt-cp-decl.h"