[AArch64 Testsuite] Add a test of vldN_dup intrinsics
[official-gcc.git] / gcc / cp / class.c
blob09f946fcdf7c45eef7c09dffe99ee71ed49c18a3
1 /* Functions related to building classes and their related objects.
2 Copyright (C) 1987-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 /* High-level class interface. */
24 #include "config.h"
25 #include "system.h"
26 #include "coretypes.h"
27 #include "tm.h"
28 #include "tree.h"
29 #include "stringpool.h"
30 #include "stor-layout.h"
31 #include "attribs.h"
32 #include "hash-table.h"
33 #include "cp-tree.h"
34 #include "flags.h"
35 #include "toplev.h"
36 #include "target.h"
37 #include "convert.h"
38 #include "cgraph.h"
39 #include "dumpfile.h"
40 #include "splay-tree.h"
41 #include "gimplify.h"
42 #include "wide-int.h"
44 /* The number of nested classes being processed. If we are not in the
45 scope of any class, this is zero. */
47 int current_class_depth;
49 /* In order to deal with nested classes, we keep a stack of classes.
50 The topmost entry is the innermost class, and is the entry at index
51 CURRENT_CLASS_DEPTH */
53 typedef struct class_stack_node {
54 /* The name of the class. */
55 tree name;
57 /* The _TYPE node for the class. */
58 tree type;
60 /* The access specifier pending for new declarations in the scope of
61 this class. */
62 tree access;
64 /* If were defining TYPE, the names used in this class. */
65 splay_tree names_used;
67 /* Nonzero if this class is no longer open, because of a call to
68 push_to_top_level. */
69 size_t hidden;
70 }* class_stack_node_t;
72 typedef struct vtbl_init_data_s
74 /* The base for which we're building initializers. */
75 tree binfo;
76 /* The type of the most-derived type. */
77 tree derived;
78 /* The binfo for the dynamic type. This will be TYPE_BINFO (derived),
79 unless ctor_vtbl_p is true. */
80 tree rtti_binfo;
81 /* The negative-index vtable initializers built up so far. These
82 are in order from least negative index to most negative index. */
83 vec<constructor_elt, va_gc> *inits;
84 /* The binfo for the virtual base for which we're building
85 vcall offset initializers. */
86 tree vbase;
87 /* The functions in vbase for which we have already provided vcall
88 offsets. */
89 vec<tree, va_gc> *fns;
90 /* The vtable index of the next vcall or vbase offset. */
91 tree index;
92 /* Nonzero if we are building the initializer for the primary
93 vtable. */
94 int primary_vtbl_p;
95 /* Nonzero if we are building the initializer for a construction
96 vtable. */
97 int ctor_vtbl_p;
98 /* True when adding vcall offset entries to the vtable. False when
99 merely computing the indices. */
100 bool generate_vcall_entries;
101 } vtbl_init_data;
103 /* The type of a function passed to walk_subobject_offsets. */
104 typedef int (*subobject_offset_fn) (tree, tree, splay_tree);
106 /* The stack itself. This is a dynamically resized array. The
107 number of elements allocated is CURRENT_CLASS_STACK_SIZE. */
108 static int current_class_stack_size;
109 static class_stack_node_t current_class_stack;
111 /* The size of the largest empty class seen in this translation unit. */
112 static GTY (()) tree sizeof_biggest_empty_class;
114 /* An array of all local classes present in this translation unit, in
115 declaration order. */
116 vec<tree, va_gc> *local_classes;
118 static tree get_vfield_name (tree);
119 static void finish_struct_anon (tree);
120 static tree get_vtable_name (tree);
121 static tree get_basefndecls (tree, tree);
122 static int build_primary_vtable (tree, tree);
123 static int build_secondary_vtable (tree);
124 static void finish_vtbls (tree);
125 static void modify_vtable_entry (tree, tree, tree, tree, tree *);
126 static void finish_struct_bits (tree);
127 static int alter_access (tree, tree, tree);
128 static void handle_using_decl (tree, tree);
129 static tree dfs_modify_vtables (tree, void *);
130 static tree modify_all_vtables (tree, tree);
131 static void determine_primary_bases (tree);
132 static void finish_struct_methods (tree);
133 static void maybe_warn_about_overly_private_class (tree);
134 static int method_name_cmp (const void *, const void *);
135 static int resort_method_name_cmp (const void *, const void *);
136 static void add_implicitly_declared_members (tree, tree*, int, int);
137 static tree fixed_type_or_null (tree, int *, int *);
138 static tree build_simple_base_path (tree expr, tree binfo);
139 static tree build_vtbl_ref_1 (tree, tree);
140 static void build_vtbl_initializer (tree, tree, tree, tree, int *,
141 vec<constructor_elt, va_gc> **);
142 static int count_fields (tree);
143 static int add_fields_to_record_type (tree, struct sorted_fields_type*, int);
144 static void insert_into_classtype_sorted_fields (tree, tree, int);
145 static bool check_bitfield_decl (tree);
146 static void check_field_decl (tree, tree, int *, int *, int *);
147 static void check_field_decls (tree, tree *, int *, int *);
148 static tree *build_base_field (record_layout_info, tree, splay_tree, tree *);
149 static void build_base_fields (record_layout_info, splay_tree, tree *);
150 static void check_methods (tree);
151 static void remove_zero_width_bit_fields (tree);
152 static bool accessible_nvdtor_p (tree);
153 static void check_bases (tree, int *, int *);
154 static void check_bases_and_members (tree);
155 static tree create_vtable_ptr (tree, tree *);
156 static void include_empty_classes (record_layout_info);
157 static void layout_class_type (tree, tree *);
158 static void propagate_binfo_offsets (tree, tree);
159 static void layout_virtual_bases (record_layout_info, splay_tree);
160 static void build_vbase_offset_vtbl_entries (tree, vtbl_init_data *);
161 static void add_vcall_offset_vtbl_entries_r (tree, vtbl_init_data *);
162 static void add_vcall_offset_vtbl_entries_1 (tree, vtbl_init_data *);
163 static void build_vcall_offset_vtbl_entries (tree, vtbl_init_data *);
164 static void add_vcall_offset (tree, tree, vtbl_init_data *);
165 static void layout_vtable_decl (tree, int);
166 static tree dfs_find_final_overrider_pre (tree, void *);
167 static tree dfs_find_final_overrider_post (tree, void *);
168 static tree find_final_overrider (tree, tree, tree);
169 static int make_new_vtable (tree, tree);
170 static tree get_primary_binfo (tree);
171 static int maybe_indent_hierarchy (FILE *, int, int);
172 static tree dump_class_hierarchy_r (FILE *, int, tree, tree, int);
173 static void dump_class_hierarchy (tree);
174 static void dump_class_hierarchy_1 (FILE *, int, tree);
175 static void dump_array (FILE *, tree);
176 static void dump_vtable (tree, tree, tree);
177 static void dump_vtt (tree, tree);
178 static void dump_thunk (FILE *, int, tree);
179 static tree build_vtable (tree, tree, tree);
180 static void initialize_vtable (tree, vec<constructor_elt, va_gc> *);
181 static void layout_nonempty_base_or_field (record_layout_info,
182 tree, tree, splay_tree);
183 static tree end_of_class (tree, int);
184 static bool layout_empty_base (record_layout_info, tree, tree, splay_tree);
185 static void accumulate_vtbl_inits (tree, tree, tree, tree, tree,
186 vec<constructor_elt, va_gc> **);
187 static void dfs_accumulate_vtbl_inits (tree, tree, tree, tree, tree,
188 vec<constructor_elt, va_gc> **);
189 static void build_rtti_vtbl_entries (tree, vtbl_init_data *);
190 static void build_vcall_and_vbase_vtbl_entries (tree, vtbl_init_data *);
191 static void clone_constructors_and_destructors (tree);
192 static tree build_clone (tree, tree);
193 static void update_vtable_entry_for_fn (tree, tree, tree, tree *, unsigned);
194 static void build_ctor_vtbl_group (tree, tree);
195 static void build_vtt (tree);
196 static tree binfo_ctor_vtable (tree);
197 static void build_vtt_inits (tree, tree, vec<constructor_elt, va_gc> **,
198 tree *);
199 static tree dfs_build_secondary_vptr_vtt_inits (tree, void *);
200 static tree dfs_fixup_binfo_vtbls (tree, void *);
201 static int record_subobject_offset (tree, tree, splay_tree);
202 static int check_subobject_offset (tree, tree, splay_tree);
203 static int walk_subobject_offsets (tree, subobject_offset_fn,
204 tree, splay_tree, tree, int);
205 static void record_subobject_offsets (tree, tree, splay_tree, bool);
206 static int layout_conflict_p (tree, tree, splay_tree, int);
207 static int splay_tree_compare_integer_csts (splay_tree_key k1,
208 splay_tree_key k2);
209 static void warn_about_ambiguous_bases (tree);
210 static bool type_requires_array_cookie (tree);
211 static bool base_derived_from (tree, tree);
212 static int empty_base_at_nonzero_offset_p (tree, tree, splay_tree);
213 static tree end_of_base (tree);
214 static tree get_vcall_index (tree, tree);
216 /* Variables shared between class.c and call.c. */
218 int n_vtables = 0;
219 int n_vtable_entries = 0;
220 int n_vtable_searches = 0;
221 int n_vtable_elems = 0;
222 int n_convert_harshness = 0;
223 int n_compute_conversion_costs = 0;
224 int n_inner_fields_searched = 0;
226 /* Convert to or from a base subobject. EXPR is an expression of type
227 `A' or `A*', an expression of type `B' or `B*' is returned. To
228 convert A to a base B, CODE is PLUS_EXPR and BINFO is the binfo for
229 the B base instance within A. To convert base A to derived B, CODE
230 is MINUS_EXPR and BINFO is the binfo for the A instance within B.
231 In this latter case, A must not be a morally virtual base of B.
232 NONNULL is true if EXPR is known to be non-NULL (this is only
233 needed when EXPR is of pointer type). CV qualifiers are preserved
234 from EXPR. */
236 tree
237 build_base_path (enum tree_code code,
238 tree expr,
239 tree binfo,
240 int nonnull,
241 tsubst_flags_t complain)
243 tree v_binfo = NULL_TREE;
244 tree d_binfo = NULL_TREE;
245 tree probe;
246 tree offset;
247 tree target_type;
248 tree null_test = NULL;
249 tree ptr_target_type;
250 int fixed_type_p;
251 int want_pointer = TYPE_PTR_P (TREE_TYPE (expr));
252 bool has_empty = false;
253 bool virtual_access;
255 if (expr == error_mark_node || binfo == error_mark_node || !binfo)
256 return error_mark_node;
258 for (probe = binfo; probe; probe = BINFO_INHERITANCE_CHAIN (probe))
260 d_binfo = probe;
261 if (is_empty_class (BINFO_TYPE (probe)))
262 has_empty = true;
263 if (!v_binfo && BINFO_VIRTUAL_P (probe))
264 v_binfo = probe;
267 probe = TYPE_MAIN_VARIANT (TREE_TYPE (expr));
268 if (want_pointer)
269 probe = TYPE_MAIN_VARIANT (TREE_TYPE (probe));
271 if (code == PLUS_EXPR
272 && !SAME_BINFO_TYPE_P (BINFO_TYPE (d_binfo), probe))
274 /* This can happen when adjust_result_of_qualified_name_lookup can't
275 find a unique base binfo in a call to a member function. We
276 couldn't give the diagnostic then since we might have been calling
277 a static member function, so we do it now. */
278 if (complain & tf_error)
280 tree base = lookup_base (probe, BINFO_TYPE (d_binfo),
281 ba_unique, NULL, complain);
282 gcc_assert (base == error_mark_node);
284 return error_mark_node;
287 gcc_assert ((code == MINUS_EXPR
288 && SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), probe))
289 || code == PLUS_EXPR);
291 if (binfo == d_binfo)
292 /* Nothing to do. */
293 return expr;
295 if (code == MINUS_EXPR && v_binfo)
297 if (complain & tf_error)
299 if (SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), BINFO_TYPE (v_binfo)))
301 if (want_pointer)
302 error ("cannot convert from pointer to base class %qT to "
303 "pointer to derived class %qT because the base is "
304 "virtual", BINFO_TYPE (binfo), BINFO_TYPE (d_binfo));
305 else
306 error ("cannot convert from base class %qT to derived "
307 "class %qT because the base is virtual",
308 BINFO_TYPE (binfo), BINFO_TYPE (d_binfo));
310 else
312 if (want_pointer)
313 error ("cannot convert from pointer to base class %qT to "
314 "pointer to derived class %qT via virtual base %qT",
315 BINFO_TYPE (binfo), BINFO_TYPE (d_binfo),
316 BINFO_TYPE (v_binfo));
317 else
318 error ("cannot convert from base class %qT to derived "
319 "class %qT via virtual base %qT", BINFO_TYPE (binfo),
320 BINFO_TYPE (d_binfo), BINFO_TYPE (v_binfo));
323 return error_mark_node;
326 if (!want_pointer)
327 /* This must happen before the call to save_expr. */
328 expr = cp_build_addr_expr (expr, complain);
329 else
330 expr = mark_rvalue_use (expr);
332 offset = BINFO_OFFSET (binfo);
333 fixed_type_p = resolves_to_fixed_type_p (expr, &nonnull);
334 target_type = code == PLUS_EXPR ? BINFO_TYPE (binfo) : BINFO_TYPE (d_binfo);
335 /* TARGET_TYPE has been extracted from BINFO, and, is therefore always
336 cv-unqualified. Extract the cv-qualifiers from EXPR so that the
337 expression returned matches the input. */
338 target_type = cp_build_qualified_type
339 (target_type, cp_type_quals (TREE_TYPE (TREE_TYPE (expr))));
340 ptr_target_type = build_pointer_type (target_type);
342 /* Do we need to look in the vtable for the real offset? */
343 virtual_access = (v_binfo && fixed_type_p <= 0);
345 /* Don't bother with the calculations inside sizeof; they'll ICE if the
346 source type is incomplete and the pointer value doesn't matter. In a
347 template (even in fold_non_dependent_expr), we don't have vtables set
348 up properly yet, and the value doesn't matter there either; we're just
349 interested in the result of overload resolution. */
350 if (cp_unevaluated_operand != 0
351 || in_template_function ())
353 expr = build_nop (ptr_target_type, expr);
354 if (!want_pointer)
355 expr = build_indirect_ref (EXPR_LOCATION (expr), expr, RO_NULL);
356 return expr;
359 /* If we're in an NSDMI, we don't have the full constructor context yet
360 that we need for converting to a virtual base, so just build a stub
361 CONVERT_EXPR and expand it later in bot_replace. */
362 if (virtual_access && fixed_type_p < 0
363 && current_scope () != current_function_decl)
365 expr = build1 (CONVERT_EXPR, ptr_target_type, expr);
366 CONVERT_EXPR_VBASE_PATH (expr) = true;
367 if (!want_pointer)
368 expr = build_indirect_ref (EXPR_LOCATION (expr), expr, RO_NULL);
369 return expr;
372 /* Do we need to check for a null pointer? */
373 if (want_pointer && !nonnull)
375 /* If we know the conversion will not actually change the value
376 of EXPR, then we can avoid testing the expression for NULL.
377 We have to avoid generating a COMPONENT_REF for a base class
378 field, because other parts of the compiler know that such
379 expressions are always non-NULL. */
380 if (!virtual_access && integer_zerop (offset))
381 return build_nop (ptr_target_type, expr);
382 null_test = error_mark_node;
385 /* Protect against multiple evaluation if necessary. */
386 if (TREE_SIDE_EFFECTS (expr) && (null_test || virtual_access))
387 expr = save_expr (expr);
389 /* Now that we've saved expr, build the real null test. */
390 if (null_test)
392 tree zero = cp_convert (TREE_TYPE (expr), nullptr_node, complain);
393 null_test = fold_build2_loc (input_location, NE_EXPR, boolean_type_node,
394 expr, zero);
397 /* If this is a simple base reference, express it as a COMPONENT_REF. */
398 if (code == PLUS_EXPR && !virtual_access
399 /* We don't build base fields for empty bases, and they aren't very
400 interesting to the optimizers anyway. */
401 && !has_empty)
403 expr = cp_build_indirect_ref (expr, RO_NULL, complain);
404 expr = build_simple_base_path (expr, binfo);
405 if (want_pointer)
406 expr = build_address (expr);
407 target_type = TREE_TYPE (expr);
408 goto out;
411 if (virtual_access)
413 /* Going via virtual base V_BINFO. We need the static offset
414 from V_BINFO to BINFO, and the dynamic offset from D_BINFO to
415 V_BINFO. That offset is an entry in D_BINFO's vtable. */
416 tree v_offset;
418 if (fixed_type_p < 0 && in_base_initializer)
420 /* In a base member initializer, we cannot rely on the
421 vtable being set up. We have to indirect via the
422 vtt_parm. */
423 tree t;
425 t = TREE_TYPE (TYPE_VFIELD (current_class_type));
426 t = build_pointer_type (t);
427 v_offset = convert (t, current_vtt_parm);
428 v_offset = cp_build_indirect_ref (v_offset, RO_NULL, complain);
430 else
431 v_offset = build_vfield_ref (cp_build_indirect_ref (expr, RO_NULL,
432 complain),
433 TREE_TYPE (TREE_TYPE (expr)));
435 if (v_offset == error_mark_node)
436 return error_mark_node;
438 v_offset = fold_build_pointer_plus (v_offset, BINFO_VPTR_FIELD (v_binfo));
439 v_offset = build1 (NOP_EXPR,
440 build_pointer_type (ptrdiff_type_node),
441 v_offset);
442 v_offset = cp_build_indirect_ref (v_offset, RO_NULL, complain);
443 TREE_CONSTANT (v_offset) = 1;
445 offset = convert_to_integer (ptrdiff_type_node,
446 size_diffop_loc (input_location, offset,
447 BINFO_OFFSET (v_binfo)));
449 if (!integer_zerop (offset))
450 v_offset = build2 (code, ptrdiff_type_node, v_offset, offset);
452 if (fixed_type_p < 0)
453 /* Negative fixed_type_p means this is a constructor or destructor;
454 virtual base layout is fixed in in-charge [cd]tors, but not in
455 base [cd]tors. */
456 offset = build3 (COND_EXPR, ptrdiff_type_node,
457 build2 (EQ_EXPR, boolean_type_node,
458 current_in_charge_parm, integer_zero_node),
459 v_offset,
460 convert_to_integer (ptrdiff_type_node,
461 BINFO_OFFSET (binfo)));
462 else
463 offset = v_offset;
466 if (want_pointer)
467 target_type = ptr_target_type;
469 expr = build1 (NOP_EXPR, ptr_target_type, expr);
471 if (!integer_zerop (offset))
473 offset = fold_convert (sizetype, offset);
474 if (code == MINUS_EXPR)
475 offset = fold_build1_loc (input_location, NEGATE_EXPR, sizetype, offset);
476 expr = fold_build_pointer_plus (expr, offset);
478 else
479 null_test = NULL;
481 if (!want_pointer)
482 expr = cp_build_indirect_ref (expr, RO_NULL, complain);
484 out:
485 if (null_test)
486 expr = fold_build3_loc (input_location, COND_EXPR, target_type, null_test, expr,
487 build_zero_cst (target_type));
489 return expr;
492 /* Subroutine of build_base_path; EXPR and BINFO are as in that function.
493 Perform a derived-to-base conversion by recursively building up a
494 sequence of COMPONENT_REFs to the appropriate base fields. */
496 static tree
497 build_simple_base_path (tree expr, tree binfo)
499 tree type = BINFO_TYPE (binfo);
500 tree d_binfo = BINFO_INHERITANCE_CHAIN (binfo);
501 tree field;
503 if (d_binfo == NULL_TREE)
505 tree temp;
507 gcc_assert (TYPE_MAIN_VARIANT (TREE_TYPE (expr)) == type);
509 /* Transform `(a, b).x' into `(*(a, &b)).x', `(a ? b : c).x'
510 into `(*(a ? &b : &c)).x', and so on. A COND_EXPR is only
511 an lvalue in the front end; only _DECLs and _REFs are lvalues
512 in the back end. */
513 temp = unary_complex_lvalue (ADDR_EXPR, expr);
514 if (temp)
515 expr = cp_build_indirect_ref (temp, RO_NULL, tf_warning_or_error);
517 return expr;
520 /* Recurse. */
521 expr = build_simple_base_path (expr, d_binfo);
523 for (field = TYPE_FIELDS (BINFO_TYPE (d_binfo));
524 field; field = DECL_CHAIN (field))
525 /* Is this the base field created by build_base_field? */
526 if (TREE_CODE (field) == FIELD_DECL
527 && DECL_FIELD_IS_BASE (field)
528 && TREE_TYPE (field) == type
529 /* If we're looking for a field in the most-derived class,
530 also check the field offset; we can have two base fields
531 of the same type if one is an indirect virtual base and one
532 is a direct non-virtual base. */
533 && (BINFO_INHERITANCE_CHAIN (d_binfo)
534 || tree_int_cst_equal (byte_position (field),
535 BINFO_OFFSET (binfo))))
537 /* We don't use build_class_member_access_expr here, as that
538 has unnecessary checks, and more importantly results in
539 recursive calls to dfs_walk_once. */
540 int type_quals = cp_type_quals (TREE_TYPE (expr));
542 expr = build3 (COMPONENT_REF,
543 cp_build_qualified_type (type, type_quals),
544 expr, field, NULL_TREE);
545 expr = fold_if_not_in_template (expr);
547 /* Mark the expression const or volatile, as appropriate.
548 Even though we've dealt with the type above, we still have
549 to mark the expression itself. */
550 if (type_quals & TYPE_QUAL_CONST)
551 TREE_READONLY (expr) = 1;
552 if (type_quals & TYPE_QUAL_VOLATILE)
553 TREE_THIS_VOLATILE (expr) = 1;
555 return expr;
558 /* Didn't find the base field?!? */
559 gcc_unreachable ();
562 /* Convert OBJECT to the base TYPE. OBJECT is an expression whose
563 type is a class type or a pointer to a class type. In the former
564 case, TYPE is also a class type; in the latter it is another
565 pointer type. If CHECK_ACCESS is true, an error message is emitted
566 if TYPE is inaccessible. If OBJECT has pointer type, the value is
567 assumed to be non-NULL. */
569 tree
570 convert_to_base (tree object, tree type, bool check_access, bool nonnull,
571 tsubst_flags_t complain)
573 tree binfo;
574 tree object_type;
576 if (TYPE_PTR_P (TREE_TYPE (object)))
578 object_type = TREE_TYPE (TREE_TYPE (object));
579 type = TREE_TYPE (type);
581 else
582 object_type = TREE_TYPE (object);
584 binfo = lookup_base (object_type, type, check_access ? ba_check : ba_unique,
585 NULL, complain);
586 if (!binfo || binfo == error_mark_node)
587 return error_mark_node;
589 return build_base_path (PLUS_EXPR, object, binfo, nonnull, complain);
592 /* EXPR is an expression with unqualified class type. BASE is a base
593 binfo of that class type. Returns EXPR, converted to the BASE
594 type. This function assumes that EXPR is the most derived class;
595 therefore virtual bases can be found at their static offsets. */
597 tree
598 convert_to_base_statically (tree expr, tree base)
600 tree expr_type;
602 expr_type = TREE_TYPE (expr);
603 if (!SAME_BINFO_TYPE_P (BINFO_TYPE (base), expr_type))
605 /* If this is a non-empty base, use a COMPONENT_REF. */
606 if (!is_empty_class (BINFO_TYPE (base)))
607 return build_simple_base_path (expr, base);
609 /* We use fold_build2 and fold_convert below to simplify the trees
610 provided to the optimizers. It is not safe to call these functions
611 when processing a template because they do not handle C++-specific
612 trees. */
613 gcc_assert (!processing_template_decl);
614 expr = cp_build_addr_expr (expr, tf_warning_or_error);
615 if (!integer_zerop (BINFO_OFFSET (base)))
616 expr = fold_build_pointer_plus_loc (input_location,
617 expr, BINFO_OFFSET (base));
618 expr = fold_convert (build_pointer_type (BINFO_TYPE (base)), expr);
619 expr = build_fold_indirect_ref_loc (input_location, expr);
622 return expr;
626 tree
627 build_vfield_ref (tree datum, tree type)
629 tree vfield, vcontext;
631 if (datum == error_mark_node
632 /* Can happen in case of duplicate base types (c++/59082). */
633 || !TYPE_VFIELD (type))
634 return error_mark_node;
636 /* First, convert to the requested type. */
637 if (!same_type_ignoring_top_level_qualifiers_p (TREE_TYPE (datum), type))
638 datum = convert_to_base (datum, type, /*check_access=*/false,
639 /*nonnull=*/true, tf_warning_or_error);
641 /* Second, the requested type may not be the owner of its own vptr.
642 If not, convert to the base class that owns it. We cannot use
643 convert_to_base here, because VCONTEXT may appear more than once
644 in the inheritance hierarchy of TYPE, and thus direct conversion
645 between the types may be ambiguous. Following the path back up
646 one step at a time via primary bases avoids the problem. */
647 vfield = TYPE_VFIELD (type);
648 vcontext = DECL_CONTEXT (vfield);
649 while (!same_type_ignoring_top_level_qualifiers_p (vcontext, type))
651 datum = build_simple_base_path (datum, CLASSTYPE_PRIMARY_BINFO (type));
652 type = TREE_TYPE (datum);
655 return build3 (COMPONENT_REF, TREE_TYPE (vfield), datum, vfield, NULL_TREE);
658 /* Given an object INSTANCE, return an expression which yields the
659 vtable element corresponding to INDEX. There are many special
660 cases for INSTANCE which we take care of here, mainly to avoid
661 creating extra tree nodes when we don't have to. */
663 static tree
664 build_vtbl_ref_1 (tree instance, tree idx)
666 tree aref;
667 tree vtbl = NULL_TREE;
669 /* Try to figure out what a reference refers to, and
670 access its virtual function table directly. */
672 int cdtorp = 0;
673 tree fixed_type = fixed_type_or_null (instance, NULL, &cdtorp);
675 tree basetype = non_reference (TREE_TYPE (instance));
677 if (fixed_type && !cdtorp)
679 tree binfo = lookup_base (fixed_type, basetype,
680 ba_unique, NULL, tf_none);
681 if (binfo && binfo != error_mark_node)
682 vtbl = unshare_expr (BINFO_VTABLE (binfo));
685 if (!vtbl)
686 vtbl = build_vfield_ref (instance, basetype);
688 aref = build_array_ref (input_location, vtbl, idx);
689 TREE_CONSTANT (aref) |= TREE_CONSTANT (vtbl) && TREE_CONSTANT (idx);
691 return aref;
694 tree
695 build_vtbl_ref (tree instance, tree idx)
697 tree aref = build_vtbl_ref_1 (instance, idx);
699 return aref;
702 /* Given a stable object pointer INSTANCE_PTR, return an expression which
703 yields a function pointer corresponding to vtable element INDEX. */
705 tree
706 build_vfn_ref (tree instance_ptr, tree idx)
708 tree aref;
710 aref = build_vtbl_ref_1 (cp_build_indirect_ref (instance_ptr, RO_NULL,
711 tf_warning_or_error),
712 idx);
714 /* When using function descriptors, the address of the
715 vtable entry is treated as a function pointer. */
716 if (TARGET_VTABLE_USES_DESCRIPTORS)
717 aref = build1 (NOP_EXPR, TREE_TYPE (aref),
718 cp_build_addr_expr (aref, tf_warning_or_error));
720 /* Remember this as a method reference, for later devirtualization. */
721 aref = build3 (OBJ_TYPE_REF, TREE_TYPE (aref), aref, instance_ptr, idx);
723 return aref;
726 /* Return the name of the virtual function table (as an IDENTIFIER_NODE)
727 for the given TYPE. */
729 static tree
730 get_vtable_name (tree type)
732 return mangle_vtbl_for_type (type);
735 /* DECL is an entity associated with TYPE, like a virtual table or an
736 implicitly generated constructor. Determine whether or not DECL
737 should have external or internal linkage at the object file
738 level. This routine does not deal with COMDAT linkage and other
739 similar complexities; it simply sets TREE_PUBLIC if it possible for
740 entities in other translation units to contain copies of DECL, in
741 the abstract. */
743 void
744 set_linkage_according_to_type (tree /*type*/, tree decl)
746 TREE_PUBLIC (decl) = 1;
747 determine_visibility (decl);
750 /* Create a VAR_DECL for a primary or secondary vtable for CLASS_TYPE.
751 (For a secondary vtable for B-in-D, CLASS_TYPE should be D, not B.)
752 Use NAME for the name of the vtable, and VTABLE_TYPE for its type. */
754 static tree
755 build_vtable (tree class_type, tree name, tree vtable_type)
757 tree decl;
759 decl = build_lang_decl (VAR_DECL, name, vtable_type);
760 /* vtable names are already mangled; give them their DECL_ASSEMBLER_NAME
761 now to avoid confusion in mangle_decl. */
762 SET_DECL_ASSEMBLER_NAME (decl, name);
763 DECL_CONTEXT (decl) = class_type;
764 DECL_ARTIFICIAL (decl) = 1;
765 TREE_STATIC (decl) = 1;
766 TREE_READONLY (decl) = 1;
767 DECL_VIRTUAL_P (decl) = 1;
768 DECL_ALIGN (decl) = TARGET_VTABLE_ENTRY_ALIGN;
769 DECL_USER_ALIGN (decl) = true;
770 DECL_VTABLE_OR_VTT_P (decl) = 1;
771 set_linkage_according_to_type (class_type, decl);
772 /* The vtable has not been defined -- yet. */
773 DECL_EXTERNAL (decl) = 1;
774 DECL_NOT_REALLY_EXTERN (decl) = 1;
776 /* Mark the VAR_DECL node representing the vtable itself as a
777 "gratuitous" one, thereby forcing dwarfout.c to ignore it. It
778 is rather important that such things be ignored because any
779 effort to actually generate DWARF for them will run into
780 trouble when/if we encounter code like:
782 #pragma interface
783 struct S { virtual void member (); };
785 because the artificial declaration of the vtable itself (as
786 manufactured by the g++ front end) will say that the vtable is
787 a static member of `S' but only *after* the debug output for
788 the definition of `S' has already been output. This causes
789 grief because the DWARF entry for the definition of the vtable
790 will try to refer back to an earlier *declaration* of the
791 vtable as a static member of `S' and there won't be one. We
792 might be able to arrange to have the "vtable static member"
793 attached to the member list for `S' before the debug info for
794 `S' get written (which would solve the problem) but that would
795 require more intrusive changes to the g++ front end. */
796 DECL_IGNORED_P (decl) = 1;
798 return decl;
801 /* Get the VAR_DECL of the vtable for TYPE. TYPE need not be polymorphic,
802 or even complete. If this does not exist, create it. If COMPLETE is
803 nonzero, then complete the definition of it -- that will render it
804 impossible to actually build the vtable, but is useful to get at those
805 which are known to exist in the runtime. */
807 tree
808 get_vtable_decl (tree type, int complete)
810 tree decl;
812 if (CLASSTYPE_VTABLES (type))
813 return CLASSTYPE_VTABLES (type);
815 decl = build_vtable (type, get_vtable_name (type), vtbl_type_node);
816 CLASSTYPE_VTABLES (type) = decl;
818 if (complete)
820 DECL_EXTERNAL (decl) = 1;
821 cp_finish_decl (decl, NULL_TREE, false, NULL_TREE, 0);
824 return decl;
827 /* Build the primary virtual function table for TYPE. If BINFO is
828 non-NULL, build the vtable starting with the initial approximation
829 that it is the same as the one which is the head of the association
830 list. Returns a nonzero value if a new vtable is actually
831 created. */
833 static int
834 build_primary_vtable (tree binfo, tree type)
836 tree decl;
837 tree virtuals;
839 decl = get_vtable_decl (type, /*complete=*/0);
841 if (binfo)
843 if (BINFO_NEW_VTABLE_MARKED (binfo))
844 /* We have already created a vtable for this base, so there's
845 no need to do it again. */
846 return 0;
848 virtuals = copy_list (BINFO_VIRTUALS (binfo));
849 TREE_TYPE (decl) = TREE_TYPE (get_vtbl_decl_for_binfo (binfo));
850 DECL_SIZE (decl) = TYPE_SIZE (TREE_TYPE (decl));
851 DECL_SIZE_UNIT (decl) = TYPE_SIZE_UNIT (TREE_TYPE (decl));
853 else
855 gcc_assert (TREE_TYPE (decl) == vtbl_type_node);
856 virtuals = NULL_TREE;
859 if (GATHER_STATISTICS)
861 n_vtables += 1;
862 n_vtable_elems += list_length (virtuals);
865 /* Initialize the association list for this type, based
866 on our first approximation. */
867 BINFO_VTABLE (TYPE_BINFO (type)) = decl;
868 BINFO_VIRTUALS (TYPE_BINFO (type)) = virtuals;
869 SET_BINFO_NEW_VTABLE_MARKED (TYPE_BINFO (type));
870 return 1;
873 /* Give BINFO a new virtual function table which is initialized
874 with a skeleton-copy of its original initialization. The only
875 entry that changes is the `delta' entry, so we can really
876 share a lot of structure.
878 FOR_TYPE is the most derived type which caused this table to
879 be needed.
881 Returns nonzero if we haven't met BINFO before.
883 The order in which vtables are built (by calling this function) for
884 an object must remain the same, otherwise a binary incompatibility
885 can result. */
887 static int
888 build_secondary_vtable (tree binfo)
890 if (BINFO_NEW_VTABLE_MARKED (binfo))
891 /* We already created a vtable for this base. There's no need to
892 do it again. */
893 return 0;
895 /* Remember that we've created a vtable for this BINFO, so that we
896 don't try to do so again. */
897 SET_BINFO_NEW_VTABLE_MARKED (binfo);
899 /* Make fresh virtual list, so we can smash it later. */
900 BINFO_VIRTUALS (binfo) = copy_list (BINFO_VIRTUALS (binfo));
902 /* Secondary vtables are laid out as part of the same structure as
903 the primary vtable. */
904 BINFO_VTABLE (binfo) = NULL_TREE;
905 return 1;
908 /* Create a new vtable for BINFO which is the hierarchy dominated by
909 T. Return nonzero if we actually created a new vtable. */
911 static int
912 make_new_vtable (tree t, tree binfo)
914 if (binfo == TYPE_BINFO (t))
915 /* In this case, it is *type*'s vtable we are modifying. We start
916 with the approximation that its vtable is that of the
917 immediate base class. */
918 return build_primary_vtable (binfo, t);
919 else
920 /* This is our very own copy of `basetype' to play with. Later,
921 we will fill in all the virtual functions that override the
922 virtual functions in these base classes which are not defined
923 by the current type. */
924 return build_secondary_vtable (binfo);
927 /* Make *VIRTUALS, an entry on the BINFO_VIRTUALS list for BINFO
928 (which is in the hierarchy dominated by T) list FNDECL as its
929 BV_FN. DELTA is the required constant adjustment from the `this'
930 pointer where the vtable entry appears to the `this' required when
931 the function is actually called. */
933 static void
934 modify_vtable_entry (tree t,
935 tree binfo,
936 tree fndecl,
937 tree delta,
938 tree *virtuals)
940 tree v;
942 v = *virtuals;
944 if (fndecl != BV_FN (v)
945 || !tree_int_cst_equal (delta, BV_DELTA (v)))
947 /* We need a new vtable for BINFO. */
948 if (make_new_vtable (t, binfo))
950 /* If we really did make a new vtable, we also made a copy
951 of the BINFO_VIRTUALS list. Now, we have to find the
952 corresponding entry in that list. */
953 *virtuals = BINFO_VIRTUALS (binfo);
954 while (BV_FN (*virtuals) != BV_FN (v))
955 *virtuals = TREE_CHAIN (*virtuals);
956 v = *virtuals;
959 BV_DELTA (v) = delta;
960 BV_VCALL_INDEX (v) = NULL_TREE;
961 BV_FN (v) = fndecl;
966 /* Add method METHOD to class TYPE. If USING_DECL is non-null, it is
967 the USING_DECL naming METHOD. Returns true if the method could be
968 added to the method vec. */
970 bool
971 add_method (tree type, tree method, tree using_decl)
973 unsigned slot;
974 tree overload;
975 bool template_conv_p = false;
976 bool conv_p;
977 vec<tree, va_gc> *method_vec;
978 bool complete_p;
979 bool insert_p = false;
980 tree current_fns;
981 tree fns;
983 if (method == error_mark_node)
984 return false;
986 complete_p = COMPLETE_TYPE_P (type);
987 conv_p = DECL_CONV_FN_P (method);
988 if (conv_p)
989 template_conv_p = (TREE_CODE (method) == TEMPLATE_DECL
990 && DECL_TEMPLATE_CONV_FN_P (method));
992 method_vec = CLASSTYPE_METHOD_VEC (type);
993 if (!method_vec)
995 /* Make a new method vector. We start with 8 entries. We must
996 allocate at least two (for constructors and destructors), and
997 we're going to end up with an assignment operator at some
998 point as well. */
999 vec_alloc (method_vec, 8);
1000 /* Create slots for constructors and destructors. */
1001 method_vec->quick_push (NULL_TREE);
1002 method_vec->quick_push (NULL_TREE);
1003 CLASSTYPE_METHOD_VEC (type) = method_vec;
1006 /* Maintain TYPE_HAS_USER_CONSTRUCTOR, etc. */
1007 grok_special_member_properties (method);
1009 /* Constructors and destructors go in special slots. */
1010 if (DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P (method))
1011 slot = CLASSTYPE_CONSTRUCTOR_SLOT;
1012 else if (DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P (method))
1014 slot = CLASSTYPE_DESTRUCTOR_SLOT;
1016 if (TYPE_FOR_JAVA (type))
1018 if (!DECL_ARTIFICIAL (method))
1019 error ("Java class %qT cannot have a destructor", type);
1020 else if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type))
1021 error ("Java class %qT cannot have an implicit non-trivial "
1022 "destructor",
1023 type);
1026 else
1028 tree m;
1030 insert_p = true;
1031 /* See if we already have an entry with this name. */
1032 for (slot = CLASSTYPE_FIRST_CONVERSION_SLOT;
1033 vec_safe_iterate (method_vec, slot, &m);
1034 ++slot)
1036 m = OVL_CURRENT (m);
1037 if (template_conv_p)
1039 if (TREE_CODE (m) == TEMPLATE_DECL
1040 && DECL_TEMPLATE_CONV_FN_P (m))
1041 insert_p = false;
1042 break;
1044 if (conv_p && !DECL_CONV_FN_P (m))
1045 break;
1046 if (DECL_NAME (m) == DECL_NAME (method))
1048 insert_p = false;
1049 break;
1051 if (complete_p
1052 && !DECL_CONV_FN_P (m)
1053 && DECL_NAME (m) > DECL_NAME (method))
1054 break;
1057 current_fns = insert_p ? NULL_TREE : (*method_vec)[slot];
1059 /* Check to see if we've already got this method. */
1060 for (fns = current_fns; fns; fns = OVL_NEXT (fns))
1062 tree fn = OVL_CURRENT (fns);
1063 tree fn_type;
1064 tree method_type;
1065 tree parms1;
1066 tree parms2;
1068 if (TREE_CODE (fn) != TREE_CODE (method))
1069 continue;
1071 /* [over.load] Member function declarations with the
1072 same name and the same parameter types cannot be
1073 overloaded if any of them is a static member
1074 function declaration.
1076 [over.load] Member function declarations with the same name and
1077 the same parameter-type-list as well as member function template
1078 declarations with the same name, the same parameter-type-list, and
1079 the same template parameter lists cannot be overloaded if any of
1080 them, but not all, have a ref-qualifier.
1082 [namespace.udecl] When a using-declaration brings names
1083 from a base class into a derived class scope, member
1084 functions in the derived class override and/or hide member
1085 functions with the same name and parameter types in a base
1086 class (rather than conflicting). */
1087 fn_type = TREE_TYPE (fn);
1088 method_type = TREE_TYPE (method);
1089 parms1 = TYPE_ARG_TYPES (fn_type);
1090 parms2 = TYPE_ARG_TYPES (method_type);
1092 /* Compare the quals on the 'this' parm. Don't compare
1093 the whole types, as used functions are treated as
1094 coming from the using class in overload resolution. */
1095 if (! DECL_STATIC_FUNCTION_P (fn)
1096 && ! DECL_STATIC_FUNCTION_P (method)
1097 /* Either both or neither need to be ref-qualified for
1098 differing quals to allow overloading. */
1099 && (FUNCTION_REF_QUALIFIED (fn_type)
1100 == FUNCTION_REF_QUALIFIED (method_type))
1101 && (type_memfn_quals (fn_type) != type_memfn_quals (method_type)
1102 || type_memfn_rqual (fn_type) != type_memfn_rqual (method_type)))
1103 continue;
1105 /* For templates, the return type and template parameters
1106 must be identical. */
1107 if (TREE_CODE (fn) == TEMPLATE_DECL
1108 && (!same_type_p (TREE_TYPE (fn_type),
1109 TREE_TYPE (method_type))
1110 || !comp_template_parms (DECL_TEMPLATE_PARMS (fn),
1111 DECL_TEMPLATE_PARMS (method))))
1112 continue;
1114 if (! DECL_STATIC_FUNCTION_P (fn))
1115 parms1 = TREE_CHAIN (parms1);
1116 if (! DECL_STATIC_FUNCTION_P (method))
1117 parms2 = TREE_CHAIN (parms2);
1119 if (compparms (parms1, parms2)
1120 && (!DECL_CONV_FN_P (fn)
1121 || same_type_p (TREE_TYPE (fn_type),
1122 TREE_TYPE (method_type))))
1124 /* For function versions, their parms and types match
1125 but they are not duplicates. Record function versions
1126 as and when they are found. extern "C" functions are
1127 not treated as versions. */
1128 if (TREE_CODE (fn) == FUNCTION_DECL
1129 && TREE_CODE (method) == FUNCTION_DECL
1130 && !DECL_EXTERN_C_P (fn)
1131 && !DECL_EXTERN_C_P (method)
1132 && targetm.target_option.function_versions (fn, method))
1134 /* Mark functions as versions if necessary. Modify the mangled
1135 decl name if necessary. */
1136 if (!DECL_FUNCTION_VERSIONED (fn))
1138 DECL_FUNCTION_VERSIONED (fn) = 1;
1139 if (DECL_ASSEMBLER_NAME_SET_P (fn))
1140 mangle_decl (fn);
1142 if (!DECL_FUNCTION_VERSIONED (method))
1144 DECL_FUNCTION_VERSIONED (method) = 1;
1145 if (DECL_ASSEMBLER_NAME_SET_P (method))
1146 mangle_decl (method);
1148 cgraph_node::record_function_versions (fn, method);
1149 continue;
1151 if (DECL_INHERITED_CTOR_BASE (method))
1153 if (DECL_INHERITED_CTOR_BASE (fn))
1155 error_at (DECL_SOURCE_LOCATION (method),
1156 "%q#D inherited from %qT", method,
1157 DECL_INHERITED_CTOR_BASE (method));
1158 error_at (DECL_SOURCE_LOCATION (fn),
1159 "conflicts with version inherited from %qT",
1160 DECL_INHERITED_CTOR_BASE (fn));
1162 /* Otherwise defer to the other function. */
1163 return false;
1165 if (using_decl)
1167 if (DECL_CONTEXT (fn) == type)
1168 /* Defer to the local function. */
1169 return false;
1171 else
1173 error ("%q+#D cannot be overloaded", method);
1174 error ("with %q+#D", fn);
1177 /* We don't call duplicate_decls here to merge the
1178 declarations because that will confuse things if the
1179 methods have inline definitions. In particular, we
1180 will crash while processing the definitions. */
1181 return false;
1185 /* A class should never have more than one destructor. */
1186 if (current_fns && DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P (method))
1187 return false;
1189 /* Add the new binding. */
1190 if (using_decl)
1192 overload = ovl_cons (method, current_fns);
1193 OVL_USED (overload) = true;
1195 else
1196 overload = build_overload (method, current_fns);
1198 if (conv_p)
1199 TYPE_HAS_CONVERSION (type) = 1;
1200 else if (slot >= CLASSTYPE_FIRST_CONVERSION_SLOT && !complete_p)
1201 push_class_level_binding (DECL_NAME (method), overload);
1203 if (insert_p)
1205 bool reallocated;
1207 /* We only expect to add few methods in the COMPLETE_P case, so
1208 just make room for one more method in that case. */
1209 if (complete_p)
1210 reallocated = vec_safe_reserve_exact (method_vec, 1);
1211 else
1212 reallocated = vec_safe_reserve (method_vec, 1);
1213 if (reallocated)
1214 CLASSTYPE_METHOD_VEC (type) = method_vec;
1215 if (slot == method_vec->length ())
1216 method_vec->quick_push (overload);
1217 else
1218 method_vec->quick_insert (slot, overload);
1220 else
1221 /* Replace the current slot. */
1222 (*method_vec)[slot] = overload;
1223 return true;
1226 /* Subroutines of finish_struct. */
1228 /* Change the access of FDECL to ACCESS in T. Return 1 if change was
1229 legit, otherwise return 0. */
1231 static int
1232 alter_access (tree t, tree fdecl, tree access)
1234 tree elem;
1236 if (!DECL_LANG_SPECIFIC (fdecl))
1237 retrofit_lang_decl (fdecl);
1239 gcc_assert (!DECL_DISCRIMINATOR_P (fdecl));
1241 elem = purpose_member (t, DECL_ACCESS (fdecl));
1242 if (elem)
1244 if (TREE_VALUE (elem) != access)
1246 if (TREE_CODE (TREE_TYPE (fdecl)) == FUNCTION_DECL)
1247 error ("conflicting access specifications for method"
1248 " %q+D, ignored", TREE_TYPE (fdecl));
1249 else
1250 error ("conflicting access specifications for field %qE, ignored",
1251 DECL_NAME (fdecl));
1253 else
1255 /* They're changing the access to the same thing they changed
1256 it to before. That's OK. */
1260 else
1262 perform_or_defer_access_check (TYPE_BINFO (t), fdecl, fdecl,
1263 tf_warning_or_error);
1264 DECL_ACCESS (fdecl) = tree_cons (t, access, DECL_ACCESS (fdecl));
1265 return 1;
1267 return 0;
1270 /* Process the USING_DECL, which is a member of T. */
1272 static void
1273 handle_using_decl (tree using_decl, tree t)
1275 tree decl = USING_DECL_DECLS (using_decl);
1276 tree name = DECL_NAME (using_decl);
1277 tree access
1278 = TREE_PRIVATE (using_decl) ? access_private_node
1279 : TREE_PROTECTED (using_decl) ? access_protected_node
1280 : access_public_node;
1281 tree flist = NULL_TREE;
1282 tree old_value;
1284 gcc_assert (!processing_template_decl && decl);
1286 old_value = lookup_member (t, name, /*protect=*/0, /*want_type=*/false,
1287 tf_warning_or_error);
1288 if (old_value)
1290 if (is_overloaded_fn (old_value))
1291 old_value = OVL_CURRENT (old_value);
1293 if (DECL_P (old_value) && DECL_CONTEXT (old_value) == t)
1294 /* OK */;
1295 else
1296 old_value = NULL_TREE;
1299 cp_emit_debug_info_for_using (decl, t);
1301 if (is_overloaded_fn (decl))
1302 flist = decl;
1304 if (! old_value)
1306 else if (is_overloaded_fn (old_value))
1308 if (flist)
1309 /* It's OK to use functions from a base when there are functions with
1310 the same name already present in the current class. */;
1311 else
1313 error ("%q+D invalid in %q#T", using_decl, t);
1314 error (" because of local method %q+#D with same name",
1315 OVL_CURRENT (old_value));
1316 return;
1319 else if (!DECL_ARTIFICIAL (old_value))
1321 error ("%q+D invalid in %q#T", using_decl, t);
1322 error (" because of local member %q+#D with same name", old_value);
1323 return;
1326 /* Make type T see field decl FDECL with access ACCESS. */
1327 if (flist)
1328 for (; flist; flist = OVL_NEXT (flist))
1330 add_method (t, OVL_CURRENT (flist), using_decl);
1331 alter_access (t, OVL_CURRENT (flist), access);
1333 else
1334 alter_access (t, decl, access);
1337 /* walk_tree callback for check_abi_tags: if the type at *TP involves any
1338 types with abi tags, add the corresponding identifiers to the VEC in
1339 *DATA and set IDENTIFIER_MARKED. */
1341 struct abi_tag_data
1343 tree t;
1344 tree subob;
1345 // error_mark_node to get diagnostics; otherwise collect missing tags here
1346 tree tags;
1349 static tree
1350 find_abi_tags_r (tree *tp, int *walk_subtrees, void *data)
1352 if (!OVERLOAD_TYPE_P (*tp))
1353 return NULL_TREE;
1355 /* walk_tree shouldn't be walking into any subtrees of a RECORD_TYPE
1356 anyway, but let's make sure of it. */
1357 *walk_subtrees = false;
1359 if (tree attributes = lookup_attribute ("abi_tag", TYPE_ATTRIBUTES (*tp)))
1361 struct abi_tag_data *p = static_cast<struct abi_tag_data*>(data);
1362 for (tree list = TREE_VALUE (attributes); list;
1363 list = TREE_CHAIN (list))
1365 tree tag = TREE_VALUE (list);
1366 tree id = get_identifier (TREE_STRING_POINTER (tag));
1367 if (!IDENTIFIER_MARKED (id))
1369 if (p->tags != error_mark_node)
1371 /* We're collecting tags from template arguments. */
1372 tree str = build_string (IDENTIFIER_LENGTH (id),
1373 IDENTIFIER_POINTER (id));
1374 p->tags = tree_cons (NULL_TREE, str, p->tags);
1375 ABI_TAG_IMPLICIT (p->tags) = true;
1377 /* Don't inherit this tag multiple times. */
1378 IDENTIFIER_MARKED (id) = true;
1381 /* Otherwise we're diagnosing missing tags. */
1382 else if (TYPE_P (p->subob))
1384 if (warning (OPT_Wabi_tag, "%qT does not have the %E abi tag "
1385 "that base %qT has", p->t, tag, p->subob))
1386 inform (location_of (p->subob), "%qT declared here",
1387 p->subob);
1389 else
1391 if (warning (OPT_Wabi_tag, "%qT does not have the %E abi tag "
1392 "that %qT (used in the type of %qD) has",
1393 p->t, tag, *tp, p->subob))
1395 inform (location_of (p->subob), "%qD declared here",
1396 p->subob);
1397 inform (location_of (*tp), "%qT declared here", *tp);
1403 return NULL_TREE;
1406 /* Set IDENTIFIER_MARKED on all the ABI tags on T and its (transitively
1407 complete) template arguments. */
1409 static void
1410 mark_type_abi_tags (tree t, bool val)
1412 tree attributes = lookup_attribute ("abi_tag", TYPE_ATTRIBUTES (t));
1413 if (attributes)
1415 for (tree list = TREE_VALUE (attributes); list;
1416 list = TREE_CHAIN (list))
1418 tree tag = TREE_VALUE (list);
1419 tree id = get_identifier (TREE_STRING_POINTER (tag));
1420 IDENTIFIER_MARKED (id) = val;
1425 /* Check that class T has all the abi tags that subobject SUBOB has, or
1426 warn if not. */
1428 static void
1429 check_abi_tags (tree t, tree subob)
1431 mark_type_abi_tags (t, true);
1433 tree subtype = TYPE_P (subob) ? subob : TREE_TYPE (subob);
1434 struct abi_tag_data data = { t, subob, error_mark_node };
1436 cp_walk_tree_without_duplicates (&subtype, find_abi_tags_r, &data);
1438 mark_type_abi_tags (t, false);
1441 void
1442 inherit_targ_abi_tags (tree t)
1444 if (CLASSTYPE_TEMPLATE_INFO (t) == NULL_TREE)
1445 return;
1447 mark_type_abi_tags (t, true);
1449 tree args = CLASSTYPE_TI_ARGS (t);
1450 struct abi_tag_data data = { t, NULL_TREE, NULL_TREE };
1451 for (int i = 0; i < TMPL_ARGS_DEPTH (args); ++i)
1453 tree level = TMPL_ARGS_LEVEL (args, i+1);
1454 for (int j = 0; j < TREE_VEC_LENGTH (level); ++j)
1456 tree arg = TREE_VEC_ELT (level, j);
1457 data.subob = arg;
1458 cp_walk_tree_without_duplicates (&arg, find_abi_tags_r, &data);
1462 // If we found some tags on our template arguments, add them to our
1463 // abi_tag attribute.
1464 if (data.tags)
1466 tree attr = lookup_attribute ("abi_tag", TYPE_ATTRIBUTES (t));
1467 if (attr)
1468 TREE_VALUE (attr) = chainon (data.tags, TREE_VALUE (attr));
1469 else
1470 TYPE_ATTRIBUTES (t)
1471 = tree_cons (get_identifier ("abi_tag"), data.tags,
1472 TYPE_ATTRIBUTES (t));
1475 mark_type_abi_tags (t, false);
1478 /* Return true, iff class T has a non-virtual destructor that is
1479 accessible from outside the class heirarchy (i.e. is public, or
1480 there's a suitable friend. */
1482 static bool
1483 accessible_nvdtor_p (tree t)
1485 tree dtor = CLASSTYPE_DESTRUCTORS (t);
1487 /* An implicitly declared destructor is always public. And,
1488 if it were virtual, we would have created it by now. */
1489 if (!dtor)
1490 return true;
1492 if (DECL_VINDEX (dtor))
1493 return false; /* Virtual */
1495 if (!TREE_PRIVATE (dtor) && !TREE_PROTECTED (dtor))
1496 return true; /* Public */
1498 if (CLASSTYPE_FRIEND_CLASSES (t)
1499 || DECL_FRIENDLIST (TYPE_MAIN_DECL (t)))
1500 return true; /* Has friends */
1502 return false;
1505 /* Run through the base classes of T, updating CANT_HAVE_CONST_CTOR_P,
1506 and NO_CONST_ASN_REF_P. Also set flag bits in T based on
1507 properties of the bases. */
1509 static void
1510 check_bases (tree t,
1511 int* cant_have_const_ctor_p,
1512 int* no_const_asn_ref_p)
1514 int i;
1515 bool seen_non_virtual_nearly_empty_base_p = 0;
1516 int seen_tm_mask = 0;
1517 tree base_binfo;
1518 tree binfo;
1519 tree field = NULL_TREE;
1521 if (!CLASSTYPE_NON_STD_LAYOUT (t))
1522 for (field = TYPE_FIELDS (t); field; field = DECL_CHAIN (field))
1523 if (TREE_CODE (field) == FIELD_DECL)
1524 break;
1526 for (binfo = TYPE_BINFO (t), i = 0;
1527 BINFO_BASE_ITERATE (binfo, i, base_binfo); i++)
1529 tree basetype = TREE_TYPE (base_binfo);
1531 gcc_assert (COMPLETE_TYPE_P (basetype));
1533 if (CLASSTYPE_FINAL (basetype))
1534 error ("cannot derive from %<final%> base %qT in derived type %qT",
1535 basetype, t);
1537 /* If any base class is non-literal, so is the derived class. */
1538 if (!CLASSTYPE_LITERAL_P (basetype))
1539 CLASSTYPE_LITERAL_P (t) = false;
1541 /* If the base class doesn't have copy constructors or
1542 assignment operators that take const references, then the
1543 derived class cannot have such a member automatically
1544 generated. */
1545 if (TYPE_HAS_COPY_CTOR (basetype)
1546 && ! TYPE_HAS_CONST_COPY_CTOR (basetype))
1547 *cant_have_const_ctor_p = 1;
1548 if (TYPE_HAS_COPY_ASSIGN (basetype)
1549 && !TYPE_HAS_CONST_COPY_ASSIGN (basetype))
1550 *no_const_asn_ref_p = 1;
1552 if (BINFO_VIRTUAL_P (base_binfo))
1553 /* A virtual base does not effect nearly emptiness. */
1555 else if (CLASSTYPE_NEARLY_EMPTY_P (basetype))
1557 if (seen_non_virtual_nearly_empty_base_p)
1558 /* And if there is more than one nearly empty base, then the
1559 derived class is not nearly empty either. */
1560 CLASSTYPE_NEARLY_EMPTY_P (t) = 0;
1561 else
1562 /* Remember we've seen one. */
1563 seen_non_virtual_nearly_empty_base_p = 1;
1565 else if (!is_empty_class (basetype))
1566 /* If the base class is not empty or nearly empty, then this
1567 class cannot be nearly empty. */
1568 CLASSTYPE_NEARLY_EMPTY_P (t) = 0;
1570 /* A lot of properties from the bases also apply to the derived
1571 class. */
1572 TYPE_NEEDS_CONSTRUCTING (t) |= TYPE_NEEDS_CONSTRUCTING (basetype);
1573 TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t)
1574 |= TYPE_HAS_NONTRIVIAL_DESTRUCTOR (basetype);
1575 TYPE_HAS_COMPLEX_COPY_ASSIGN (t)
1576 |= (TYPE_HAS_COMPLEX_COPY_ASSIGN (basetype)
1577 || !TYPE_HAS_COPY_ASSIGN (basetype));
1578 TYPE_HAS_COMPLEX_COPY_CTOR (t) |= (TYPE_HAS_COMPLEX_COPY_CTOR (basetype)
1579 || !TYPE_HAS_COPY_CTOR (basetype));
1580 TYPE_HAS_COMPLEX_MOVE_ASSIGN (t)
1581 |= TYPE_HAS_COMPLEX_MOVE_ASSIGN (basetype);
1582 TYPE_HAS_COMPLEX_MOVE_CTOR (t) |= TYPE_HAS_COMPLEX_MOVE_CTOR (basetype);
1583 TYPE_POLYMORPHIC_P (t) |= TYPE_POLYMORPHIC_P (basetype);
1584 CLASSTYPE_CONTAINS_EMPTY_CLASS_P (t)
1585 |= CLASSTYPE_CONTAINS_EMPTY_CLASS_P (basetype);
1586 TYPE_HAS_COMPLEX_DFLT (t) |= (!TYPE_HAS_DEFAULT_CONSTRUCTOR (basetype)
1587 || TYPE_HAS_COMPLEX_DFLT (basetype));
1588 SET_CLASSTYPE_READONLY_FIELDS_NEED_INIT
1589 (t, CLASSTYPE_READONLY_FIELDS_NEED_INIT (t)
1590 | CLASSTYPE_READONLY_FIELDS_NEED_INIT (basetype));
1591 SET_CLASSTYPE_REF_FIELDS_NEED_INIT
1592 (t, CLASSTYPE_REF_FIELDS_NEED_INIT (t)
1593 | CLASSTYPE_REF_FIELDS_NEED_INIT (basetype));
1595 /* A standard-layout class is a class that:
1597 * has no non-standard-layout base classes, */
1598 CLASSTYPE_NON_STD_LAYOUT (t) |= CLASSTYPE_NON_STD_LAYOUT (basetype);
1599 if (!CLASSTYPE_NON_STD_LAYOUT (t))
1601 tree basefield;
1602 /* ...has no base classes of the same type as the first non-static
1603 data member... */
1604 if (field && DECL_CONTEXT (field) == t
1605 && (same_type_ignoring_top_level_qualifiers_p
1606 (TREE_TYPE (field), basetype)))
1607 CLASSTYPE_NON_STD_LAYOUT (t) = 1;
1608 else
1609 /* ...either has no non-static data members in the most-derived
1610 class and at most one base class with non-static data
1611 members, or has no base classes with non-static data
1612 members */
1613 for (basefield = TYPE_FIELDS (basetype); basefield;
1614 basefield = DECL_CHAIN (basefield))
1615 if (TREE_CODE (basefield) == FIELD_DECL)
1617 if (field)
1618 CLASSTYPE_NON_STD_LAYOUT (t) = 1;
1619 else
1620 field = basefield;
1621 break;
1625 /* Don't bother collecting tm attributes if transactional memory
1626 support is not enabled. */
1627 if (flag_tm)
1629 tree tm_attr = find_tm_attribute (TYPE_ATTRIBUTES (basetype));
1630 if (tm_attr)
1631 seen_tm_mask |= tm_attr_to_mask (tm_attr);
1634 check_abi_tags (t, basetype);
1637 /* If one of the base classes had TM attributes, and the current class
1638 doesn't define its own, then the current class inherits one. */
1639 if (seen_tm_mask && !find_tm_attribute (TYPE_ATTRIBUTES (t)))
1641 tree tm_attr = tm_mask_to_attr (seen_tm_mask & -seen_tm_mask);
1642 TYPE_ATTRIBUTES (t) = tree_cons (tm_attr, NULL, TYPE_ATTRIBUTES (t));
1646 /* Determine all the primary bases within T. Sets BINFO_PRIMARY_BASE_P for
1647 those that are primaries. Sets BINFO_LOST_PRIMARY_P for those
1648 that have had a nearly-empty virtual primary base stolen by some
1649 other base in the hierarchy. Determines CLASSTYPE_PRIMARY_BASE for
1650 T. */
1652 static void
1653 determine_primary_bases (tree t)
1655 unsigned i;
1656 tree primary = NULL_TREE;
1657 tree type_binfo = TYPE_BINFO (t);
1658 tree base_binfo;
1660 /* Determine the primary bases of our bases. */
1661 for (base_binfo = TREE_CHAIN (type_binfo); base_binfo;
1662 base_binfo = TREE_CHAIN (base_binfo))
1664 tree primary = CLASSTYPE_PRIMARY_BINFO (BINFO_TYPE (base_binfo));
1666 /* See if we're the non-virtual primary of our inheritance
1667 chain. */
1668 if (!BINFO_VIRTUAL_P (base_binfo))
1670 tree parent = BINFO_INHERITANCE_CHAIN (base_binfo);
1671 tree parent_primary = CLASSTYPE_PRIMARY_BINFO (BINFO_TYPE (parent));
1673 if (parent_primary
1674 && SAME_BINFO_TYPE_P (BINFO_TYPE (base_binfo),
1675 BINFO_TYPE (parent_primary)))
1676 /* We are the primary binfo. */
1677 BINFO_PRIMARY_P (base_binfo) = 1;
1679 /* Determine if we have a virtual primary base, and mark it so.
1681 if (primary && BINFO_VIRTUAL_P (primary))
1683 tree this_primary = copied_binfo (primary, base_binfo);
1685 if (BINFO_PRIMARY_P (this_primary))
1686 /* Someone already claimed this base. */
1687 BINFO_LOST_PRIMARY_P (base_binfo) = 1;
1688 else
1690 tree delta;
1692 BINFO_PRIMARY_P (this_primary) = 1;
1693 BINFO_INHERITANCE_CHAIN (this_primary) = base_binfo;
1695 /* A virtual binfo might have been copied from within
1696 another hierarchy. As we're about to use it as a
1697 primary base, make sure the offsets match. */
1698 delta = size_diffop_loc (input_location,
1699 convert (ssizetype,
1700 BINFO_OFFSET (base_binfo)),
1701 convert (ssizetype,
1702 BINFO_OFFSET (this_primary)));
1704 propagate_binfo_offsets (this_primary, delta);
1709 /* First look for a dynamic direct non-virtual base. */
1710 for (i = 0; BINFO_BASE_ITERATE (type_binfo, i, base_binfo); i++)
1712 tree basetype = BINFO_TYPE (base_binfo);
1714 if (TYPE_CONTAINS_VPTR_P (basetype) && !BINFO_VIRTUAL_P (base_binfo))
1716 primary = base_binfo;
1717 goto found;
1721 /* A "nearly-empty" virtual base class can be the primary base
1722 class, if no non-virtual polymorphic base can be found. Look for
1723 a nearly-empty virtual dynamic base that is not already a primary
1724 base of something in the hierarchy. If there is no such base,
1725 just pick the first nearly-empty virtual base. */
1727 for (base_binfo = TREE_CHAIN (type_binfo); base_binfo;
1728 base_binfo = TREE_CHAIN (base_binfo))
1729 if (BINFO_VIRTUAL_P (base_binfo)
1730 && CLASSTYPE_NEARLY_EMPTY_P (BINFO_TYPE (base_binfo)))
1732 if (!BINFO_PRIMARY_P (base_binfo))
1734 /* Found one that is not primary. */
1735 primary = base_binfo;
1736 goto found;
1738 else if (!primary)
1739 /* Remember the first candidate. */
1740 primary = base_binfo;
1743 found:
1744 /* If we've got a primary base, use it. */
1745 if (primary)
1747 tree basetype = BINFO_TYPE (primary);
1749 CLASSTYPE_PRIMARY_BINFO (t) = primary;
1750 if (BINFO_PRIMARY_P (primary))
1751 /* We are stealing a primary base. */
1752 BINFO_LOST_PRIMARY_P (BINFO_INHERITANCE_CHAIN (primary)) = 1;
1753 BINFO_PRIMARY_P (primary) = 1;
1754 if (BINFO_VIRTUAL_P (primary))
1756 tree delta;
1758 BINFO_INHERITANCE_CHAIN (primary) = type_binfo;
1759 /* A virtual binfo might have been copied from within
1760 another hierarchy. As we're about to use it as a primary
1761 base, make sure the offsets match. */
1762 delta = size_diffop_loc (input_location, ssize_int (0),
1763 convert (ssizetype, BINFO_OFFSET (primary)));
1765 propagate_binfo_offsets (primary, delta);
1768 primary = TYPE_BINFO (basetype);
1770 TYPE_VFIELD (t) = TYPE_VFIELD (basetype);
1771 BINFO_VTABLE (type_binfo) = BINFO_VTABLE (primary);
1772 BINFO_VIRTUALS (type_binfo) = BINFO_VIRTUALS (primary);
1776 /* Update the variant types of T. */
1778 void
1779 fixup_type_variants (tree t)
1781 tree variants;
1783 if (!t)
1784 return;
1786 for (variants = TYPE_NEXT_VARIANT (t);
1787 variants;
1788 variants = TYPE_NEXT_VARIANT (variants))
1790 /* These fields are in the _TYPE part of the node, not in
1791 the TYPE_LANG_SPECIFIC component, so they are not shared. */
1792 TYPE_HAS_USER_CONSTRUCTOR (variants) = TYPE_HAS_USER_CONSTRUCTOR (t);
1793 TYPE_NEEDS_CONSTRUCTING (variants) = TYPE_NEEDS_CONSTRUCTING (t);
1794 TYPE_HAS_NONTRIVIAL_DESTRUCTOR (variants)
1795 = TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t);
1797 TYPE_POLYMORPHIC_P (variants) = TYPE_POLYMORPHIC_P (t);
1799 TYPE_BINFO (variants) = TYPE_BINFO (t);
1801 /* Copy whatever these are holding today. */
1802 TYPE_VFIELD (variants) = TYPE_VFIELD (t);
1803 TYPE_METHODS (variants) = TYPE_METHODS (t);
1804 TYPE_FIELDS (variants) = TYPE_FIELDS (t);
1808 /* Early variant fixups: we apply attributes at the beginning of the class
1809 definition, and we need to fix up any variants that have already been
1810 made via elaborated-type-specifier so that check_qualified_type works. */
1812 void
1813 fixup_attribute_variants (tree t)
1815 tree variants;
1817 if (!t)
1818 return;
1820 for (variants = TYPE_NEXT_VARIANT (t);
1821 variants;
1822 variants = TYPE_NEXT_VARIANT (variants))
1824 /* These are the two fields that check_qualified_type looks at and
1825 are affected by attributes. */
1826 TYPE_ATTRIBUTES (variants) = TYPE_ATTRIBUTES (t);
1827 TYPE_ALIGN (variants) = TYPE_ALIGN (t);
1831 /* Set memoizing fields and bits of T (and its variants) for later
1832 use. */
1834 static void
1835 finish_struct_bits (tree t)
1837 /* Fix up variants (if any). */
1838 fixup_type_variants (t);
1840 if (BINFO_N_BASE_BINFOS (TYPE_BINFO (t)) && TYPE_POLYMORPHIC_P (t))
1841 /* For a class w/o baseclasses, 'finish_struct' has set
1842 CLASSTYPE_PURE_VIRTUALS correctly (by definition).
1843 Similarly for a class whose base classes do not have vtables.
1844 When neither of these is true, we might have removed abstract
1845 virtuals (by providing a definition), added some (by declaring
1846 new ones), or redeclared ones from a base class. We need to
1847 recalculate what's really an abstract virtual at this point (by
1848 looking in the vtables). */
1849 get_pure_virtuals (t);
1851 /* If this type has a copy constructor or a destructor, force its
1852 mode to be BLKmode, and force its TREE_ADDRESSABLE bit to be
1853 nonzero. This will cause it to be passed by invisible reference
1854 and prevent it from being returned in a register. */
1855 if (type_has_nontrivial_copy_init (t)
1856 || TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t))
1858 tree variants;
1859 DECL_MODE (TYPE_MAIN_DECL (t)) = BLKmode;
1860 for (variants = t; variants; variants = TYPE_NEXT_VARIANT (variants))
1862 SET_TYPE_MODE (variants, BLKmode);
1863 TREE_ADDRESSABLE (variants) = 1;
1868 /* Issue warnings about T having private constructors, but no friends,
1869 and so forth.
1871 HAS_NONPRIVATE_METHOD is nonzero if T has any non-private methods or
1872 static members. HAS_NONPRIVATE_STATIC_FN is nonzero if T has any
1873 non-private static member functions. */
1875 static void
1876 maybe_warn_about_overly_private_class (tree t)
1878 int has_member_fn = 0;
1879 int has_nonprivate_method = 0;
1880 tree fn;
1882 if (!warn_ctor_dtor_privacy
1883 /* If the class has friends, those entities might create and
1884 access instances, so we should not warn. */
1885 || (CLASSTYPE_FRIEND_CLASSES (t)
1886 || DECL_FRIENDLIST (TYPE_MAIN_DECL (t)))
1887 /* We will have warned when the template was declared; there's
1888 no need to warn on every instantiation. */
1889 || CLASSTYPE_TEMPLATE_INSTANTIATION (t))
1890 /* There's no reason to even consider warning about this
1891 class. */
1892 return;
1894 /* We only issue one warning, if more than one applies, because
1895 otherwise, on code like:
1897 class A {
1898 // Oops - forgot `public:'
1899 A();
1900 A(const A&);
1901 ~A();
1904 we warn several times about essentially the same problem. */
1906 /* Check to see if all (non-constructor, non-destructor) member
1907 functions are private. (Since there are no friends or
1908 non-private statics, we can't ever call any of the private member
1909 functions.) */
1910 for (fn = TYPE_METHODS (t); fn; fn = DECL_CHAIN (fn))
1911 /* We're not interested in compiler-generated methods; they don't
1912 provide any way to call private members. */
1913 if (!DECL_ARTIFICIAL (fn))
1915 if (!TREE_PRIVATE (fn))
1917 if (DECL_STATIC_FUNCTION_P (fn))
1918 /* A non-private static member function is just like a
1919 friend; it can create and invoke private member
1920 functions, and be accessed without a class
1921 instance. */
1922 return;
1924 has_nonprivate_method = 1;
1925 /* Keep searching for a static member function. */
1927 else if (!DECL_CONSTRUCTOR_P (fn) && !DECL_DESTRUCTOR_P (fn))
1928 has_member_fn = 1;
1931 if (!has_nonprivate_method && has_member_fn)
1933 /* There are no non-private methods, and there's at least one
1934 private member function that isn't a constructor or
1935 destructor. (If all the private members are
1936 constructors/destructors we want to use the code below that
1937 issues error messages specifically referring to
1938 constructors/destructors.) */
1939 unsigned i;
1940 tree binfo = TYPE_BINFO (t);
1942 for (i = 0; i != BINFO_N_BASE_BINFOS (binfo); i++)
1943 if (BINFO_BASE_ACCESS (binfo, i) != access_private_node)
1945 has_nonprivate_method = 1;
1946 break;
1948 if (!has_nonprivate_method)
1950 warning (OPT_Wctor_dtor_privacy,
1951 "all member functions in class %qT are private", t);
1952 return;
1956 /* Even if some of the member functions are non-private, the class
1957 won't be useful for much if all the constructors or destructors
1958 are private: such an object can never be created or destroyed. */
1959 fn = CLASSTYPE_DESTRUCTORS (t);
1960 if (fn && TREE_PRIVATE (fn))
1962 warning (OPT_Wctor_dtor_privacy,
1963 "%q#T only defines a private destructor and has no friends",
1965 return;
1968 /* Warn about classes that have private constructors and no friends. */
1969 if (TYPE_HAS_USER_CONSTRUCTOR (t)
1970 /* Implicitly generated constructors are always public. */
1971 && (!CLASSTYPE_LAZY_DEFAULT_CTOR (t)
1972 || !CLASSTYPE_LAZY_COPY_CTOR (t)))
1974 int nonprivate_ctor = 0;
1976 /* If a non-template class does not define a copy
1977 constructor, one is defined for it, enabling it to avoid
1978 this warning. For a template class, this does not
1979 happen, and so we would normally get a warning on:
1981 template <class T> class C { private: C(); };
1983 To avoid this asymmetry, we check TYPE_HAS_COPY_CTOR. All
1984 complete non-template or fully instantiated classes have this
1985 flag set. */
1986 if (!TYPE_HAS_COPY_CTOR (t))
1987 nonprivate_ctor = 1;
1988 else
1989 for (fn = CLASSTYPE_CONSTRUCTORS (t); fn; fn = OVL_NEXT (fn))
1991 tree ctor = OVL_CURRENT (fn);
1992 /* Ideally, we wouldn't count copy constructors (or, in
1993 fact, any constructor that takes an argument of the
1994 class type as a parameter) because such things cannot
1995 be used to construct an instance of the class unless
1996 you already have one. But, for now at least, we're
1997 more generous. */
1998 if (! TREE_PRIVATE (ctor))
2000 nonprivate_ctor = 1;
2001 break;
2005 if (nonprivate_ctor == 0)
2007 warning (OPT_Wctor_dtor_privacy,
2008 "%q#T only defines private constructors and has no friends",
2010 return;
2015 static struct {
2016 gt_pointer_operator new_value;
2017 void *cookie;
2018 } resort_data;
2020 /* Comparison function to compare two TYPE_METHOD_VEC entries by name. */
2022 static int
2023 method_name_cmp (const void* m1_p, const void* m2_p)
2025 const tree *const m1 = (const tree *) m1_p;
2026 const tree *const m2 = (const tree *) m2_p;
2028 if (*m1 == NULL_TREE && *m2 == NULL_TREE)
2029 return 0;
2030 if (*m1 == NULL_TREE)
2031 return -1;
2032 if (*m2 == NULL_TREE)
2033 return 1;
2034 if (DECL_NAME (OVL_CURRENT (*m1)) < DECL_NAME (OVL_CURRENT (*m2)))
2035 return -1;
2036 return 1;
2039 /* This routine compares two fields like method_name_cmp but using the
2040 pointer operator in resort_field_decl_data. */
2042 static int
2043 resort_method_name_cmp (const void* m1_p, const void* m2_p)
2045 const tree *const m1 = (const tree *) m1_p;
2046 const tree *const m2 = (const tree *) m2_p;
2047 if (*m1 == NULL_TREE && *m2 == NULL_TREE)
2048 return 0;
2049 if (*m1 == NULL_TREE)
2050 return -1;
2051 if (*m2 == NULL_TREE)
2052 return 1;
2054 tree d1 = DECL_NAME (OVL_CURRENT (*m1));
2055 tree d2 = DECL_NAME (OVL_CURRENT (*m2));
2056 resort_data.new_value (&d1, resort_data.cookie);
2057 resort_data.new_value (&d2, resort_data.cookie);
2058 if (d1 < d2)
2059 return -1;
2061 return 1;
2064 /* Resort TYPE_METHOD_VEC because pointers have been reordered. */
2066 void
2067 resort_type_method_vec (void* obj,
2068 void* /*orig_obj*/,
2069 gt_pointer_operator new_value,
2070 void* cookie)
2072 vec<tree, va_gc> *method_vec = (vec<tree, va_gc> *) obj;
2073 int len = vec_safe_length (method_vec);
2074 size_t slot;
2075 tree fn;
2077 /* The type conversion ops have to live at the front of the vec, so we
2078 can't sort them. */
2079 for (slot = CLASSTYPE_FIRST_CONVERSION_SLOT;
2080 vec_safe_iterate (method_vec, slot, &fn);
2081 ++slot)
2082 if (!DECL_CONV_FN_P (OVL_CURRENT (fn)))
2083 break;
2085 if (len - slot > 1)
2087 resort_data.new_value = new_value;
2088 resort_data.cookie = cookie;
2089 qsort (method_vec->address () + slot, len - slot, sizeof (tree),
2090 resort_method_name_cmp);
2094 /* Warn about duplicate methods in fn_fields.
2096 Sort methods that are not special (i.e., constructors, destructors,
2097 and type conversion operators) so that we can find them faster in
2098 search. */
2100 static void
2101 finish_struct_methods (tree t)
2103 tree fn_fields;
2104 vec<tree, va_gc> *method_vec;
2105 int slot, len;
2107 method_vec = CLASSTYPE_METHOD_VEC (t);
2108 if (!method_vec)
2109 return;
2111 len = method_vec->length ();
2113 /* Clear DECL_IN_AGGR_P for all functions. */
2114 for (fn_fields = TYPE_METHODS (t); fn_fields;
2115 fn_fields = DECL_CHAIN (fn_fields))
2116 DECL_IN_AGGR_P (fn_fields) = 0;
2118 /* Issue warnings about private constructors and such. If there are
2119 no methods, then some public defaults are generated. */
2120 maybe_warn_about_overly_private_class (t);
2122 /* The type conversion ops have to live at the front of the vec, so we
2123 can't sort them. */
2124 for (slot = CLASSTYPE_FIRST_CONVERSION_SLOT;
2125 method_vec->iterate (slot, &fn_fields);
2126 ++slot)
2127 if (!DECL_CONV_FN_P (OVL_CURRENT (fn_fields)))
2128 break;
2129 if (len - slot > 1)
2130 qsort (method_vec->address () + slot,
2131 len-slot, sizeof (tree), method_name_cmp);
2134 /* Make BINFO's vtable have N entries, including RTTI entries,
2135 vbase and vcall offsets, etc. Set its type and call the back end
2136 to lay it out. */
2138 static void
2139 layout_vtable_decl (tree binfo, int n)
2141 tree atype;
2142 tree vtable;
2144 atype = build_array_of_n_type (vtable_entry_type, n);
2145 layout_type (atype);
2147 /* We may have to grow the vtable. */
2148 vtable = get_vtbl_decl_for_binfo (binfo);
2149 if (!same_type_p (TREE_TYPE (vtable), atype))
2151 TREE_TYPE (vtable) = atype;
2152 DECL_SIZE (vtable) = DECL_SIZE_UNIT (vtable) = NULL_TREE;
2153 layout_decl (vtable, 0);
2157 /* True iff FNDECL and BASE_FNDECL (both non-static member functions)
2158 have the same signature. */
2161 same_signature_p (const_tree fndecl, const_tree base_fndecl)
2163 /* One destructor overrides another if they are the same kind of
2164 destructor. */
2165 if (DECL_DESTRUCTOR_P (base_fndecl) && DECL_DESTRUCTOR_P (fndecl)
2166 && special_function_p (base_fndecl) == special_function_p (fndecl))
2167 return 1;
2168 /* But a non-destructor never overrides a destructor, nor vice
2169 versa, nor do different kinds of destructors override
2170 one-another. For example, a complete object destructor does not
2171 override a deleting destructor. */
2172 if (DECL_DESTRUCTOR_P (base_fndecl) || DECL_DESTRUCTOR_P (fndecl))
2173 return 0;
2175 if (DECL_NAME (fndecl) == DECL_NAME (base_fndecl)
2176 || (DECL_CONV_FN_P (fndecl)
2177 && DECL_CONV_FN_P (base_fndecl)
2178 && same_type_p (DECL_CONV_FN_TYPE (fndecl),
2179 DECL_CONV_FN_TYPE (base_fndecl))))
2181 tree fntype = TREE_TYPE (fndecl);
2182 tree base_fntype = TREE_TYPE (base_fndecl);
2183 if (type_memfn_quals (fntype) == type_memfn_quals (base_fntype)
2184 && type_memfn_rqual (fntype) == type_memfn_rqual (base_fntype)
2185 && compparms (FUNCTION_FIRST_USER_PARMTYPE (fndecl),
2186 FUNCTION_FIRST_USER_PARMTYPE (base_fndecl)))
2187 return 1;
2189 return 0;
2192 /* Returns TRUE if DERIVED is a binfo containing the binfo BASE as a
2193 subobject. */
2195 static bool
2196 base_derived_from (tree derived, tree base)
2198 tree probe;
2200 for (probe = base; probe; probe = BINFO_INHERITANCE_CHAIN (probe))
2202 if (probe == derived)
2203 return true;
2204 else if (BINFO_VIRTUAL_P (probe))
2205 /* If we meet a virtual base, we can't follow the inheritance
2206 any more. See if the complete type of DERIVED contains
2207 such a virtual base. */
2208 return (binfo_for_vbase (BINFO_TYPE (probe), BINFO_TYPE (derived))
2209 != NULL_TREE);
2211 return false;
2214 typedef struct find_final_overrider_data_s {
2215 /* The function for which we are trying to find a final overrider. */
2216 tree fn;
2217 /* The base class in which the function was declared. */
2218 tree declaring_base;
2219 /* The candidate overriders. */
2220 tree candidates;
2221 /* Path to most derived. */
2222 vec<tree> path;
2223 } find_final_overrider_data;
2225 /* Add the overrider along the current path to FFOD->CANDIDATES.
2226 Returns true if an overrider was found; false otherwise. */
2228 static bool
2229 dfs_find_final_overrider_1 (tree binfo,
2230 find_final_overrider_data *ffod,
2231 unsigned depth)
2233 tree method;
2235 /* If BINFO is not the most derived type, try a more derived class.
2236 A definition there will overrider a definition here. */
2237 if (depth)
2239 depth--;
2240 if (dfs_find_final_overrider_1
2241 (ffod->path[depth], ffod, depth))
2242 return true;
2245 method = look_for_overrides_here (BINFO_TYPE (binfo), ffod->fn);
2246 if (method)
2248 tree *candidate = &ffod->candidates;
2250 /* Remove any candidates overridden by this new function. */
2251 while (*candidate)
2253 /* If *CANDIDATE overrides METHOD, then METHOD
2254 cannot override anything else on the list. */
2255 if (base_derived_from (TREE_VALUE (*candidate), binfo))
2256 return true;
2257 /* If METHOD overrides *CANDIDATE, remove *CANDIDATE. */
2258 if (base_derived_from (binfo, TREE_VALUE (*candidate)))
2259 *candidate = TREE_CHAIN (*candidate);
2260 else
2261 candidate = &TREE_CHAIN (*candidate);
2264 /* Add the new function. */
2265 ffod->candidates = tree_cons (method, binfo, ffod->candidates);
2266 return true;
2269 return false;
2272 /* Called from find_final_overrider via dfs_walk. */
2274 static tree
2275 dfs_find_final_overrider_pre (tree binfo, void *data)
2277 find_final_overrider_data *ffod = (find_final_overrider_data *) data;
2279 if (binfo == ffod->declaring_base)
2280 dfs_find_final_overrider_1 (binfo, ffod, ffod->path.length ());
2281 ffod->path.safe_push (binfo);
2283 return NULL_TREE;
2286 static tree
2287 dfs_find_final_overrider_post (tree /*binfo*/, void *data)
2289 find_final_overrider_data *ffod = (find_final_overrider_data *) data;
2290 ffod->path.pop ();
2292 return NULL_TREE;
2295 /* Returns a TREE_LIST whose TREE_PURPOSE is the final overrider for
2296 FN and whose TREE_VALUE is the binfo for the base where the
2297 overriding occurs. BINFO (in the hierarchy dominated by the binfo
2298 DERIVED) is the base object in which FN is declared. */
2300 static tree
2301 find_final_overrider (tree derived, tree binfo, tree fn)
2303 find_final_overrider_data ffod;
2305 /* Getting this right is a little tricky. This is valid:
2307 struct S { virtual void f (); };
2308 struct T { virtual void f (); };
2309 struct U : public S, public T { };
2311 even though calling `f' in `U' is ambiguous. But,
2313 struct R { virtual void f(); };
2314 struct S : virtual public R { virtual void f (); };
2315 struct T : virtual public R { virtual void f (); };
2316 struct U : public S, public T { };
2318 is not -- there's no way to decide whether to put `S::f' or
2319 `T::f' in the vtable for `R'.
2321 The solution is to look at all paths to BINFO. If we find
2322 different overriders along any two, then there is a problem. */
2323 if (DECL_THUNK_P (fn))
2324 fn = THUNK_TARGET (fn);
2326 /* Determine the depth of the hierarchy. */
2327 ffod.fn = fn;
2328 ffod.declaring_base = binfo;
2329 ffod.candidates = NULL_TREE;
2330 ffod.path.create (30);
2332 dfs_walk_all (derived, dfs_find_final_overrider_pre,
2333 dfs_find_final_overrider_post, &ffod);
2335 ffod.path.release ();
2337 /* If there was no winner, issue an error message. */
2338 if (!ffod.candidates || TREE_CHAIN (ffod.candidates))
2339 return error_mark_node;
2341 return ffod.candidates;
2344 /* Return the index of the vcall offset for FN when TYPE is used as a
2345 virtual base. */
2347 static tree
2348 get_vcall_index (tree fn, tree type)
2350 vec<tree_pair_s, va_gc> *indices = CLASSTYPE_VCALL_INDICES (type);
2351 tree_pair_p p;
2352 unsigned ix;
2354 FOR_EACH_VEC_SAFE_ELT (indices, ix, p)
2355 if ((DECL_DESTRUCTOR_P (fn) && DECL_DESTRUCTOR_P (p->purpose))
2356 || same_signature_p (fn, p->purpose))
2357 return p->value;
2359 /* There should always be an appropriate index. */
2360 gcc_unreachable ();
2363 /* Update an entry in the vtable for BINFO, which is in the hierarchy
2364 dominated by T. FN is the old function; VIRTUALS points to the
2365 corresponding position in the new BINFO_VIRTUALS list. IX is the index
2366 of that entry in the list. */
2368 static void
2369 update_vtable_entry_for_fn (tree t, tree binfo, tree fn, tree* virtuals,
2370 unsigned ix)
2372 tree b;
2373 tree overrider;
2374 tree delta;
2375 tree virtual_base;
2376 tree first_defn;
2377 tree overrider_fn, overrider_target;
2378 tree target_fn = DECL_THUNK_P (fn) ? THUNK_TARGET (fn) : fn;
2379 tree over_return, base_return;
2380 bool lost = false;
2382 /* Find the nearest primary base (possibly binfo itself) which defines
2383 this function; this is the class the caller will convert to when
2384 calling FN through BINFO. */
2385 for (b = binfo; ; b = get_primary_binfo (b))
2387 gcc_assert (b);
2388 if (look_for_overrides_here (BINFO_TYPE (b), target_fn))
2389 break;
2391 /* The nearest definition is from a lost primary. */
2392 if (BINFO_LOST_PRIMARY_P (b))
2393 lost = true;
2395 first_defn = b;
2397 /* Find the final overrider. */
2398 overrider = find_final_overrider (TYPE_BINFO (t), b, target_fn);
2399 if (overrider == error_mark_node)
2401 error ("no unique final overrider for %qD in %qT", target_fn, t);
2402 return;
2404 overrider_target = overrider_fn = TREE_PURPOSE (overrider);
2406 /* Check for adjusting covariant return types. */
2407 over_return = TREE_TYPE (TREE_TYPE (overrider_target));
2408 base_return = TREE_TYPE (TREE_TYPE (target_fn));
2410 if (POINTER_TYPE_P (over_return)
2411 && TREE_CODE (over_return) == TREE_CODE (base_return)
2412 && CLASS_TYPE_P (TREE_TYPE (over_return))
2413 && CLASS_TYPE_P (TREE_TYPE (base_return))
2414 /* If the overrider is invalid, don't even try. */
2415 && !DECL_INVALID_OVERRIDER_P (overrider_target))
2417 /* If FN is a covariant thunk, we must figure out the adjustment
2418 to the final base FN was converting to. As OVERRIDER_TARGET might
2419 also be converting to the return type of FN, we have to
2420 combine the two conversions here. */
2421 tree fixed_offset, virtual_offset;
2423 over_return = TREE_TYPE (over_return);
2424 base_return = TREE_TYPE (base_return);
2426 if (DECL_THUNK_P (fn))
2428 gcc_assert (DECL_RESULT_THUNK_P (fn));
2429 fixed_offset = ssize_int (THUNK_FIXED_OFFSET (fn));
2430 virtual_offset = THUNK_VIRTUAL_OFFSET (fn);
2432 else
2433 fixed_offset = virtual_offset = NULL_TREE;
2435 if (virtual_offset)
2436 /* Find the equivalent binfo within the return type of the
2437 overriding function. We will want the vbase offset from
2438 there. */
2439 virtual_offset = binfo_for_vbase (BINFO_TYPE (virtual_offset),
2440 over_return);
2441 else if (!same_type_ignoring_top_level_qualifiers_p
2442 (over_return, base_return))
2444 /* There was no existing virtual thunk (which takes
2445 precedence). So find the binfo of the base function's
2446 return type within the overriding function's return type.
2447 We cannot call lookup base here, because we're inside a
2448 dfs_walk, and will therefore clobber the BINFO_MARKED
2449 flags. Fortunately we know the covariancy is valid (it
2450 has already been checked), so we can just iterate along
2451 the binfos, which have been chained in inheritance graph
2452 order. Of course it is lame that we have to repeat the
2453 search here anyway -- we should really be caching pieces
2454 of the vtable and avoiding this repeated work. */
2455 tree thunk_binfo, base_binfo;
2457 /* Find the base binfo within the overriding function's
2458 return type. We will always find a thunk_binfo, except
2459 when the covariancy is invalid (which we will have
2460 already diagnosed). */
2461 for (base_binfo = TYPE_BINFO (base_return),
2462 thunk_binfo = TYPE_BINFO (over_return);
2463 thunk_binfo;
2464 thunk_binfo = TREE_CHAIN (thunk_binfo))
2465 if (SAME_BINFO_TYPE_P (BINFO_TYPE (thunk_binfo),
2466 BINFO_TYPE (base_binfo)))
2467 break;
2469 /* See if virtual inheritance is involved. */
2470 for (virtual_offset = thunk_binfo;
2471 virtual_offset;
2472 virtual_offset = BINFO_INHERITANCE_CHAIN (virtual_offset))
2473 if (BINFO_VIRTUAL_P (virtual_offset))
2474 break;
2476 if (virtual_offset
2477 || (thunk_binfo && !BINFO_OFFSET_ZEROP (thunk_binfo)))
2479 tree offset = convert (ssizetype, BINFO_OFFSET (thunk_binfo));
2481 if (virtual_offset)
2483 /* We convert via virtual base. Adjust the fixed
2484 offset to be from there. */
2485 offset =
2486 size_diffop (offset,
2487 convert (ssizetype,
2488 BINFO_OFFSET (virtual_offset)));
2490 if (fixed_offset)
2491 /* There was an existing fixed offset, this must be
2492 from the base just converted to, and the base the
2493 FN was thunking to. */
2494 fixed_offset = size_binop (PLUS_EXPR, fixed_offset, offset);
2495 else
2496 fixed_offset = offset;
2500 if (fixed_offset || virtual_offset)
2501 /* Replace the overriding function with a covariant thunk. We
2502 will emit the overriding function in its own slot as
2503 well. */
2504 overrider_fn = make_thunk (overrider_target, /*this_adjusting=*/0,
2505 fixed_offset, virtual_offset);
2507 else
2508 gcc_assert (DECL_INVALID_OVERRIDER_P (overrider_target) ||
2509 !DECL_THUNK_P (fn));
2511 /* If we need a covariant thunk, then we may need to adjust first_defn.
2512 The ABI specifies that the thunks emitted with a function are
2513 determined by which bases the function overrides, so we need to be
2514 sure that we're using a thunk for some overridden base; even if we
2515 know that the necessary this adjustment is zero, there may not be an
2516 appropriate zero-this-adjusment thunk for us to use since thunks for
2517 overriding virtual bases always use the vcall offset.
2519 Furthermore, just choosing any base that overrides this function isn't
2520 quite right, as this slot won't be used for calls through a type that
2521 puts a covariant thunk here. Calling the function through such a type
2522 will use a different slot, and that slot is the one that determines
2523 the thunk emitted for that base.
2525 So, keep looking until we find the base that we're really overriding
2526 in this slot: the nearest primary base that doesn't use a covariant
2527 thunk in this slot. */
2528 if (overrider_target != overrider_fn)
2530 if (BINFO_TYPE (b) == DECL_CONTEXT (overrider_target))
2531 /* We already know that the overrider needs a covariant thunk. */
2532 b = get_primary_binfo (b);
2533 for (; ; b = get_primary_binfo (b))
2535 tree main_binfo = TYPE_BINFO (BINFO_TYPE (b));
2536 tree bv = chain_index (ix, BINFO_VIRTUALS (main_binfo));
2537 if (!DECL_THUNK_P (TREE_VALUE (bv)))
2538 break;
2539 if (BINFO_LOST_PRIMARY_P (b))
2540 lost = true;
2542 first_defn = b;
2545 /* Assume that we will produce a thunk that convert all the way to
2546 the final overrider, and not to an intermediate virtual base. */
2547 virtual_base = NULL_TREE;
2549 /* See if we can convert to an intermediate virtual base first, and then
2550 use the vcall offset located there to finish the conversion. */
2551 for (; b; b = BINFO_INHERITANCE_CHAIN (b))
2553 /* If we find the final overrider, then we can stop
2554 walking. */
2555 if (SAME_BINFO_TYPE_P (BINFO_TYPE (b),
2556 BINFO_TYPE (TREE_VALUE (overrider))))
2557 break;
2559 /* If we find a virtual base, and we haven't yet found the
2560 overrider, then there is a virtual base between the
2561 declaring base (first_defn) and the final overrider. */
2562 if (BINFO_VIRTUAL_P (b))
2564 virtual_base = b;
2565 break;
2569 /* Compute the constant adjustment to the `this' pointer. The
2570 `this' pointer, when this function is called, will point at BINFO
2571 (or one of its primary bases, which are at the same offset). */
2572 if (virtual_base)
2573 /* The `this' pointer needs to be adjusted from the declaration to
2574 the nearest virtual base. */
2575 delta = size_diffop_loc (input_location,
2576 convert (ssizetype, BINFO_OFFSET (virtual_base)),
2577 convert (ssizetype, BINFO_OFFSET (first_defn)));
2578 else if (lost)
2579 /* If the nearest definition is in a lost primary, we don't need an
2580 entry in our vtable. Except possibly in a constructor vtable,
2581 if we happen to get our primary back. In that case, the offset
2582 will be zero, as it will be a primary base. */
2583 delta = size_zero_node;
2584 else
2585 /* The `this' pointer needs to be adjusted from pointing to
2586 BINFO to pointing at the base where the final overrider
2587 appears. */
2588 delta = size_diffop_loc (input_location,
2589 convert (ssizetype,
2590 BINFO_OFFSET (TREE_VALUE (overrider))),
2591 convert (ssizetype, BINFO_OFFSET (binfo)));
2593 modify_vtable_entry (t, binfo, overrider_fn, delta, virtuals);
2595 if (virtual_base)
2596 BV_VCALL_INDEX (*virtuals)
2597 = get_vcall_index (overrider_target, BINFO_TYPE (virtual_base));
2598 else
2599 BV_VCALL_INDEX (*virtuals) = NULL_TREE;
2601 BV_LOST_PRIMARY (*virtuals) = lost;
2604 /* Called from modify_all_vtables via dfs_walk. */
2606 static tree
2607 dfs_modify_vtables (tree binfo, void* data)
2609 tree t = (tree) data;
2610 tree virtuals;
2611 tree old_virtuals;
2612 unsigned ix;
2614 if (!TYPE_CONTAINS_VPTR_P (BINFO_TYPE (binfo)))
2615 /* A base without a vtable needs no modification, and its bases
2616 are uninteresting. */
2617 return dfs_skip_bases;
2619 if (SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), t)
2620 && !CLASSTYPE_HAS_PRIMARY_BASE_P (t))
2621 /* Don't do the primary vtable, if it's new. */
2622 return NULL_TREE;
2624 if (BINFO_PRIMARY_P (binfo) && !BINFO_VIRTUAL_P (binfo))
2625 /* There's no need to modify the vtable for a non-virtual primary
2626 base; we're not going to use that vtable anyhow. We do still
2627 need to do this for virtual primary bases, as they could become
2628 non-primary in a construction vtable. */
2629 return NULL_TREE;
2631 make_new_vtable (t, binfo);
2633 /* Now, go through each of the virtual functions in the virtual
2634 function table for BINFO. Find the final overrider, and update
2635 the BINFO_VIRTUALS list appropriately. */
2636 for (ix = 0, virtuals = BINFO_VIRTUALS (binfo),
2637 old_virtuals = BINFO_VIRTUALS (TYPE_BINFO (BINFO_TYPE (binfo)));
2638 virtuals;
2639 ix++, virtuals = TREE_CHAIN (virtuals),
2640 old_virtuals = TREE_CHAIN (old_virtuals))
2641 update_vtable_entry_for_fn (t,
2642 binfo,
2643 BV_FN (old_virtuals),
2644 &virtuals, ix);
2646 return NULL_TREE;
2649 /* Update all of the primary and secondary vtables for T. Create new
2650 vtables as required, and initialize their RTTI information. Each
2651 of the functions in VIRTUALS is declared in T and may override a
2652 virtual function from a base class; find and modify the appropriate
2653 entries to point to the overriding functions. Returns a list, in
2654 declaration order, of the virtual functions that are declared in T,
2655 but do not appear in the primary base class vtable, and which
2656 should therefore be appended to the end of the vtable for T. */
2658 static tree
2659 modify_all_vtables (tree t, tree virtuals)
2661 tree binfo = TYPE_BINFO (t);
2662 tree *fnsp;
2664 /* Mangle the vtable name before entering dfs_walk (c++/51884). */
2665 if (TYPE_CONTAINS_VPTR_P (t))
2666 get_vtable_decl (t, false);
2668 /* Update all of the vtables. */
2669 dfs_walk_once (binfo, dfs_modify_vtables, NULL, t);
2671 /* Add virtual functions not already in our primary vtable. These
2672 will be both those introduced by this class, and those overridden
2673 from secondary bases. It does not include virtuals merely
2674 inherited from secondary bases. */
2675 for (fnsp = &virtuals; *fnsp; )
2677 tree fn = TREE_VALUE (*fnsp);
2679 if (!value_member (fn, BINFO_VIRTUALS (binfo))
2680 || DECL_VINDEX (fn) == error_mark_node)
2682 /* We don't need to adjust the `this' pointer when
2683 calling this function. */
2684 BV_DELTA (*fnsp) = integer_zero_node;
2685 BV_VCALL_INDEX (*fnsp) = NULL_TREE;
2687 /* This is a function not already in our vtable. Keep it. */
2688 fnsp = &TREE_CHAIN (*fnsp);
2690 else
2691 /* We've already got an entry for this function. Skip it. */
2692 *fnsp = TREE_CHAIN (*fnsp);
2695 return virtuals;
2698 /* Get the base virtual function declarations in T that have the
2699 indicated NAME. */
2701 static tree
2702 get_basefndecls (tree name, tree t)
2704 tree methods;
2705 tree base_fndecls = NULL_TREE;
2706 int n_baseclasses = BINFO_N_BASE_BINFOS (TYPE_BINFO (t));
2707 int i;
2709 /* Find virtual functions in T with the indicated NAME. */
2710 i = lookup_fnfields_1 (t, name);
2711 if (i != -1)
2712 for (methods = (*CLASSTYPE_METHOD_VEC (t))[i];
2713 methods;
2714 methods = OVL_NEXT (methods))
2716 tree method = OVL_CURRENT (methods);
2718 if (TREE_CODE (method) == FUNCTION_DECL
2719 && DECL_VINDEX (method))
2720 base_fndecls = tree_cons (NULL_TREE, method, base_fndecls);
2723 if (base_fndecls)
2724 return base_fndecls;
2726 for (i = 0; i < n_baseclasses; i++)
2728 tree basetype = BINFO_TYPE (BINFO_BASE_BINFO (TYPE_BINFO (t), i));
2729 base_fndecls = chainon (get_basefndecls (name, basetype),
2730 base_fndecls);
2733 return base_fndecls;
2736 /* If this declaration supersedes the declaration of
2737 a method declared virtual in the base class, then
2738 mark this field as being virtual as well. */
2740 void
2741 check_for_override (tree decl, tree ctype)
2743 bool overrides_found = false;
2744 if (TREE_CODE (decl) == TEMPLATE_DECL)
2745 /* In [temp.mem] we have:
2747 A specialization of a member function template does not
2748 override a virtual function from a base class. */
2749 return;
2750 if ((DECL_DESTRUCTOR_P (decl)
2751 || IDENTIFIER_VIRTUAL_P (DECL_NAME (decl))
2752 || DECL_CONV_FN_P (decl))
2753 && look_for_overrides (ctype, decl)
2754 && !DECL_STATIC_FUNCTION_P (decl))
2755 /* Set DECL_VINDEX to a value that is neither an INTEGER_CST nor
2756 the error_mark_node so that we know it is an overriding
2757 function. */
2759 DECL_VINDEX (decl) = decl;
2760 overrides_found = true;
2763 if (DECL_VIRTUAL_P (decl))
2765 if (!DECL_VINDEX (decl))
2766 DECL_VINDEX (decl) = error_mark_node;
2767 IDENTIFIER_VIRTUAL_P (DECL_NAME (decl)) = 1;
2768 if (DECL_DESTRUCTOR_P (decl))
2769 TYPE_HAS_NONTRIVIAL_DESTRUCTOR (ctype) = true;
2771 else if (DECL_FINAL_P (decl))
2772 error ("%q+#D marked %<final%>, but is not virtual", decl);
2773 if (DECL_OVERRIDE_P (decl) && !overrides_found)
2774 error ("%q+#D marked %<override%>, but does not override", decl);
2777 /* Warn about hidden virtual functions that are not overridden in t.
2778 We know that constructors and destructors don't apply. */
2780 static void
2781 warn_hidden (tree t)
2783 vec<tree, va_gc> *method_vec = CLASSTYPE_METHOD_VEC (t);
2784 tree fns;
2785 size_t i;
2787 /* We go through each separately named virtual function. */
2788 for (i = CLASSTYPE_FIRST_CONVERSION_SLOT;
2789 vec_safe_iterate (method_vec, i, &fns);
2790 ++i)
2792 tree fn;
2793 tree name;
2794 tree fndecl;
2795 tree base_fndecls;
2796 tree base_binfo;
2797 tree binfo;
2798 int j;
2800 /* All functions in this slot in the CLASSTYPE_METHOD_VEC will
2801 have the same name. Figure out what name that is. */
2802 name = DECL_NAME (OVL_CURRENT (fns));
2803 /* There are no possibly hidden functions yet. */
2804 base_fndecls = NULL_TREE;
2805 /* Iterate through all of the base classes looking for possibly
2806 hidden functions. */
2807 for (binfo = TYPE_BINFO (t), j = 0;
2808 BINFO_BASE_ITERATE (binfo, j, base_binfo); j++)
2810 tree basetype = BINFO_TYPE (base_binfo);
2811 base_fndecls = chainon (get_basefndecls (name, basetype),
2812 base_fndecls);
2815 /* If there are no functions to hide, continue. */
2816 if (!base_fndecls)
2817 continue;
2819 /* Remove any overridden functions. */
2820 for (fn = fns; fn; fn = OVL_NEXT (fn))
2822 fndecl = OVL_CURRENT (fn);
2823 if (DECL_VINDEX (fndecl))
2825 tree *prev = &base_fndecls;
2827 while (*prev)
2828 /* If the method from the base class has the same
2829 signature as the method from the derived class, it
2830 has been overridden. */
2831 if (same_signature_p (fndecl, TREE_VALUE (*prev)))
2832 *prev = TREE_CHAIN (*prev);
2833 else
2834 prev = &TREE_CHAIN (*prev);
2838 /* Now give a warning for all base functions without overriders,
2839 as they are hidden. */
2840 while (base_fndecls)
2842 /* Here we know it is a hider, and no overrider exists. */
2843 warning (OPT_Woverloaded_virtual, "%q+D was hidden", TREE_VALUE (base_fndecls));
2844 warning (OPT_Woverloaded_virtual, " by %q+D", fns);
2845 base_fndecls = TREE_CHAIN (base_fndecls);
2850 /* Recursive helper for finish_struct_anon. */
2852 static void
2853 finish_struct_anon_r (tree field, bool complain)
2855 bool is_union = TREE_CODE (TREE_TYPE (field)) == UNION_TYPE;
2856 tree elt = TYPE_FIELDS (TREE_TYPE (field));
2857 for (; elt; elt = DECL_CHAIN (elt))
2859 /* We're generally only interested in entities the user
2860 declared, but we also find nested classes by noticing
2861 the TYPE_DECL that we create implicitly. You're
2862 allowed to put one anonymous union inside another,
2863 though, so we explicitly tolerate that. We use
2864 TYPE_ANONYMOUS_P rather than ANON_AGGR_TYPE_P so that
2865 we also allow unnamed types used for defining fields. */
2866 if (DECL_ARTIFICIAL (elt)
2867 && (!DECL_IMPLICIT_TYPEDEF_P (elt)
2868 || TYPE_ANONYMOUS_P (TREE_TYPE (elt))))
2869 continue;
2871 if (TREE_CODE (elt) != FIELD_DECL)
2873 /* We already complained about static data members in
2874 finish_static_data_member_decl. */
2875 if (complain && TREE_CODE (elt) != VAR_DECL)
2877 if (is_union)
2878 permerror (input_location,
2879 "%q+#D invalid; an anonymous union can "
2880 "only have non-static data members", elt);
2881 else
2882 permerror (input_location,
2883 "%q+#D invalid; an anonymous struct can "
2884 "only have non-static data members", elt);
2886 continue;
2889 if (complain)
2891 if (TREE_PRIVATE (elt))
2893 if (is_union)
2894 permerror (input_location,
2895 "private member %q+#D in anonymous union", elt);
2896 else
2897 permerror (input_location,
2898 "private member %q+#D in anonymous struct", elt);
2900 else if (TREE_PROTECTED (elt))
2902 if (is_union)
2903 permerror (input_location,
2904 "protected member %q+#D in anonymous union", elt);
2905 else
2906 permerror (input_location,
2907 "protected member %q+#D in anonymous struct", elt);
2911 TREE_PRIVATE (elt) = TREE_PRIVATE (field);
2912 TREE_PROTECTED (elt) = TREE_PROTECTED (field);
2914 /* Recurse into the anonymous aggregates to handle correctly
2915 access control (c++/24926):
2917 class A {
2918 union {
2919 union {
2920 int i;
2925 int j=A().i; */
2926 if (DECL_NAME (elt) == NULL_TREE
2927 && ANON_AGGR_TYPE_P (TREE_TYPE (elt)))
2928 finish_struct_anon_r (elt, /*complain=*/false);
2932 /* Check for things that are invalid. There are probably plenty of other
2933 things we should check for also. */
2935 static void
2936 finish_struct_anon (tree t)
2938 for (tree field = TYPE_FIELDS (t); field; field = DECL_CHAIN (field))
2940 if (TREE_STATIC (field))
2941 continue;
2942 if (TREE_CODE (field) != FIELD_DECL)
2943 continue;
2945 if (DECL_NAME (field) == NULL_TREE
2946 && ANON_AGGR_TYPE_P (TREE_TYPE (field)))
2947 finish_struct_anon_r (field, /*complain=*/true);
2951 /* Add T to CLASSTYPE_DECL_LIST of current_class_type which
2952 will be used later during class template instantiation.
2953 When FRIEND_P is zero, T can be a static member data (VAR_DECL),
2954 a non-static member data (FIELD_DECL), a member function
2955 (FUNCTION_DECL), a nested type (RECORD_TYPE, ENUM_TYPE),
2956 a typedef (TYPE_DECL) or a member class template (TEMPLATE_DECL)
2957 When FRIEND_P is nonzero, T is either a friend class
2958 (RECORD_TYPE, TEMPLATE_DECL) or a friend function
2959 (FUNCTION_DECL, TEMPLATE_DECL). */
2961 void
2962 maybe_add_class_template_decl_list (tree type, tree t, int friend_p)
2964 /* Save some memory by not creating TREE_LIST if TYPE is not template. */
2965 if (CLASSTYPE_TEMPLATE_INFO (type))
2966 CLASSTYPE_DECL_LIST (type)
2967 = tree_cons (friend_p ? NULL_TREE : type,
2968 t, CLASSTYPE_DECL_LIST (type));
2971 /* This function is called from declare_virt_assop_and_dtor via
2972 dfs_walk_all.
2974 DATA is a type that direcly or indirectly inherits the base
2975 represented by BINFO. If BINFO contains a virtual assignment [copy
2976 assignment or move assigment] operator or a virtual constructor,
2977 declare that function in DATA if it hasn't been already declared. */
2979 static tree
2980 dfs_declare_virt_assop_and_dtor (tree binfo, void *data)
2982 tree bv, fn, t = (tree)data;
2983 tree opname = ansi_assopname (NOP_EXPR);
2985 gcc_assert (t && CLASS_TYPE_P (t));
2986 gcc_assert (binfo && TREE_CODE (binfo) == TREE_BINFO);
2988 if (!TYPE_CONTAINS_VPTR_P (BINFO_TYPE (binfo)))
2989 /* A base without a vtable needs no modification, and its bases
2990 are uninteresting. */
2991 return dfs_skip_bases;
2993 if (BINFO_PRIMARY_P (binfo))
2994 /* If this is a primary base, then we have already looked at the
2995 virtual functions of its vtable. */
2996 return NULL_TREE;
2998 for (bv = BINFO_VIRTUALS (binfo); bv; bv = TREE_CHAIN (bv))
3000 fn = BV_FN (bv);
3002 if (DECL_NAME (fn) == opname)
3004 if (CLASSTYPE_LAZY_COPY_ASSIGN (t))
3005 lazily_declare_fn (sfk_copy_assignment, t);
3006 if (CLASSTYPE_LAZY_MOVE_ASSIGN (t))
3007 lazily_declare_fn (sfk_move_assignment, t);
3009 else if (DECL_DESTRUCTOR_P (fn)
3010 && CLASSTYPE_LAZY_DESTRUCTOR (t))
3011 lazily_declare_fn (sfk_destructor, t);
3014 return NULL_TREE;
3017 /* If the class type T has a direct or indirect base that contains a
3018 virtual assignment operator or a virtual destructor, declare that
3019 function in T if it hasn't been already declared. */
3021 static void
3022 declare_virt_assop_and_dtor (tree t)
3024 if (!(TYPE_POLYMORPHIC_P (t)
3025 && (CLASSTYPE_LAZY_COPY_ASSIGN (t)
3026 || CLASSTYPE_LAZY_MOVE_ASSIGN (t)
3027 || CLASSTYPE_LAZY_DESTRUCTOR (t))))
3028 return;
3030 dfs_walk_all (TYPE_BINFO (t),
3031 dfs_declare_virt_assop_and_dtor,
3032 NULL, t);
3035 /* Declare the inheriting constructor for class T inherited from base
3036 constructor CTOR with the parameter array PARMS of size NPARMS. */
3038 static void
3039 one_inheriting_sig (tree t, tree ctor, tree *parms, int nparms)
3041 /* We don't declare an inheriting ctor that would be a default,
3042 copy or move ctor for derived or base. */
3043 if (nparms == 0)
3044 return;
3045 if (nparms == 1
3046 && TREE_CODE (parms[0]) == REFERENCE_TYPE)
3048 tree parm = TYPE_MAIN_VARIANT (TREE_TYPE (parms[0]));
3049 if (parm == t || parm == DECL_CONTEXT (ctor))
3050 return;
3053 tree parmlist = void_list_node;
3054 for (int i = nparms - 1; i >= 0; i--)
3055 parmlist = tree_cons (NULL_TREE, parms[i], parmlist);
3056 tree fn = implicitly_declare_fn (sfk_inheriting_constructor,
3057 t, false, ctor, parmlist);
3058 if (add_method (t, fn, NULL_TREE))
3060 DECL_CHAIN (fn) = TYPE_METHODS (t);
3061 TYPE_METHODS (t) = fn;
3065 /* Declare all the inheriting constructors for class T inherited from base
3066 constructor CTOR. */
3068 static void
3069 one_inherited_ctor (tree ctor, tree t)
3071 tree parms = FUNCTION_FIRST_USER_PARMTYPE (ctor);
3073 tree *new_parms = XALLOCAVEC (tree, list_length (parms));
3074 int i = 0;
3075 for (; parms && parms != void_list_node; parms = TREE_CHAIN (parms))
3077 if (TREE_PURPOSE (parms))
3078 one_inheriting_sig (t, ctor, new_parms, i);
3079 new_parms[i++] = TREE_VALUE (parms);
3081 one_inheriting_sig (t, ctor, new_parms, i);
3082 if (parms == NULL_TREE)
3084 if (warning (OPT_Winherited_variadic_ctor,
3085 "the ellipsis in %qD is not inherited", ctor))
3086 inform (DECL_SOURCE_LOCATION (ctor), "%qD declared here", ctor);
3090 /* Create default constructors, assignment operators, and so forth for
3091 the type indicated by T, if they are needed. CANT_HAVE_CONST_CTOR,
3092 and CANT_HAVE_CONST_ASSIGNMENT are nonzero if, for whatever reason,
3093 the class cannot have a default constructor, copy constructor
3094 taking a const reference argument, or an assignment operator taking
3095 a const reference, respectively. */
3097 static void
3098 add_implicitly_declared_members (tree t, tree* access_decls,
3099 int cant_have_const_cctor,
3100 int cant_have_const_assignment)
3102 bool move_ok = false;
3104 if (cxx_dialect >= cxx11 && !CLASSTYPE_DESTRUCTORS (t)
3105 && !TYPE_HAS_COPY_CTOR (t) && !TYPE_HAS_COPY_ASSIGN (t)
3106 && !type_has_move_constructor (t) && !type_has_move_assign (t))
3107 move_ok = true;
3109 /* Destructor. */
3110 if (!CLASSTYPE_DESTRUCTORS (t))
3112 /* In general, we create destructors lazily. */
3113 CLASSTYPE_LAZY_DESTRUCTOR (t) = 1;
3115 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t)
3116 && TYPE_FOR_JAVA (t))
3117 /* But if this is a Java class, any non-trivial destructor is
3118 invalid, even if compiler-generated. Therefore, if the
3119 destructor is non-trivial we create it now. */
3120 lazily_declare_fn (sfk_destructor, t);
3123 /* [class.ctor]
3125 If there is no user-declared constructor for a class, a default
3126 constructor is implicitly declared. */
3127 if (! TYPE_HAS_USER_CONSTRUCTOR (t))
3129 TYPE_HAS_DEFAULT_CONSTRUCTOR (t) = 1;
3130 CLASSTYPE_LAZY_DEFAULT_CTOR (t) = 1;
3131 if (cxx_dialect >= cxx11)
3132 TYPE_HAS_CONSTEXPR_CTOR (t)
3133 /* This might force the declaration. */
3134 = type_has_constexpr_default_constructor (t);
3137 /* [class.ctor]
3139 If a class definition does not explicitly declare a copy
3140 constructor, one is declared implicitly. */
3141 if (! TYPE_HAS_COPY_CTOR (t) && ! TYPE_FOR_JAVA (t))
3143 TYPE_HAS_COPY_CTOR (t) = 1;
3144 TYPE_HAS_CONST_COPY_CTOR (t) = !cant_have_const_cctor;
3145 CLASSTYPE_LAZY_COPY_CTOR (t) = 1;
3146 if (move_ok)
3147 CLASSTYPE_LAZY_MOVE_CTOR (t) = 1;
3150 /* If there is no assignment operator, one will be created if and
3151 when it is needed. For now, just record whether or not the type
3152 of the parameter to the assignment operator will be a const or
3153 non-const reference. */
3154 if (!TYPE_HAS_COPY_ASSIGN (t) && !TYPE_FOR_JAVA (t))
3156 TYPE_HAS_COPY_ASSIGN (t) = 1;
3157 TYPE_HAS_CONST_COPY_ASSIGN (t) = !cant_have_const_assignment;
3158 CLASSTYPE_LAZY_COPY_ASSIGN (t) = 1;
3159 if (move_ok)
3160 CLASSTYPE_LAZY_MOVE_ASSIGN (t) = 1;
3163 /* We can't be lazy about declaring functions that might override
3164 a virtual function from a base class. */
3165 declare_virt_assop_and_dtor (t);
3167 while (*access_decls)
3169 tree using_decl = TREE_VALUE (*access_decls);
3170 tree decl = USING_DECL_DECLS (using_decl);
3171 if (DECL_NAME (using_decl) == ctor_identifier)
3173 /* declare, then remove the decl */
3174 tree ctor_list = decl;
3175 location_t loc = input_location;
3176 input_location = DECL_SOURCE_LOCATION (using_decl);
3177 if (ctor_list)
3178 for (; ctor_list; ctor_list = OVL_NEXT (ctor_list))
3179 one_inherited_ctor (OVL_CURRENT (ctor_list), t);
3180 *access_decls = TREE_CHAIN (*access_decls);
3181 input_location = loc;
3183 else
3184 access_decls = &TREE_CHAIN (*access_decls);
3188 /* Subroutine of insert_into_classtype_sorted_fields. Recursively
3189 count the number of fields in TYPE, including anonymous union
3190 members. */
3192 static int
3193 count_fields (tree fields)
3195 tree x;
3196 int n_fields = 0;
3197 for (x = fields; x; x = DECL_CHAIN (x))
3199 if (TREE_CODE (x) == FIELD_DECL && ANON_AGGR_TYPE_P (TREE_TYPE (x)))
3200 n_fields += count_fields (TYPE_FIELDS (TREE_TYPE (x)));
3201 else
3202 n_fields += 1;
3204 return n_fields;
3207 /* Subroutine of insert_into_classtype_sorted_fields. Recursively add
3208 all the fields in the TREE_LIST FIELDS to the SORTED_FIELDS_TYPE
3209 elts, starting at offset IDX. */
3211 static int
3212 add_fields_to_record_type (tree fields, struct sorted_fields_type *field_vec, int idx)
3214 tree x;
3215 for (x = fields; x; x = DECL_CHAIN (x))
3217 if (TREE_CODE (x) == FIELD_DECL && ANON_AGGR_TYPE_P (TREE_TYPE (x)))
3218 idx = add_fields_to_record_type (TYPE_FIELDS (TREE_TYPE (x)), field_vec, idx);
3219 else
3220 field_vec->elts[idx++] = x;
3222 return idx;
3225 /* Add all of the enum values of ENUMTYPE, to the FIELD_VEC elts,
3226 starting at offset IDX. */
3228 static int
3229 add_enum_fields_to_record_type (tree enumtype,
3230 struct sorted_fields_type *field_vec,
3231 int idx)
3233 tree values;
3234 for (values = TYPE_VALUES (enumtype); values; values = TREE_CHAIN (values))
3235 field_vec->elts[idx++] = TREE_VALUE (values);
3236 return idx;
3239 /* FIELD is a bit-field. We are finishing the processing for its
3240 enclosing type. Issue any appropriate messages and set appropriate
3241 flags. Returns false if an error has been diagnosed. */
3243 static bool
3244 check_bitfield_decl (tree field)
3246 tree type = TREE_TYPE (field);
3247 tree w;
3249 /* Extract the declared width of the bitfield, which has been
3250 temporarily stashed in DECL_INITIAL. */
3251 w = DECL_INITIAL (field);
3252 gcc_assert (w != NULL_TREE);
3253 /* Remove the bit-field width indicator so that the rest of the
3254 compiler does not treat that value as an initializer. */
3255 DECL_INITIAL (field) = NULL_TREE;
3257 /* Detect invalid bit-field type. */
3258 if (!INTEGRAL_OR_ENUMERATION_TYPE_P (type))
3260 error ("bit-field %q+#D with non-integral type", field);
3261 w = error_mark_node;
3263 else
3265 location_t loc = input_location;
3266 /* Avoid the non_lvalue wrapper added by fold for PLUS_EXPRs. */
3267 STRIP_NOPS (w);
3269 /* detect invalid field size. */
3270 input_location = DECL_SOURCE_LOCATION (field);
3271 w = cxx_constant_value (w);
3272 input_location = loc;
3274 if (TREE_CODE (w) != INTEGER_CST)
3276 error ("bit-field %q+D width not an integer constant", field);
3277 w = error_mark_node;
3279 else if (tree_int_cst_sgn (w) < 0)
3281 error ("negative width in bit-field %q+D", field);
3282 w = error_mark_node;
3284 else if (integer_zerop (w) && DECL_NAME (field) != 0)
3286 error ("zero width for bit-field %q+D", field);
3287 w = error_mark_node;
3289 else if ((TREE_CODE (type) != ENUMERAL_TYPE
3290 && TREE_CODE (type) != BOOLEAN_TYPE
3291 && compare_tree_int (w, TYPE_PRECISION (type)) > 0)
3292 || ((TREE_CODE (type) == ENUMERAL_TYPE
3293 || TREE_CODE (type) == BOOLEAN_TYPE)
3294 && tree_int_cst_lt (TYPE_SIZE (type), w)))
3295 warning (0, "width of %q+D exceeds its type", field);
3296 else if (TREE_CODE (type) == ENUMERAL_TYPE
3297 && (0 > (compare_tree_int
3298 (w, TYPE_PRECISION (ENUM_UNDERLYING_TYPE (type))))))
3299 warning (0, "%q+D is too small to hold all values of %q#T", field, type);
3302 if (w != error_mark_node)
3304 DECL_SIZE (field) = convert (bitsizetype, w);
3305 DECL_BIT_FIELD (field) = 1;
3306 return true;
3308 else
3310 /* Non-bit-fields are aligned for their type. */
3311 DECL_BIT_FIELD (field) = 0;
3312 CLEAR_DECL_C_BIT_FIELD (field);
3313 return false;
3317 /* FIELD is a non bit-field. We are finishing the processing for its
3318 enclosing type T. Issue any appropriate messages and set appropriate
3319 flags. */
3321 static void
3322 check_field_decl (tree field,
3323 tree t,
3324 int* cant_have_const_ctor,
3325 int* no_const_asn_ref,
3326 int* any_default_members)
3328 tree type = strip_array_types (TREE_TYPE (field));
3330 /* In C++98 an anonymous union cannot contain any fields which would change
3331 the settings of CANT_HAVE_CONST_CTOR and friends. */
3332 if (ANON_UNION_TYPE_P (type) && cxx_dialect < cxx11)
3334 /* And, we don't set TYPE_HAS_CONST_COPY_CTOR, etc., for anonymous
3335 structs. So, we recurse through their fields here. */
3336 else if (ANON_AGGR_TYPE_P (type))
3338 tree fields;
3340 for (fields = TYPE_FIELDS (type); fields; fields = DECL_CHAIN (fields))
3341 if (TREE_CODE (fields) == FIELD_DECL && !DECL_C_BIT_FIELD (field))
3342 check_field_decl (fields, t, cant_have_const_ctor,
3343 no_const_asn_ref, any_default_members);
3345 /* Check members with class type for constructors, destructors,
3346 etc. */
3347 else if (CLASS_TYPE_P (type))
3349 /* Never let anything with uninheritable virtuals
3350 make it through without complaint. */
3351 abstract_virtuals_error (field, type);
3353 if (TREE_CODE (t) == UNION_TYPE && cxx_dialect < cxx11)
3355 static bool warned;
3356 int oldcount = errorcount;
3357 if (TYPE_NEEDS_CONSTRUCTING (type))
3358 error ("member %q+#D with constructor not allowed in union",
3359 field);
3360 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type))
3361 error ("member %q+#D with destructor not allowed in union", field);
3362 if (TYPE_HAS_COMPLEX_COPY_ASSIGN (type))
3363 error ("member %q+#D with copy assignment operator not allowed in union",
3364 field);
3365 if (!warned && errorcount > oldcount)
3367 inform (DECL_SOURCE_LOCATION (field), "unrestricted unions "
3368 "only available with -std=c++11 or -std=gnu++11");
3369 warned = true;
3372 else
3374 TYPE_NEEDS_CONSTRUCTING (t) |= TYPE_NEEDS_CONSTRUCTING (type);
3375 TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t)
3376 |= TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type);
3377 TYPE_HAS_COMPLEX_COPY_ASSIGN (t)
3378 |= (TYPE_HAS_COMPLEX_COPY_ASSIGN (type)
3379 || !TYPE_HAS_COPY_ASSIGN (type));
3380 TYPE_HAS_COMPLEX_COPY_CTOR (t) |= (TYPE_HAS_COMPLEX_COPY_CTOR (type)
3381 || !TYPE_HAS_COPY_CTOR (type));
3382 TYPE_HAS_COMPLEX_MOVE_ASSIGN (t) |= TYPE_HAS_COMPLEX_MOVE_ASSIGN (type);
3383 TYPE_HAS_COMPLEX_MOVE_CTOR (t) |= TYPE_HAS_COMPLEX_MOVE_CTOR (type);
3384 TYPE_HAS_COMPLEX_DFLT (t) |= (!TYPE_HAS_DEFAULT_CONSTRUCTOR (type)
3385 || TYPE_HAS_COMPLEX_DFLT (type));
3388 if (TYPE_HAS_COPY_CTOR (type)
3389 && !TYPE_HAS_CONST_COPY_CTOR (type))
3390 *cant_have_const_ctor = 1;
3392 if (TYPE_HAS_COPY_ASSIGN (type)
3393 && !TYPE_HAS_CONST_COPY_ASSIGN (type))
3394 *no_const_asn_ref = 1;
3397 check_abi_tags (t, field);
3399 if (DECL_INITIAL (field) != NULL_TREE)
3401 /* `build_class_init_list' does not recognize
3402 non-FIELD_DECLs. */
3403 if (TREE_CODE (t) == UNION_TYPE && *any_default_members != 0)
3404 error ("multiple fields in union %qT initialized", t);
3405 *any_default_members = 1;
3409 /* Check the data members (both static and non-static), class-scoped
3410 typedefs, etc., appearing in the declaration of T. Issue
3411 appropriate diagnostics. Sets ACCESS_DECLS to a list (in
3412 declaration order) of access declarations; each TREE_VALUE in this
3413 list is a USING_DECL.
3415 In addition, set the following flags:
3417 EMPTY_P
3418 The class is empty, i.e., contains no non-static data members.
3420 CANT_HAVE_CONST_CTOR_P
3421 This class cannot have an implicitly generated copy constructor
3422 taking a const reference.
3424 CANT_HAVE_CONST_ASN_REF
3425 This class cannot have an implicitly generated assignment
3426 operator taking a const reference.
3428 All of these flags should be initialized before calling this
3429 function.
3431 Returns a pointer to the end of the TYPE_FIELDs chain; additional
3432 fields can be added by adding to this chain. */
3434 static void
3435 check_field_decls (tree t, tree *access_decls,
3436 int *cant_have_const_ctor_p,
3437 int *no_const_asn_ref_p)
3439 tree *field;
3440 tree *next;
3441 bool has_pointers;
3442 int any_default_members;
3443 int cant_pack = 0;
3444 int field_access = -1;
3446 /* Assume there are no access declarations. */
3447 *access_decls = NULL_TREE;
3448 /* Assume this class has no pointer members. */
3449 has_pointers = false;
3450 /* Assume none of the members of this class have default
3451 initializations. */
3452 any_default_members = 0;
3454 for (field = &TYPE_FIELDS (t); *field; field = next)
3456 tree x = *field;
3457 tree type = TREE_TYPE (x);
3458 int this_field_access;
3460 next = &DECL_CHAIN (x);
3462 if (TREE_CODE (x) == USING_DECL)
3464 /* Save the access declarations for our caller. */
3465 *access_decls = tree_cons (NULL_TREE, x, *access_decls);
3466 continue;
3469 if (TREE_CODE (x) == TYPE_DECL
3470 || TREE_CODE (x) == TEMPLATE_DECL)
3471 continue;
3473 /* If we've gotten this far, it's a data member, possibly static,
3474 or an enumerator. */
3475 if (TREE_CODE (x) != CONST_DECL)
3476 DECL_CONTEXT (x) = t;
3478 /* When this goes into scope, it will be a non-local reference. */
3479 DECL_NONLOCAL (x) = 1;
3481 if (TREE_CODE (t) == UNION_TYPE
3482 && cxx_dialect < cxx11)
3484 /* [class.union] (C++98)
3486 If a union contains a static data member, or a member of
3487 reference type, the program is ill-formed.
3489 In C++11 this limitation doesn't exist anymore. */
3490 if (VAR_P (x))
3492 error ("in C++98 %q+D may not be static because it is "
3493 "a member of a union", x);
3494 continue;
3496 if (TREE_CODE (type) == REFERENCE_TYPE)
3498 error ("in C++98 %q+D may not have reference type %qT "
3499 "because it is a member of a union", x, type);
3500 continue;
3504 /* Perform error checking that did not get done in
3505 grokdeclarator. */
3506 if (TREE_CODE (type) == FUNCTION_TYPE)
3508 error ("field %q+D invalidly declared function type", x);
3509 type = build_pointer_type (type);
3510 TREE_TYPE (x) = type;
3512 else if (TREE_CODE (type) == METHOD_TYPE)
3514 error ("field %q+D invalidly declared method type", x);
3515 type = build_pointer_type (type);
3516 TREE_TYPE (x) = type;
3519 if (type == error_mark_node)
3520 continue;
3522 if (TREE_CODE (x) == CONST_DECL || VAR_P (x))
3523 continue;
3525 /* Now it can only be a FIELD_DECL. */
3527 if (TREE_PRIVATE (x) || TREE_PROTECTED (x))
3528 CLASSTYPE_NON_AGGREGATE (t) = 1;
3530 /* If at least one non-static data member is non-literal, the whole
3531 class becomes non-literal. Per Core/1453, volatile non-static
3532 data members and base classes are also not allowed.
3533 Note: if the type is incomplete we will complain later on. */
3534 if (COMPLETE_TYPE_P (type)
3535 && (!literal_type_p (type) || CP_TYPE_VOLATILE_P (type)))
3536 CLASSTYPE_LITERAL_P (t) = false;
3538 /* A standard-layout class is a class that:
3540 has the same access control (Clause 11) for all non-static data members,
3541 ... */
3542 this_field_access = TREE_PROTECTED (x) ? 1 : TREE_PRIVATE (x) ? 2 : 0;
3543 if (field_access == -1)
3544 field_access = this_field_access;
3545 else if (this_field_access != field_access)
3546 CLASSTYPE_NON_STD_LAYOUT (t) = 1;
3548 /* If this is of reference type, check if it needs an init. */
3549 if (TREE_CODE (type) == REFERENCE_TYPE)
3551 CLASSTYPE_NON_LAYOUT_POD_P (t) = 1;
3552 CLASSTYPE_NON_STD_LAYOUT (t) = 1;
3553 if (DECL_INITIAL (x) == NULL_TREE)
3554 SET_CLASSTYPE_REF_FIELDS_NEED_INIT (t, 1);
3556 /* ARM $12.6.2: [A member initializer list] (or, for an
3557 aggregate, initialization by a brace-enclosed list) is the
3558 only way to initialize nonstatic const and reference
3559 members. */
3560 TYPE_HAS_COMPLEX_COPY_ASSIGN (t) = 1;
3561 TYPE_HAS_COMPLEX_MOVE_ASSIGN (t) = 1;
3564 type = strip_array_types (type);
3566 if (TYPE_PACKED (t))
3568 if (!layout_pod_type_p (type) && !TYPE_PACKED (type))
3570 warning
3572 "ignoring packed attribute because of unpacked non-POD field %q+#D",
3574 cant_pack = 1;
3576 else if (DECL_C_BIT_FIELD (x)
3577 || TYPE_ALIGN (TREE_TYPE (x)) > BITS_PER_UNIT)
3578 DECL_PACKED (x) = 1;
3581 if (DECL_C_BIT_FIELD (x) && integer_zerop (DECL_INITIAL (x)))
3582 /* We don't treat zero-width bitfields as making a class
3583 non-empty. */
3585 else
3587 /* The class is non-empty. */
3588 CLASSTYPE_EMPTY_P (t) = 0;
3589 /* The class is not even nearly empty. */
3590 CLASSTYPE_NEARLY_EMPTY_P (t) = 0;
3591 /* If one of the data members contains an empty class,
3592 so does T. */
3593 if (CLASS_TYPE_P (type)
3594 && CLASSTYPE_CONTAINS_EMPTY_CLASS_P (type))
3595 CLASSTYPE_CONTAINS_EMPTY_CLASS_P (t) = 1;
3598 /* This is used by -Weffc++ (see below). Warn only for pointers
3599 to members which might hold dynamic memory. So do not warn
3600 for pointers to functions or pointers to members. */
3601 if (TYPE_PTR_P (type)
3602 && !TYPE_PTRFN_P (type))
3603 has_pointers = true;
3605 if (CLASS_TYPE_P (type))
3607 if (CLASSTYPE_REF_FIELDS_NEED_INIT (type))
3608 SET_CLASSTYPE_REF_FIELDS_NEED_INIT (t, 1);
3609 if (CLASSTYPE_READONLY_FIELDS_NEED_INIT (type))
3610 SET_CLASSTYPE_READONLY_FIELDS_NEED_INIT (t, 1);
3613 if (DECL_MUTABLE_P (x) || TYPE_HAS_MUTABLE_P (type))
3614 CLASSTYPE_HAS_MUTABLE (t) = 1;
3616 if (DECL_MUTABLE_P (x))
3618 if (CP_TYPE_CONST_P (type))
3620 error ("member %q+D cannot be declared both %<const%> "
3621 "and %<mutable%>", x);
3622 continue;
3624 if (TREE_CODE (type) == REFERENCE_TYPE)
3626 error ("member %q+D cannot be declared as a %<mutable%> "
3627 "reference", x);
3628 continue;
3632 if (! layout_pod_type_p (type))
3633 /* DR 148 now allows pointers to members (which are POD themselves),
3634 to be allowed in POD structs. */
3635 CLASSTYPE_NON_LAYOUT_POD_P (t) = 1;
3637 if (!std_layout_type_p (type))
3638 CLASSTYPE_NON_STD_LAYOUT (t) = 1;
3640 if (! zero_init_p (type))
3641 CLASSTYPE_NON_ZERO_INIT_P (t) = 1;
3643 /* We set DECL_C_BIT_FIELD in grokbitfield.
3644 If the type and width are valid, we'll also set DECL_BIT_FIELD. */
3645 if (! DECL_C_BIT_FIELD (x) || ! check_bitfield_decl (x))
3646 check_field_decl (x, t,
3647 cant_have_const_ctor_p,
3648 no_const_asn_ref_p,
3649 &any_default_members);
3651 /* Now that we've removed bit-field widths from DECL_INITIAL,
3652 anything left in DECL_INITIAL is an NSDMI that makes the class
3653 non-aggregate. */
3654 if (DECL_INITIAL (x))
3655 CLASSTYPE_NON_AGGREGATE (t) = true;
3657 /* If any field is const, the structure type is pseudo-const. */
3658 if (CP_TYPE_CONST_P (type))
3660 C_TYPE_FIELDS_READONLY (t) = 1;
3661 if (DECL_INITIAL (x) == NULL_TREE)
3662 SET_CLASSTYPE_READONLY_FIELDS_NEED_INIT (t, 1);
3664 /* ARM $12.6.2: [A member initializer list] (or, for an
3665 aggregate, initialization by a brace-enclosed list) is the
3666 only way to initialize nonstatic const and reference
3667 members. */
3668 TYPE_HAS_COMPLEX_COPY_ASSIGN (t) = 1;
3669 TYPE_HAS_COMPLEX_MOVE_ASSIGN (t) = 1;
3671 /* A field that is pseudo-const makes the structure likewise. */
3672 else if (CLASS_TYPE_P (type))
3674 C_TYPE_FIELDS_READONLY (t) |= C_TYPE_FIELDS_READONLY (type);
3675 SET_CLASSTYPE_READONLY_FIELDS_NEED_INIT (t,
3676 CLASSTYPE_READONLY_FIELDS_NEED_INIT (t)
3677 | CLASSTYPE_READONLY_FIELDS_NEED_INIT (type));
3680 /* Core issue 80: A nonstatic data member is required to have a
3681 different name from the class iff the class has a
3682 user-declared constructor. */
3683 if (constructor_name_p (DECL_NAME (x), t)
3684 && TYPE_HAS_USER_CONSTRUCTOR (t))
3685 permerror (input_location, "field %q+#D with same name as class", x);
3688 /* Effective C++ rule 11: if a class has dynamic memory held by pointers,
3689 it should also define a copy constructor and an assignment operator to
3690 implement the correct copy semantic (deep vs shallow, etc.). As it is
3691 not feasible to check whether the constructors do allocate dynamic memory
3692 and store it within members, we approximate the warning like this:
3694 -- Warn only if there are members which are pointers
3695 -- Warn only if there is a non-trivial constructor (otherwise,
3696 there cannot be memory allocated).
3697 -- Warn only if there is a non-trivial destructor. We assume that the
3698 user at least implemented the cleanup correctly, and a destructor
3699 is needed to free dynamic memory.
3701 This seems enough for practical purposes. */
3702 if (warn_ecpp
3703 && has_pointers
3704 && TYPE_HAS_USER_CONSTRUCTOR (t)
3705 && TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t)
3706 && !(TYPE_HAS_COPY_CTOR (t) && TYPE_HAS_COPY_ASSIGN (t)))
3708 warning (OPT_Weffc__, "%q#T has pointer data members", t);
3710 if (! TYPE_HAS_COPY_CTOR (t))
3712 warning (OPT_Weffc__,
3713 " but does not override %<%T(const %T&)%>", t, t);
3714 if (!TYPE_HAS_COPY_ASSIGN (t))
3715 warning (OPT_Weffc__, " or %<operator=(const %T&)%>", t);
3717 else if (! TYPE_HAS_COPY_ASSIGN (t))
3718 warning (OPT_Weffc__,
3719 " but does not override %<operator=(const %T&)%>", t);
3722 /* Non-static data member initializers make the default constructor
3723 non-trivial. */
3724 if (any_default_members)
3726 TYPE_NEEDS_CONSTRUCTING (t) = true;
3727 TYPE_HAS_COMPLEX_DFLT (t) = true;
3730 /* If any of the fields couldn't be packed, unset TYPE_PACKED. */
3731 if (cant_pack)
3732 TYPE_PACKED (t) = 0;
3734 /* Check anonymous struct/anonymous union fields. */
3735 finish_struct_anon (t);
3737 /* We've built up the list of access declarations in reverse order.
3738 Fix that now. */
3739 *access_decls = nreverse (*access_decls);
3742 /* If TYPE is an empty class type, records its OFFSET in the table of
3743 OFFSETS. */
3745 static int
3746 record_subobject_offset (tree type, tree offset, splay_tree offsets)
3748 splay_tree_node n;
3750 if (!is_empty_class (type))
3751 return 0;
3753 /* Record the location of this empty object in OFFSETS. */
3754 n = splay_tree_lookup (offsets, (splay_tree_key) offset);
3755 if (!n)
3756 n = splay_tree_insert (offsets,
3757 (splay_tree_key) offset,
3758 (splay_tree_value) NULL_TREE);
3759 n->value = ((splay_tree_value)
3760 tree_cons (NULL_TREE,
3761 type,
3762 (tree) n->value));
3764 return 0;
3767 /* Returns nonzero if TYPE is an empty class type and there is
3768 already an entry in OFFSETS for the same TYPE as the same OFFSET. */
3770 static int
3771 check_subobject_offset (tree type, tree offset, splay_tree offsets)
3773 splay_tree_node n;
3774 tree t;
3776 if (!is_empty_class (type))
3777 return 0;
3779 /* Record the location of this empty object in OFFSETS. */
3780 n = splay_tree_lookup (offsets, (splay_tree_key) offset);
3781 if (!n)
3782 return 0;
3784 for (t = (tree) n->value; t; t = TREE_CHAIN (t))
3785 if (same_type_p (TREE_VALUE (t), type))
3786 return 1;
3788 return 0;
3791 /* Walk through all the subobjects of TYPE (located at OFFSET). Call
3792 F for every subobject, passing it the type, offset, and table of
3793 OFFSETS. If VBASES_P is one, then virtual non-primary bases should
3794 be traversed.
3796 If MAX_OFFSET is non-NULL, then subobjects with an offset greater
3797 than MAX_OFFSET will not be walked.
3799 If F returns a nonzero value, the traversal ceases, and that value
3800 is returned. Otherwise, returns zero. */
3802 static int
3803 walk_subobject_offsets (tree type,
3804 subobject_offset_fn f,
3805 tree offset,
3806 splay_tree offsets,
3807 tree max_offset,
3808 int vbases_p)
3810 int r = 0;
3811 tree type_binfo = NULL_TREE;
3813 /* If this OFFSET is bigger than the MAX_OFFSET, then we should
3814 stop. */
3815 if (max_offset && tree_int_cst_lt (max_offset, offset))
3816 return 0;
3818 if (type == error_mark_node)
3819 return 0;
3821 if (!TYPE_P (type))
3823 type_binfo = type;
3824 type = BINFO_TYPE (type);
3827 if (CLASS_TYPE_P (type))
3829 tree field;
3830 tree binfo;
3831 int i;
3833 /* Avoid recursing into objects that are not interesting. */
3834 if (!CLASSTYPE_CONTAINS_EMPTY_CLASS_P (type))
3835 return 0;
3837 /* Record the location of TYPE. */
3838 r = (*f) (type, offset, offsets);
3839 if (r)
3840 return r;
3842 /* Iterate through the direct base classes of TYPE. */
3843 if (!type_binfo)
3844 type_binfo = TYPE_BINFO (type);
3845 for (i = 0; BINFO_BASE_ITERATE (type_binfo, i, binfo); i++)
3847 tree binfo_offset;
3849 if (BINFO_VIRTUAL_P (binfo))
3850 continue;
3852 tree orig_binfo;
3853 /* We cannot rely on BINFO_OFFSET being set for the base
3854 class yet, but the offsets for direct non-virtual
3855 bases can be calculated by going back to the TYPE. */
3856 orig_binfo = BINFO_BASE_BINFO (TYPE_BINFO (type), i);
3857 binfo_offset = size_binop (PLUS_EXPR,
3858 offset,
3859 BINFO_OFFSET (orig_binfo));
3861 r = walk_subobject_offsets (binfo,
3863 binfo_offset,
3864 offsets,
3865 max_offset,
3866 /*vbases_p=*/0);
3867 if (r)
3868 return r;
3871 if (CLASSTYPE_VBASECLASSES (type))
3873 unsigned ix;
3874 vec<tree, va_gc> *vbases;
3876 /* Iterate through the virtual base classes of TYPE. In G++
3877 3.2, we included virtual bases in the direct base class
3878 loop above, which results in incorrect results; the
3879 correct offsets for virtual bases are only known when
3880 working with the most derived type. */
3881 if (vbases_p)
3882 for (vbases = CLASSTYPE_VBASECLASSES (type), ix = 0;
3883 vec_safe_iterate (vbases, ix, &binfo); ix++)
3885 r = walk_subobject_offsets (binfo,
3887 size_binop (PLUS_EXPR,
3888 offset,
3889 BINFO_OFFSET (binfo)),
3890 offsets,
3891 max_offset,
3892 /*vbases_p=*/0);
3893 if (r)
3894 return r;
3896 else
3898 /* We still have to walk the primary base, if it is
3899 virtual. (If it is non-virtual, then it was walked
3900 above.) */
3901 tree vbase = get_primary_binfo (type_binfo);
3903 if (vbase && BINFO_VIRTUAL_P (vbase)
3904 && BINFO_PRIMARY_P (vbase)
3905 && BINFO_INHERITANCE_CHAIN (vbase) == type_binfo)
3907 r = (walk_subobject_offsets
3908 (vbase, f, offset,
3909 offsets, max_offset, /*vbases_p=*/0));
3910 if (r)
3911 return r;
3916 /* Iterate through the fields of TYPE. */
3917 for (field = TYPE_FIELDS (type); field; field = DECL_CHAIN (field))
3918 if (TREE_CODE (field) == FIELD_DECL
3919 && TREE_TYPE (field) != error_mark_node
3920 && !DECL_ARTIFICIAL (field))
3922 tree field_offset;
3924 field_offset = byte_position (field);
3926 r = walk_subobject_offsets (TREE_TYPE (field),
3928 size_binop (PLUS_EXPR,
3929 offset,
3930 field_offset),
3931 offsets,
3932 max_offset,
3933 /*vbases_p=*/1);
3934 if (r)
3935 return r;
3938 else if (TREE_CODE (type) == ARRAY_TYPE)
3940 tree element_type = strip_array_types (type);
3941 tree domain = TYPE_DOMAIN (type);
3942 tree index;
3944 /* Avoid recursing into objects that are not interesting. */
3945 if (!CLASS_TYPE_P (element_type)
3946 || !CLASSTYPE_CONTAINS_EMPTY_CLASS_P (element_type))
3947 return 0;
3949 /* Step through each of the elements in the array. */
3950 for (index = size_zero_node;
3951 !tree_int_cst_lt (TYPE_MAX_VALUE (domain), index);
3952 index = size_binop (PLUS_EXPR, index, size_one_node))
3954 r = walk_subobject_offsets (TREE_TYPE (type),
3956 offset,
3957 offsets,
3958 max_offset,
3959 /*vbases_p=*/1);
3960 if (r)
3961 return r;
3962 offset = size_binop (PLUS_EXPR, offset,
3963 TYPE_SIZE_UNIT (TREE_TYPE (type)));
3964 /* If this new OFFSET is bigger than the MAX_OFFSET, then
3965 there's no point in iterating through the remaining
3966 elements of the array. */
3967 if (max_offset && tree_int_cst_lt (max_offset, offset))
3968 break;
3972 return 0;
3975 /* Record all of the empty subobjects of TYPE (either a type or a
3976 binfo). If IS_DATA_MEMBER is true, then a non-static data member
3977 is being placed at OFFSET; otherwise, it is a base class that is
3978 being placed at OFFSET. */
3980 static void
3981 record_subobject_offsets (tree type,
3982 tree offset,
3983 splay_tree offsets,
3984 bool is_data_member)
3986 tree max_offset;
3987 /* If recording subobjects for a non-static data member or a
3988 non-empty base class , we do not need to record offsets beyond
3989 the size of the biggest empty class. Additional data members
3990 will go at the end of the class. Additional base classes will go
3991 either at offset zero (if empty, in which case they cannot
3992 overlap with offsets past the size of the biggest empty class) or
3993 at the end of the class.
3995 However, if we are placing an empty base class, then we must record
3996 all offsets, as either the empty class is at offset zero (where
3997 other empty classes might later be placed) or at the end of the
3998 class (where other objects might then be placed, so other empty
3999 subobjects might later overlap). */
4000 if (is_data_member
4001 || !is_empty_class (BINFO_TYPE (type)))
4002 max_offset = sizeof_biggest_empty_class;
4003 else
4004 max_offset = NULL_TREE;
4005 walk_subobject_offsets (type, record_subobject_offset, offset,
4006 offsets, max_offset, is_data_member);
4009 /* Returns nonzero if any of the empty subobjects of TYPE (located at
4010 OFFSET) conflict with entries in OFFSETS. If VBASES_P is nonzero,
4011 virtual bases of TYPE are examined. */
4013 static int
4014 layout_conflict_p (tree type,
4015 tree offset,
4016 splay_tree offsets,
4017 int vbases_p)
4019 splay_tree_node max_node;
4021 /* Get the node in OFFSETS that indicates the maximum offset where
4022 an empty subobject is located. */
4023 max_node = splay_tree_max (offsets);
4024 /* If there aren't any empty subobjects, then there's no point in
4025 performing this check. */
4026 if (!max_node)
4027 return 0;
4029 return walk_subobject_offsets (type, check_subobject_offset, offset,
4030 offsets, (tree) (max_node->key),
4031 vbases_p);
4034 /* DECL is a FIELD_DECL corresponding either to a base subobject of a
4035 non-static data member of the type indicated by RLI. BINFO is the
4036 binfo corresponding to the base subobject, OFFSETS maps offsets to
4037 types already located at those offsets. This function determines
4038 the position of the DECL. */
4040 static void
4041 layout_nonempty_base_or_field (record_layout_info rli,
4042 tree decl,
4043 tree binfo,
4044 splay_tree offsets)
4046 tree offset = NULL_TREE;
4047 bool field_p;
4048 tree type;
4050 if (binfo)
4052 /* For the purposes of determining layout conflicts, we want to
4053 use the class type of BINFO; TREE_TYPE (DECL) will be the
4054 CLASSTYPE_AS_BASE version, which does not contain entries for
4055 zero-sized bases. */
4056 type = TREE_TYPE (binfo);
4057 field_p = false;
4059 else
4061 type = TREE_TYPE (decl);
4062 field_p = true;
4065 /* Try to place the field. It may take more than one try if we have
4066 a hard time placing the field without putting two objects of the
4067 same type at the same address. */
4068 while (1)
4070 struct record_layout_info_s old_rli = *rli;
4072 /* Place this field. */
4073 place_field (rli, decl);
4074 offset = byte_position (decl);
4076 /* We have to check to see whether or not there is already
4077 something of the same type at the offset we're about to use.
4078 For example, consider:
4080 struct S {};
4081 struct T : public S { int i; };
4082 struct U : public S, public T {};
4084 Here, we put S at offset zero in U. Then, we can't put T at
4085 offset zero -- its S component would be at the same address
4086 as the S we already allocated. So, we have to skip ahead.
4087 Since all data members, including those whose type is an
4088 empty class, have nonzero size, any overlap can happen only
4089 with a direct or indirect base-class -- it can't happen with
4090 a data member. */
4091 /* In a union, overlap is permitted; all members are placed at
4092 offset zero. */
4093 if (TREE_CODE (rli->t) == UNION_TYPE)
4094 break;
4095 if (layout_conflict_p (field_p ? type : binfo, offset,
4096 offsets, field_p))
4098 /* Strip off the size allocated to this field. That puts us
4099 at the first place we could have put the field with
4100 proper alignment. */
4101 *rli = old_rli;
4103 /* Bump up by the alignment required for the type. */
4104 rli->bitpos
4105 = size_binop (PLUS_EXPR, rli->bitpos,
4106 bitsize_int (binfo
4107 ? CLASSTYPE_ALIGN (type)
4108 : TYPE_ALIGN (type)));
4109 normalize_rli (rli);
4111 else
4112 /* There was no conflict. We're done laying out this field. */
4113 break;
4116 /* Now that we know where it will be placed, update its
4117 BINFO_OFFSET. */
4118 if (binfo && CLASS_TYPE_P (BINFO_TYPE (binfo)))
4119 /* Indirect virtual bases may have a nonzero BINFO_OFFSET at
4120 this point because their BINFO_OFFSET is copied from another
4121 hierarchy. Therefore, we may not need to add the entire
4122 OFFSET. */
4123 propagate_binfo_offsets (binfo,
4124 size_diffop_loc (input_location,
4125 convert (ssizetype, offset),
4126 convert (ssizetype,
4127 BINFO_OFFSET (binfo))));
4130 /* Returns true if TYPE is empty and OFFSET is nonzero. */
4132 static int
4133 empty_base_at_nonzero_offset_p (tree type,
4134 tree offset,
4135 splay_tree /*offsets*/)
4137 return is_empty_class (type) && !integer_zerop (offset);
4140 /* Layout the empty base BINFO. EOC indicates the byte currently just
4141 past the end of the class, and should be correctly aligned for a
4142 class of the type indicated by BINFO; OFFSETS gives the offsets of
4143 the empty bases allocated so far. T is the most derived
4144 type. Return nonzero iff we added it at the end. */
4146 static bool
4147 layout_empty_base (record_layout_info rli, tree binfo,
4148 tree eoc, splay_tree offsets)
4150 tree alignment;
4151 tree basetype = BINFO_TYPE (binfo);
4152 bool atend = false;
4154 /* This routine should only be used for empty classes. */
4155 gcc_assert (is_empty_class (basetype));
4156 alignment = ssize_int (CLASSTYPE_ALIGN_UNIT (basetype));
4158 if (!integer_zerop (BINFO_OFFSET (binfo)))
4159 propagate_binfo_offsets
4160 (binfo, size_diffop_loc (input_location,
4161 size_zero_node, BINFO_OFFSET (binfo)));
4163 /* This is an empty base class. We first try to put it at offset
4164 zero. */
4165 if (layout_conflict_p (binfo,
4166 BINFO_OFFSET (binfo),
4167 offsets,
4168 /*vbases_p=*/0))
4170 /* That didn't work. Now, we move forward from the next
4171 available spot in the class. */
4172 atend = true;
4173 propagate_binfo_offsets (binfo, convert (ssizetype, eoc));
4174 while (1)
4176 if (!layout_conflict_p (binfo,
4177 BINFO_OFFSET (binfo),
4178 offsets,
4179 /*vbases_p=*/0))
4180 /* We finally found a spot where there's no overlap. */
4181 break;
4183 /* There's overlap here, too. Bump along to the next spot. */
4184 propagate_binfo_offsets (binfo, alignment);
4188 if (CLASSTYPE_USER_ALIGN (basetype))
4190 rli->record_align = MAX (rli->record_align, CLASSTYPE_ALIGN (basetype));
4191 if (warn_packed)
4192 rli->unpacked_align = MAX (rli->unpacked_align, CLASSTYPE_ALIGN (basetype));
4193 TYPE_USER_ALIGN (rli->t) = 1;
4196 return atend;
4199 /* Layout the base given by BINFO in the class indicated by RLI.
4200 *BASE_ALIGN is a running maximum of the alignments of
4201 any base class. OFFSETS gives the location of empty base
4202 subobjects. T is the most derived type. Return nonzero if the new
4203 object cannot be nearly-empty. A new FIELD_DECL is inserted at
4204 *NEXT_FIELD, unless BINFO is for an empty base class.
4206 Returns the location at which the next field should be inserted. */
4208 static tree *
4209 build_base_field (record_layout_info rli, tree binfo,
4210 splay_tree offsets, tree *next_field)
4212 tree t = rli->t;
4213 tree basetype = BINFO_TYPE (binfo);
4215 if (!COMPLETE_TYPE_P (basetype))
4216 /* This error is now reported in xref_tag, thus giving better
4217 location information. */
4218 return next_field;
4220 /* Place the base class. */
4221 if (!is_empty_class (basetype))
4223 tree decl;
4225 /* The containing class is non-empty because it has a non-empty
4226 base class. */
4227 CLASSTYPE_EMPTY_P (t) = 0;
4229 /* Create the FIELD_DECL. */
4230 decl = build_decl (input_location,
4231 FIELD_DECL, NULL_TREE, CLASSTYPE_AS_BASE (basetype));
4232 DECL_ARTIFICIAL (decl) = 1;
4233 DECL_IGNORED_P (decl) = 1;
4234 DECL_FIELD_CONTEXT (decl) = t;
4235 if (CLASSTYPE_AS_BASE (basetype))
4237 DECL_SIZE (decl) = CLASSTYPE_SIZE (basetype);
4238 DECL_SIZE_UNIT (decl) = CLASSTYPE_SIZE_UNIT (basetype);
4239 DECL_ALIGN (decl) = CLASSTYPE_ALIGN (basetype);
4240 DECL_USER_ALIGN (decl) = CLASSTYPE_USER_ALIGN (basetype);
4241 DECL_MODE (decl) = TYPE_MODE (basetype);
4242 DECL_FIELD_IS_BASE (decl) = 1;
4244 /* Try to place the field. It may take more than one try if we
4245 have a hard time placing the field without putting two
4246 objects of the same type at the same address. */
4247 layout_nonempty_base_or_field (rli, decl, binfo, offsets);
4248 /* Add the new FIELD_DECL to the list of fields for T. */
4249 DECL_CHAIN (decl) = *next_field;
4250 *next_field = decl;
4251 next_field = &DECL_CHAIN (decl);
4254 else
4256 tree eoc;
4257 bool atend;
4259 /* On some platforms (ARM), even empty classes will not be
4260 byte-aligned. */
4261 eoc = round_up_loc (input_location,
4262 rli_size_unit_so_far (rli),
4263 CLASSTYPE_ALIGN_UNIT (basetype));
4264 atend = layout_empty_base (rli, binfo, eoc, offsets);
4265 /* A nearly-empty class "has no proper base class that is empty,
4266 not morally virtual, and at an offset other than zero." */
4267 if (!BINFO_VIRTUAL_P (binfo) && CLASSTYPE_NEARLY_EMPTY_P (t))
4269 if (atend)
4270 CLASSTYPE_NEARLY_EMPTY_P (t) = 0;
4271 /* The check above (used in G++ 3.2) is insufficient because
4272 an empty class placed at offset zero might itself have an
4273 empty base at a nonzero offset. */
4274 else if (walk_subobject_offsets (basetype,
4275 empty_base_at_nonzero_offset_p,
4276 size_zero_node,
4277 /*offsets=*/NULL,
4278 /*max_offset=*/NULL_TREE,
4279 /*vbases_p=*/true))
4280 CLASSTYPE_NEARLY_EMPTY_P (t) = 0;
4283 /* We do not create a FIELD_DECL for empty base classes because
4284 it might overlap some other field. We want to be able to
4285 create CONSTRUCTORs for the class by iterating over the
4286 FIELD_DECLs, and the back end does not handle overlapping
4287 FIELD_DECLs. */
4289 /* An empty virtual base causes a class to be non-empty
4290 -- but in that case we do not need to clear CLASSTYPE_EMPTY_P
4291 here because that was already done when the virtual table
4292 pointer was created. */
4295 /* Record the offsets of BINFO and its base subobjects. */
4296 record_subobject_offsets (binfo,
4297 BINFO_OFFSET (binfo),
4298 offsets,
4299 /*is_data_member=*/false);
4301 return next_field;
4304 /* Layout all of the non-virtual base classes. Record empty
4305 subobjects in OFFSETS. T is the most derived type. Return nonzero
4306 if the type cannot be nearly empty. The fields created
4307 corresponding to the base classes will be inserted at
4308 *NEXT_FIELD. */
4310 static void
4311 build_base_fields (record_layout_info rli,
4312 splay_tree offsets, tree *next_field)
4314 /* Chain to hold all the new FIELD_DECLs which stand in for base class
4315 subobjects. */
4316 tree t = rli->t;
4317 int n_baseclasses = BINFO_N_BASE_BINFOS (TYPE_BINFO (t));
4318 int i;
4320 /* The primary base class is always allocated first. */
4321 if (CLASSTYPE_HAS_PRIMARY_BASE_P (t))
4322 next_field = build_base_field (rli, CLASSTYPE_PRIMARY_BINFO (t),
4323 offsets, next_field);
4325 /* Now allocate the rest of the bases. */
4326 for (i = 0; i < n_baseclasses; ++i)
4328 tree base_binfo;
4330 base_binfo = BINFO_BASE_BINFO (TYPE_BINFO (t), i);
4332 /* The primary base was already allocated above, so we don't
4333 need to allocate it again here. */
4334 if (base_binfo == CLASSTYPE_PRIMARY_BINFO (t))
4335 continue;
4337 /* Virtual bases are added at the end (a primary virtual base
4338 will have already been added). */
4339 if (BINFO_VIRTUAL_P (base_binfo))
4340 continue;
4342 next_field = build_base_field (rli, base_binfo,
4343 offsets, next_field);
4347 /* Go through the TYPE_METHODS of T issuing any appropriate
4348 diagnostics, figuring out which methods override which other
4349 methods, and so forth. */
4351 static void
4352 check_methods (tree t)
4354 tree x;
4356 for (x = TYPE_METHODS (t); x; x = DECL_CHAIN (x))
4358 check_for_override (x, t);
4359 if (DECL_PURE_VIRTUAL_P (x) && (TREE_CODE (x) != FUNCTION_DECL || ! DECL_VINDEX (x)))
4360 error ("initializer specified for non-virtual method %q+D", x);
4361 /* The name of the field is the original field name
4362 Save this in auxiliary field for later overloading. */
4363 if (TREE_CODE (x) == FUNCTION_DECL && DECL_VINDEX (x))
4365 TYPE_POLYMORPHIC_P (t) = 1;
4366 if (DECL_PURE_VIRTUAL_P (x))
4367 vec_safe_push (CLASSTYPE_PURE_VIRTUALS (t), x);
4369 /* All user-provided destructors are non-trivial.
4370 Constructors and assignment ops are handled in
4371 grok_special_member_properties. */
4372 if (DECL_DESTRUCTOR_P (x) && user_provided_p (x))
4373 TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t) = 1;
4377 /* FN is a constructor or destructor. Clone the declaration to create
4378 a specialized in-charge or not-in-charge version, as indicated by
4379 NAME. */
4381 static tree
4382 build_clone (tree fn, tree name)
4384 tree parms;
4385 tree clone;
4387 /* Copy the function. */
4388 clone = copy_decl (fn);
4389 /* Reset the function name. */
4390 DECL_NAME (clone) = name;
4391 /* Remember where this function came from. */
4392 DECL_ABSTRACT_ORIGIN (clone) = fn;
4393 /* Make it easy to find the CLONE given the FN. */
4394 DECL_CHAIN (clone) = DECL_CHAIN (fn);
4395 DECL_CHAIN (fn) = clone;
4397 /* If this is a template, do the rest on the DECL_TEMPLATE_RESULT. */
4398 if (TREE_CODE (clone) == TEMPLATE_DECL)
4400 tree result = build_clone (DECL_TEMPLATE_RESULT (clone), name);
4401 DECL_TEMPLATE_RESULT (clone) = result;
4402 DECL_TEMPLATE_INFO (result) = copy_node (DECL_TEMPLATE_INFO (result));
4403 DECL_TI_TEMPLATE (result) = clone;
4404 TREE_TYPE (clone) = TREE_TYPE (result);
4405 return clone;
4408 SET_DECL_ASSEMBLER_NAME (clone, NULL_TREE);
4409 DECL_CLONED_FUNCTION (clone) = fn;
4410 /* There's no pending inline data for this function. */
4411 DECL_PENDING_INLINE_INFO (clone) = NULL;
4412 DECL_PENDING_INLINE_P (clone) = 0;
4414 /* The base-class destructor is not virtual. */
4415 if (name == base_dtor_identifier)
4417 DECL_VIRTUAL_P (clone) = 0;
4418 if (TREE_CODE (clone) != TEMPLATE_DECL)
4419 DECL_VINDEX (clone) = NULL_TREE;
4422 /* If there was an in-charge parameter, drop it from the function
4423 type. */
4424 if (DECL_HAS_IN_CHARGE_PARM_P (clone))
4426 tree basetype;
4427 tree parmtypes;
4428 tree exceptions;
4430 exceptions = TYPE_RAISES_EXCEPTIONS (TREE_TYPE (clone));
4431 basetype = TYPE_METHOD_BASETYPE (TREE_TYPE (clone));
4432 parmtypes = TYPE_ARG_TYPES (TREE_TYPE (clone));
4433 /* Skip the `this' parameter. */
4434 parmtypes = TREE_CHAIN (parmtypes);
4435 /* Skip the in-charge parameter. */
4436 parmtypes = TREE_CHAIN (parmtypes);
4437 /* And the VTT parm, in a complete [cd]tor. */
4438 if (DECL_HAS_VTT_PARM_P (fn)
4439 && ! DECL_NEEDS_VTT_PARM_P (clone))
4440 parmtypes = TREE_CHAIN (parmtypes);
4441 /* If this is subobject constructor or destructor, add the vtt
4442 parameter. */
4443 TREE_TYPE (clone)
4444 = build_method_type_directly (basetype,
4445 TREE_TYPE (TREE_TYPE (clone)),
4446 parmtypes);
4447 if (exceptions)
4448 TREE_TYPE (clone) = build_exception_variant (TREE_TYPE (clone),
4449 exceptions);
4450 TREE_TYPE (clone)
4451 = cp_build_type_attribute_variant (TREE_TYPE (clone),
4452 TYPE_ATTRIBUTES (TREE_TYPE (fn)));
4455 /* Copy the function parameters. */
4456 DECL_ARGUMENTS (clone) = copy_list (DECL_ARGUMENTS (clone));
4457 /* Remove the in-charge parameter. */
4458 if (DECL_HAS_IN_CHARGE_PARM_P (clone))
4460 DECL_CHAIN (DECL_ARGUMENTS (clone))
4461 = DECL_CHAIN (DECL_CHAIN (DECL_ARGUMENTS (clone)));
4462 DECL_HAS_IN_CHARGE_PARM_P (clone) = 0;
4464 /* And the VTT parm, in a complete [cd]tor. */
4465 if (DECL_HAS_VTT_PARM_P (fn))
4467 if (DECL_NEEDS_VTT_PARM_P (clone))
4468 DECL_HAS_VTT_PARM_P (clone) = 1;
4469 else
4471 DECL_CHAIN (DECL_ARGUMENTS (clone))
4472 = DECL_CHAIN (DECL_CHAIN (DECL_ARGUMENTS (clone)));
4473 DECL_HAS_VTT_PARM_P (clone) = 0;
4477 for (parms = DECL_ARGUMENTS (clone); parms; parms = DECL_CHAIN (parms))
4479 DECL_CONTEXT (parms) = clone;
4480 cxx_dup_lang_specific_decl (parms);
4483 /* Create the RTL for this function. */
4484 SET_DECL_RTL (clone, NULL);
4485 rest_of_decl_compilation (clone, /*top_level=*/1, at_eof);
4487 if (pch_file)
4488 note_decl_for_pch (clone);
4490 return clone;
4493 /* Implementation of DECL_CLONED_FUNCTION and DECL_CLONED_FUNCTION_P, do
4494 not invoke this function directly.
4496 For a non-thunk function, returns the address of the slot for storing
4497 the function it is a clone of. Otherwise returns NULL_TREE.
4499 If JUST_TESTING, looks through TEMPLATE_DECL and returns NULL if
4500 cloned_function is unset. This is to support the separate
4501 DECL_CLONED_FUNCTION and DECL_CLONED_FUNCTION_P modes; using the latter
4502 on a template makes sense, but not the former. */
4504 tree *
4505 decl_cloned_function_p (const_tree decl, bool just_testing)
4507 tree *ptr;
4508 if (just_testing)
4509 decl = STRIP_TEMPLATE (decl);
4511 if (TREE_CODE (decl) != FUNCTION_DECL
4512 || !DECL_LANG_SPECIFIC (decl)
4513 || DECL_LANG_SPECIFIC (decl)->u.fn.thunk_p)
4515 #if defined ENABLE_TREE_CHECKING && (GCC_VERSION >= 2007)
4516 if (!just_testing)
4517 lang_check_failed (__FILE__, __LINE__, __FUNCTION__);
4518 else
4519 #endif
4520 return NULL;
4523 ptr = &DECL_LANG_SPECIFIC (decl)->u.fn.u5.cloned_function;
4524 if (just_testing && *ptr == NULL_TREE)
4525 return NULL;
4526 else
4527 return ptr;
4530 /* Produce declarations for all appropriate clones of FN. If
4531 UPDATE_METHOD_VEC_P is nonzero, the clones are added to the
4532 CLASTYPE_METHOD_VEC as well. */
4534 void
4535 clone_function_decl (tree fn, int update_method_vec_p)
4537 tree clone;
4539 /* Avoid inappropriate cloning. */
4540 if (DECL_CHAIN (fn)
4541 && DECL_CLONED_FUNCTION_P (DECL_CHAIN (fn)))
4542 return;
4544 if (DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P (fn))
4546 /* For each constructor, we need two variants: an in-charge version
4547 and a not-in-charge version. */
4548 clone = build_clone (fn, complete_ctor_identifier);
4549 if (update_method_vec_p)
4550 add_method (DECL_CONTEXT (clone), clone, NULL_TREE);
4551 clone = build_clone (fn, base_ctor_identifier);
4552 if (update_method_vec_p)
4553 add_method (DECL_CONTEXT (clone), clone, NULL_TREE);
4555 else
4557 gcc_assert (DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P (fn));
4559 /* For each destructor, we need three variants: an in-charge
4560 version, a not-in-charge version, and an in-charge deleting
4561 version. We clone the deleting version first because that
4562 means it will go second on the TYPE_METHODS list -- and that
4563 corresponds to the correct layout order in the virtual
4564 function table.
4566 For a non-virtual destructor, we do not build a deleting
4567 destructor. */
4568 if (DECL_VIRTUAL_P (fn))
4570 clone = build_clone (fn, deleting_dtor_identifier);
4571 if (update_method_vec_p)
4572 add_method (DECL_CONTEXT (clone), clone, NULL_TREE);
4574 clone = build_clone (fn, complete_dtor_identifier);
4575 if (update_method_vec_p)
4576 add_method (DECL_CONTEXT (clone), clone, NULL_TREE);
4577 clone = build_clone (fn, base_dtor_identifier);
4578 if (update_method_vec_p)
4579 add_method (DECL_CONTEXT (clone), clone, NULL_TREE);
4582 /* Note that this is an abstract function that is never emitted. */
4583 DECL_ABSTRACT (fn) = 1;
4586 /* DECL is an in charge constructor, which is being defined. This will
4587 have had an in class declaration, from whence clones were
4588 declared. An out-of-class definition can specify additional default
4589 arguments. As it is the clones that are involved in overload
4590 resolution, we must propagate the information from the DECL to its
4591 clones. */
4593 void
4594 adjust_clone_args (tree decl)
4596 tree clone;
4598 for (clone = DECL_CHAIN (decl); clone && DECL_CLONED_FUNCTION_P (clone);
4599 clone = DECL_CHAIN (clone))
4601 tree orig_clone_parms = TYPE_ARG_TYPES (TREE_TYPE (clone));
4602 tree orig_decl_parms = TYPE_ARG_TYPES (TREE_TYPE (decl));
4603 tree decl_parms, clone_parms;
4605 clone_parms = orig_clone_parms;
4607 /* Skip the 'this' parameter. */
4608 orig_clone_parms = TREE_CHAIN (orig_clone_parms);
4609 orig_decl_parms = TREE_CHAIN (orig_decl_parms);
4611 if (DECL_HAS_IN_CHARGE_PARM_P (decl))
4612 orig_decl_parms = TREE_CHAIN (orig_decl_parms);
4613 if (DECL_HAS_VTT_PARM_P (decl))
4614 orig_decl_parms = TREE_CHAIN (orig_decl_parms);
4616 clone_parms = orig_clone_parms;
4617 if (DECL_HAS_VTT_PARM_P (clone))
4618 clone_parms = TREE_CHAIN (clone_parms);
4620 for (decl_parms = orig_decl_parms; decl_parms;
4621 decl_parms = TREE_CHAIN (decl_parms),
4622 clone_parms = TREE_CHAIN (clone_parms))
4624 gcc_assert (same_type_p (TREE_TYPE (decl_parms),
4625 TREE_TYPE (clone_parms)));
4627 if (TREE_PURPOSE (decl_parms) && !TREE_PURPOSE (clone_parms))
4629 /* A default parameter has been added. Adjust the
4630 clone's parameters. */
4631 tree exceptions = TYPE_RAISES_EXCEPTIONS (TREE_TYPE (clone));
4632 tree attrs = TYPE_ATTRIBUTES (TREE_TYPE (clone));
4633 tree basetype = TYPE_METHOD_BASETYPE (TREE_TYPE (clone));
4634 tree type;
4636 clone_parms = orig_decl_parms;
4638 if (DECL_HAS_VTT_PARM_P (clone))
4640 clone_parms = tree_cons (TREE_PURPOSE (orig_clone_parms),
4641 TREE_VALUE (orig_clone_parms),
4642 clone_parms);
4643 TREE_TYPE (clone_parms) = TREE_TYPE (orig_clone_parms);
4645 type = build_method_type_directly (basetype,
4646 TREE_TYPE (TREE_TYPE (clone)),
4647 clone_parms);
4648 if (exceptions)
4649 type = build_exception_variant (type, exceptions);
4650 if (attrs)
4651 type = cp_build_type_attribute_variant (type, attrs);
4652 TREE_TYPE (clone) = type;
4654 clone_parms = NULL_TREE;
4655 break;
4658 gcc_assert (!clone_parms);
4662 /* For each of the constructors and destructors in T, create an
4663 in-charge and not-in-charge variant. */
4665 static void
4666 clone_constructors_and_destructors (tree t)
4668 tree fns;
4670 /* If for some reason we don't have a CLASSTYPE_METHOD_VEC, we bail
4671 out now. */
4672 if (!CLASSTYPE_METHOD_VEC (t))
4673 return;
4675 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
4676 clone_function_decl (OVL_CURRENT (fns), /*update_method_vec_p=*/1);
4677 for (fns = CLASSTYPE_DESTRUCTORS (t); fns; fns = OVL_NEXT (fns))
4678 clone_function_decl (OVL_CURRENT (fns), /*update_method_vec_p=*/1);
4681 /* Deduce noexcept for a destructor DTOR. */
4683 void
4684 deduce_noexcept_on_destructor (tree dtor)
4686 if (!TYPE_RAISES_EXCEPTIONS (TREE_TYPE (dtor)))
4688 tree eh_spec = unevaluated_noexcept_spec ();
4689 TREE_TYPE (dtor) = build_exception_variant (TREE_TYPE (dtor), eh_spec);
4693 /* For each destructor in T, deduce noexcept:
4695 12.4/3: A declaration of a destructor that does not have an
4696 exception-specification is implicitly considered to have the
4697 same exception-specification as an implicit declaration (15.4). */
4699 static void
4700 deduce_noexcept_on_destructors (tree t)
4702 /* If for some reason we don't have a CLASSTYPE_METHOD_VEC, we bail
4703 out now. */
4704 if (!CLASSTYPE_METHOD_VEC (t))
4705 return;
4707 for (tree fns = CLASSTYPE_DESTRUCTORS (t); fns; fns = OVL_NEXT (fns))
4708 deduce_noexcept_on_destructor (OVL_CURRENT (fns));
4711 /* Subroutine of set_one_vmethod_tm_attributes. Search base classes
4712 of TYPE for virtual functions which FNDECL overrides. Return a
4713 mask of the tm attributes found therein. */
4715 static int
4716 look_for_tm_attr_overrides (tree type, tree fndecl)
4718 tree binfo = TYPE_BINFO (type);
4719 tree base_binfo;
4720 int ix, found = 0;
4722 for (ix = 0; BINFO_BASE_ITERATE (binfo, ix, base_binfo); ++ix)
4724 tree o, basetype = BINFO_TYPE (base_binfo);
4726 if (!TYPE_POLYMORPHIC_P (basetype))
4727 continue;
4729 o = look_for_overrides_here (basetype, fndecl);
4730 if (o)
4731 found |= tm_attr_to_mask (find_tm_attribute
4732 (TYPE_ATTRIBUTES (TREE_TYPE (o))));
4733 else
4734 found |= look_for_tm_attr_overrides (basetype, fndecl);
4737 return found;
4740 /* Subroutine of set_method_tm_attributes. Handle the checks and
4741 inheritance for one virtual method FNDECL. */
4743 static void
4744 set_one_vmethod_tm_attributes (tree type, tree fndecl)
4746 tree tm_attr;
4747 int found, have;
4749 found = look_for_tm_attr_overrides (type, fndecl);
4751 /* If FNDECL doesn't actually override anything (i.e. T is the
4752 class that first declares FNDECL virtual), then we're done. */
4753 if (found == 0)
4754 return;
4756 tm_attr = find_tm_attribute (TYPE_ATTRIBUTES (TREE_TYPE (fndecl)));
4757 have = tm_attr_to_mask (tm_attr);
4759 /* Intel STM Language Extension 3.0, Section 4.2 table 4:
4760 tm_pure must match exactly, otherwise no weakening of
4761 tm_safe > tm_callable > nothing. */
4762 /* ??? The tm_pure attribute didn't make the transition to the
4763 multivendor language spec. */
4764 if (have == TM_ATTR_PURE)
4766 if (found != TM_ATTR_PURE)
4768 found &= -found;
4769 goto err_override;
4772 /* If the overridden function is tm_pure, then FNDECL must be. */
4773 else if (found == TM_ATTR_PURE && tm_attr)
4774 goto err_override;
4775 /* Look for base class combinations that cannot be satisfied. */
4776 else if (found != TM_ATTR_PURE && (found & TM_ATTR_PURE))
4778 found &= ~TM_ATTR_PURE;
4779 found &= -found;
4780 error_at (DECL_SOURCE_LOCATION (fndecl),
4781 "method overrides both %<transaction_pure%> and %qE methods",
4782 tm_mask_to_attr (found));
4784 /* If FNDECL did not declare an attribute, then inherit the most
4785 restrictive one. */
4786 else if (tm_attr == NULL)
4788 apply_tm_attr (fndecl, tm_mask_to_attr (found & -found));
4790 /* Otherwise validate that we're not weaker than a function
4791 that is being overridden. */
4792 else
4794 found &= -found;
4795 if (found <= TM_ATTR_CALLABLE && have > found)
4796 goto err_override;
4798 return;
4800 err_override:
4801 error_at (DECL_SOURCE_LOCATION (fndecl),
4802 "method declared %qE overriding %qE method",
4803 tm_attr, tm_mask_to_attr (found));
4806 /* For each of the methods in T, propagate a class-level tm attribute. */
4808 static void
4809 set_method_tm_attributes (tree t)
4811 tree class_tm_attr, fndecl;
4813 /* Don't bother collecting tm attributes if transactional memory
4814 support is not enabled. */
4815 if (!flag_tm)
4816 return;
4818 /* Process virtual methods first, as they inherit directly from the
4819 base virtual function and also require validation of new attributes. */
4820 if (TYPE_CONTAINS_VPTR_P (t))
4822 tree vchain;
4823 for (vchain = BINFO_VIRTUALS (TYPE_BINFO (t)); vchain;
4824 vchain = TREE_CHAIN (vchain))
4826 fndecl = BV_FN (vchain);
4827 if (DECL_THUNK_P (fndecl))
4828 fndecl = THUNK_TARGET (fndecl);
4829 set_one_vmethod_tm_attributes (t, fndecl);
4833 /* If the class doesn't have an attribute, nothing more to do. */
4834 class_tm_attr = find_tm_attribute (TYPE_ATTRIBUTES (t));
4835 if (class_tm_attr == NULL)
4836 return;
4838 /* Any method that does not yet have a tm attribute inherits
4839 the one from the class. */
4840 for (fndecl = TYPE_METHODS (t); fndecl; fndecl = TREE_CHAIN (fndecl))
4842 if (!find_tm_attribute (TYPE_ATTRIBUTES (TREE_TYPE (fndecl))))
4843 apply_tm_attr (fndecl, class_tm_attr);
4847 /* Returns true iff class T has a user-defined constructor other than
4848 the default constructor. */
4850 bool
4851 type_has_user_nondefault_constructor (tree t)
4853 tree fns;
4855 if (!TYPE_HAS_USER_CONSTRUCTOR (t))
4856 return false;
4858 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
4860 tree fn = OVL_CURRENT (fns);
4861 if (!DECL_ARTIFICIAL (fn)
4862 && (TREE_CODE (fn) == TEMPLATE_DECL
4863 || (skip_artificial_parms_for (fn, DECL_ARGUMENTS (fn))
4864 != NULL_TREE)))
4865 return true;
4868 return false;
4871 /* Returns the defaulted constructor if T has one. Otherwise, returns
4872 NULL_TREE. */
4874 tree
4875 in_class_defaulted_default_constructor (tree t)
4877 tree fns, args;
4879 if (!TYPE_HAS_USER_CONSTRUCTOR (t))
4880 return NULL_TREE;
4882 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
4884 tree fn = OVL_CURRENT (fns);
4886 if (DECL_DEFAULTED_IN_CLASS_P (fn))
4888 args = FUNCTION_FIRST_USER_PARMTYPE (fn);
4889 while (args && TREE_PURPOSE (args))
4890 args = TREE_CHAIN (args);
4891 if (!args || args == void_list_node)
4892 return fn;
4896 return NULL_TREE;
4899 /* Returns true iff FN is a user-provided function, i.e. user-declared
4900 and not defaulted at its first declaration; or explicit, private,
4901 protected, or non-const. */
4903 bool
4904 user_provided_p (tree fn)
4906 if (TREE_CODE (fn) == TEMPLATE_DECL)
4907 return true;
4908 else
4909 return (!DECL_ARTIFICIAL (fn)
4910 && !(DECL_INITIALIZED_IN_CLASS_P (fn)
4911 && (DECL_DEFAULTED_FN (fn) || DECL_DELETED_FN (fn))));
4914 /* Returns true iff class T has a user-provided constructor. */
4916 bool
4917 type_has_user_provided_constructor (tree t)
4919 tree fns;
4921 if (!CLASS_TYPE_P (t))
4922 return false;
4924 if (!TYPE_HAS_USER_CONSTRUCTOR (t))
4925 return false;
4927 /* This can happen in error cases; avoid crashing. */
4928 if (!CLASSTYPE_METHOD_VEC (t))
4929 return false;
4931 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
4932 if (user_provided_p (OVL_CURRENT (fns)))
4933 return true;
4935 return false;
4938 /* Returns true iff class T has a user-provided default constructor. */
4940 bool
4941 type_has_user_provided_default_constructor (tree t)
4943 tree fns;
4945 if (!TYPE_HAS_USER_CONSTRUCTOR (t))
4946 return false;
4948 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
4950 tree fn = OVL_CURRENT (fns);
4951 if (TREE_CODE (fn) == FUNCTION_DECL
4952 && user_provided_p (fn)
4953 && sufficient_parms_p (FUNCTION_FIRST_USER_PARMTYPE (fn)))
4954 return true;
4957 return false;
4960 /* TYPE is being used as a virtual base, and has a non-trivial move
4961 assignment. Return true if this is due to there being a user-provided
4962 move assignment in TYPE or one of its subobjects; if there isn't, then
4963 multiple move assignment can't cause any harm. */
4965 bool
4966 vbase_has_user_provided_move_assign (tree type)
4968 /* Does the type itself have a user-provided move assignment operator? */
4969 for (tree fns
4970 = lookup_fnfields_slot_nolazy (type, ansi_assopname (NOP_EXPR));
4971 fns; fns = OVL_NEXT (fns))
4973 tree fn = OVL_CURRENT (fns);
4974 if (move_fn_p (fn) && user_provided_p (fn))
4975 return true;
4978 /* Do any of its bases? */
4979 tree binfo = TYPE_BINFO (type);
4980 tree base_binfo;
4981 for (int i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
4982 if (vbase_has_user_provided_move_assign (BINFO_TYPE (base_binfo)))
4983 return true;
4985 /* Or non-static data members? */
4986 for (tree field = TYPE_FIELDS (type); field; field = DECL_CHAIN (field))
4988 if (TREE_CODE (field) == FIELD_DECL
4989 && CLASS_TYPE_P (TREE_TYPE (field))
4990 && vbase_has_user_provided_move_assign (TREE_TYPE (field)))
4991 return true;
4994 /* Seems not. */
4995 return false;
4998 /* If default-initialization leaves part of TYPE uninitialized, returns
4999 a DECL for the field or TYPE itself (DR 253). */
5001 tree
5002 default_init_uninitialized_part (tree type)
5004 tree t, r, binfo;
5005 int i;
5007 type = strip_array_types (type);
5008 if (!CLASS_TYPE_P (type))
5009 return type;
5010 if (type_has_user_provided_default_constructor (type))
5011 return NULL_TREE;
5012 for (binfo = TYPE_BINFO (type), i = 0;
5013 BINFO_BASE_ITERATE (binfo, i, t); ++i)
5015 r = default_init_uninitialized_part (BINFO_TYPE (t));
5016 if (r)
5017 return r;
5019 for (t = TYPE_FIELDS (type); t; t = DECL_CHAIN (t))
5020 if (TREE_CODE (t) == FIELD_DECL
5021 && !DECL_ARTIFICIAL (t)
5022 && !DECL_INITIAL (t))
5024 r = default_init_uninitialized_part (TREE_TYPE (t));
5025 if (r)
5026 return DECL_P (r) ? r : t;
5029 return NULL_TREE;
5032 /* Returns true iff for class T, a trivial synthesized default constructor
5033 would be constexpr. */
5035 bool
5036 trivial_default_constructor_is_constexpr (tree t)
5038 /* A defaulted trivial default constructor is constexpr
5039 if there is nothing to initialize. */
5040 gcc_assert (!TYPE_HAS_COMPLEX_DFLT (t));
5041 return is_really_empty_class (t);
5044 /* Returns true iff class T has a constexpr default constructor. */
5046 bool
5047 type_has_constexpr_default_constructor (tree t)
5049 tree fns;
5051 if (!CLASS_TYPE_P (t))
5053 /* The caller should have stripped an enclosing array. */
5054 gcc_assert (TREE_CODE (t) != ARRAY_TYPE);
5055 return false;
5057 if (CLASSTYPE_LAZY_DEFAULT_CTOR (t))
5059 if (!TYPE_HAS_COMPLEX_DFLT (t))
5060 return trivial_default_constructor_is_constexpr (t);
5061 /* Non-trivial, we need to check subobject constructors. */
5062 lazily_declare_fn (sfk_constructor, t);
5064 fns = locate_ctor (t);
5065 return (fns && DECL_DECLARED_CONSTEXPR_P (fns));
5068 /* Returns true iff class TYPE has a virtual destructor. */
5070 bool
5071 type_has_virtual_destructor (tree type)
5073 tree dtor;
5075 if (!CLASS_TYPE_P (type))
5076 return false;
5078 gcc_assert (COMPLETE_TYPE_P (type));
5079 dtor = CLASSTYPE_DESTRUCTORS (type);
5080 return (dtor && DECL_VIRTUAL_P (dtor));
5083 /* Returns true iff class T has a move constructor. */
5085 bool
5086 type_has_move_constructor (tree t)
5088 tree fns;
5090 if (CLASSTYPE_LAZY_MOVE_CTOR (t))
5092 gcc_assert (COMPLETE_TYPE_P (t));
5093 lazily_declare_fn (sfk_move_constructor, t);
5096 if (!CLASSTYPE_METHOD_VEC (t))
5097 return false;
5099 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
5100 if (move_fn_p (OVL_CURRENT (fns)))
5101 return true;
5103 return false;
5106 /* Returns true iff class T has a move assignment operator. */
5108 bool
5109 type_has_move_assign (tree t)
5111 tree fns;
5113 if (CLASSTYPE_LAZY_MOVE_ASSIGN (t))
5115 gcc_assert (COMPLETE_TYPE_P (t));
5116 lazily_declare_fn (sfk_move_assignment, t);
5119 for (fns = lookup_fnfields_slot_nolazy (t, ansi_assopname (NOP_EXPR));
5120 fns; fns = OVL_NEXT (fns))
5121 if (move_fn_p (OVL_CURRENT (fns)))
5122 return true;
5124 return false;
5127 /* Returns true iff class T has a move constructor that was explicitly
5128 declared in the class body. Note that this is different from
5129 "user-provided", which doesn't include functions that are defaulted in
5130 the class. */
5132 bool
5133 type_has_user_declared_move_constructor (tree t)
5135 tree fns;
5137 if (CLASSTYPE_LAZY_MOVE_CTOR (t))
5138 return false;
5140 if (!CLASSTYPE_METHOD_VEC (t))
5141 return false;
5143 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
5145 tree fn = OVL_CURRENT (fns);
5146 if (move_fn_p (fn) && !DECL_ARTIFICIAL (fn))
5147 return true;
5150 return false;
5153 /* Returns true iff class T has a move assignment operator that was
5154 explicitly declared in the class body. */
5156 bool
5157 type_has_user_declared_move_assign (tree t)
5159 tree fns;
5161 if (CLASSTYPE_LAZY_MOVE_ASSIGN (t))
5162 return false;
5164 for (fns = lookup_fnfields_slot_nolazy (t, ansi_assopname (NOP_EXPR));
5165 fns; fns = OVL_NEXT (fns))
5167 tree fn = OVL_CURRENT (fns);
5168 if (move_fn_p (fn) && !DECL_ARTIFICIAL (fn))
5169 return true;
5172 return false;
5175 /* Nonzero if we need to build up a constructor call when initializing an
5176 object of this class, either because it has a user-declared constructor
5177 or because it doesn't have a default constructor (so we need to give an
5178 error if no initializer is provided). Use TYPE_NEEDS_CONSTRUCTING when
5179 what you care about is whether or not an object can be produced by a
5180 constructor (e.g. so we don't set TREE_READONLY on const variables of
5181 such type); use this function when what you care about is whether or not
5182 to try to call a constructor to create an object. The latter case is
5183 the former plus some cases of constructors that cannot be called. */
5185 bool
5186 type_build_ctor_call (tree t)
5188 tree inner;
5189 if (TYPE_NEEDS_CONSTRUCTING (t))
5190 return true;
5191 inner = strip_array_types (t);
5192 if (!CLASS_TYPE_P (inner) || ANON_AGGR_TYPE_P (inner))
5193 return false;
5194 if (!TYPE_HAS_DEFAULT_CONSTRUCTOR (inner))
5195 return true;
5196 if (cxx_dialect < cxx11)
5197 return false;
5198 /* A user-declared constructor might be private, and a constructor might
5199 be trivial but deleted. */
5200 for (tree fns = lookup_fnfields_slot (inner, complete_ctor_identifier);
5201 fns; fns = OVL_NEXT (fns))
5203 tree fn = OVL_CURRENT (fns);
5204 if (!DECL_ARTIFICIAL (fn)
5205 || DECL_DELETED_FN (fn))
5206 return true;
5208 return false;
5211 /* Like type_build_ctor_call, but for destructors. */
5213 bool
5214 type_build_dtor_call (tree t)
5216 tree inner;
5217 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t))
5218 return true;
5219 inner = strip_array_types (t);
5220 if (!CLASS_TYPE_P (inner) || ANON_AGGR_TYPE_P (inner)
5221 || !COMPLETE_TYPE_P (inner))
5222 return false;
5223 if (cxx_dialect < cxx11)
5224 return false;
5225 /* A user-declared destructor might be private, and a destructor might
5226 be trivial but deleted. */
5227 for (tree fns = lookup_fnfields_slot (inner, complete_dtor_identifier);
5228 fns; fns = OVL_NEXT (fns))
5230 tree fn = OVL_CURRENT (fns);
5231 if (!DECL_ARTIFICIAL (fn)
5232 || DECL_DELETED_FN (fn))
5233 return true;
5235 return false;
5238 /* Remove all zero-width bit-fields from T. */
5240 static void
5241 remove_zero_width_bit_fields (tree t)
5243 tree *fieldsp;
5245 fieldsp = &TYPE_FIELDS (t);
5246 while (*fieldsp)
5248 if (TREE_CODE (*fieldsp) == FIELD_DECL
5249 && DECL_C_BIT_FIELD (*fieldsp)
5250 /* We should not be confused by the fact that grokbitfield
5251 temporarily sets the width of the bit field into
5252 DECL_INITIAL (*fieldsp).
5253 check_bitfield_decl eventually sets DECL_SIZE (*fieldsp)
5254 to that width. */
5255 && integer_zerop (DECL_SIZE (*fieldsp)))
5256 *fieldsp = DECL_CHAIN (*fieldsp);
5257 else
5258 fieldsp = &DECL_CHAIN (*fieldsp);
5262 /* Returns TRUE iff we need a cookie when dynamically allocating an
5263 array whose elements have the indicated class TYPE. */
5265 static bool
5266 type_requires_array_cookie (tree type)
5268 tree fns;
5269 bool has_two_argument_delete_p = false;
5271 gcc_assert (CLASS_TYPE_P (type));
5273 /* If there's a non-trivial destructor, we need a cookie. In order
5274 to iterate through the array calling the destructor for each
5275 element, we'll have to know how many elements there are. */
5276 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type))
5277 return true;
5279 /* If the usual deallocation function is a two-argument whose second
5280 argument is of type `size_t', then we have to pass the size of
5281 the array to the deallocation function, so we will need to store
5282 a cookie. */
5283 fns = lookup_fnfields (TYPE_BINFO (type),
5284 ansi_opname (VEC_DELETE_EXPR),
5285 /*protect=*/0);
5286 /* If there are no `operator []' members, or the lookup is
5287 ambiguous, then we don't need a cookie. */
5288 if (!fns || fns == error_mark_node)
5289 return false;
5290 /* Loop through all of the functions. */
5291 for (fns = BASELINK_FUNCTIONS (fns); fns; fns = OVL_NEXT (fns))
5293 tree fn;
5294 tree second_parm;
5296 /* Select the current function. */
5297 fn = OVL_CURRENT (fns);
5298 /* See if this function is a one-argument delete function. If
5299 it is, then it will be the usual deallocation function. */
5300 second_parm = TREE_CHAIN (TYPE_ARG_TYPES (TREE_TYPE (fn)));
5301 if (second_parm == void_list_node)
5302 return false;
5303 /* Do not consider this function if its second argument is an
5304 ellipsis. */
5305 if (!second_parm)
5306 continue;
5307 /* Otherwise, if we have a two-argument function and the second
5308 argument is `size_t', it will be the usual deallocation
5309 function -- unless there is one-argument function, too. */
5310 if (TREE_CHAIN (second_parm) == void_list_node
5311 && same_type_p (TREE_VALUE (second_parm), size_type_node))
5312 has_two_argument_delete_p = true;
5315 return has_two_argument_delete_p;
5318 /* Finish computing the `literal type' property of class type T.
5320 At this point, we have already processed base classes and
5321 non-static data members. We need to check whether the copy
5322 constructor is trivial, the destructor is trivial, and there
5323 is a trivial default constructor or at least one constexpr
5324 constructor other than the copy constructor. */
5326 static void
5327 finalize_literal_type_property (tree t)
5329 tree fn;
5331 if (cxx_dialect < cxx11
5332 || TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t))
5333 CLASSTYPE_LITERAL_P (t) = false;
5334 else if (CLASSTYPE_LITERAL_P (t) && !TYPE_HAS_TRIVIAL_DFLT (t)
5335 && CLASSTYPE_NON_AGGREGATE (t)
5336 && !TYPE_HAS_CONSTEXPR_CTOR (t))
5337 CLASSTYPE_LITERAL_P (t) = false;
5339 if (!CLASSTYPE_LITERAL_P (t))
5340 for (fn = TYPE_METHODS (t); fn; fn = DECL_CHAIN (fn))
5341 if (DECL_DECLARED_CONSTEXPR_P (fn)
5342 && TREE_CODE (fn) != TEMPLATE_DECL
5343 && DECL_NONSTATIC_MEMBER_FUNCTION_P (fn)
5344 && !DECL_CONSTRUCTOR_P (fn))
5346 DECL_DECLARED_CONSTEXPR_P (fn) = false;
5347 if (!DECL_GENERATED_P (fn))
5349 error ("enclosing class of constexpr non-static member "
5350 "function %q+#D is not a literal type", fn);
5351 explain_non_literal_class (t);
5356 /* T is a non-literal type used in a context which requires a constant
5357 expression. Explain why it isn't literal. */
5359 void
5360 explain_non_literal_class (tree t)
5362 static hash_set<tree> *diagnosed;
5364 if (!CLASS_TYPE_P (t))
5365 return;
5366 t = TYPE_MAIN_VARIANT (t);
5368 if (diagnosed == NULL)
5369 diagnosed = new hash_set<tree>;
5370 if (diagnosed->add (t))
5371 /* Already explained. */
5372 return;
5374 inform (0, "%q+T is not literal because:", t);
5375 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t))
5376 inform (0, " %q+T has a non-trivial destructor", t);
5377 else if (CLASSTYPE_NON_AGGREGATE (t)
5378 && !TYPE_HAS_TRIVIAL_DFLT (t)
5379 && !TYPE_HAS_CONSTEXPR_CTOR (t))
5381 inform (0, " %q+T is not an aggregate, does not have a trivial "
5382 "default constructor, and has no constexpr constructor that "
5383 "is not a copy or move constructor", t);
5384 if (TYPE_HAS_DEFAULT_CONSTRUCTOR (t)
5385 && !type_has_user_provided_default_constructor (t))
5387 /* Note that we can't simply call locate_ctor because when the
5388 constructor is deleted it just returns NULL_TREE. */
5389 tree fns;
5390 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
5392 tree fn = OVL_CURRENT (fns);
5393 tree parms = TYPE_ARG_TYPES (TREE_TYPE (fn));
5395 parms = skip_artificial_parms_for (fn, parms);
5397 if (sufficient_parms_p (parms))
5399 if (DECL_DELETED_FN (fn))
5400 maybe_explain_implicit_delete (fn);
5401 else
5402 explain_invalid_constexpr_fn (fn);
5403 break;
5408 else
5410 tree binfo, base_binfo, field; int i;
5411 for (binfo = TYPE_BINFO (t), i = 0;
5412 BINFO_BASE_ITERATE (binfo, i, base_binfo); i++)
5414 tree basetype = TREE_TYPE (base_binfo);
5415 if (!CLASSTYPE_LITERAL_P (basetype))
5417 inform (0, " base class %qT of %q+T is non-literal",
5418 basetype, t);
5419 explain_non_literal_class (basetype);
5420 return;
5423 for (field = TYPE_FIELDS (t); field; field = TREE_CHAIN (field))
5425 tree ftype;
5426 if (TREE_CODE (field) != FIELD_DECL)
5427 continue;
5428 ftype = TREE_TYPE (field);
5429 if (!literal_type_p (ftype))
5431 inform (0, " non-static data member %q+D has "
5432 "non-literal type", field);
5433 if (CLASS_TYPE_P (ftype))
5434 explain_non_literal_class (ftype);
5436 if (CP_TYPE_VOLATILE_P (ftype))
5437 inform (0, " non-static data member %q+D has "
5438 "volatile type", field);
5443 /* Check the validity of the bases and members declared in T. Add any
5444 implicitly-generated functions (like copy-constructors and
5445 assignment operators). Compute various flag bits (like
5446 CLASSTYPE_NON_LAYOUT_POD_T) for T. This routine works purely at the C++
5447 level: i.e., independently of the ABI in use. */
5449 static void
5450 check_bases_and_members (tree t)
5452 /* Nonzero if the implicitly generated copy constructor should take
5453 a non-const reference argument. */
5454 int cant_have_const_ctor;
5455 /* Nonzero if the implicitly generated assignment operator
5456 should take a non-const reference argument. */
5457 int no_const_asn_ref;
5458 tree access_decls;
5459 bool saved_complex_asn_ref;
5460 bool saved_nontrivial_dtor;
5461 tree fn;
5463 /* Pick up any abi_tags from our template arguments before checking. */
5464 inherit_targ_abi_tags (t);
5466 /* By default, we use const reference arguments and generate default
5467 constructors. */
5468 cant_have_const_ctor = 0;
5469 no_const_asn_ref = 0;
5471 /* Check all the base-classes. */
5472 check_bases (t, &cant_have_const_ctor,
5473 &no_const_asn_ref);
5475 /* Deduce noexcept on destructors. This needs to happen after we've set
5476 triviality flags appropriately for our bases. */
5477 if (cxx_dialect >= cxx11)
5478 deduce_noexcept_on_destructors (t);
5480 /* Check all the method declarations. */
5481 check_methods (t);
5483 /* Save the initial values of these flags which only indicate whether
5484 or not the class has user-provided functions. As we analyze the
5485 bases and members we can set these flags for other reasons. */
5486 saved_complex_asn_ref = TYPE_HAS_COMPLEX_COPY_ASSIGN (t);
5487 saved_nontrivial_dtor = TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t);
5489 /* Check all the data member declarations. We cannot call
5490 check_field_decls until we have called check_bases check_methods,
5491 as check_field_decls depends on TYPE_HAS_NONTRIVIAL_DESTRUCTOR
5492 being set appropriately. */
5493 check_field_decls (t, &access_decls,
5494 &cant_have_const_ctor,
5495 &no_const_asn_ref);
5497 /* A nearly-empty class has to be vptr-containing; a nearly empty
5498 class contains just a vptr. */
5499 if (!TYPE_CONTAINS_VPTR_P (t))
5500 CLASSTYPE_NEARLY_EMPTY_P (t) = 0;
5502 /* Do some bookkeeping that will guide the generation of implicitly
5503 declared member functions. */
5504 TYPE_HAS_COMPLEX_COPY_CTOR (t) |= TYPE_CONTAINS_VPTR_P (t);
5505 TYPE_HAS_COMPLEX_MOVE_CTOR (t) |= TYPE_CONTAINS_VPTR_P (t);
5506 /* We need to call a constructor for this class if it has a
5507 user-provided constructor, or if the default constructor is going
5508 to initialize the vptr. (This is not an if-and-only-if;
5509 TYPE_NEEDS_CONSTRUCTING is set elsewhere if bases or members
5510 themselves need constructing.) */
5511 TYPE_NEEDS_CONSTRUCTING (t)
5512 |= (type_has_user_provided_constructor (t) || TYPE_CONTAINS_VPTR_P (t));
5513 /* [dcl.init.aggr]
5515 An aggregate is an array or a class with no user-provided
5516 constructors ... and no virtual functions.
5518 Again, other conditions for being an aggregate are checked
5519 elsewhere. */
5520 CLASSTYPE_NON_AGGREGATE (t)
5521 |= (type_has_user_provided_constructor (t) || TYPE_POLYMORPHIC_P (t));
5522 /* This is the C++98/03 definition of POD; it changed in C++0x, but we
5523 retain the old definition internally for ABI reasons. */
5524 CLASSTYPE_NON_LAYOUT_POD_P (t)
5525 |= (CLASSTYPE_NON_AGGREGATE (t)
5526 || saved_nontrivial_dtor || saved_complex_asn_ref);
5527 CLASSTYPE_NON_STD_LAYOUT (t) |= TYPE_CONTAINS_VPTR_P (t);
5528 TYPE_HAS_COMPLEX_COPY_ASSIGN (t) |= TYPE_CONTAINS_VPTR_P (t);
5529 TYPE_HAS_COMPLEX_MOVE_ASSIGN (t) |= TYPE_CONTAINS_VPTR_P (t);
5530 TYPE_HAS_COMPLEX_DFLT (t) |= TYPE_CONTAINS_VPTR_P (t);
5532 /* Warn if a public base of a polymorphic type has an accessible
5533 non-virtual destructor. It is only now that we know the class is
5534 polymorphic. Although a polymorphic base will have a already
5535 been diagnosed during its definition, we warn on use too. */
5536 if (TYPE_POLYMORPHIC_P (t) && warn_nonvdtor)
5538 tree binfo = TYPE_BINFO (t);
5539 vec<tree, va_gc> *accesses = BINFO_BASE_ACCESSES (binfo);
5540 tree base_binfo;
5541 unsigned i;
5543 for (i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); i++)
5545 tree basetype = TREE_TYPE (base_binfo);
5547 if ((*accesses)[i] == access_public_node
5548 && (TYPE_POLYMORPHIC_P (basetype) || warn_ecpp)
5549 && accessible_nvdtor_p (basetype))
5550 warning (OPT_Wnon_virtual_dtor,
5551 "base class %q#T has accessible non-virtual destructor",
5552 basetype);
5556 /* If the class has no user-declared constructor, but does have
5557 non-static const or reference data members that can never be
5558 initialized, issue a warning. */
5559 if (warn_uninitialized
5560 /* Classes with user-declared constructors are presumed to
5561 initialize these members. */
5562 && !TYPE_HAS_USER_CONSTRUCTOR (t)
5563 /* Aggregates can be initialized with brace-enclosed
5564 initializers. */
5565 && CLASSTYPE_NON_AGGREGATE (t))
5567 tree field;
5569 for (field = TYPE_FIELDS (t); field; field = DECL_CHAIN (field))
5571 tree type;
5573 if (TREE_CODE (field) != FIELD_DECL
5574 || DECL_INITIAL (field) != NULL_TREE)
5575 continue;
5577 type = TREE_TYPE (field);
5578 if (TREE_CODE (type) == REFERENCE_TYPE)
5579 warning (OPT_Wuninitialized, "non-static reference %q+#D "
5580 "in class without a constructor", field);
5581 else if (CP_TYPE_CONST_P (type)
5582 && (!CLASS_TYPE_P (type)
5583 || !TYPE_HAS_DEFAULT_CONSTRUCTOR (type)))
5584 warning (OPT_Wuninitialized, "non-static const member %q+#D "
5585 "in class without a constructor", field);
5589 /* Synthesize any needed methods. */
5590 add_implicitly_declared_members (t, &access_decls,
5591 cant_have_const_ctor,
5592 no_const_asn_ref);
5594 /* Check defaulted declarations here so we have cant_have_const_ctor
5595 and don't need to worry about clones. */
5596 for (fn = TYPE_METHODS (t); fn; fn = DECL_CHAIN (fn))
5597 if (!DECL_ARTIFICIAL (fn) && DECL_DEFAULTED_IN_CLASS_P (fn))
5599 int copy = copy_fn_p (fn);
5600 if (copy > 0)
5602 bool imp_const_p
5603 = (DECL_CONSTRUCTOR_P (fn) ? !cant_have_const_ctor
5604 : !no_const_asn_ref);
5605 bool fn_const_p = (copy == 2);
5607 if (fn_const_p && !imp_const_p)
5608 /* If the function is defaulted outside the class, we just
5609 give the synthesis error. */
5610 error ("%q+D declared to take const reference, but implicit "
5611 "declaration would take non-const", fn);
5613 defaulted_late_check (fn);
5616 if (LAMBDA_TYPE_P (t))
5618 /* "The closure type associated with a lambda-expression has a deleted
5619 default constructor and a deleted copy assignment operator." */
5620 TYPE_NEEDS_CONSTRUCTING (t) = 1;
5621 TYPE_HAS_COMPLEX_DFLT (t) = 1;
5622 TYPE_HAS_COMPLEX_COPY_ASSIGN (t) = 1;
5623 CLASSTYPE_LAZY_MOVE_ASSIGN (t) = 0;
5625 /* "This class type is not an aggregate." */
5626 CLASSTYPE_NON_AGGREGATE (t) = 1;
5629 /* Compute the 'literal type' property before we
5630 do anything with non-static member functions. */
5631 finalize_literal_type_property (t);
5633 /* Create the in-charge and not-in-charge variants of constructors
5634 and destructors. */
5635 clone_constructors_and_destructors (t);
5637 /* Process the using-declarations. */
5638 for (; access_decls; access_decls = TREE_CHAIN (access_decls))
5639 handle_using_decl (TREE_VALUE (access_decls), t);
5641 /* Build and sort the CLASSTYPE_METHOD_VEC. */
5642 finish_struct_methods (t);
5644 /* Figure out whether or not we will need a cookie when dynamically
5645 allocating an array of this type. */
5646 TYPE_LANG_SPECIFIC (t)->u.c.vec_new_uses_cookie
5647 = type_requires_array_cookie (t);
5650 /* If T needs a pointer to its virtual function table, set TYPE_VFIELD
5651 accordingly. If a new vfield was created (because T doesn't have a
5652 primary base class), then the newly created field is returned. It
5653 is not added to the TYPE_FIELDS list; it is the caller's
5654 responsibility to do that. Accumulate declared virtual functions
5655 on VIRTUALS_P. */
5657 static tree
5658 create_vtable_ptr (tree t, tree* virtuals_p)
5660 tree fn;
5662 /* Collect the virtual functions declared in T. */
5663 for (fn = TYPE_METHODS (t); fn; fn = DECL_CHAIN (fn))
5664 if (TREE_CODE (fn) == FUNCTION_DECL
5665 && DECL_VINDEX (fn) && !DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P (fn)
5666 && TREE_CODE (DECL_VINDEX (fn)) != INTEGER_CST)
5668 tree new_virtual = make_node (TREE_LIST);
5670 BV_FN (new_virtual) = fn;
5671 BV_DELTA (new_virtual) = integer_zero_node;
5672 BV_VCALL_INDEX (new_virtual) = NULL_TREE;
5674 TREE_CHAIN (new_virtual) = *virtuals_p;
5675 *virtuals_p = new_virtual;
5678 /* If we couldn't find an appropriate base class, create a new field
5679 here. Even if there weren't any new virtual functions, we might need a
5680 new virtual function table if we're supposed to include vptrs in
5681 all classes that need them. */
5682 if (!TYPE_VFIELD (t) && (*virtuals_p || TYPE_CONTAINS_VPTR_P (t)))
5684 /* We build this decl with vtbl_ptr_type_node, which is a
5685 `vtable_entry_type*'. It might seem more precise to use
5686 `vtable_entry_type (*)[N]' where N is the number of virtual
5687 functions. However, that would require the vtable pointer in
5688 base classes to have a different type than the vtable pointer
5689 in derived classes. We could make that happen, but that
5690 still wouldn't solve all the problems. In particular, the
5691 type-based alias analysis code would decide that assignments
5692 to the base class vtable pointer can't alias assignments to
5693 the derived class vtable pointer, since they have different
5694 types. Thus, in a derived class destructor, where the base
5695 class constructor was inlined, we could generate bad code for
5696 setting up the vtable pointer.
5698 Therefore, we use one type for all vtable pointers. We still
5699 use a type-correct type; it's just doesn't indicate the array
5700 bounds. That's better than using `void*' or some such; it's
5701 cleaner, and it let's the alias analysis code know that these
5702 stores cannot alias stores to void*! */
5703 tree field;
5705 field = build_decl (input_location,
5706 FIELD_DECL, get_vfield_name (t), vtbl_ptr_type_node);
5707 DECL_VIRTUAL_P (field) = 1;
5708 DECL_ARTIFICIAL (field) = 1;
5709 DECL_FIELD_CONTEXT (field) = t;
5710 DECL_FCONTEXT (field) = t;
5711 if (TYPE_PACKED (t))
5712 DECL_PACKED (field) = 1;
5714 TYPE_VFIELD (t) = field;
5716 /* This class is non-empty. */
5717 CLASSTYPE_EMPTY_P (t) = 0;
5719 return field;
5722 return NULL_TREE;
5725 /* Add OFFSET to all base types of BINFO which is a base in the
5726 hierarchy dominated by T.
5728 OFFSET, which is a type offset, is number of bytes. */
5730 static void
5731 propagate_binfo_offsets (tree binfo, tree offset)
5733 int i;
5734 tree primary_binfo;
5735 tree base_binfo;
5737 /* Update BINFO's offset. */
5738 BINFO_OFFSET (binfo)
5739 = convert (sizetype,
5740 size_binop (PLUS_EXPR,
5741 convert (ssizetype, BINFO_OFFSET (binfo)),
5742 offset));
5744 /* Find the primary base class. */
5745 primary_binfo = get_primary_binfo (binfo);
5747 if (primary_binfo && BINFO_INHERITANCE_CHAIN (primary_binfo) == binfo)
5748 propagate_binfo_offsets (primary_binfo, offset);
5750 /* Scan all of the bases, pushing the BINFO_OFFSET adjust
5751 downwards. */
5752 for (i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
5754 /* Don't do the primary base twice. */
5755 if (base_binfo == primary_binfo)
5756 continue;
5758 if (BINFO_VIRTUAL_P (base_binfo))
5759 continue;
5761 propagate_binfo_offsets (base_binfo, offset);
5765 /* Set BINFO_OFFSET for all of the virtual bases for RLI->T. Update
5766 TYPE_ALIGN and TYPE_SIZE for T. OFFSETS gives the location of
5767 empty subobjects of T. */
5769 static void
5770 layout_virtual_bases (record_layout_info rli, splay_tree offsets)
5772 tree vbase;
5773 tree t = rli->t;
5774 tree *next_field;
5776 if (BINFO_N_BASE_BINFOS (TYPE_BINFO (t)) == 0)
5777 return;
5779 /* Find the last field. The artificial fields created for virtual
5780 bases will go after the last extant field to date. */
5781 next_field = &TYPE_FIELDS (t);
5782 while (*next_field)
5783 next_field = &DECL_CHAIN (*next_field);
5785 /* Go through the virtual bases, allocating space for each virtual
5786 base that is not already a primary base class. These are
5787 allocated in inheritance graph order. */
5788 for (vbase = TYPE_BINFO (t); vbase; vbase = TREE_CHAIN (vbase))
5790 if (!BINFO_VIRTUAL_P (vbase))
5791 continue;
5793 if (!BINFO_PRIMARY_P (vbase))
5795 /* This virtual base is not a primary base of any class in the
5796 hierarchy, so we have to add space for it. */
5797 next_field = build_base_field (rli, vbase,
5798 offsets, next_field);
5803 /* Returns the offset of the byte just past the end of the base class
5804 BINFO. */
5806 static tree
5807 end_of_base (tree binfo)
5809 tree size;
5811 if (!CLASSTYPE_AS_BASE (BINFO_TYPE (binfo)))
5812 size = TYPE_SIZE_UNIT (char_type_node);
5813 else if (is_empty_class (BINFO_TYPE (binfo)))
5814 /* An empty class has zero CLASSTYPE_SIZE_UNIT, but we need to
5815 allocate some space for it. It cannot have virtual bases, so
5816 TYPE_SIZE_UNIT is fine. */
5817 size = TYPE_SIZE_UNIT (BINFO_TYPE (binfo));
5818 else
5819 size = CLASSTYPE_SIZE_UNIT (BINFO_TYPE (binfo));
5821 return size_binop (PLUS_EXPR, BINFO_OFFSET (binfo), size);
5824 /* Returns the offset of the byte just past the end of the base class
5825 with the highest offset in T. If INCLUDE_VIRTUALS_P is zero, then
5826 only non-virtual bases are included. */
5828 static tree
5829 end_of_class (tree t, int include_virtuals_p)
5831 tree result = size_zero_node;
5832 vec<tree, va_gc> *vbases;
5833 tree binfo;
5834 tree base_binfo;
5835 tree offset;
5836 int i;
5838 for (binfo = TYPE_BINFO (t), i = 0;
5839 BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
5841 if (!include_virtuals_p
5842 && BINFO_VIRTUAL_P (base_binfo)
5843 && (!BINFO_PRIMARY_P (base_binfo)
5844 || BINFO_INHERITANCE_CHAIN (base_binfo) != TYPE_BINFO (t)))
5845 continue;
5847 offset = end_of_base (base_binfo);
5848 if (tree_int_cst_lt (result, offset))
5849 result = offset;
5852 if (include_virtuals_p)
5853 for (vbases = CLASSTYPE_VBASECLASSES (t), i = 0;
5854 vec_safe_iterate (vbases, i, &base_binfo); i++)
5856 offset = end_of_base (base_binfo);
5857 if (tree_int_cst_lt (result, offset))
5858 result = offset;
5861 return result;
5864 /* Warn about bases of T that are inaccessible because they are
5865 ambiguous. For example:
5867 struct S {};
5868 struct T : public S {};
5869 struct U : public S, public T {};
5871 Here, `(S*) new U' is not allowed because there are two `S'
5872 subobjects of U. */
5874 static void
5875 warn_about_ambiguous_bases (tree t)
5877 int i;
5878 vec<tree, va_gc> *vbases;
5879 tree basetype;
5880 tree binfo;
5881 tree base_binfo;
5883 /* If there are no repeated bases, nothing can be ambiguous. */
5884 if (!CLASSTYPE_REPEATED_BASE_P (t))
5885 return;
5887 /* Check direct bases. */
5888 for (binfo = TYPE_BINFO (t), i = 0;
5889 BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
5891 basetype = BINFO_TYPE (base_binfo);
5893 if (!uniquely_derived_from_p (basetype, t))
5894 warning (0, "direct base %qT inaccessible in %qT due to ambiguity",
5895 basetype, t);
5898 /* Check for ambiguous virtual bases. */
5899 if (extra_warnings)
5900 for (vbases = CLASSTYPE_VBASECLASSES (t), i = 0;
5901 vec_safe_iterate (vbases, i, &binfo); i++)
5903 basetype = BINFO_TYPE (binfo);
5905 if (!uniquely_derived_from_p (basetype, t))
5906 warning (OPT_Wextra, "virtual base %qT inaccessible in %qT due "
5907 "to ambiguity", basetype, t);
5911 /* Compare two INTEGER_CSTs K1 and K2. */
5913 static int
5914 splay_tree_compare_integer_csts (splay_tree_key k1, splay_tree_key k2)
5916 return tree_int_cst_compare ((tree) k1, (tree) k2);
5919 /* Increase the size indicated in RLI to account for empty classes
5920 that are "off the end" of the class. */
5922 static void
5923 include_empty_classes (record_layout_info rli)
5925 tree eoc;
5926 tree rli_size;
5928 /* It might be the case that we grew the class to allocate a
5929 zero-sized base class. That won't be reflected in RLI, yet,
5930 because we are willing to overlay multiple bases at the same
5931 offset. However, now we need to make sure that RLI is big enough
5932 to reflect the entire class. */
5933 eoc = end_of_class (rli->t,
5934 CLASSTYPE_AS_BASE (rli->t) != NULL_TREE);
5935 rli_size = rli_size_unit_so_far (rli);
5936 if (TREE_CODE (rli_size) == INTEGER_CST
5937 && tree_int_cst_lt (rli_size, eoc))
5939 /* The size should have been rounded to a whole byte. */
5940 gcc_assert (tree_int_cst_equal
5941 (rli->bitpos, round_down (rli->bitpos, BITS_PER_UNIT)));
5942 rli->bitpos
5943 = size_binop (PLUS_EXPR,
5944 rli->bitpos,
5945 size_binop (MULT_EXPR,
5946 convert (bitsizetype,
5947 size_binop (MINUS_EXPR,
5948 eoc, rli_size)),
5949 bitsize_int (BITS_PER_UNIT)));
5950 normalize_rli (rli);
5954 /* Calculate the TYPE_SIZE, TYPE_ALIGN, etc for T. Calculate
5955 BINFO_OFFSETs for all of the base-classes. Position the vtable
5956 pointer. Accumulate declared virtual functions on VIRTUALS_P. */
5958 static void
5959 layout_class_type (tree t, tree *virtuals_p)
5961 tree non_static_data_members;
5962 tree field;
5963 tree vptr;
5964 record_layout_info rli;
5965 /* Maps offsets (represented as INTEGER_CSTs) to a TREE_LIST of
5966 types that appear at that offset. */
5967 splay_tree empty_base_offsets;
5968 /* True if the last field laid out was a bit-field. */
5969 bool last_field_was_bitfield = false;
5970 /* The location at which the next field should be inserted. */
5971 tree *next_field;
5972 /* T, as a base class. */
5973 tree base_t;
5975 /* Keep track of the first non-static data member. */
5976 non_static_data_members = TYPE_FIELDS (t);
5978 /* Start laying out the record. */
5979 rli = start_record_layout (t);
5981 /* Mark all the primary bases in the hierarchy. */
5982 determine_primary_bases (t);
5984 /* Create a pointer to our virtual function table. */
5985 vptr = create_vtable_ptr (t, virtuals_p);
5987 /* The vptr is always the first thing in the class. */
5988 if (vptr)
5990 DECL_CHAIN (vptr) = TYPE_FIELDS (t);
5991 TYPE_FIELDS (t) = vptr;
5992 next_field = &DECL_CHAIN (vptr);
5993 place_field (rli, vptr);
5995 else
5996 next_field = &TYPE_FIELDS (t);
5998 /* Build FIELD_DECLs for all of the non-virtual base-types. */
5999 empty_base_offsets = splay_tree_new (splay_tree_compare_integer_csts,
6000 NULL, NULL);
6001 build_base_fields (rli, empty_base_offsets, next_field);
6003 /* Layout the non-static data members. */
6004 for (field = non_static_data_members; field; field = DECL_CHAIN (field))
6006 tree type;
6007 tree padding;
6009 /* We still pass things that aren't non-static data members to
6010 the back end, in case it wants to do something with them. */
6011 if (TREE_CODE (field) != FIELD_DECL)
6013 place_field (rli, field);
6014 /* If the static data member has incomplete type, keep track
6015 of it so that it can be completed later. (The handling
6016 of pending statics in finish_record_layout is
6017 insufficient; consider:
6019 struct S1;
6020 struct S2 { static S1 s1; };
6022 At this point, finish_record_layout will be called, but
6023 S1 is still incomplete.) */
6024 if (VAR_P (field))
6026 maybe_register_incomplete_var (field);
6027 /* The visibility of static data members is determined
6028 at their point of declaration, not their point of
6029 definition. */
6030 determine_visibility (field);
6032 continue;
6035 type = TREE_TYPE (field);
6036 if (type == error_mark_node)
6037 continue;
6039 padding = NULL_TREE;
6041 /* If this field is a bit-field whose width is greater than its
6042 type, then there are some special rules for allocating
6043 it. */
6044 if (DECL_C_BIT_FIELD (field)
6045 && tree_int_cst_lt (TYPE_SIZE (type), DECL_SIZE (field)))
6047 unsigned int itk;
6048 tree integer_type;
6049 bool was_unnamed_p = false;
6050 /* We must allocate the bits as if suitably aligned for the
6051 longest integer type that fits in this many bits. type
6052 of the field. Then, we are supposed to use the left over
6053 bits as additional padding. */
6054 for (itk = itk_char; itk != itk_none; ++itk)
6055 if (integer_types[itk] != NULL_TREE
6056 && (tree_int_cst_lt (size_int (MAX_FIXED_MODE_SIZE),
6057 TYPE_SIZE (integer_types[itk]))
6058 || tree_int_cst_lt (DECL_SIZE (field),
6059 TYPE_SIZE (integer_types[itk]))))
6060 break;
6062 /* ITK now indicates a type that is too large for the
6063 field. We have to back up by one to find the largest
6064 type that fits. */
6067 --itk;
6068 integer_type = integer_types[itk];
6069 } while (itk > 0 && integer_type == NULL_TREE);
6071 /* Figure out how much additional padding is required. */
6072 if (tree_int_cst_lt (TYPE_SIZE (integer_type), DECL_SIZE (field)))
6074 if (TREE_CODE (t) == UNION_TYPE)
6075 /* In a union, the padding field must have the full width
6076 of the bit-field; all fields start at offset zero. */
6077 padding = DECL_SIZE (field);
6078 else
6079 padding = size_binop (MINUS_EXPR, DECL_SIZE (field),
6080 TYPE_SIZE (integer_type));
6082 #ifdef PCC_BITFIELD_TYPE_MATTERS
6083 /* An unnamed bitfield does not normally affect the
6084 alignment of the containing class on a target where
6085 PCC_BITFIELD_TYPE_MATTERS. But, the C++ ABI does not
6086 make any exceptions for unnamed bitfields when the
6087 bitfields are longer than their types. Therefore, we
6088 temporarily give the field a name. */
6089 if (PCC_BITFIELD_TYPE_MATTERS && !DECL_NAME (field))
6091 was_unnamed_p = true;
6092 DECL_NAME (field) = make_anon_name ();
6094 #endif
6095 DECL_SIZE (field) = TYPE_SIZE (integer_type);
6096 DECL_ALIGN (field) = TYPE_ALIGN (integer_type);
6097 DECL_USER_ALIGN (field) = TYPE_USER_ALIGN (integer_type);
6098 layout_nonempty_base_or_field (rli, field, NULL_TREE,
6099 empty_base_offsets);
6100 if (was_unnamed_p)
6101 DECL_NAME (field) = NULL_TREE;
6102 /* Now that layout has been performed, set the size of the
6103 field to the size of its declared type; the rest of the
6104 field is effectively invisible. */
6105 DECL_SIZE (field) = TYPE_SIZE (type);
6106 /* We must also reset the DECL_MODE of the field. */
6107 DECL_MODE (field) = TYPE_MODE (type);
6109 else
6110 layout_nonempty_base_or_field (rli, field, NULL_TREE,
6111 empty_base_offsets);
6113 /* Remember the location of any empty classes in FIELD. */
6114 record_subobject_offsets (TREE_TYPE (field),
6115 byte_position(field),
6116 empty_base_offsets,
6117 /*is_data_member=*/true);
6119 /* If a bit-field does not immediately follow another bit-field,
6120 and yet it starts in the middle of a byte, we have failed to
6121 comply with the ABI. */
6122 if (warn_abi
6123 && DECL_C_BIT_FIELD (field)
6124 /* The TREE_NO_WARNING flag gets set by Objective-C when
6125 laying out an Objective-C class. The ObjC ABI differs
6126 from the C++ ABI, and so we do not want a warning
6127 here. */
6128 && !TREE_NO_WARNING (field)
6129 && !last_field_was_bitfield
6130 && !integer_zerop (size_binop (TRUNC_MOD_EXPR,
6131 DECL_FIELD_BIT_OFFSET (field),
6132 bitsize_unit_node)))
6133 warning (OPT_Wabi, "offset of %q+D is not ABI-compliant and may "
6134 "change in a future version of GCC", field);
6136 /* The middle end uses the type of expressions to determine the
6137 possible range of expression values. In order to optimize
6138 "x.i > 7" to "false" for a 2-bit bitfield "i", the middle end
6139 must be made aware of the width of "i", via its type.
6141 Because C++ does not have integer types of arbitrary width,
6142 we must (for the purposes of the front end) convert from the
6143 type assigned here to the declared type of the bitfield
6144 whenever a bitfield expression is used as an rvalue.
6145 Similarly, when assigning a value to a bitfield, the value
6146 must be converted to the type given the bitfield here. */
6147 if (DECL_C_BIT_FIELD (field))
6149 unsigned HOST_WIDE_INT width;
6150 tree ftype = TREE_TYPE (field);
6151 width = tree_to_uhwi (DECL_SIZE (field));
6152 if (width != TYPE_PRECISION (ftype))
6154 TREE_TYPE (field)
6155 = c_build_bitfield_integer_type (width,
6156 TYPE_UNSIGNED (ftype));
6157 TREE_TYPE (field)
6158 = cp_build_qualified_type (TREE_TYPE (field),
6159 cp_type_quals (ftype));
6163 /* If we needed additional padding after this field, add it
6164 now. */
6165 if (padding)
6167 tree padding_field;
6169 padding_field = build_decl (input_location,
6170 FIELD_DECL,
6171 NULL_TREE,
6172 char_type_node);
6173 DECL_BIT_FIELD (padding_field) = 1;
6174 DECL_SIZE (padding_field) = padding;
6175 DECL_CONTEXT (padding_field) = t;
6176 DECL_ARTIFICIAL (padding_field) = 1;
6177 DECL_IGNORED_P (padding_field) = 1;
6178 layout_nonempty_base_or_field (rli, padding_field,
6179 NULL_TREE,
6180 empty_base_offsets);
6183 last_field_was_bitfield = DECL_C_BIT_FIELD (field);
6186 if (!integer_zerop (rli->bitpos))
6188 /* Make sure that we are on a byte boundary so that the size of
6189 the class without virtual bases will always be a round number
6190 of bytes. */
6191 rli->bitpos = round_up_loc (input_location, rli->bitpos, BITS_PER_UNIT);
6192 normalize_rli (rli);
6195 /* Delete all zero-width bit-fields from the list of fields. Now
6196 that the type is laid out they are no longer important. */
6197 remove_zero_width_bit_fields (t);
6199 /* Create the version of T used for virtual bases. We do not use
6200 make_class_type for this version; this is an artificial type. For
6201 a POD type, we just reuse T. */
6202 if (CLASSTYPE_NON_LAYOUT_POD_P (t) || CLASSTYPE_EMPTY_P (t))
6204 base_t = make_node (TREE_CODE (t));
6206 /* Set the size and alignment for the new type. */
6207 tree eoc;
6209 /* If the ABI version is not at least two, and the last
6210 field was a bit-field, RLI may not be on a byte
6211 boundary. In particular, rli_size_unit_so_far might
6212 indicate the last complete byte, while rli_size_so_far
6213 indicates the total number of bits used. Therefore,
6214 rli_size_so_far, rather than rli_size_unit_so_far, is
6215 used to compute TYPE_SIZE_UNIT. */
6216 eoc = end_of_class (t, /*include_virtuals_p=*/0);
6217 TYPE_SIZE_UNIT (base_t)
6218 = size_binop (MAX_EXPR,
6219 convert (sizetype,
6220 size_binop (CEIL_DIV_EXPR,
6221 rli_size_so_far (rli),
6222 bitsize_int (BITS_PER_UNIT))),
6223 eoc);
6224 TYPE_SIZE (base_t)
6225 = size_binop (MAX_EXPR,
6226 rli_size_so_far (rli),
6227 size_binop (MULT_EXPR,
6228 convert (bitsizetype, eoc),
6229 bitsize_int (BITS_PER_UNIT)));
6230 TYPE_ALIGN (base_t) = rli->record_align;
6231 TYPE_USER_ALIGN (base_t) = TYPE_USER_ALIGN (t);
6233 /* Copy the fields from T. */
6234 next_field = &TYPE_FIELDS (base_t);
6235 for (field = TYPE_FIELDS (t); field; field = DECL_CHAIN (field))
6236 if (TREE_CODE (field) == FIELD_DECL)
6238 *next_field = build_decl (input_location,
6239 FIELD_DECL,
6240 DECL_NAME (field),
6241 TREE_TYPE (field));
6242 DECL_CONTEXT (*next_field) = base_t;
6243 DECL_FIELD_OFFSET (*next_field) = DECL_FIELD_OFFSET (field);
6244 DECL_FIELD_BIT_OFFSET (*next_field)
6245 = DECL_FIELD_BIT_OFFSET (field);
6246 DECL_SIZE (*next_field) = DECL_SIZE (field);
6247 DECL_MODE (*next_field) = DECL_MODE (field);
6248 next_field = &DECL_CHAIN (*next_field);
6251 /* Record the base version of the type. */
6252 CLASSTYPE_AS_BASE (t) = base_t;
6253 TYPE_CONTEXT (base_t) = t;
6255 else
6256 CLASSTYPE_AS_BASE (t) = t;
6258 /* Every empty class contains an empty class. */
6259 if (CLASSTYPE_EMPTY_P (t))
6260 CLASSTYPE_CONTAINS_EMPTY_CLASS_P (t) = 1;
6262 /* Set the TYPE_DECL for this type to contain the right
6263 value for DECL_OFFSET, so that we can use it as part
6264 of a COMPONENT_REF for multiple inheritance. */
6265 layout_decl (TYPE_MAIN_DECL (t), 0);
6267 /* Now fix up any virtual base class types that we left lying
6268 around. We must get these done before we try to lay out the
6269 virtual function table. As a side-effect, this will remove the
6270 base subobject fields. */
6271 layout_virtual_bases (rli, empty_base_offsets);
6273 /* Make sure that empty classes are reflected in RLI at this
6274 point. */
6275 include_empty_classes(rli);
6277 /* Make sure not to create any structures with zero size. */
6278 if (integer_zerop (rli_size_unit_so_far (rli)) && CLASSTYPE_EMPTY_P (t))
6279 place_field (rli,
6280 build_decl (input_location,
6281 FIELD_DECL, NULL_TREE, char_type_node));
6283 /* If this is a non-POD, declaring it packed makes a difference to how it
6284 can be used as a field; don't let finalize_record_size undo it. */
6285 if (TYPE_PACKED (t) && !layout_pod_type_p (t))
6286 rli->packed_maybe_necessary = true;
6288 /* Let the back end lay out the type. */
6289 finish_record_layout (rli, /*free_p=*/true);
6291 if (TYPE_SIZE_UNIT (t)
6292 && TREE_CODE (TYPE_SIZE_UNIT (t)) == INTEGER_CST
6293 && !TREE_OVERFLOW (TYPE_SIZE_UNIT (t))
6294 && !valid_constant_size_p (TYPE_SIZE_UNIT (t)))
6295 error ("type %qT is too large", t);
6297 /* Warn about bases that can't be talked about due to ambiguity. */
6298 warn_about_ambiguous_bases (t);
6300 /* Now that we're done with layout, give the base fields the real types. */
6301 for (field = TYPE_FIELDS (t); field; field = DECL_CHAIN (field))
6302 if (DECL_ARTIFICIAL (field) && IS_FAKE_BASE_TYPE (TREE_TYPE (field)))
6303 TREE_TYPE (field) = TYPE_CONTEXT (TREE_TYPE (field));
6305 /* Clean up. */
6306 splay_tree_delete (empty_base_offsets);
6308 if (CLASSTYPE_EMPTY_P (t)
6309 && tree_int_cst_lt (sizeof_biggest_empty_class,
6310 TYPE_SIZE_UNIT (t)))
6311 sizeof_biggest_empty_class = TYPE_SIZE_UNIT (t);
6314 /* Determine the "key method" for the class type indicated by TYPE,
6315 and set CLASSTYPE_KEY_METHOD accordingly. */
6317 void
6318 determine_key_method (tree type)
6320 tree method;
6322 if (TYPE_FOR_JAVA (type)
6323 || processing_template_decl
6324 || CLASSTYPE_TEMPLATE_INSTANTIATION (type)
6325 || CLASSTYPE_INTERFACE_KNOWN (type))
6326 return;
6328 /* The key method is the first non-pure virtual function that is not
6329 inline at the point of class definition. On some targets the
6330 key function may not be inline; those targets should not call
6331 this function until the end of the translation unit. */
6332 for (method = TYPE_METHODS (type); method != NULL_TREE;
6333 method = DECL_CHAIN (method))
6334 if (TREE_CODE (method) == FUNCTION_DECL
6335 && DECL_VINDEX (method) != NULL_TREE
6336 && ! DECL_DECLARED_INLINE_P (method)
6337 && ! DECL_PURE_VIRTUAL_P (method))
6339 CLASSTYPE_KEY_METHOD (type) = method;
6340 break;
6343 return;
6347 /* Allocate and return an instance of struct sorted_fields_type with
6348 N fields. */
6350 static struct sorted_fields_type *
6351 sorted_fields_type_new (int n)
6353 struct sorted_fields_type *sft;
6354 sft = (sorted_fields_type *) ggc_internal_alloc (sizeof (sorted_fields_type)
6355 + n * sizeof (tree));
6356 sft->len = n;
6358 return sft;
6362 /* Perform processing required when the definition of T (a class type)
6363 is complete. */
6365 void
6366 finish_struct_1 (tree t)
6368 tree x;
6369 /* A TREE_LIST. The TREE_VALUE of each node is a FUNCTION_DECL. */
6370 tree virtuals = NULL_TREE;
6372 if (COMPLETE_TYPE_P (t))
6374 gcc_assert (MAYBE_CLASS_TYPE_P (t));
6375 error ("redefinition of %q#T", t);
6376 popclass ();
6377 return;
6380 /* If this type was previously laid out as a forward reference,
6381 make sure we lay it out again. */
6382 TYPE_SIZE (t) = NULL_TREE;
6383 CLASSTYPE_PRIMARY_BINFO (t) = NULL_TREE;
6385 /* Make assumptions about the class; we'll reset the flags if
6386 necessary. */
6387 CLASSTYPE_EMPTY_P (t) = 1;
6388 CLASSTYPE_NEARLY_EMPTY_P (t) = 1;
6389 CLASSTYPE_CONTAINS_EMPTY_CLASS_P (t) = 0;
6390 CLASSTYPE_LITERAL_P (t) = true;
6392 /* Do end-of-class semantic processing: checking the validity of the
6393 bases and members and add implicitly generated methods. */
6394 check_bases_and_members (t);
6396 /* Find the key method. */
6397 if (TYPE_CONTAINS_VPTR_P (t))
6399 /* The Itanium C++ ABI permits the key method to be chosen when
6400 the class is defined -- even though the key method so
6401 selected may later turn out to be an inline function. On
6402 some systems (such as ARM Symbian OS) the key method cannot
6403 be determined until the end of the translation unit. On such
6404 systems, we leave CLASSTYPE_KEY_METHOD set to NULL, which
6405 will cause the class to be added to KEYED_CLASSES. Then, in
6406 finish_file we will determine the key method. */
6407 if (targetm.cxx.key_method_may_be_inline ())
6408 determine_key_method (t);
6410 /* If a polymorphic class has no key method, we may emit the vtable
6411 in every translation unit where the class definition appears. If
6412 we're devirtualizing, we can look into the vtable even if we
6413 aren't emitting it. */
6414 if (CLASSTYPE_KEY_METHOD (t) == NULL_TREE)
6415 keyed_classes = tree_cons (NULL_TREE, t, keyed_classes);
6418 /* Layout the class itself. */
6419 layout_class_type (t, &virtuals);
6420 if (CLASSTYPE_AS_BASE (t) != t)
6421 /* We use the base type for trivial assignments, and hence it
6422 needs a mode. */
6423 compute_record_mode (CLASSTYPE_AS_BASE (t));
6425 virtuals = modify_all_vtables (t, nreverse (virtuals));
6427 /* If necessary, create the primary vtable for this class. */
6428 if (virtuals || TYPE_CONTAINS_VPTR_P (t))
6430 /* We must enter these virtuals into the table. */
6431 if (!CLASSTYPE_HAS_PRIMARY_BASE_P (t))
6432 build_primary_vtable (NULL_TREE, t);
6433 else if (! BINFO_NEW_VTABLE_MARKED (TYPE_BINFO (t)))
6434 /* Here we know enough to change the type of our virtual
6435 function table, but we will wait until later this function. */
6436 build_primary_vtable (CLASSTYPE_PRIMARY_BINFO (t), t);
6438 /* If we're warning about ABI tags, check the types of the new
6439 virtual functions. */
6440 if (warn_abi_tag)
6441 for (tree v = virtuals; v; v = TREE_CHAIN (v))
6442 check_abi_tags (t, TREE_VALUE (v));
6445 if (TYPE_CONTAINS_VPTR_P (t))
6447 int vindex;
6448 tree fn;
6450 if (BINFO_VTABLE (TYPE_BINFO (t)))
6451 gcc_assert (DECL_VIRTUAL_P (BINFO_VTABLE (TYPE_BINFO (t))));
6452 if (!CLASSTYPE_HAS_PRIMARY_BASE_P (t))
6453 gcc_assert (BINFO_VIRTUALS (TYPE_BINFO (t)) == NULL_TREE);
6455 /* Add entries for virtual functions introduced by this class. */
6456 BINFO_VIRTUALS (TYPE_BINFO (t))
6457 = chainon (BINFO_VIRTUALS (TYPE_BINFO (t)), virtuals);
6459 /* Set DECL_VINDEX for all functions declared in this class. */
6460 for (vindex = 0, fn = BINFO_VIRTUALS (TYPE_BINFO (t));
6462 fn = TREE_CHAIN (fn),
6463 vindex += (TARGET_VTABLE_USES_DESCRIPTORS
6464 ? TARGET_VTABLE_USES_DESCRIPTORS : 1))
6466 tree fndecl = BV_FN (fn);
6468 if (DECL_THUNK_P (fndecl))
6469 /* A thunk. We should never be calling this entry directly
6470 from this vtable -- we'd use the entry for the non
6471 thunk base function. */
6472 DECL_VINDEX (fndecl) = NULL_TREE;
6473 else if (TREE_CODE (DECL_VINDEX (fndecl)) != INTEGER_CST)
6474 DECL_VINDEX (fndecl) = build_int_cst (NULL_TREE, vindex);
6478 finish_struct_bits (t);
6479 set_method_tm_attributes (t);
6481 /* Complete the rtl for any static member objects of the type we're
6482 working on. */
6483 for (x = TYPE_FIELDS (t); x; x = DECL_CHAIN (x))
6484 if (VAR_P (x) && TREE_STATIC (x)
6485 && TREE_TYPE (x) != error_mark_node
6486 && same_type_p (TYPE_MAIN_VARIANT (TREE_TYPE (x)), t))
6487 DECL_MODE (x) = TYPE_MODE (t);
6489 /* Done with FIELDS...now decide whether to sort these for
6490 faster lookups later.
6492 We use a small number because most searches fail (succeeding
6493 ultimately as the search bores through the inheritance
6494 hierarchy), and we want this failure to occur quickly. */
6496 insert_into_classtype_sorted_fields (TYPE_FIELDS (t), t, 8);
6498 /* Complain if one of the field types requires lower visibility. */
6499 constrain_class_visibility (t);
6501 /* Make the rtl for any new vtables we have created, and unmark
6502 the base types we marked. */
6503 finish_vtbls (t);
6505 /* Build the VTT for T. */
6506 build_vtt (t);
6508 /* This warning does not make sense for Java classes, since they
6509 cannot have destructors. */
6510 if (!TYPE_FOR_JAVA (t) && warn_nonvdtor
6511 && TYPE_POLYMORPHIC_P (t) && accessible_nvdtor_p (t))
6512 warning (OPT_Wnon_virtual_dtor,
6513 "%q#T has virtual functions and accessible"
6514 " non-virtual destructor", t);
6516 complete_vars (t);
6518 if (warn_overloaded_virtual)
6519 warn_hidden (t);
6521 /* Class layout, assignment of virtual table slots, etc., is now
6522 complete. Give the back end a chance to tweak the visibility of
6523 the class or perform any other required target modifications. */
6524 targetm.cxx.adjust_class_at_definition (t);
6526 maybe_suppress_debug_info (t);
6528 if (flag_vtable_verify)
6529 vtv_save_class_info (t);
6531 dump_class_hierarchy (t);
6533 /* Finish debugging output for this type. */
6534 rest_of_type_compilation (t, ! LOCAL_CLASS_P (t));
6536 if (TYPE_TRANSPARENT_AGGR (t))
6538 tree field = first_field (t);
6539 if (field == NULL_TREE || error_operand_p (field))
6541 error ("type transparent %q#T does not have any fields", t);
6542 TYPE_TRANSPARENT_AGGR (t) = 0;
6544 else if (DECL_ARTIFICIAL (field))
6546 if (DECL_FIELD_IS_BASE (field))
6547 error ("type transparent class %qT has base classes", t);
6548 else
6550 gcc_checking_assert (DECL_VIRTUAL_P (field));
6551 error ("type transparent class %qT has virtual functions", t);
6553 TYPE_TRANSPARENT_AGGR (t) = 0;
6555 else if (TYPE_MODE (t) != DECL_MODE (field))
6557 error ("type transparent %q#T cannot be made transparent because "
6558 "the type of the first field has a different ABI from the "
6559 "class overall", t);
6560 TYPE_TRANSPARENT_AGGR (t) = 0;
6565 /* Insert FIELDS into T for the sorted case if the FIELDS count is
6566 equal to THRESHOLD or greater than THRESHOLD. */
6568 static void
6569 insert_into_classtype_sorted_fields (tree fields, tree t, int threshold)
6571 int n_fields = count_fields (fields);
6572 if (n_fields >= threshold)
6574 struct sorted_fields_type *field_vec = sorted_fields_type_new (n_fields);
6575 add_fields_to_record_type (fields, field_vec, 0);
6576 qsort (field_vec->elts, n_fields, sizeof (tree), field_decl_cmp);
6577 CLASSTYPE_SORTED_FIELDS (t) = field_vec;
6581 /* Insert lately defined enum ENUMTYPE into T for the sorted case. */
6583 void
6584 insert_late_enum_def_into_classtype_sorted_fields (tree enumtype, tree t)
6586 struct sorted_fields_type *sorted_fields = CLASSTYPE_SORTED_FIELDS (t);
6587 if (sorted_fields)
6589 int i;
6590 int n_fields
6591 = list_length (TYPE_VALUES (enumtype)) + sorted_fields->len;
6592 struct sorted_fields_type *field_vec = sorted_fields_type_new (n_fields);
6594 for (i = 0; i < sorted_fields->len; ++i)
6595 field_vec->elts[i] = sorted_fields->elts[i];
6597 add_enum_fields_to_record_type (enumtype, field_vec,
6598 sorted_fields->len);
6599 qsort (field_vec->elts, n_fields, sizeof (tree), field_decl_cmp);
6600 CLASSTYPE_SORTED_FIELDS (t) = field_vec;
6604 /* When T was built up, the member declarations were added in reverse
6605 order. Rearrange them to declaration order. */
6607 void
6608 unreverse_member_declarations (tree t)
6610 tree next;
6611 tree prev;
6612 tree x;
6614 /* The following lists are all in reverse order. Put them in
6615 declaration order now. */
6616 TYPE_METHODS (t) = nreverse (TYPE_METHODS (t));
6617 CLASSTYPE_DECL_LIST (t) = nreverse (CLASSTYPE_DECL_LIST (t));
6619 /* Actually, for the TYPE_FIELDS, only the non TYPE_DECLs are in
6620 reverse order, so we can't just use nreverse. */
6621 prev = NULL_TREE;
6622 for (x = TYPE_FIELDS (t);
6623 x && TREE_CODE (x) != TYPE_DECL;
6624 x = next)
6626 next = DECL_CHAIN (x);
6627 DECL_CHAIN (x) = prev;
6628 prev = x;
6630 if (prev)
6632 DECL_CHAIN (TYPE_FIELDS (t)) = x;
6633 if (prev)
6634 TYPE_FIELDS (t) = prev;
6638 tree
6639 finish_struct (tree t, tree attributes)
6641 location_t saved_loc = input_location;
6643 /* Now that we've got all the field declarations, reverse everything
6644 as necessary. */
6645 unreverse_member_declarations (t);
6647 cplus_decl_attributes (&t, attributes, (int) ATTR_FLAG_TYPE_IN_PLACE);
6649 /* Nadger the current location so that diagnostics point to the start of
6650 the struct, not the end. */
6651 input_location = DECL_SOURCE_LOCATION (TYPE_NAME (t));
6653 if (processing_template_decl)
6655 tree x;
6657 finish_struct_methods (t);
6658 TYPE_SIZE (t) = bitsize_zero_node;
6659 TYPE_SIZE_UNIT (t) = size_zero_node;
6661 /* We need to emit an error message if this type was used as a parameter
6662 and it is an abstract type, even if it is a template. We construct
6663 a simple CLASSTYPE_PURE_VIRTUALS list without taking bases into
6664 account and we call complete_vars with this type, which will check
6665 the PARM_DECLS. Note that while the type is being defined,
6666 CLASSTYPE_PURE_VIRTUALS contains the list of the inline friends
6667 (see CLASSTYPE_INLINE_FRIENDS) so we need to clear it. */
6668 CLASSTYPE_PURE_VIRTUALS (t) = NULL;
6669 for (x = TYPE_METHODS (t); x; x = DECL_CHAIN (x))
6670 if (DECL_PURE_VIRTUAL_P (x))
6671 vec_safe_push (CLASSTYPE_PURE_VIRTUALS (t), x);
6672 complete_vars (t);
6673 /* We need to add the target functions to the CLASSTYPE_METHOD_VEC if
6674 an enclosing scope is a template class, so that this function be
6675 found by lookup_fnfields_1 when the using declaration is not
6676 instantiated yet. */
6677 for (x = TYPE_FIELDS (t); x; x = DECL_CHAIN (x))
6678 if (TREE_CODE (x) == USING_DECL)
6680 tree fn = strip_using_decl (x);
6681 if (is_overloaded_fn (fn))
6682 for (; fn; fn = OVL_NEXT (fn))
6683 add_method (t, OVL_CURRENT (fn), x);
6686 /* Remember current #pragma pack value. */
6687 TYPE_PRECISION (t) = maximum_field_alignment;
6689 /* Fix up any variants we've already built. */
6690 for (x = TYPE_NEXT_VARIANT (t); x; x = TYPE_NEXT_VARIANT (x))
6692 TYPE_SIZE (x) = TYPE_SIZE (t);
6693 TYPE_SIZE_UNIT (x) = TYPE_SIZE_UNIT (t);
6694 TYPE_FIELDS (x) = TYPE_FIELDS (t);
6695 TYPE_METHODS (x) = TYPE_METHODS (t);
6698 else
6699 finish_struct_1 (t);
6701 if (is_std_init_list (t))
6703 /* People keep complaining that the compiler crashes on an invalid
6704 definition of initializer_list, so I guess we should explicitly
6705 reject it. What the compiler internals care about is that it's a
6706 template and has a pointer field followed by an integer field. */
6707 bool ok = false;
6708 if (processing_template_decl)
6710 tree f = next_initializable_field (TYPE_FIELDS (t));
6711 if (f && TREE_CODE (TREE_TYPE (f)) == POINTER_TYPE)
6713 f = next_initializable_field (DECL_CHAIN (f));
6714 if (f && TREE_CODE (TREE_TYPE (f)) == INTEGER_TYPE)
6715 ok = true;
6718 if (!ok)
6719 fatal_error ("definition of std::initializer_list does not match "
6720 "#include <initializer_list>");
6723 input_location = saved_loc;
6725 TYPE_BEING_DEFINED (t) = 0;
6727 if (current_class_type)
6728 popclass ();
6729 else
6730 error ("trying to finish struct, but kicked out due to previous parse errors");
6732 if (processing_template_decl && at_function_scope_p ()
6733 /* Lambdas are defined by the LAMBDA_EXPR. */
6734 && !LAMBDA_TYPE_P (t))
6735 add_stmt (build_min (TAG_DEFN, t));
6737 return t;
6740 /* Hash table to avoid endless recursion when handling references. */
6741 static hash_table<pointer_hash<tree_node> > *fixed_type_or_null_ref_ht;
6743 /* Return the dynamic type of INSTANCE, if known.
6744 Used to determine whether the virtual function table is needed
6745 or not.
6747 *NONNULL is set iff INSTANCE can be known to be nonnull, regardless
6748 of our knowledge of its type. *NONNULL should be initialized
6749 before this function is called. */
6751 static tree
6752 fixed_type_or_null (tree instance, int *nonnull, int *cdtorp)
6754 #define RECUR(T) fixed_type_or_null((T), nonnull, cdtorp)
6756 switch (TREE_CODE (instance))
6758 case INDIRECT_REF:
6759 if (POINTER_TYPE_P (TREE_TYPE (instance)))
6760 return NULL_TREE;
6761 else
6762 return RECUR (TREE_OPERAND (instance, 0));
6764 case CALL_EXPR:
6765 /* This is a call to a constructor, hence it's never zero. */
6766 if (TREE_HAS_CONSTRUCTOR (instance))
6768 if (nonnull)
6769 *nonnull = 1;
6770 return TREE_TYPE (instance);
6772 return NULL_TREE;
6774 case SAVE_EXPR:
6775 /* This is a call to a constructor, hence it's never zero. */
6776 if (TREE_HAS_CONSTRUCTOR (instance))
6778 if (nonnull)
6779 *nonnull = 1;
6780 return TREE_TYPE (instance);
6782 return RECUR (TREE_OPERAND (instance, 0));
6784 case POINTER_PLUS_EXPR:
6785 case PLUS_EXPR:
6786 case MINUS_EXPR:
6787 if (TREE_CODE (TREE_OPERAND (instance, 0)) == ADDR_EXPR)
6788 return RECUR (TREE_OPERAND (instance, 0));
6789 if (TREE_CODE (TREE_OPERAND (instance, 1)) == INTEGER_CST)
6790 /* Propagate nonnull. */
6791 return RECUR (TREE_OPERAND (instance, 0));
6793 return NULL_TREE;
6795 CASE_CONVERT:
6796 return RECUR (TREE_OPERAND (instance, 0));
6798 case ADDR_EXPR:
6799 instance = TREE_OPERAND (instance, 0);
6800 if (nonnull)
6802 /* Just because we see an ADDR_EXPR doesn't mean we're dealing
6803 with a real object -- given &p->f, p can still be null. */
6804 tree t = get_base_address (instance);
6805 /* ??? Probably should check DECL_WEAK here. */
6806 if (t && DECL_P (t))
6807 *nonnull = 1;
6809 return RECUR (instance);
6811 case COMPONENT_REF:
6812 /* If this component is really a base class reference, then the field
6813 itself isn't definitive. */
6814 if (DECL_FIELD_IS_BASE (TREE_OPERAND (instance, 1)))
6815 return RECUR (TREE_OPERAND (instance, 0));
6816 return RECUR (TREE_OPERAND (instance, 1));
6818 case VAR_DECL:
6819 case FIELD_DECL:
6820 if (TREE_CODE (TREE_TYPE (instance)) == ARRAY_TYPE
6821 && MAYBE_CLASS_TYPE_P (TREE_TYPE (TREE_TYPE (instance))))
6823 if (nonnull)
6824 *nonnull = 1;
6825 return TREE_TYPE (TREE_TYPE (instance));
6827 /* fall through... */
6828 case TARGET_EXPR:
6829 case PARM_DECL:
6830 case RESULT_DECL:
6831 if (MAYBE_CLASS_TYPE_P (TREE_TYPE (instance)))
6833 if (nonnull)
6834 *nonnull = 1;
6835 return TREE_TYPE (instance);
6837 else if (instance == current_class_ptr)
6839 if (nonnull)
6840 *nonnull = 1;
6842 /* if we're in a ctor or dtor, we know our type. If
6843 current_class_ptr is set but we aren't in a function, we're in
6844 an NSDMI (and therefore a constructor). */
6845 if (current_scope () != current_function_decl
6846 || (DECL_LANG_SPECIFIC (current_function_decl)
6847 && (DECL_CONSTRUCTOR_P (current_function_decl)
6848 || DECL_DESTRUCTOR_P (current_function_decl))))
6850 if (cdtorp)
6851 *cdtorp = 1;
6852 return TREE_TYPE (TREE_TYPE (instance));
6855 else if (TREE_CODE (TREE_TYPE (instance)) == REFERENCE_TYPE)
6857 /* We only need one hash table because it is always left empty. */
6858 if (!fixed_type_or_null_ref_ht)
6859 fixed_type_or_null_ref_ht
6860 = new hash_table<pointer_hash<tree_node> > (37);
6862 /* Reference variables should be references to objects. */
6863 if (nonnull)
6864 *nonnull = 1;
6866 /* Enter the INSTANCE in a table to prevent recursion; a
6867 variable's initializer may refer to the variable
6868 itself. */
6869 if (VAR_P (instance)
6870 && DECL_INITIAL (instance)
6871 && !type_dependent_expression_p_push (DECL_INITIAL (instance))
6872 && !fixed_type_or_null_ref_ht->find (instance))
6874 tree type;
6875 tree_node **slot;
6877 slot = fixed_type_or_null_ref_ht->find_slot (instance, INSERT);
6878 *slot = instance;
6879 type = RECUR (DECL_INITIAL (instance));
6880 fixed_type_or_null_ref_ht->remove_elt (instance);
6882 return type;
6885 return NULL_TREE;
6887 default:
6888 return NULL_TREE;
6890 #undef RECUR
6893 /* Return nonzero if the dynamic type of INSTANCE is known, and
6894 equivalent to the static type. We also handle the case where
6895 INSTANCE is really a pointer. Return negative if this is a
6896 ctor/dtor. There the dynamic type is known, but this might not be
6897 the most derived base of the original object, and hence virtual
6898 bases may not be laid out according to this type.
6900 Used to determine whether the virtual function table is needed
6901 or not.
6903 *NONNULL is set iff INSTANCE can be known to be nonnull, regardless
6904 of our knowledge of its type. *NONNULL should be initialized
6905 before this function is called. */
6908 resolves_to_fixed_type_p (tree instance, int* nonnull)
6910 tree t = TREE_TYPE (instance);
6911 int cdtorp = 0;
6912 tree fixed;
6914 /* processing_template_decl can be false in a template if we're in
6915 fold_non_dependent_expr, but we still want to suppress this check. */
6916 if (in_template_function ())
6918 /* In a template we only care about the type of the result. */
6919 if (nonnull)
6920 *nonnull = true;
6921 return true;
6924 fixed = fixed_type_or_null (instance, nonnull, &cdtorp);
6925 if (fixed == NULL_TREE)
6926 return 0;
6927 if (POINTER_TYPE_P (t))
6928 t = TREE_TYPE (t);
6929 if (!same_type_ignoring_top_level_qualifiers_p (t, fixed))
6930 return 0;
6931 return cdtorp ? -1 : 1;
6935 void
6936 init_class_processing (void)
6938 current_class_depth = 0;
6939 current_class_stack_size = 10;
6940 current_class_stack
6941 = XNEWVEC (struct class_stack_node, current_class_stack_size);
6942 vec_alloc (local_classes, 8);
6943 sizeof_biggest_empty_class = size_zero_node;
6945 ridpointers[(int) RID_PUBLIC] = access_public_node;
6946 ridpointers[(int) RID_PRIVATE] = access_private_node;
6947 ridpointers[(int) RID_PROTECTED] = access_protected_node;
6950 /* Restore the cached PREVIOUS_CLASS_LEVEL. */
6952 static void
6953 restore_class_cache (void)
6955 tree type;
6957 /* We are re-entering the same class we just left, so we don't
6958 have to search the whole inheritance matrix to find all the
6959 decls to bind again. Instead, we install the cached
6960 class_shadowed list and walk through it binding names. */
6961 push_binding_level (previous_class_level);
6962 class_binding_level = previous_class_level;
6963 /* Restore IDENTIFIER_TYPE_VALUE. */
6964 for (type = class_binding_level->type_shadowed;
6965 type;
6966 type = TREE_CHAIN (type))
6967 SET_IDENTIFIER_TYPE_VALUE (TREE_PURPOSE (type), TREE_TYPE (type));
6970 /* Set global variables CURRENT_CLASS_NAME and CURRENT_CLASS_TYPE as
6971 appropriate for TYPE.
6973 So that we may avoid calls to lookup_name, we cache the _TYPE
6974 nodes of local TYPE_DECLs in the TREE_TYPE field of the name.
6976 For multiple inheritance, we perform a two-pass depth-first search
6977 of the type lattice. */
6979 void
6980 pushclass (tree type)
6982 class_stack_node_t csn;
6984 type = TYPE_MAIN_VARIANT (type);
6986 /* Make sure there is enough room for the new entry on the stack. */
6987 if (current_class_depth + 1 >= current_class_stack_size)
6989 current_class_stack_size *= 2;
6990 current_class_stack
6991 = XRESIZEVEC (struct class_stack_node, current_class_stack,
6992 current_class_stack_size);
6995 /* Insert a new entry on the class stack. */
6996 csn = current_class_stack + current_class_depth;
6997 csn->name = current_class_name;
6998 csn->type = current_class_type;
6999 csn->access = current_access_specifier;
7000 csn->names_used = 0;
7001 csn->hidden = 0;
7002 current_class_depth++;
7004 /* Now set up the new type. */
7005 current_class_name = TYPE_NAME (type);
7006 if (TREE_CODE (current_class_name) == TYPE_DECL)
7007 current_class_name = DECL_NAME (current_class_name);
7008 current_class_type = type;
7010 /* By default, things in classes are private, while things in
7011 structures or unions are public. */
7012 current_access_specifier = (CLASSTYPE_DECLARED_CLASS (type)
7013 ? access_private_node
7014 : access_public_node);
7016 if (previous_class_level
7017 && type != previous_class_level->this_entity
7018 && current_class_depth == 1)
7020 /* Forcibly remove any old class remnants. */
7021 invalidate_class_lookup_cache ();
7024 if (!previous_class_level
7025 || type != previous_class_level->this_entity
7026 || current_class_depth > 1)
7027 pushlevel_class ();
7028 else
7029 restore_class_cache ();
7032 /* When we exit a toplevel class scope, we save its binding level so
7033 that we can restore it quickly. Here, we've entered some other
7034 class, so we must invalidate our cache. */
7036 void
7037 invalidate_class_lookup_cache (void)
7039 previous_class_level = NULL;
7042 /* Get out of the current class scope. If we were in a class scope
7043 previously, that is the one popped to. */
7045 void
7046 popclass (void)
7048 poplevel_class ();
7050 current_class_depth--;
7051 current_class_name = current_class_stack[current_class_depth].name;
7052 current_class_type = current_class_stack[current_class_depth].type;
7053 current_access_specifier = current_class_stack[current_class_depth].access;
7054 if (current_class_stack[current_class_depth].names_used)
7055 splay_tree_delete (current_class_stack[current_class_depth].names_used);
7058 /* Mark the top of the class stack as hidden. */
7060 void
7061 push_class_stack (void)
7063 if (current_class_depth)
7064 ++current_class_stack[current_class_depth - 1].hidden;
7067 /* Mark the top of the class stack as un-hidden. */
7069 void
7070 pop_class_stack (void)
7072 if (current_class_depth)
7073 --current_class_stack[current_class_depth - 1].hidden;
7076 /* Returns 1 if the class type currently being defined is either T or
7077 a nested type of T. */
7079 bool
7080 currently_open_class (tree t)
7082 int i;
7084 if (!CLASS_TYPE_P (t))
7085 return false;
7087 t = TYPE_MAIN_VARIANT (t);
7089 /* We start looking from 1 because entry 0 is from global scope,
7090 and has no type. */
7091 for (i = current_class_depth; i > 0; --i)
7093 tree c;
7094 if (i == current_class_depth)
7095 c = current_class_type;
7096 else
7098 if (current_class_stack[i].hidden)
7099 break;
7100 c = current_class_stack[i].type;
7102 if (!c)
7103 continue;
7104 if (same_type_p (c, t))
7105 return true;
7107 return false;
7110 /* If either current_class_type or one of its enclosing classes are derived
7111 from T, return the appropriate type. Used to determine how we found
7112 something via unqualified lookup. */
7114 tree
7115 currently_open_derived_class (tree t)
7117 int i;
7119 /* The bases of a dependent type are unknown. */
7120 if (dependent_type_p (t))
7121 return NULL_TREE;
7123 if (!current_class_type)
7124 return NULL_TREE;
7126 if (DERIVED_FROM_P (t, current_class_type))
7127 return current_class_type;
7129 for (i = current_class_depth - 1; i > 0; --i)
7131 if (current_class_stack[i].hidden)
7132 break;
7133 if (DERIVED_FROM_P (t, current_class_stack[i].type))
7134 return current_class_stack[i].type;
7137 return NULL_TREE;
7140 /* Return the outermost enclosing class type that is still open, or
7141 NULL_TREE. */
7143 tree
7144 outermost_open_class (void)
7146 if (!current_class_type)
7147 return NULL_TREE;
7148 tree r = NULL_TREE;
7149 if (TYPE_BEING_DEFINED (current_class_type))
7150 r = current_class_type;
7151 for (int i = current_class_depth - 1; i > 0; --i)
7153 if (current_class_stack[i].hidden)
7154 break;
7155 tree t = current_class_stack[i].type;
7156 if (!TYPE_BEING_DEFINED (t))
7157 break;
7158 r = t;
7160 return r;
7163 /* Returns the innermost class type which is not a lambda closure type. */
7165 tree
7166 current_nonlambda_class_type (void)
7168 int i;
7170 /* We start looking from 1 because entry 0 is from global scope,
7171 and has no type. */
7172 for (i = current_class_depth; i > 0; --i)
7174 tree c;
7175 if (i == current_class_depth)
7176 c = current_class_type;
7177 else
7179 if (current_class_stack[i].hidden)
7180 break;
7181 c = current_class_stack[i].type;
7183 if (!c)
7184 continue;
7185 if (!LAMBDA_TYPE_P (c))
7186 return c;
7188 return NULL_TREE;
7191 /* When entering a class scope, all enclosing class scopes' names with
7192 static meaning (static variables, static functions, types and
7193 enumerators) have to be visible. This recursive function calls
7194 pushclass for all enclosing class contexts until global or a local
7195 scope is reached. TYPE is the enclosed class. */
7197 void
7198 push_nested_class (tree type)
7200 /* A namespace might be passed in error cases, like A::B:C. */
7201 if (type == NULL_TREE
7202 || !CLASS_TYPE_P (type))
7203 return;
7205 push_nested_class (DECL_CONTEXT (TYPE_MAIN_DECL (type)));
7207 pushclass (type);
7210 /* Undoes a push_nested_class call. */
7212 void
7213 pop_nested_class (void)
7215 tree context = DECL_CONTEXT (TYPE_MAIN_DECL (current_class_type));
7217 popclass ();
7218 if (context && CLASS_TYPE_P (context))
7219 pop_nested_class ();
7222 /* Returns the number of extern "LANG" blocks we are nested within. */
7225 current_lang_depth (void)
7227 return vec_safe_length (current_lang_base);
7230 /* Set global variables CURRENT_LANG_NAME to appropriate value
7231 so that behavior of name-mangling machinery is correct. */
7233 void
7234 push_lang_context (tree name)
7236 vec_safe_push (current_lang_base, current_lang_name);
7238 if (name == lang_name_cplusplus)
7240 current_lang_name = name;
7242 else if (name == lang_name_java)
7244 current_lang_name = name;
7245 /* DECL_IGNORED_P is initially set for these types, to avoid clutter.
7246 (See record_builtin_java_type in decl.c.) However, that causes
7247 incorrect debug entries if these types are actually used.
7248 So we re-enable debug output after extern "Java". */
7249 DECL_IGNORED_P (TYPE_NAME (java_byte_type_node)) = 0;
7250 DECL_IGNORED_P (TYPE_NAME (java_short_type_node)) = 0;
7251 DECL_IGNORED_P (TYPE_NAME (java_int_type_node)) = 0;
7252 DECL_IGNORED_P (TYPE_NAME (java_long_type_node)) = 0;
7253 DECL_IGNORED_P (TYPE_NAME (java_float_type_node)) = 0;
7254 DECL_IGNORED_P (TYPE_NAME (java_double_type_node)) = 0;
7255 DECL_IGNORED_P (TYPE_NAME (java_char_type_node)) = 0;
7256 DECL_IGNORED_P (TYPE_NAME (java_boolean_type_node)) = 0;
7258 else if (name == lang_name_c)
7260 current_lang_name = name;
7262 else
7263 error ("language string %<\"%E\"%> not recognized", name);
7266 /* Get out of the current language scope. */
7268 void
7269 pop_lang_context (void)
7271 current_lang_name = current_lang_base->pop ();
7274 /* Type instantiation routines. */
7276 /* Given an OVERLOAD and a TARGET_TYPE, return the function that
7277 matches the TARGET_TYPE. If there is no satisfactory match, return
7278 error_mark_node, and issue an error & warning messages under
7279 control of FLAGS. Permit pointers to member function if FLAGS
7280 permits. If TEMPLATE_ONLY, the name of the overloaded function was
7281 a template-id, and EXPLICIT_TARGS are the explicitly provided
7282 template arguments.
7284 If OVERLOAD is for one or more member functions, then ACCESS_PATH
7285 is the base path used to reference those member functions. If
7286 the address is resolved to a member function, access checks will be
7287 performed and errors issued if appropriate. */
7289 static tree
7290 resolve_address_of_overloaded_function (tree target_type,
7291 tree overload,
7292 tsubst_flags_t flags,
7293 bool template_only,
7294 tree explicit_targs,
7295 tree access_path)
7297 /* Here's what the standard says:
7299 [over.over]
7301 If the name is a function template, template argument deduction
7302 is done, and if the argument deduction succeeds, the deduced
7303 arguments are used to generate a single template function, which
7304 is added to the set of overloaded functions considered.
7306 Non-member functions and static member functions match targets of
7307 type "pointer-to-function" or "reference-to-function." Nonstatic
7308 member functions match targets of type "pointer-to-member
7309 function;" the function type of the pointer to member is used to
7310 select the member function from the set of overloaded member
7311 functions. If a nonstatic member function is selected, the
7312 reference to the overloaded function name is required to have the
7313 form of a pointer to member as described in 5.3.1.
7315 If more than one function is selected, any template functions in
7316 the set are eliminated if the set also contains a non-template
7317 function, and any given template function is eliminated if the
7318 set contains a second template function that is more specialized
7319 than the first according to the partial ordering rules 14.5.5.2.
7320 After such eliminations, if any, there shall remain exactly one
7321 selected function. */
7323 int is_ptrmem = 0;
7324 /* We store the matches in a TREE_LIST rooted here. The functions
7325 are the TREE_PURPOSE, not the TREE_VALUE, in this list, for easy
7326 interoperability with most_specialized_instantiation. */
7327 tree matches = NULL_TREE;
7328 tree fn;
7329 tree target_fn_type;
7331 /* By the time we get here, we should be seeing only real
7332 pointer-to-member types, not the internal POINTER_TYPE to
7333 METHOD_TYPE representation. */
7334 gcc_assert (!TYPE_PTR_P (target_type)
7335 || TREE_CODE (TREE_TYPE (target_type)) != METHOD_TYPE);
7337 gcc_assert (is_overloaded_fn (overload));
7339 /* Check that the TARGET_TYPE is reasonable. */
7340 if (TYPE_PTRFN_P (target_type)
7341 || TYPE_REFFN_P (target_type))
7342 /* This is OK. */;
7343 else if (TYPE_PTRMEMFUNC_P (target_type))
7344 /* This is OK, too. */
7345 is_ptrmem = 1;
7346 else if (TREE_CODE (target_type) == FUNCTION_TYPE)
7347 /* This is OK, too. This comes from a conversion to reference
7348 type. */
7349 target_type = build_reference_type (target_type);
7350 else
7352 if (flags & tf_error)
7353 error ("cannot resolve overloaded function %qD based on"
7354 " conversion to type %qT",
7355 DECL_NAME (OVL_FUNCTION (overload)), target_type);
7356 return error_mark_node;
7359 /* Non-member functions and static member functions match targets of type
7360 "pointer-to-function" or "reference-to-function." Nonstatic member
7361 functions match targets of type "pointer-to-member-function;" the
7362 function type of the pointer to member is used to select the member
7363 function from the set of overloaded member functions.
7365 So figure out the FUNCTION_TYPE that we want to match against. */
7366 target_fn_type = static_fn_type (target_type);
7368 /* If we can find a non-template function that matches, we can just
7369 use it. There's no point in generating template instantiations
7370 if we're just going to throw them out anyhow. But, of course, we
7371 can only do this when we don't *need* a template function. */
7372 if (!template_only)
7374 tree fns;
7376 for (fns = overload; fns; fns = OVL_NEXT (fns))
7378 tree fn = OVL_CURRENT (fns);
7380 if (TREE_CODE (fn) == TEMPLATE_DECL)
7381 /* We're not looking for templates just yet. */
7382 continue;
7384 if ((TREE_CODE (TREE_TYPE (fn)) == METHOD_TYPE)
7385 != is_ptrmem)
7386 /* We're looking for a non-static member, and this isn't
7387 one, or vice versa. */
7388 continue;
7390 /* Ignore functions which haven't been explicitly
7391 declared. */
7392 if (DECL_ANTICIPATED (fn))
7393 continue;
7395 /* See if there's a match. */
7396 if (same_type_p (target_fn_type, static_fn_type (fn)))
7397 matches = tree_cons (fn, NULL_TREE, matches);
7401 /* Now, if we've already got a match (or matches), there's no need
7402 to proceed to the template functions. But, if we don't have a
7403 match we need to look at them, too. */
7404 if (!matches)
7406 tree target_arg_types;
7407 tree target_ret_type;
7408 tree fns;
7409 tree *args;
7410 unsigned int nargs, ia;
7411 tree arg;
7413 target_arg_types = TYPE_ARG_TYPES (target_fn_type);
7414 target_ret_type = TREE_TYPE (target_fn_type);
7416 nargs = list_length (target_arg_types);
7417 args = XALLOCAVEC (tree, nargs);
7418 for (arg = target_arg_types, ia = 0;
7419 arg != NULL_TREE && arg != void_list_node;
7420 arg = TREE_CHAIN (arg), ++ia)
7421 args[ia] = TREE_VALUE (arg);
7422 nargs = ia;
7424 for (fns = overload; fns; fns = OVL_NEXT (fns))
7426 tree fn = OVL_CURRENT (fns);
7427 tree instantiation;
7428 tree targs;
7430 if (TREE_CODE (fn) != TEMPLATE_DECL)
7431 /* We're only looking for templates. */
7432 continue;
7434 if ((TREE_CODE (TREE_TYPE (fn)) == METHOD_TYPE)
7435 != is_ptrmem)
7436 /* We're not looking for a non-static member, and this is
7437 one, or vice versa. */
7438 continue;
7440 tree ret = target_ret_type;
7442 /* If the template has a deduced return type, don't expose it to
7443 template argument deduction. */
7444 if (undeduced_auto_decl (fn))
7445 ret = NULL_TREE;
7447 /* Try to do argument deduction. */
7448 targs = make_tree_vec (DECL_NTPARMS (fn));
7449 instantiation = fn_type_unification (fn, explicit_targs, targs, args,
7450 nargs, ret,
7451 DEDUCE_EXACT, LOOKUP_NORMAL,
7452 false, false);
7453 if (instantiation == error_mark_node)
7454 /* Instantiation failed. */
7455 continue;
7457 /* And now force instantiation to do return type deduction. */
7458 if (undeduced_auto_decl (instantiation))
7460 ++function_depth;
7461 instantiate_decl (instantiation, /*defer*/false, /*class*/false);
7462 --function_depth;
7464 require_deduced_type (instantiation);
7467 /* See if there's a match. */
7468 if (same_type_p (target_fn_type, static_fn_type (instantiation)))
7469 matches = tree_cons (instantiation, fn, matches);
7472 /* Now, remove all but the most specialized of the matches. */
7473 if (matches)
7475 tree match = most_specialized_instantiation (matches);
7477 if (match != error_mark_node)
7478 matches = tree_cons (TREE_PURPOSE (match),
7479 NULL_TREE,
7480 NULL_TREE);
7484 /* Now we should have exactly one function in MATCHES. */
7485 if (matches == NULL_TREE)
7487 /* There were *no* matches. */
7488 if (flags & tf_error)
7490 error ("no matches converting function %qD to type %q#T",
7491 DECL_NAME (OVL_CURRENT (overload)),
7492 target_type);
7494 print_candidates (overload);
7496 return error_mark_node;
7498 else if (TREE_CHAIN (matches))
7500 /* There were too many matches. First check if they're all
7501 the same function. */
7502 tree match = NULL_TREE;
7504 fn = TREE_PURPOSE (matches);
7506 /* For multi-versioned functions, more than one match is just fine and
7507 decls_match will return false as they are different. */
7508 for (match = TREE_CHAIN (matches); match; match = TREE_CHAIN (match))
7509 if (!decls_match (fn, TREE_PURPOSE (match))
7510 && !targetm.target_option.function_versions
7511 (fn, TREE_PURPOSE (match)))
7512 break;
7514 if (match)
7516 if (flags & tf_error)
7518 error ("converting overloaded function %qD to type %q#T is ambiguous",
7519 DECL_NAME (OVL_FUNCTION (overload)),
7520 target_type);
7522 /* Since print_candidates expects the functions in the
7523 TREE_VALUE slot, we flip them here. */
7524 for (match = matches; match; match = TREE_CHAIN (match))
7525 TREE_VALUE (match) = TREE_PURPOSE (match);
7527 print_candidates (matches);
7530 return error_mark_node;
7534 /* Good, exactly one match. Now, convert it to the correct type. */
7535 fn = TREE_PURPOSE (matches);
7537 if (DECL_NONSTATIC_MEMBER_FUNCTION_P (fn)
7538 && !(flags & tf_ptrmem_ok) && !flag_ms_extensions)
7540 static int explained;
7542 if (!(flags & tf_error))
7543 return error_mark_node;
7545 permerror (input_location, "assuming pointer to member %qD", fn);
7546 if (!explained)
7548 inform (input_location, "(a pointer to member can only be formed with %<&%E%>)", fn);
7549 explained = 1;
7553 /* If a pointer to a function that is multi-versioned is requested, the
7554 pointer to the dispatcher function is returned instead. This works
7555 well because indirectly calling the function will dispatch the right
7556 function version at run-time. */
7557 if (DECL_FUNCTION_VERSIONED (fn))
7559 fn = get_function_version_dispatcher (fn);
7560 if (fn == NULL)
7561 return error_mark_node;
7562 /* Mark all the versions corresponding to the dispatcher as used. */
7563 if (!(flags & tf_conv))
7564 mark_versions_used (fn);
7567 /* If we're doing overload resolution purely for the purpose of
7568 determining conversion sequences, we should not consider the
7569 function used. If this conversion sequence is selected, the
7570 function will be marked as used at this point. */
7571 if (!(flags & tf_conv))
7573 /* Make =delete work with SFINAE. */
7574 if (DECL_DELETED_FN (fn) && !(flags & tf_error))
7575 return error_mark_node;
7577 mark_used (fn);
7580 /* We could not check access to member functions when this
7581 expression was originally created since we did not know at that
7582 time to which function the expression referred. */
7583 if (DECL_FUNCTION_MEMBER_P (fn))
7585 gcc_assert (access_path);
7586 perform_or_defer_access_check (access_path, fn, fn, flags);
7589 if (TYPE_PTRFN_P (target_type) || TYPE_PTRMEMFUNC_P (target_type))
7590 return cp_build_addr_expr (fn, flags);
7591 else
7593 /* The target must be a REFERENCE_TYPE. Above, cp_build_unary_op
7594 will mark the function as addressed, but here we must do it
7595 explicitly. */
7596 cxx_mark_addressable (fn);
7598 return fn;
7602 /* This function will instantiate the type of the expression given in
7603 RHS to match the type of LHSTYPE. If errors exist, then return
7604 error_mark_node. FLAGS is a bit mask. If TF_ERROR is set, then
7605 we complain on errors. If we are not complaining, never modify rhs,
7606 as overload resolution wants to try many possible instantiations, in
7607 the hope that at least one will work.
7609 For non-recursive calls, LHSTYPE should be a function, pointer to
7610 function, or a pointer to member function. */
7612 tree
7613 instantiate_type (tree lhstype, tree rhs, tsubst_flags_t flags)
7615 tsubst_flags_t flags_in = flags;
7616 tree access_path = NULL_TREE;
7618 flags &= ~tf_ptrmem_ok;
7620 if (lhstype == unknown_type_node)
7622 if (flags & tf_error)
7623 error ("not enough type information");
7624 return error_mark_node;
7627 if (TREE_TYPE (rhs) != NULL_TREE && ! (type_unknown_p (rhs)))
7629 tree fntype = non_reference (lhstype);
7630 if (same_type_p (fntype, TREE_TYPE (rhs)))
7631 return rhs;
7632 if (flag_ms_extensions
7633 && TYPE_PTRMEMFUNC_P (fntype)
7634 && !TYPE_PTRMEMFUNC_P (TREE_TYPE (rhs)))
7635 /* Microsoft allows `A::f' to be resolved to a
7636 pointer-to-member. */
7638 else
7640 if (flags & tf_error)
7641 error ("cannot convert %qE from type %qT to type %qT",
7642 rhs, TREE_TYPE (rhs), fntype);
7643 return error_mark_node;
7647 if (BASELINK_P (rhs))
7649 access_path = BASELINK_ACCESS_BINFO (rhs);
7650 rhs = BASELINK_FUNCTIONS (rhs);
7653 /* If we are in a template, and have a NON_DEPENDENT_EXPR, we cannot
7654 deduce any type information. */
7655 if (TREE_CODE (rhs) == NON_DEPENDENT_EXPR)
7657 if (flags & tf_error)
7658 error ("not enough type information");
7659 return error_mark_node;
7662 /* There only a few kinds of expressions that may have a type
7663 dependent on overload resolution. */
7664 gcc_assert (TREE_CODE (rhs) == ADDR_EXPR
7665 || TREE_CODE (rhs) == COMPONENT_REF
7666 || is_overloaded_fn (rhs)
7667 || (flag_ms_extensions && TREE_CODE (rhs) == FUNCTION_DECL));
7669 /* This should really only be used when attempting to distinguish
7670 what sort of a pointer to function we have. For now, any
7671 arithmetic operation which is not supported on pointers
7672 is rejected as an error. */
7674 switch (TREE_CODE (rhs))
7676 case COMPONENT_REF:
7678 tree member = TREE_OPERAND (rhs, 1);
7680 member = instantiate_type (lhstype, member, flags);
7681 if (member != error_mark_node
7682 && TREE_SIDE_EFFECTS (TREE_OPERAND (rhs, 0)))
7683 /* Do not lose object's side effects. */
7684 return build2 (COMPOUND_EXPR, TREE_TYPE (member),
7685 TREE_OPERAND (rhs, 0), member);
7686 return member;
7689 case OFFSET_REF:
7690 rhs = TREE_OPERAND (rhs, 1);
7691 if (BASELINK_P (rhs))
7692 return instantiate_type (lhstype, rhs, flags_in);
7694 /* This can happen if we are forming a pointer-to-member for a
7695 member template. */
7696 gcc_assert (TREE_CODE (rhs) == TEMPLATE_ID_EXPR);
7698 /* Fall through. */
7700 case TEMPLATE_ID_EXPR:
7702 tree fns = TREE_OPERAND (rhs, 0);
7703 tree args = TREE_OPERAND (rhs, 1);
7705 return
7706 resolve_address_of_overloaded_function (lhstype, fns, flags_in,
7707 /*template_only=*/true,
7708 args, access_path);
7711 case OVERLOAD:
7712 case FUNCTION_DECL:
7713 return
7714 resolve_address_of_overloaded_function (lhstype, rhs, flags_in,
7715 /*template_only=*/false,
7716 /*explicit_targs=*/NULL_TREE,
7717 access_path);
7719 case ADDR_EXPR:
7721 if (PTRMEM_OK_P (rhs))
7722 flags |= tf_ptrmem_ok;
7724 return instantiate_type (lhstype, TREE_OPERAND (rhs, 0), flags);
7727 case ERROR_MARK:
7728 return error_mark_node;
7730 default:
7731 gcc_unreachable ();
7733 return error_mark_node;
7736 /* Return the name of the virtual function pointer field
7737 (as an IDENTIFIER_NODE) for the given TYPE. Note that
7738 this may have to look back through base types to find the
7739 ultimate field name. (For single inheritance, these could
7740 all be the same name. Who knows for multiple inheritance). */
7742 static tree
7743 get_vfield_name (tree type)
7745 tree binfo, base_binfo;
7746 char *buf;
7748 for (binfo = TYPE_BINFO (type);
7749 BINFO_N_BASE_BINFOS (binfo);
7750 binfo = base_binfo)
7752 base_binfo = BINFO_BASE_BINFO (binfo, 0);
7754 if (BINFO_VIRTUAL_P (base_binfo)
7755 || !TYPE_CONTAINS_VPTR_P (BINFO_TYPE (base_binfo)))
7756 break;
7759 type = BINFO_TYPE (binfo);
7760 buf = (char *) alloca (sizeof (VFIELD_NAME_FORMAT)
7761 + TYPE_NAME_LENGTH (type) + 2);
7762 sprintf (buf, VFIELD_NAME_FORMAT,
7763 IDENTIFIER_POINTER (constructor_name (type)));
7764 return get_identifier (buf);
7767 void
7768 print_class_statistics (void)
7770 if (! GATHER_STATISTICS)
7771 return;
7773 fprintf (stderr, "convert_harshness = %d\n", n_convert_harshness);
7774 fprintf (stderr, "compute_conversion_costs = %d\n", n_compute_conversion_costs);
7775 if (n_vtables)
7777 fprintf (stderr, "vtables = %d; vtable searches = %d\n",
7778 n_vtables, n_vtable_searches);
7779 fprintf (stderr, "vtable entries = %d; vtable elems = %d\n",
7780 n_vtable_entries, n_vtable_elems);
7784 /* Build a dummy reference to ourselves so Derived::Base (and A::A) works,
7785 according to [class]:
7786 The class-name is also inserted
7787 into the scope of the class itself. For purposes of access checking,
7788 the inserted class name is treated as if it were a public member name. */
7790 void
7791 build_self_reference (void)
7793 tree name = constructor_name (current_class_type);
7794 tree value = build_lang_decl (TYPE_DECL, name, current_class_type);
7795 tree saved_cas;
7797 DECL_NONLOCAL (value) = 1;
7798 DECL_CONTEXT (value) = current_class_type;
7799 DECL_ARTIFICIAL (value) = 1;
7800 SET_DECL_SELF_REFERENCE_P (value);
7801 set_underlying_type (value);
7803 if (processing_template_decl)
7804 value = push_template_decl (value);
7806 saved_cas = current_access_specifier;
7807 current_access_specifier = access_public_node;
7808 finish_member_declaration (value);
7809 current_access_specifier = saved_cas;
7812 /* Returns 1 if TYPE contains only padding bytes. */
7815 is_empty_class (tree type)
7817 if (type == error_mark_node)
7818 return 0;
7820 if (! CLASS_TYPE_P (type))
7821 return 0;
7823 return CLASSTYPE_EMPTY_P (type);
7826 /* Returns true if TYPE contains no actual data, just various
7827 possible combinations of empty classes and possibly a vptr. */
7829 bool
7830 is_really_empty_class (tree type)
7832 if (CLASS_TYPE_P (type))
7834 tree field;
7835 tree binfo;
7836 tree base_binfo;
7837 int i;
7839 /* CLASSTYPE_EMPTY_P isn't set properly until the class is actually laid
7840 out, but we'd like to be able to check this before then. */
7841 if (COMPLETE_TYPE_P (type) && is_empty_class (type))
7842 return true;
7844 for (binfo = TYPE_BINFO (type), i = 0;
7845 BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
7846 if (!is_really_empty_class (BINFO_TYPE (base_binfo)))
7847 return false;
7848 for (field = TYPE_FIELDS (type); field; field = DECL_CHAIN (field))
7849 if (TREE_CODE (field) == FIELD_DECL
7850 && !DECL_ARTIFICIAL (field)
7851 && !is_really_empty_class (TREE_TYPE (field)))
7852 return false;
7853 return true;
7855 else if (TREE_CODE (type) == ARRAY_TYPE)
7856 return is_really_empty_class (TREE_TYPE (type));
7857 return false;
7860 /* Note that NAME was looked up while the current class was being
7861 defined and that the result of that lookup was DECL. */
7863 void
7864 maybe_note_name_used_in_class (tree name, tree decl)
7866 splay_tree names_used;
7868 /* If we're not defining a class, there's nothing to do. */
7869 if (!(innermost_scope_kind() == sk_class
7870 && TYPE_BEING_DEFINED (current_class_type)
7871 && !LAMBDA_TYPE_P (current_class_type)))
7872 return;
7874 /* If there's already a binding for this NAME, then we don't have
7875 anything to worry about. */
7876 if (lookup_member (current_class_type, name,
7877 /*protect=*/0, /*want_type=*/false, tf_warning_or_error))
7878 return;
7880 if (!current_class_stack[current_class_depth - 1].names_used)
7881 current_class_stack[current_class_depth - 1].names_used
7882 = splay_tree_new (splay_tree_compare_pointers, 0, 0);
7883 names_used = current_class_stack[current_class_depth - 1].names_used;
7885 splay_tree_insert (names_used,
7886 (splay_tree_key) name,
7887 (splay_tree_value) decl);
7890 /* Note that NAME was declared (as DECL) in the current class. Check
7891 to see that the declaration is valid. */
7893 void
7894 note_name_declared_in_class (tree name, tree decl)
7896 splay_tree names_used;
7897 splay_tree_node n;
7899 /* Look to see if we ever used this name. */
7900 names_used
7901 = current_class_stack[current_class_depth - 1].names_used;
7902 if (!names_used)
7903 return;
7904 /* The C language allows members to be declared with a type of the same
7905 name, and the C++ standard says this diagnostic is not required. So
7906 allow it in extern "C" blocks unless predantic is specified.
7907 Allow it in all cases if -ms-extensions is specified. */
7908 if ((!pedantic && current_lang_name == lang_name_c)
7909 || flag_ms_extensions)
7910 return;
7911 n = splay_tree_lookup (names_used, (splay_tree_key) name);
7912 if (n)
7914 /* [basic.scope.class]
7916 A name N used in a class S shall refer to the same declaration
7917 in its context and when re-evaluated in the completed scope of
7918 S. */
7919 permerror (input_location, "declaration of %q#D", decl);
7920 permerror (input_location, "changes meaning of %qD from %q+#D",
7921 DECL_NAME (OVL_CURRENT (decl)), (tree) n->value);
7925 /* Returns the VAR_DECL for the complete vtable associated with BINFO.
7926 Secondary vtables are merged with primary vtables; this function
7927 will return the VAR_DECL for the primary vtable. */
7929 tree
7930 get_vtbl_decl_for_binfo (tree binfo)
7932 tree decl;
7934 decl = BINFO_VTABLE (binfo);
7935 if (decl && TREE_CODE (decl) == POINTER_PLUS_EXPR)
7937 gcc_assert (TREE_CODE (TREE_OPERAND (decl, 0)) == ADDR_EXPR);
7938 decl = TREE_OPERAND (TREE_OPERAND (decl, 0), 0);
7940 if (decl)
7941 gcc_assert (VAR_P (decl));
7942 return decl;
7946 /* Returns the binfo for the primary base of BINFO. If the resulting
7947 BINFO is a virtual base, and it is inherited elsewhere in the
7948 hierarchy, then the returned binfo might not be the primary base of
7949 BINFO in the complete object. Check BINFO_PRIMARY_P or
7950 BINFO_LOST_PRIMARY_P to be sure. */
7952 static tree
7953 get_primary_binfo (tree binfo)
7955 tree primary_base;
7957 primary_base = CLASSTYPE_PRIMARY_BINFO (BINFO_TYPE (binfo));
7958 if (!primary_base)
7959 return NULL_TREE;
7961 return copied_binfo (primary_base, binfo);
7964 /* If INDENTED_P is zero, indent to INDENT. Return nonzero. */
7966 static int
7967 maybe_indent_hierarchy (FILE * stream, int indent, int indented_p)
7969 if (!indented_p)
7970 fprintf (stream, "%*s", indent, "");
7971 return 1;
7974 /* Dump the offsets of all the bases rooted at BINFO to STREAM.
7975 INDENT should be zero when called from the top level; it is
7976 incremented recursively. IGO indicates the next expected BINFO in
7977 inheritance graph ordering. */
7979 static tree
7980 dump_class_hierarchy_r (FILE *stream,
7981 int flags,
7982 tree binfo,
7983 tree igo,
7984 int indent)
7986 int indented = 0;
7987 tree base_binfo;
7988 int i;
7990 indented = maybe_indent_hierarchy (stream, indent, 0);
7991 fprintf (stream, "%s (0x" HOST_WIDE_INT_PRINT_HEX ") ",
7992 type_as_string (BINFO_TYPE (binfo), TFF_PLAIN_IDENTIFIER),
7993 (HOST_WIDE_INT) (uintptr_t) binfo);
7994 if (binfo != igo)
7996 fprintf (stream, "alternative-path\n");
7997 return igo;
7999 igo = TREE_CHAIN (binfo);
8001 fprintf (stream, HOST_WIDE_INT_PRINT_DEC,
8002 tree_to_shwi (BINFO_OFFSET (binfo)));
8003 if (is_empty_class (BINFO_TYPE (binfo)))
8004 fprintf (stream, " empty");
8005 else if (CLASSTYPE_NEARLY_EMPTY_P (BINFO_TYPE (binfo)))
8006 fprintf (stream, " nearly-empty");
8007 if (BINFO_VIRTUAL_P (binfo))
8008 fprintf (stream, " virtual");
8009 fprintf (stream, "\n");
8011 indented = 0;
8012 if (BINFO_PRIMARY_P (binfo))
8014 indented = maybe_indent_hierarchy (stream, indent + 3, indented);
8015 fprintf (stream, " primary-for %s (0x" HOST_WIDE_INT_PRINT_HEX ")",
8016 type_as_string (BINFO_TYPE (BINFO_INHERITANCE_CHAIN (binfo)),
8017 TFF_PLAIN_IDENTIFIER),
8018 (HOST_WIDE_INT) (uintptr_t) BINFO_INHERITANCE_CHAIN (binfo));
8020 if (BINFO_LOST_PRIMARY_P (binfo))
8022 indented = maybe_indent_hierarchy (stream, indent + 3, indented);
8023 fprintf (stream, " lost-primary");
8025 if (indented)
8026 fprintf (stream, "\n");
8028 if (!(flags & TDF_SLIM))
8030 int indented = 0;
8032 if (BINFO_SUBVTT_INDEX (binfo))
8034 indented = maybe_indent_hierarchy (stream, indent + 3, indented);
8035 fprintf (stream, " subvttidx=%s",
8036 expr_as_string (BINFO_SUBVTT_INDEX (binfo),
8037 TFF_PLAIN_IDENTIFIER));
8039 if (BINFO_VPTR_INDEX (binfo))
8041 indented = maybe_indent_hierarchy (stream, indent + 3, indented);
8042 fprintf (stream, " vptridx=%s",
8043 expr_as_string (BINFO_VPTR_INDEX (binfo),
8044 TFF_PLAIN_IDENTIFIER));
8046 if (BINFO_VPTR_FIELD (binfo))
8048 indented = maybe_indent_hierarchy (stream, indent + 3, indented);
8049 fprintf (stream, " vbaseoffset=%s",
8050 expr_as_string (BINFO_VPTR_FIELD (binfo),
8051 TFF_PLAIN_IDENTIFIER));
8053 if (BINFO_VTABLE (binfo))
8055 indented = maybe_indent_hierarchy (stream, indent + 3, indented);
8056 fprintf (stream, " vptr=%s",
8057 expr_as_string (BINFO_VTABLE (binfo),
8058 TFF_PLAIN_IDENTIFIER));
8061 if (indented)
8062 fprintf (stream, "\n");
8065 for (i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); i++)
8066 igo = dump_class_hierarchy_r (stream, flags, base_binfo, igo, indent + 2);
8068 return igo;
8071 /* Dump the BINFO hierarchy for T. */
8073 static void
8074 dump_class_hierarchy_1 (FILE *stream, int flags, tree t)
8076 fprintf (stream, "Class %s\n", type_as_string (t, TFF_PLAIN_IDENTIFIER));
8077 fprintf (stream, " size=%lu align=%lu\n",
8078 (unsigned long)(tree_to_shwi (TYPE_SIZE (t)) / BITS_PER_UNIT),
8079 (unsigned long)(TYPE_ALIGN (t) / BITS_PER_UNIT));
8080 fprintf (stream, " base size=%lu base align=%lu\n",
8081 (unsigned long)(tree_to_shwi (TYPE_SIZE (CLASSTYPE_AS_BASE (t)))
8082 / BITS_PER_UNIT),
8083 (unsigned long)(TYPE_ALIGN (CLASSTYPE_AS_BASE (t))
8084 / BITS_PER_UNIT));
8085 dump_class_hierarchy_r (stream, flags, TYPE_BINFO (t), TYPE_BINFO (t), 0);
8086 fprintf (stream, "\n");
8089 /* Debug interface to hierarchy dumping. */
8091 void
8092 debug_class (tree t)
8094 dump_class_hierarchy_1 (stderr, TDF_SLIM, t);
8097 static void
8098 dump_class_hierarchy (tree t)
8100 int flags;
8101 FILE *stream = get_dump_info (TDI_class, &flags);
8103 if (stream)
8105 dump_class_hierarchy_1 (stream, flags, t);
8109 static void
8110 dump_array (FILE * stream, tree decl)
8112 tree value;
8113 unsigned HOST_WIDE_INT ix;
8114 HOST_WIDE_INT elt;
8115 tree size = TYPE_MAX_VALUE (TYPE_DOMAIN (TREE_TYPE (decl)));
8117 elt = (tree_to_shwi (TYPE_SIZE (TREE_TYPE (TREE_TYPE (decl))))
8118 / BITS_PER_UNIT);
8119 fprintf (stream, "%s:", decl_as_string (decl, TFF_PLAIN_IDENTIFIER));
8120 fprintf (stream, " %s entries",
8121 expr_as_string (size_binop (PLUS_EXPR, size, size_one_node),
8122 TFF_PLAIN_IDENTIFIER));
8123 fprintf (stream, "\n");
8125 FOR_EACH_CONSTRUCTOR_VALUE (CONSTRUCTOR_ELTS (DECL_INITIAL (decl)),
8126 ix, value)
8127 fprintf (stream, "%-4ld %s\n", (long)(ix * elt),
8128 expr_as_string (value, TFF_PLAIN_IDENTIFIER));
8131 static void
8132 dump_vtable (tree t, tree binfo, tree vtable)
8134 int flags;
8135 FILE *stream = get_dump_info (TDI_class, &flags);
8137 if (!stream)
8138 return;
8140 if (!(flags & TDF_SLIM))
8142 int ctor_vtbl_p = TYPE_BINFO (t) != binfo;
8144 fprintf (stream, "%s for %s",
8145 ctor_vtbl_p ? "Construction vtable" : "Vtable",
8146 type_as_string (BINFO_TYPE (binfo), TFF_PLAIN_IDENTIFIER));
8147 if (ctor_vtbl_p)
8149 if (!BINFO_VIRTUAL_P (binfo))
8150 fprintf (stream, " (0x" HOST_WIDE_INT_PRINT_HEX " instance)",
8151 (HOST_WIDE_INT) (uintptr_t) binfo);
8152 fprintf (stream, " in %s", type_as_string (t, TFF_PLAIN_IDENTIFIER));
8154 fprintf (stream, "\n");
8155 dump_array (stream, vtable);
8156 fprintf (stream, "\n");
8160 static void
8161 dump_vtt (tree t, tree vtt)
8163 int flags;
8164 FILE *stream = get_dump_info (TDI_class, &flags);
8166 if (!stream)
8167 return;
8169 if (!(flags & TDF_SLIM))
8171 fprintf (stream, "VTT for %s\n",
8172 type_as_string (t, TFF_PLAIN_IDENTIFIER));
8173 dump_array (stream, vtt);
8174 fprintf (stream, "\n");
8178 /* Dump a function or thunk and its thunkees. */
8180 static void
8181 dump_thunk (FILE *stream, int indent, tree thunk)
8183 static const char spaces[] = " ";
8184 tree name = DECL_NAME (thunk);
8185 tree thunks;
8187 fprintf (stream, "%.*s%p %s %s", indent, spaces,
8188 (void *)thunk,
8189 !DECL_THUNK_P (thunk) ? "function"
8190 : DECL_THIS_THUNK_P (thunk) ? "this-thunk" : "covariant-thunk",
8191 name ? IDENTIFIER_POINTER (name) : "<unset>");
8192 if (DECL_THUNK_P (thunk))
8194 HOST_WIDE_INT fixed_adjust = THUNK_FIXED_OFFSET (thunk);
8195 tree virtual_adjust = THUNK_VIRTUAL_OFFSET (thunk);
8197 fprintf (stream, " fixed=" HOST_WIDE_INT_PRINT_DEC, fixed_adjust);
8198 if (!virtual_adjust)
8199 /*NOP*/;
8200 else if (DECL_THIS_THUNK_P (thunk))
8201 fprintf (stream, " vcall=" HOST_WIDE_INT_PRINT_DEC,
8202 tree_to_shwi (virtual_adjust));
8203 else
8204 fprintf (stream, " vbase=" HOST_WIDE_INT_PRINT_DEC "(%s)",
8205 tree_to_shwi (BINFO_VPTR_FIELD (virtual_adjust)),
8206 type_as_string (BINFO_TYPE (virtual_adjust), TFF_SCOPE));
8207 if (THUNK_ALIAS (thunk))
8208 fprintf (stream, " alias to %p", (void *)THUNK_ALIAS (thunk));
8210 fprintf (stream, "\n");
8211 for (thunks = DECL_THUNKS (thunk); thunks; thunks = TREE_CHAIN (thunks))
8212 dump_thunk (stream, indent + 2, thunks);
8215 /* Dump the thunks for FN. */
8217 void
8218 debug_thunks (tree fn)
8220 dump_thunk (stderr, 0, fn);
8223 /* Virtual function table initialization. */
8225 /* Create all the necessary vtables for T and its base classes. */
8227 static void
8228 finish_vtbls (tree t)
8230 tree vbase;
8231 vec<constructor_elt, va_gc> *v = NULL;
8232 tree vtable = BINFO_VTABLE (TYPE_BINFO (t));
8234 /* We lay out the primary and secondary vtables in one contiguous
8235 vtable. The primary vtable is first, followed by the non-virtual
8236 secondary vtables in inheritance graph order. */
8237 accumulate_vtbl_inits (TYPE_BINFO (t), TYPE_BINFO (t), TYPE_BINFO (t),
8238 vtable, t, &v);
8240 /* Then come the virtual bases, also in inheritance graph order. */
8241 for (vbase = TYPE_BINFO (t); vbase; vbase = TREE_CHAIN (vbase))
8243 if (!BINFO_VIRTUAL_P (vbase))
8244 continue;
8245 accumulate_vtbl_inits (vbase, vbase, TYPE_BINFO (t), vtable, t, &v);
8248 if (BINFO_VTABLE (TYPE_BINFO (t)))
8249 initialize_vtable (TYPE_BINFO (t), v);
8252 /* Initialize the vtable for BINFO with the INITS. */
8254 static void
8255 initialize_vtable (tree binfo, vec<constructor_elt, va_gc> *inits)
8257 tree decl;
8259 layout_vtable_decl (binfo, vec_safe_length (inits));
8260 decl = get_vtbl_decl_for_binfo (binfo);
8261 initialize_artificial_var (decl, inits);
8262 dump_vtable (BINFO_TYPE (binfo), binfo, decl);
8265 /* Build the VTT (virtual table table) for T.
8266 A class requires a VTT if it has virtual bases.
8268 This holds
8269 1 - primary virtual pointer for complete object T
8270 2 - secondary VTTs for each direct non-virtual base of T which requires a
8272 3 - secondary virtual pointers for each direct or indirect base of T which
8273 has virtual bases or is reachable via a virtual path from T.
8274 4 - secondary VTTs for each direct or indirect virtual base of T.
8276 Secondary VTTs look like complete object VTTs without part 4. */
8278 static void
8279 build_vtt (tree t)
8281 tree type;
8282 tree vtt;
8283 tree index;
8284 vec<constructor_elt, va_gc> *inits;
8286 /* Build up the initializers for the VTT. */
8287 inits = NULL;
8288 index = size_zero_node;
8289 build_vtt_inits (TYPE_BINFO (t), t, &inits, &index);
8291 /* If we didn't need a VTT, we're done. */
8292 if (!inits)
8293 return;
8295 /* Figure out the type of the VTT. */
8296 type = build_array_of_n_type (const_ptr_type_node,
8297 inits->length ());
8299 /* Now, build the VTT object itself. */
8300 vtt = build_vtable (t, mangle_vtt_for_type (t), type);
8301 initialize_artificial_var (vtt, inits);
8302 /* Add the VTT to the vtables list. */
8303 DECL_CHAIN (vtt) = DECL_CHAIN (CLASSTYPE_VTABLES (t));
8304 DECL_CHAIN (CLASSTYPE_VTABLES (t)) = vtt;
8306 dump_vtt (t, vtt);
8309 /* When building a secondary VTT, BINFO_VTABLE is set to a TREE_LIST with
8310 PURPOSE the RTTI_BINFO, VALUE the real vtable pointer for this binfo,
8311 and CHAIN the vtable pointer for this binfo after construction is
8312 complete. VALUE can also be another BINFO, in which case we recurse. */
8314 static tree
8315 binfo_ctor_vtable (tree binfo)
8317 tree vt;
8319 while (1)
8321 vt = BINFO_VTABLE (binfo);
8322 if (TREE_CODE (vt) == TREE_LIST)
8323 vt = TREE_VALUE (vt);
8324 if (TREE_CODE (vt) == TREE_BINFO)
8325 binfo = vt;
8326 else
8327 break;
8330 return vt;
8333 /* Data for secondary VTT initialization. */
8334 typedef struct secondary_vptr_vtt_init_data_s
8336 /* Is this the primary VTT? */
8337 bool top_level_p;
8339 /* Current index into the VTT. */
8340 tree index;
8342 /* Vector of initializers built up. */
8343 vec<constructor_elt, va_gc> *inits;
8345 /* The type being constructed by this secondary VTT. */
8346 tree type_being_constructed;
8347 } secondary_vptr_vtt_init_data;
8349 /* Recursively build the VTT-initializer for BINFO (which is in the
8350 hierarchy dominated by T). INITS points to the end of the initializer
8351 list to date. INDEX is the VTT index where the next element will be
8352 replaced. Iff BINFO is the binfo for T, this is the top level VTT (i.e.
8353 not a subvtt for some base of T). When that is so, we emit the sub-VTTs
8354 for virtual bases of T. When it is not so, we build the constructor
8355 vtables for the BINFO-in-T variant. */
8357 static void
8358 build_vtt_inits (tree binfo, tree t, vec<constructor_elt, va_gc> **inits,
8359 tree *index)
8361 int i;
8362 tree b;
8363 tree init;
8364 secondary_vptr_vtt_init_data data;
8365 int top_level_p = SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), t);
8367 /* We only need VTTs for subobjects with virtual bases. */
8368 if (!CLASSTYPE_VBASECLASSES (BINFO_TYPE (binfo)))
8369 return;
8371 /* We need to use a construction vtable if this is not the primary
8372 VTT. */
8373 if (!top_level_p)
8375 build_ctor_vtbl_group (binfo, t);
8377 /* Record the offset in the VTT where this sub-VTT can be found. */
8378 BINFO_SUBVTT_INDEX (binfo) = *index;
8381 /* Add the address of the primary vtable for the complete object. */
8382 init = binfo_ctor_vtable (binfo);
8383 CONSTRUCTOR_APPEND_ELT (*inits, NULL_TREE, init);
8384 if (top_level_p)
8386 gcc_assert (!BINFO_VPTR_INDEX (binfo));
8387 BINFO_VPTR_INDEX (binfo) = *index;
8389 *index = size_binop (PLUS_EXPR, *index, TYPE_SIZE_UNIT (ptr_type_node));
8391 /* Recursively add the secondary VTTs for non-virtual bases. */
8392 for (i = 0; BINFO_BASE_ITERATE (binfo, i, b); ++i)
8393 if (!BINFO_VIRTUAL_P (b))
8394 build_vtt_inits (b, t, inits, index);
8396 /* Add secondary virtual pointers for all subobjects of BINFO with
8397 either virtual bases or reachable along a virtual path, except
8398 subobjects that are non-virtual primary bases. */
8399 data.top_level_p = top_level_p;
8400 data.index = *index;
8401 data.inits = *inits;
8402 data.type_being_constructed = BINFO_TYPE (binfo);
8404 dfs_walk_once (binfo, dfs_build_secondary_vptr_vtt_inits, NULL, &data);
8406 *index = data.index;
8408 /* data.inits might have grown as we added secondary virtual pointers.
8409 Make sure our caller knows about the new vector. */
8410 *inits = data.inits;
8412 if (top_level_p)
8413 /* Add the secondary VTTs for virtual bases in inheritance graph
8414 order. */
8415 for (b = TYPE_BINFO (BINFO_TYPE (binfo)); b; b = TREE_CHAIN (b))
8417 if (!BINFO_VIRTUAL_P (b))
8418 continue;
8420 build_vtt_inits (b, t, inits, index);
8422 else
8423 /* Remove the ctor vtables we created. */
8424 dfs_walk_all (binfo, dfs_fixup_binfo_vtbls, NULL, binfo);
8427 /* Called from build_vtt_inits via dfs_walk. BINFO is the binfo for the base
8428 in most derived. DATA is a SECONDARY_VPTR_VTT_INIT_DATA structure. */
8430 static tree
8431 dfs_build_secondary_vptr_vtt_inits (tree binfo, void *data_)
8433 secondary_vptr_vtt_init_data *data = (secondary_vptr_vtt_init_data *)data_;
8435 /* We don't care about bases that don't have vtables. */
8436 if (!TYPE_VFIELD (BINFO_TYPE (binfo)))
8437 return dfs_skip_bases;
8439 /* We're only interested in proper subobjects of the type being
8440 constructed. */
8441 if (SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), data->type_being_constructed))
8442 return NULL_TREE;
8444 /* We're only interested in bases with virtual bases or reachable
8445 via a virtual path from the type being constructed. */
8446 if (!(CLASSTYPE_VBASECLASSES (BINFO_TYPE (binfo))
8447 || binfo_via_virtual (binfo, data->type_being_constructed)))
8448 return dfs_skip_bases;
8450 /* We're not interested in non-virtual primary bases. */
8451 if (!BINFO_VIRTUAL_P (binfo) && BINFO_PRIMARY_P (binfo))
8452 return NULL_TREE;
8454 /* Record the index where this secondary vptr can be found. */
8455 if (data->top_level_p)
8457 gcc_assert (!BINFO_VPTR_INDEX (binfo));
8458 BINFO_VPTR_INDEX (binfo) = data->index;
8460 if (BINFO_VIRTUAL_P (binfo))
8462 /* It's a primary virtual base, and this is not a
8463 construction vtable. Find the base this is primary of in
8464 the inheritance graph, and use that base's vtable
8465 now. */
8466 while (BINFO_PRIMARY_P (binfo))
8467 binfo = BINFO_INHERITANCE_CHAIN (binfo);
8471 /* Add the initializer for the secondary vptr itself. */
8472 CONSTRUCTOR_APPEND_ELT (data->inits, NULL_TREE, binfo_ctor_vtable (binfo));
8474 /* Advance the vtt index. */
8475 data->index = size_binop (PLUS_EXPR, data->index,
8476 TYPE_SIZE_UNIT (ptr_type_node));
8478 return NULL_TREE;
8481 /* Called from build_vtt_inits via dfs_walk. After building
8482 constructor vtables and generating the sub-vtt from them, we need
8483 to restore the BINFO_VTABLES that were scribbled on. DATA is the
8484 binfo of the base whose sub vtt was generated. */
8486 static tree
8487 dfs_fixup_binfo_vtbls (tree binfo, void* data)
8489 tree vtable = BINFO_VTABLE (binfo);
8491 if (!TYPE_CONTAINS_VPTR_P (BINFO_TYPE (binfo)))
8492 /* If this class has no vtable, none of its bases do. */
8493 return dfs_skip_bases;
8495 if (!vtable)
8496 /* This might be a primary base, so have no vtable in this
8497 hierarchy. */
8498 return NULL_TREE;
8500 /* If we scribbled the construction vtable vptr into BINFO, clear it
8501 out now. */
8502 if (TREE_CODE (vtable) == TREE_LIST
8503 && (TREE_PURPOSE (vtable) == (tree) data))
8504 BINFO_VTABLE (binfo) = TREE_CHAIN (vtable);
8506 return NULL_TREE;
8509 /* Build the construction vtable group for BINFO which is in the
8510 hierarchy dominated by T. */
8512 static void
8513 build_ctor_vtbl_group (tree binfo, tree t)
8515 tree type;
8516 tree vtbl;
8517 tree id;
8518 tree vbase;
8519 vec<constructor_elt, va_gc> *v;
8521 /* See if we've already created this construction vtable group. */
8522 id = mangle_ctor_vtbl_for_type (t, binfo);
8523 if (IDENTIFIER_GLOBAL_VALUE (id))
8524 return;
8526 gcc_assert (!SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), t));
8527 /* Build a version of VTBL (with the wrong type) for use in
8528 constructing the addresses of secondary vtables in the
8529 construction vtable group. */
8530 vtbl = build_vtable (t, id, ptr_type_node);
8531 DECL_CONSTRUCTION_VTABLE_P (vtbl) = 1;
8532 /* Don't export construction vtables from shared libraries. Even on
8533 targets that don't support hidden visibility, this tells
8534 can_refer_decl_in_current_unit_p not to assume that it's safe to
8535 access from a different compilation unit (bz 54314). */
8536 DECL_VISIBILITY (vtbl) = VISIBILITY_HIDDEN;
8537 DECL_VISIBILITY_SPECIFIED (vtbl) = true;
8539 v = NULL;
8540 accumulate_vtbl_inits (binfo, TYPE_BINFO (TREE_TYPE (binfo)),
8541 binfo, vtbl, t, &v);
8543 /* Add the vtables for each of our virtual bases using the vbase in T
8544 binfo. */
8545 for (vbase = TYPE_BINFO (BINFO_TYPE (binfo));
8546 vbase;
8547 vbase = TREE_CHAIN (vbase))
8549 tree b;
8551 if (!BINFO_VIRTUAL_P (vbase))
8552 continue;
8553 b = copied_binfo (vbase, binfo);
8555 accumulate_vtbl_inits (b, vbase, binfo, vtbl, t, &v);
8558 /* Figure out the type of the construction vtable. */
8559 type = build_array_of_n_type (vtable_entry_type, v->length ());
8560 layout_type (type);
8561 TREE_TYPE (vtbl) = type;
8562 DECL_SIZE (vtbl) = DECL_SIZE_UNIT (vtbl) = NULL_TREE;
8563 layout_decl (vtbl, 0);
8565 /* Initialize the construction vtable. */
8566 CLASSTYPE_VTABLES (t) = chainon (CLASSTYPE_VTABLES (t), vtbl);
8567 initialize_artificial_var (vtbl, v);
8568 dump_vtable (t, binfo, vtbl);
8571 /* Add the vtbl initializers for BINFO (and its bases other than
8572 non-virtual primaries) to the list of INITS. BINFO is in the
8573 hierarchy dominated by T. RTTI_BINFO is the binfo within T of
8574 the constructor the vtbl inits should be accumulated for. (If this
8575 is the complete object vtbl then RTTI_BINFO will be TYPE_BINFO (T).)
8576 ORIG_BINFO is the binfo for this object within BINFO_TYPE (RTTI_BINFO).
8577 BINFO is the active base equivalent of ORIG_BINFO in the inheritance
8578 graph of T. Both BINFO and ORIG_BINFO will have the same BINFO_TYPE,
8579 but are not necessarily the same in terms of layout. */
8581 static void
8582 accumulate_vtbl_inits (tree binfo,
8583 tree orig_binfo,
8584 tree rtti_binfo,
8585 tree vtbl,
8586 tree t,
8587 vec<constructor_elt, va_gc> **inits)
8589 int i;
8590 tree base_binfo;
8591 int ctor_vtbl_p = !SAME_BINFO_TYPE_P (BINFO_TYPE (rtti_binfo), t);
8593 gcc_assert (SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), BINFO_TYPE (orig_binfo)));
8595 /* If it doesn't have a vptr, we don't do anything. */
8596 if (!TYPE_CONTAINS_VPTR_P (BINFO_TYPE (binfo)))
8597 return;
8599 /* If we're building a construction vtable, we're not interested in
8600 subobjects that don't require construction vtables. */
8601 if (ctor_vtbl_p
8602 && !CLASSTYPE_VBASECLASSES (BINFO_TYPE (binfo))
8603 && !binfo_via_virtual (orig_binfo, BINFO_TYPE (rtti_binfo)))
8604 return;
8606 /* Build the initializers for the BINFO-in-T vtable. */
8607 dfs_accumulate_vtbl_inits (binfo, orig_binfo, rtti_binfo, vtbl, t, inits);
8609 /* Walk the BINFO and its bases. We walk in preorder so that as we
8610 initialize each vtable we can figure out at what offset the
8611 secondary vtable lies from the primary vtable. We can't use
8612 dfs_walk here because we need to iterate through bases of BINFO
8613 and RTTI_BINFO simultaneously. */
8614 for (i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
8616 /* Skip virtual bases. */
8617 if (BINFO_VIRTUAL_P (base_binfo))
8618 continue;
8619 accumulate_vtbl_inits (base_binfo,
8620 BINFO_BASE_BINFO (orig_binfo, i),
8621 rtti_binfo, vtbl, t,
8622 inits);
8626 /* Called from accumulate_vtbl_inits. Adds the initializers for the
8627 BINFO vtable to L. */
8629 static void
8630 dfs_accumulate_vtbl_inits (tree binfo,
8631 tree orig_binfo,
8632 tree rtti_binfo,
8633 tree orig_vtbl,
8634 tree t,
8635 vec<constructor_elt, va_gc> **l)
8637 tree vtbl = NULL_TREE;
8638 int ctor_vtbl_p = !SAME_BINFO_TYPE_P (BINFO_TYPE (rtti_binfo), t);
8639 int n_inits;
8641 if (ctor_vtbl_p
8642 && BINFO_VIRTUAL_P (orig_binfo) && BINFO_PRIMARY_P (orig_binfo))
8644 /* In the hierarchy of BINFO_TYPE (RTTI_BINFO), this is a
8645 primary virtual base. If it is not the same primary in
8646 the hierarchy of T, we'll need to generate a ctor vtable
8647 for it, to place at its location in T. If it is the same
8648 primary, we still need a VTT entry for the vtable, but it
8649 should point to the ctor vtable for the base it is a
8650 primary for within the sub-hierarchy of RTTI_BINFO.
8652 There are three possible cases:
8654 1) We are in the same place.
8655 2) We are a primary base within a lost primary virtual base of
8656 RTTI_BINFO.
8657 3) We are primary to something not a base of RTTI_BINFO. */
8659 tree b;
8660 tree last = NULL_TREE;
8662 /* First, look through the bases we are primary to for RTTI_BINFO
8663 or a virtual base. */
8664 b = binfo;
8665 while (BINFO_PRIMARY_P (b))
8667 b = BINFO_INHERITANCE_CHAIN (b);
8668 last = b;
8669 if (BINFO_VIRTUAL_P (b) || b == rtti_binfo)
8670 goto found;
8672 /* If we run out of primary links, keep looking down our
8673 inheritance chain; we might be an indirect primary. */
8674 for (b = last; b; b = BINFO_INHERITANCE_CHAIN (b))
8675 if (BINFO_VIRTUAL_P (b) || b == rtti_binfo)
8676 break;
8677 found:
8679 /* If we found RTTI_BINFO, this is case 1. If we found a virtual
8680 base B and it is a base of RTTI_BINFO, this is case 2. In
8681 either case, we share our vtable with LAST, i.e. the
8682 derived-most base within B of which we are a primary. */
8683 if (b == rtti_binfo
8684 || (b && binfo_for_vbase (BINFO_TYPE (b), BINFO_TYPE (rtti_binfo))))
8685 /* Just set our BINFO_VTABLE to point to LAST, as we may not have
8686 set LAST's BINFO_VTABLE yet. We'll extract the actual vptr in
8687 binfo_ctor_vtable after everything's been set up. */
8688 vtbl = last;
8690 /* Otherwise, this is case 3 and we get our own. */
8692 else if (!BINFO_NEW_VTABLE_MARKED (orig_binfo))
8693 return;
8695 n_inits = vec_safe_length (*l);
8697 if (!vtbl)
8699 tree index;
8700 int non_fn_entries;
8702 /* Add the initializer for this vtable. */
8703 build_vtbl_initializer (binfo, orig_binfo, t, rtti_binfo,
8704 &non_fn_entries, l);
8706 /* Figure out the position to which the VPTR should point. */
8707 vtbl = build1 (ADDR_EXPR, vtbl_ptr_type_node, orig_vtbl);
8708 index = size_binop (MULT_EXPR,
8709 TYPE_SIZE_UNIT (vtable_entry_type),
8710 size_int (non_fn_entries + n_inits));
8711 vtbl = fold_build_pointer_plus (vtbl, index);
8714 if (ctor_vtbl_p)
8715 /* For a construction vtable, we can't overwrite BINFO_VTABLE.
8716 So, we make a TREE_LIST. Later, dfs_fixup_binfo_vtbls will
8717 straighten this out. */
8718 BINFO_VTABLE (binfo) = tree_cons (rtti_binfo, vtbl, BINFO_VTABLE (binfo));
8719 else if (BINFO_PRIMARY_P (binfo) && BINFO_VIRTUAL_P (binfo))
8720 /* Throw away any unneeded intializers. */
8721 (*l)->truncate (n_inits);
8722 else
8723 /* For an ordinary vtable, set BINFO_VTABLE. */
8724 BINFO_VTABLE (binfo) = vtbl;
8727 static GTY(()) tree abort_fndecl_addr;
8729 /* Construct the initializer for BINFO's virtual function table. BINFO
8730 is part of the hierarchy dominated by T. If we're building a
8731 construction vtable, the ORIG_BINFO is the binfo we should use to
8732 find the actual function pointers to put in the vtable - but they
8733 can be overridden on the path to most-derived in the graph that
8734 ORIG_BINFO belongs. Otherwise,
8735 ORIG_BINFO should be the same as BINFO. The RTTI_BINFO is the
8736 BINFO that should be indicated by the RTTI information in the
8737 vtable; it will be a base class of T, rather than T itself, if we
8738 are building a construction vtable.
8740 The value returned is a TREE_LIST suitable for wrapping in a
8741 CONSTRUCTOR to use as the DECL_INITIAL for a vtable. If
8742 NON_FN_ENTRIES_P is not NULL, *NON_FN_ENTRIES_P is set to the
8743 number of non-function entries in the vtable.
8745 It might seem that this function should never be called with a
8746 BINFO for which BINFO_PRIMARY_P holds, the vtable for such a
8747 base is always subsumed by a derived class vtable. However, when
8748 we are building construction vtables, we do build vtables for
8749 primary bases; we need these while the primary base is being
8750 constructed. */
8752 static void
8753 build_vtbl_initializer (tree binfo,
8754 tree orig_binfo,
8755 tree t,
8756 tree rtti_binfo,
8757 int* non_fn_entries_p,
8758 vec<constructor_elt, va_gc> **inits)
8760 tree v;
8761 vtbl_init_data vid;
8762 unsigned ix, jx;
8763 tree vbinfo;
8764 vec<tree, va_gc> *vbases;
8765 constructor_elt *e;
8767 /* Initialize VID. */
8768 memset (&vid, 0, sizeof (vid));
8769 vid.binfo = binfo;
8770 vid.derived = t;
8771 vid.rtti_binfo = rtti_binfo;
8772 vid.primary_vtbl_p = SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), t);
8773 vid.ctor_vtbl_p = !SAME_BINFO_TYPE_P (BINFO_TYPE (rtti_binfo), t);
8774 vid.generate_vcall_entries = true;
8775 /* The first vbase or vcall offset is at index -3 in the vtable. */
8776 vid.index = ssize_int(-3 * TARGET_VTABLE_DATA_ENTRY_DISTANCE);
8778 /* Add entries to the vtable for RTTI. */
8779 build_rtti_vtbl_entries (binfo, &vid);
8781 /* Create an array for keeping track of the functions we've
8782 processed. When we see multiple functions with the same
8783 signature, we share the vcall offsets. */
8784 vec_alloc (vid.fns, 32);
8785 /* Add the vcall and vbase offset entries. */
8786 build_vcall_and_vbase_vtbl_entries (binfo, &vid);
8788 /* Clear BINFO_VTABLE_PATH_MARKED; it's set by
8789 build_vbase_offset_vtbl_entries. */
8790 for (vbases = CLASSTYPE_VBASECLASSES (t), ix = 0;
8791 vec_safe_iterate (vbases, ix, &vbinfo); ix++)
8792 BINFO_VTABLE_PATH_MARKED (vbinfo) = 0;
8794 /* If the target requires padding between data entries, add that now. */
8795 if (TARGET_VTABLE_DATA_ENTRY_DISTANCE > 1)
8797 int n_entries = vec_safe_length (vid.inits);
8799 vec_safe_grow (vid.inits, TARGET_VTABLE_DATA_ENTRY_DISTANCE * n_entries);
8801 /* Move data entries into their new positions and add padding
8802 after the new positions. Iterate backwards so we don't
8803 overwrite entries that we would need to process later. */
8804 for (ix = n_entries - 1;
8805 vid.inits->iterate (ix, &e);
8806 ix--)
8808 int j;
8809 int new_position = (TARGET_VTABLE_DATA_ENTRY_DISTANCE * ix
8810 + (TARGET_VTABLE_DATA_ENTRY_DISTANCE - 1));
8812 (*vid.inits)[new_position] = *e;
8814 for (j = 1; j < TARGET_VTABLE_DATA_ENTRY_DISTANCE; ++j)
8816 constructor_elt *f = &(*vid.inits)[new_position - j];
8817 f->index = NULL_TREE;
8818 f->value = build1 (NOP_EXPR, vtable_entry_type,
8819 null_pointer_node);
8824 if (non_fn_entries_p)
8825 *non_fn_entries_p = vec_safe_length (vid.inits);
8827 /* The initializers for virtual functions were built up in reverse
8828 order. Straighten them out and add them to the running list in one
8829 step. */
8830 jx = vec_safe_length (*inits);
8831 vec_safe_grow (*inits, jx + vid.inits->length ());
8833 for (ix = vid.inits->length () - 1;
8834 vid.inits->iterate (ix, &e);
8835 ix--, jx++)
8836 (**inits)[jx] = *e;
8838 /* Go through all the ordinary virtual functions, building up
8839 initializers. */
8840 for (v = BINFO_VIRTUALS (orig_binfo); v; v = TREE_CHAIN (v))
8842 tree delta;
8843 tree vcall_index;
8844 tree fn, fn_original;
8845 tree init = NULL_TREE;
8847 fn = BV_FN (v);
8848 fn_original = fn;
8849 if (DECL_THUNK_P (fn))
8851 if (!DECL_NAME (fn))
8852 finish_thunk (fn);
8853 if (THUNK_ALIAS (fn))
8855 fn = THUNK_ALIAS (fn);
8856 BV_FN (v) = fn;
8858 fn_original = THUNK_TARGET (fn);
8861 /* If the only definition of this function signature along our
8862 primary base chain is from a lost primary, this vtable slot will
8863 never be used, so just zero it out. This is important to avoid
8864 requiring extra thunks which cannot be generated with the function.
8866 We first check this in update_vtable_entry_for_fn, so we handle
8867 restored primary bases properly; we also need to do it here so we
8868 zero out unused slots in ctor vtables, rather than filling them
8869 with erroneous values (though harmless, apart from relocation
8870 costs). */
8871 if (BV_LOST_PRIMARY (v))
8872 init = size_zero_node;
8874 if (! init)
8876 /* Pull the offset for `this', and the function to call, out of
8877 the list. */
8878 delta = BV_DELTA (v);
8879 vcall_index = BV_VCALL_INDEX (v);
8881 gcc_assert (TREE_CODE (delta) == INTEGER_CST);
8882 gcc_assert (TREE_CODE (fn) == FUNCTION_DECL);
8884 /* You can't call an abstract virtual function; it's abstract.
8885 So, we replace these functions with __pure_virtual. */
8886 if (DECL_PURE_VIRTUAL_P (fn_original))
8888 fn = abort_fndecl;
8889 if (!TARGET_VTABLE_USES_DESCRIPTORS)
8891 if (abort_fndecl_addr == NULL)
8892 abort_fndecl_addr
8893 = fold_convert (vfunc_ptr_type_node,
8894 build_fold_addr_expr (fn));
8895 init = abort_fndecl_addr;
8898 /* Likewise for deleted virtuals. */
8899 else if (DECL_DELETED_FN (fn_original))
8901 fn = get_identifier ("__cxa_deleted_virtual");
8902 if (!get_global_value_if_present (fn, &fn))
8903 fn = push_library_fn (fn, (build_function_type_list
8904 (void_type_node, NULL_TREE)),
8905 NULL_TREE, ECF_NORETURN);
8906 if (!TARGET_VTABLE_USES_DESCRIPTORS)
8907 init = fold_convert (vfunc_ptr_type_node,
8908 build_fold_addr_expr (fn));
8910 else
8912 if (!integer_zerop (delta) || vcall_index)
8914 fn = make_thunk (fn, /*this_adjusting=*/1, delta, vcall_index);
8915 if (!DECL_NAME (fn))
8916 finish_thunk (fn);
8918 /* Take the address of the function, considering it to be of an
8919 appropriate generic type. */
8920 if (!TARGET_VTABLE_USES_DESCRIPTORS)
8921 init = fold_convert (vfunc_ptr_type_node,
8922 build_fold_addr_expr (fn));
8923 /* Don't refer to a virtual destructor from a constructor
8924 vtable or a vtable for an abstract class, since destroying
8925 an object under construction is undefined behavior and we
8926 don't want it to be considered a candidate for speculative
8927 devirtualization. But do create the thunk for ABI
8928 compliance. */
8929 if (DECL_DESTRUCTOR_P (fn_original)
8930 && (CLASSTYPE_PURE_VIRTUALS (DECL_CONTEXT (fn_original))
8931 || orig_binfo != binfo))
8932 init = size_zero_node;
8936 /* And add it to the chain of initializers. */
8937 if (TARGET_VTABLE_USES_DESCRIPTORS)
8939 int i;
8940 if (init == size_zero_node)
8941 for (i = 0; i < TARGET_VTABLE_USES_DESCRIPTORS; ++i)
8942 CONSTRUCTOR_APPEND_ELT (*inits, NULL_TREE, init);
8943 else
8944 for (i = 0; i < TARGET_VTABLE_USES_DESCRIPTORS; ++i)
8946 tree fdesc = build2 (FDESC_EXPR, vfunc_ptr_type_node,
8947 fn, build_int_cst (NULL_TREE, i));
8948 TREE_CONSTANT (fdesc) = 1;
8950 CONSTRUCTOR_APPEND_ELT (*inits, NULL_TREE, fdesc);
8953 else
8954 CONSTRUCTOR_APPEND_ELT (*inits, NULL_TREE, init);
8958 /* Adds to vid->inits the initializers for the vbase and vcall
8959 offsets in BINFO, which is in the hierarchy dominated by T. */
8961 static void
8962 build_vcall_and_vbase_vtbl_entries (tree binfo, vtbl_init_data* vid)
8964 tree b;
8966 /* If this is a derived class, we must first create entries
8967 corresponding to the primary base class. */
8968 b = get_primary_binfo (binfo);
8969 if (b)
8970 build_vcall_and_vbase_vtbl_entries (b, vid);
8972 /* Add the vbase entries for this base. */
8973 build_vbase_offset_vtbl_entries (binfo, vid);
8974 /* Add the vcall entries for this base. */
8975 build_vcall_offset_vtbl_entries (binfo, vid);
8978 /* Returns the initializers for the vbase offset entries in the vtable
8979 for BINFO (which is part of the class hierarchy dominated by T), in
8980 reverse order. VBASE_OFFSET_INDEX gives the vtable index
8981 where the next vbase offset will go. */
8983 static void
8984 build_vbase_offset_vtbl_entries (tree binfo, vtbl_init_data* vid)
8986 tree vbase;
8987 tree t;
8988 tree non_primary_binfo;
8990 /* If there are no virtual baseclasses, then there is nothing to
8991 do. */
8992 if (!CLASSTYPE_VBASECLASSES (BINFO_TYPE (binfo)))
8993 return;
8995 t = vid->derived;
8997 /* We might be a primary base class. Go up the inheritance hierarchy
8998 until we find the most derived class of which we are a primary base:
8999 it is the offset of that which we need to use. */
9000 non_primary_binfo = binfo;
9001 while (BINFO_INHERITANCE_CHAIN (non_primary_binfo))
9003 tree b;
9005 /* If we have reached a virtual base, then it must be a primary
9006 base (possibly multi-level) of vid->binfo, or we wouldn't
9007 have called build_vcall_and_vbase_vtbl_entries for it. But it
9008 might be a lost primary, so just skip down to vid->binfo. */
9009 if (BINFO_VIRTUAL_P (non_primary_binfo))
9011 non_primary_binfo = vid->binfo;
9012 break;
9015 b = BINFO_INHERITANCE_CHAIN (non_primary_binfo);
9016 if (get_primary_binfo (b) != non_primary_binfo)
9017 break;
9018 non_primary_binfo = b;
9021 /* Go through the virtual bases, adding the offsets. */
9022 for (vbase = TYPE_BINFO (BINFO_TYPE (binfo));
9023 vbase;
9024 vbase = TREE_CHAIN (vbase))
9026 tree b;
9027 tree delta;
9029 if (!BINFO_VIRTUAL_P (vbase))
9030 continue;
9032 /* Find the instance of this virtual base in the complete
9033 object. */
9034 b = copied_binfo (vbase, binfo);
9036 /* If we've already got an offset for this virtual base, we
9037 don't need another one. */
9038 if (BINFO_VTABLE_PATH_MARKED (b))
9039 continue;
9040 BINFO_VTABLE_PATH_MARKED (b) = 1;
9042 /* Figure out where we can find this vbase offset. */
9043 delta = size_binop (MULT_EXPR,
9044 vid->index,
9045 convert (ssizetype,
9046 TYPE_SIZE_UNIT (vtable_entry_type)));
9047 if (vid->primary_vtbl_p)
9048 BINFO_VPTR_FIELD (b) = delta;
9050 if (binfo != TYPE_BINFO (t))
9051 /* The vbase offset had better be the same. */
9052 gcc_assert (tree_int_cst_equal (delta, BINFO_VPTR_FIELD (vbase)));
9054 /* The next vbase will come at a more negative offset. */
9055 vid->index = size_binop (MINUS_EXPR, vid->index,
9056 ssize_int (TARGET_VTABLE_DATA_ENTRY_DISTANCE));
9058 /* The initializer is the delta from BINFO to this virtual base.
9059 The vbase offsets go in reverse inheritance-graph order, and
9060 we are walking in inheritance graph order so these end up in
9061 the right order. */
9062 delta = size_diffop_loc (input_location,
9063 BINFO_OFFSET (b), BINFO_OFFSET (non_primary_binfo));
9065 CONSTRUCTOR_APPEND_ELT (vid->inits, NULL_TREE,
9066 fold_build1_loc (input_location, NOP_EXPR,
9067 vtable_entry_type, delta));
9071 /* Adds the initializers for the vcall offset entries in the vtable
9072 for BINFO (which is part of the class hierarchy dominated by VID->DERIVED)
9073 to VID->INITS. */
9075 static void
9076 build_vcall_offset_vtbl_entries (tree binfo, vtbl_init_data* vid)
9078 /* We only need these entries if this base is a virtual base. We
9079 compute the indices -- but do not add to the vtable -- when
9080 building the main vtable for a class. */
9081 if (binfo == TYPE_BINFO (vid->derived)
9082 || (BINFO_VIRTUAL_P (binfo)
9083 /* If BINFO is RTTI_BINFO, then (since BINFO does not
9084 correspond to VID->DERIVED), we are building a primary
9085 construction virtual table. Since this is a primary
9086 virtual table, we do not need the vcall offsets for
9087 BINFO. */
9088 && binfo != vid->rtti_binfo))
9090 /* We need a vcall offset for each of the virtual functions in this
9091 vtable. For example:
9093 class A { virtual void f (); };
9094 class B1 : virtual public A { virtual void f (); };
9095 class B2 : virtual public A { virtual void f (); };
9096 class C: public B1, public B2 { virtual void f (); };
9098 A C object has a primary base of B1, which has a primary base of A. A
9099 C also has a secondary base of B2, which no longer has a primary base
9100 of A. So the B2-in-C construction vtable needs a secondary vtable for
9101 A, which will adjust the A* to a B2* to call f. We have no way of
9102 knowing what (or even whether) this offset will be when we define B2,
9103 so we store this "vcall offset" in the A sub-vtable and look it up in
9104 a "virtual thunk" for B2::f.
9106 We need entries for all the functions in our primary vtable and
9107 in our non-virtual bases' secondary vtables. */
9108 vid->vbase = binfo;
9109 /* If we are just computing the vcall indices -- but do not need
9110 the actual entries -- not that. */
9111 if (!BINFO_VIRTUAL_P (binfo))
9112 vid->generate_vcall_entries = false;
9113 /* Now, walk through the non-virtual bases, adding vcall offsets. */
9114 add_vcall_offset_vtbl_entries_r (binfo, vid);
9118 /* Build vcall offsets, starting with those for BINFO. */
9120 static void
9121 add_vcall_offset_vtbl_entries_r (tree binfo, vtbl_init_data* vid)
9123 int i;
9124 tree primary_binfo;
9125 tree base_binfo;
9127 /* Don't walk into virtual bases -- except, of course, for the
9128 virtual base for which we are building vcall offsets. Any
9129 primary virtual base will have already had its offsets generated
9130 through the recursion in build_vcall_and_vbase_vtbl_entries. */
9131 if (BINFO_VIRTUAL_P (binfo) && vid->vbase != binfo)
9132 return;
9134 /* If BINFO has a primary base, process it first. */
9135 primary_binfo = get_primary_binfo (binfo);
9136 if (primary_binfo)
9137 add_vcall_offset_vtbl_entries_r (primary_binfo, vid);
9139 /* Add BINFO itself to the list. */
9140 add_vcall_offset_vtbl_entries_1 (binfo, vid);
9142 /* Scan the non-primary bases of BINFO. */
9143 for (i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
9144 if (base_binfo != primary_binfo)
9145 add_vcall_offset_vtbl_entries_r (base_binfo, vid);
9148 /* Called from build_vcall_offset_vtbl_entries_r. */
9150 static void
9151 add_vcall_offset_vtbl_entries_1 (tree binfo, vtbl_init_data* vid)
9153 /* Make entries for the rest of the virtuals. */
9154 tree orig_fn;
9156 /* The ABI requires that the methods be processed in declaration
9157 order. */
9158 for (orig_fn = TYPE_METHODS (BINFO_TYPE (binfo));
9159 orig_fn;
9160 orig_fn = DECL_CHAIN (orig_fn))
9161 if (TREE_CODE (orig_fn) == FUNCTION_DECL && DECL_VINDEX (orig_fn))
9162 add_vcall_offset (orig_fn, binfo, vid);
9165 /* Add a vcall offset entry for ORIG_FN to the vtable. */
9167 static void
9168 add_vcall_offset (tree orig_fn, tree binfo, vtbl_init_data *vid)
9170 size_t i;
9171 tree vcall_offset;
9172 tree derived_entry;
9174 /* If there is already an entry for a function with the same
9175 signature as FN, then we do not need a second vcall offset.
9176 Check the list of functions already present in the derived
9177 class vtable. */
9178 FOR_EACH_VEC_SAFE_ELT (vid->fns, i, derived_entry)
9180 if (same_signature_p (derived_entry, orig_fn)
9181 /* We only use one vcall offset for virtual destructors,
9182 even though there are two virtual table entries. */
9183 || (DECL_DESTRUCTOR_P (derived_entry)
9184 && DECL_DESTRUCTOR_P (orig_fn)))
9185 return;
9188 /* If we are building these vcall offsets as part of building
9189 the vtable for the most derived class, remember the vcall
9190 offset. */
9191 if (vid->binfo == TYPE_BINFO (vid->derived))
9193 tree_pair_s elt = {orig_fn, vid->index};
9194 vec_safe_push (CLASSTYPE_VCALL_INDICES (vid->derived), elt);
9197 /* The next vcall offset will be found at a more negative
9198 offset. */
9199 vid->index = size_binop (MINUS_EXPR, vid->index,
9200 ssize_int (TARGET_VTABLE_DATA_ENTRY_DISTANCE));
9202 /* Keep track of this function. */
9203 vec_safe_push (vid->fns, orig_fn);
9205 if (vid->generate_vcall_entries)
9207 tree base;
9208 tree fn;
9210 /* Find the overriding function. */
9211 fn = find_final_overrider (vid->rtti_binfo, binfo, orig_fn);
9212 if (fn == error_mark_node)
9213 vcall_offset = build_zero_cst (vtable_entry_type);
9214 else
9216 base = TREE_VALUE (fn);
9218 /* The vbase we're working on is a primary base of
9219 vid->binfo. But it might be a lost primary, so its
9220 BINFO_OFFSET might be wrong, so we just use the
9221 BINFO_OFFSET from vid->binfo. */
9222 vcall_offset = size_diffop_loc (input_location,
9223 BINFO_OFFSET (base),
9224 BINFO_OFFSET (vid->binfo));
9225 vcall_offset = fold_build1_loc (input_location,
9226 NOP_EXPR, vtable_entry_type,
9227 vcall_offset);
9229 /* Add the initializer to the vtable. */
9230 CONSTRUCTOR_APPEND_ELT (vid->inits, NULL_TREE, vcall_offset);
9234 /* Return vtbl initializers for the RTTI entries corresponding to the
9235 BINFO's vtable. The RTTI entries should indicate the object given
9236 by VID->rtti_binfo. */
9238 static void
9239 build_rtti_vtbl_entries (tree binfo, vtbl_init_data* vid)
9241 tree b;
9242 tree t;
9243 tree offset;
9244 tree decl;
9245 tree init;
9247 t = BINFO_TYPE (vid->rtti_binfo);
9249 /* To find the complete object, we will first convert to our most
9250 primary base, and then add the offset in the vtbl to that value. */
9251 b = binfo;
9252 while (CLASSTYPE_HAS_PRIMARY_BASE_P (BINFO_TYPE (b))
9253 && !BINFO_LOST_PRIMARY_P (b))
9255 tree primary_base;
9257 primary_base = get_primary_binfo (b);
9258 gcc_assert (BINFO_PRIMARY_P (primary_base)
9259 && BINFO_INHERITANCE_CHAIN (primary_base) == b);
9260 b = primary_base;
9262 offset = size_diffop_loc (input_location,
9263 BINFO_OFFSET (vid->rtti_binfo), BINFO_OFFSET (b));
9265 /* The second entry is the address of the typeinfo object. */
9266 if (flag_rtti)
9267 decl = build_address (get_tinfo_decl (t));
9268 else
9269 decl = integer_zero_node;
9271 /* Convert the declaration to a type that can be stored in the
9272 vtable. */
9273 init = build_nop (vfunc_ptr_type_node, decl);
9274 CONSTRUCTOR_APPEND_ELT (vid->inits, NULL_TREE, init);
9276 /* Add the offset-to-top entry. It comes earlier in the vtable than
9277 the typeinfo entry. Convert the offset to look like a
9278 function pointer, so that we can put it in the vtable. */
9279 init = build_nop (vfunc_ptr_type_node, offset);
9280 CONSTRUCTOR_APPEND_ELT (vid->inits, NULL_TREE, init);
9283 /* TRUE iff TYPE is uniquely derived from PARENT. Ignores
9284 accessibility. */
9286 bool
9287 uniquely_derived_from_p (tree parent, tree type)
9289 tree base = lookup_base (type, parent, ba_unique, NULL, tf_none);
9290 return base && base != error_mark_node;
9293 /* TRUE iff TYPE is publicly & uniquely derived from PARENT. */
9295 bool
9296 publicly_uniquely_derived_p (tree parent, tree type)
9298 tree base = lookup_base (type, parent, ba_ignore_scope | ba_check,
9299 NULL, tf_none);
9300 return base && base != error_mark_node;
9303 /* CTX1 and CTX2 are declaration contexts. Return the innermost common
9304 class between them, if any. */
9306 tree
9307 common_enclosing_class (tree ctx1, tree ctx2)
9309 if (!TYPE_P (ctx1) || !TYPE_P (ctx2))
9310 return NULL_TREE;
9311 gcc_assert (ctx1 == TYPE_MAIN_VARIANT (ctx1)
9312 && ctx2 == TYPE_MAIN_VARIANT (ctx2));
9313 if (ctx1 == ctx2)
9314 return ctx1;
9315 for (tree t = ctx1; TYPE_P (t); t = TYPE_CONTEXT (t))
9316 TYPE_MARKED_P (t) = true;
9317 tree found = NULL_TREE;
9318 for (tree t = ctx2; TYPE_P (t); t = TYPE_CONTEXT (t))
9319 if (TYPE_MARKED_P (t))
9321 found = t;
9322 break;
9324 for (tree t = ctx1; TYPE_P (t); t = TYPE_CONTEXT (t))
9325 TYPE_MARKED_P (t) = false;
9326 return found;
9329 #include "gt-cp-class.h"