re PR c++/65046 (-Wabi-tag doesn't warn about variables or function return types)
[gcc.git] / gcc / cp / class.c
1 /* Functions related to building classes and their related objects.
2 Copyright (C) 1987-2015 Free Software Foundation, Inc.
3 Contributed by Michael Tiemann (tiemann@cygnus.com)
4
5 This file is part of GCC.
6
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.
11
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.
16
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/>. */
20
21
22 /* High-level class interface. */
23
24 #include "config.h"
25 #include "system.h"
26 #include "coretypes.h"
27 #include "hash-set.h"
28 #include "machmode.h"
29 #include "vec.h"
30 #include "double-int.h"
31 #include "input.h"
32 #include "alias.h"
33 #include "symtab.h"
34 #include "options.h"
35 #include "wide-int.h"
36 #include "inchash.h"
37 #include "tm.h"
38 #include "tree.h"
39 #include "stringpool.h"
40 #include "stor-layout.h"
41 #include "attribs.h"
42 #include "hash-table.h"
43 #include "cp-tree.h"
44 #include "flags.h"
45 #include "toplev.h"
46 #include "target.h"
47 #include "convert.h"
48 #include "hash-map.h"
49 #include "is-a.h"
50 #include "plugin-api.h"
51 #include "hard-reg-set.h"
52 #include "input.h"
53 #include "function.h"
54 #include "ipa-ref.h"
55 #include "cgraph.h"
56 #include "dumpfile.h"
57 #include "splay-tree.h"
58 #include "gimplify.h"
59 #include "wide-int.h"
60
61 /* The number of nested classes being processed. If we are not in the
62 scope of any class, this is zero. */
63
64 int current_class_depth;
65
66 /* In order to deal with nested classes, we keep a stack of classes.
67 The topmost entry is the innermost class, and is the entry at index
68 CURRENT_CLASS_DEPTH */
69
70 typedef struct class_stack_node {
71 /* The name of the class. */
72 tree name;
73
74 /* The _TYPE node for the class. */
75 tree type;
76
77 /* The access specifier pending for new declarations in the scope of
78 this class. */
79 tree access;
80
81 /* If were defining TYPE, the names used in this class. */
82 splay_tree names_used;
83
84 /* Nonzero if this class is no longer open, because of a call to
85 push_to_top_level. */
86 size_t hidden;
87 }* class_stack_node_t;
88
89 typedef struct vtbl_init_data_s
90 {
91 /* The base for which we're building initializers. */
92 tree binfo;
93 /* The type of the most-derived type. */
94 tree derived;
95 /* The binfo for the dynamic type. This will be TYPE_BINFO (derived),
96 unless ctor_vtbl_p is true. */
97 tree rtti_binfo;
98 /* The negative-index vtable initializers built up so far. These
99 are in order from least negative index to most negative index. */
100 vec<constructor_elt, va_gc> *inits;
101 /* The binfo for the virtual base for which we're building
102 vcall offset initializers. */
103 tree vbase;
104 /* The functions in vbase for which we have already provided vcall
105 offsets. */
106 vec<tree, va_gc> *fns;
107 /* The vtable index of the next vcall or vbase offset. */
108 tree index;
109 /* Nonzero if we are building the initializer for the primary
110 vtable. */
111 int primary_vtbl_p;
112 /* Nonzero if we are building the initializer for a construction
113 vtable. */
114 int ctor_vtbl_p;
115 /* True when adding vcall offset entries to the vtable. False when
116 merely computing the indices. */
117 bool generate_vcall_entries;
118 } vtbl_init_data;
119
120 /* The type of a function passed to walk_subobject_offsets. */
121 typedef int (*subobject_offset_fn) (tree, tree, splay_tree);
122
123 /* The stack itself. This is a dynamically resized array. The
124 number of elements allocated is CURRENT_CLASS_STACK_SIZE. */
125 static int current_class_stack_size;
126 static class_stack_node_t current_class_stack;
127
128 /* The size of the largest empty class seen in this translation unit. */
129 static GTY (()) tree sizeof_biggest_empty_class;
130
131 /* An array of all local classes present in this translation unit, in
132 declaration order. */
133 vec<tree, va_gc> *local_classes;
134
135 static tree get_vfield_name (tree);
136 static void finish_struct_anon (tree);
137 static tree get_vtable_name (tree);
138 static void get_basefndecls (tree, tree, vec<tree> *);
139 static int build_primary_vtable (tree, tree);
140 static int build_secondary_vtable (tree);
141 static void finish_vtbls (tree);
142 static void modify_vtable_entry (tree, tree, tree, tree, tree *);
143 static void finish_struct_bits (tree);
144 static int alter_access (tree, tree, tree);
145 static void handle_using_decl (tree, tree);
146 static tree dfs_modify_vtables (tree, void *);
147 static tree modify_all_vtables (tree, tree);
148 static void determine_primary_bases (tree);
149 static void finish_struct_methods (tree);
150 static void maybe_warn_about_overly_private_class (tree);
151 static int method_name_cmp (const void *, const void *);
152 static int resort_method_name_cmp (const void *, const void *);
153 static void add_implicitly_declared_members (tree, tree*, int, int);
154 static tree fixed_type_or_null (tree, int *, int *);
155 static tree build_simple_base_path (tree expr, tree binfo);
156 static tree build_vtbl_ref_1 (tree, tree);
157 static void build_vtbl_initializer (tree, tree, tree, tree, int *,
158 vec<constructor_elt, va_gc> **);
159 static int count_fields (tree);
160 static int add_fields_to_record_type (tree, struct sorted_fields_type*, int);
161 static void insert_into_classtype_sorted_fields (tree, tree, int);
162 static bool check_bitfield_decl (tree);
163 static void check_field_decl (tree, tree, int *, int *, int *);
164 static void check_field_decls (tree, tree *, int *, int *);
165 static tree *build_base_field (record_layout_info, tree, splay_tree, tree *);
166 static void build_base_fields (record_layout_info, splay_tree, tree *);
167 static void check_methods (tree);
168 static void remove_zero_width_bit_fields (tree);
169 static bool accessible_nvdtor_p (tree);
170 static void check_bases (tree, int *, int *);
171 static void check_bases_and_members (tree);
172 static tree create_vtable_ptr (tree, tree *);
173 static void include_empty_classes (record_layout_info);
174 static void layout_class_type (tree, tree *);
175 static void propagate_binfo_offsets (tree, tree);
176 static void layout_virtual_bases (record_layout_info, splay_tree);
177 static void build_vbase_offset_vtbl_entries (tree, vtbl_init_data *);
178 static void add_vcall_offset_vtbl_entries_r (tree, vtbl_init_data *);
179 static void add_vcall_offset_vtbl_entries_1 (tree, vtbl_init_data *);
180 static void build_vcall_offset_vtbl_entries (tree, vtbl_init_data *);
181 static void add_vcall_offset (tree, tree, vtbl_init_data *);
182 static void layout_vtable_decl (tree, int);
183 static tree dfs_find_final_overrider_pre (tree, void *);
184 static tree dfs_find_final_overrider_post (tree, void *);
185 static tree find_final_overrider (tree, tree, tree);
186 static int make_new_vtable (tree, tree);
187 static tree get_primary_binfo (tree);
188 static int maybe_indent_hierarchy (FILE *, int, int);
189 static tree dump_class_hierarchy_r (FILE *, int, tree, tree, int);
190 static void dump_class_hierarchy (tree);
191 static void dump_class_hierarchy_1 (FILE *, int, tree);
192 static void dump_array (FILE *, tree);
193 static void dump_vtable (tree, tree, tree);
194 static void dump_vtt (tree, tree);
195 static void dump_thunk (FILE *, int, tree);
196 static tree build_vtable (tree, tree, tree);
197 static void initialize_vtable (tree, vec<constructor_elt, va_gc> *);
198 static void layout_nonempty_base_or_field (record_layout_info,
199 tree, tree, splay_tree);
200 static tree end_of_class (tree, int);
201 static bool layout_empty_base (record_layout_info, tree, tree, splay_tree);
202 static void accumulate_vtbl_inits (tree, tree, tree, tree, tree,
203 vec<constructor_elt, va_gc> **);
204 static void dfs_accumulate_vtbl_inits (tree, tree, tree, tree, tree,
205 vec<constructor_elt, va_gc> **);
206 static void build_rtti_vtbl_entries (tree, vtbl_init_data *);
207 static void build_vcall_and_vbase_vtbl_entries (tree, vtbl_init_data *);
208 static void clone_constructors_and_destructors (tree);
209 static tree build_clone (tree, tree);
210 static void update_vtable_entry_for_fn (tree, tree, tree, tree *, unsigned);
211 static void build_ctor_vtbl_group (tree, tree);
212 static void build_vtt (tree);
213 static tree binfo_ctor_vtable (tree);
214 static void build_vtt_inits (tree, tree, vec<constructor_elt, va_gc> **,
215 tree *);
216 static tree dfs_build_secondary_vptr_vtt_inits (tree, void *);
217 static tree dfs_fixup_binfo_vtbls (tree, void *);
218 static int record_subobject_offset (tree, tree, splay_tree);
219 static int check_subobject_offset (tree, tree, splay_tree);
220 static int walk_subobject_offsets (tree, subobject_offset_fn,
221 tree, splay_tree, tree, int);
222 static void record_subobject_offsets (tree, tree, splay_tree, bool);
223 static int layout_conflict_p (tree, tree, splay_tree, int);
224 static int splay_tree_compare_integer_csts (splay_tree_key k1,
225 splay_tree_key k2);
226 static void warn_about_ambiguous_bases (tree);
227 static bool type_requires_array_cookie (tree);
228 static bool base_derived_from (tree, tree);
229 static int empty_base_at_nonzero_offset_p (tree, tree, splay_tree);
230 static tree end_of_base (tree);
231 static tree get_vcall_index (tree, tree);
232
233 /* Variables shared between class.c and call.c. */
234
235 int n_vtables = 0;
236 int n_vtable_entries = 0;
237 int n_vtable_searches = 0;
238 int n_vtable_elems = 0;
239 int n_convert_harshness = 0;
240 int n_compute_conversion_costs = 0;
241 int n_inner_fields_searched = 0;
242
243 /* Convert to or from a base subobject. EXPR is an expression of type
244 `A' or `A*', an expression of type `B' or `B*' is returned. To
245 convert A to a base B, CODE is PLUS_EXPR and BINFO is the binfo for
246 the B base instance within A. To convert base A to derived B, CODE
247 is MINUS_EXPR and BINFO is the binfo for the A instance within B.
248 In this latter case, A must not be a morally virtual base of B.
249 NONNULL is true if EXPR is known to be non-NULL (this is only
250 needed when EXPR is of pointer type). CV qualifiers are preserved
251 from EXPR. */
252
253 tree
254 build_base_path (enum tree_code code,
255 tree expr,
256 tree binfo,
257 int nonnull,
258 tsubst_flags_t complain)
259 {
260 tree v_binfo = NULL_TREE;
261 tree d_binfo = NULL_TREE;
262 tree probe;
263 tree offset;
264 tree target_type;
265 tree null_test = NULL;
266 tree ptr_target_type;
267 int fixed_type_p;
268 int want_pointer = TYPE_PTR_P (TREE_TYPE (expr));
269 bool has_empty = false;
270 bool virtual_access;
271 bool rvalue = false;
272
273 if (expr == error_mark_node || binfo == error_mark_node || !binfo)
274 return error_mark_node;
275
276 for (probe = binfo; probe; probe = BINFO_INHERITANCE_CHAIN (probe))
277 {
278 d_binfo = probe;
279 if (is_empty_class (BINFO_TYPE (probe)))
280 has_empty = true;
281 if (!v_binfo && BINFO_VIRTUAL_P (probe))
282 v_binfo = probe;
283 }
284
285 probe = TYPE_MAIN_VARIANT (TREE_TYPE (expr));
286 if (want_pointer)
287 probe = TYPE_MAIN_VARIANT (TREE_TYPE (probe));
288
289 if (code == PLUS_EXPR
290 && !SAME_BINFO_TYPE_P (BINFO_TYPE (d_binfo), probe))
291 {
292 /* This can happen when adjust_result_of_qualified_name_lookup can't
293 find a unique base binfo in a call to a member function. We
294 couldn't give the diagnostic then since we might have been calling
295 a static member function, so we do it now. */
296 if (complain & tf_error)
297 {
298 tree base = lookup_base (probe, BINFO_TYPE (d_binfo),
299 ba_unique, NULL, complain);
300 gcc_assert (base == error_mark_node);
301 }
302 return error_mark_node;
303 }
304
305 gcc_assert ((code == MINUS_EXPR
306 && SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), probe))
307 || code == PLUS_EXPR);
308
309 if (binfo == d_binfo)
310 /* Nothing to do. */
311 return expr;
312
313 if (code == MINUS_EXPR && v_binfo)
314 {
315 if (complain & tf_error)
316 {
317 if (SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), BINFO_TYPE (v_binfo)))
318 {
319 if (want_pointer)
320 error ("cannot convert from pointer to base class %qT to "
321 "pointer to derived class %qT because the base is "
322 "virtual", BINFO_TYPE (binfo), BINFO_TYPE (d_binfo));
323 else
324 error ("cannot convert from base class %qT to derived "
325 "class %qT because the base is virtual",
326 BINFO_TYPE (binfo), BINFO_TYPE (d_binfo));
327 }
328 else
329 {
330 if (want_pointer)
331 error ("cannot convert from pointer to base class %qT to "
332 "pointer to derived class %qT via virtual base %qT",
333 BINFO_TYPE (binfo), BINFO_TYPE (d_binfo),
334 BINFO_TYPE (v_binfo));
335 else
336 error ("cannot convert from base class %qT to derived "
337 "class %qT via virtual base %qT", BINFO_TYPE (binfo),
338 BINFO_TYPE (d_binfo), BINFO_TYPE (v_binfo));
339 }
340 }
341 return error_mark_node;
342 }
343
344 if (!want_pointer)
345 {
346 rvalue = !real_lvalue_p (expr);
347 /* This must happen before the call to save_expr. */
348 expr = cp_build_addr_expr (expr, complain);
349 }
350 else
351 expr = mark_rvalue_use (expr);
352
353 offset = BINFO_OFFSET (binfo);
354 fixed_type_p = resolves_to_fixed_type_p (expr, &nonnull);
355 target_type = code == PLUS_EXPR ? BINFO_TYPE (binfo) : BINFO_TYPE (d_binfo);
356 /* TARGET_TYPE has been extracted from BINFO, and, is therefore always
357 cv-unqualified. Extract the cv-qualifiers from EXPR so that the
358 expression returned matches the input. */
359 target_type = cp_build_qualified_type
360 (target_type, cp_type_quals (TREE_TYPE (TREE_TYPE (expr))));
361 ptr_target_type = build_pointer_type (target_type);
362
363 /* Do we need to look in the vtable for the real offset? */
364 virtual_access = (v_binfo && fixed_type_p <= 0);
365
366 /* Don't bother with the calculations inside sizeof; they'll ICE if the
367 source type is incomplete and the pointer value doesn't matter. In a
368 template (even in instantiate_non_dependent_expr), we don't have vtables
369 set up properly yet, and the value doesn't matter there either; we're
370 just interested in the result of overload resolution. */
371 if (cp_unevaluated_operand != 0
372 || in_template_function ())
373 {
374 expr = build_nop (ptr_target_type, expr);
375 goto indout;
376 }
377
378 /* If we're in an NSDMI, we don't have the full constructor context yet
379 that we need for converting to a virtual base, so just build a stub
380 CONVERT_EXPR and expand it later in bot_replace. */
381 if (virtual_access && fixed_type_p < 0
382 && current_scope () != current_function_decl)
383 {
384 expr = build1 (CONVERT_EXPR, ptr_target_type, expr);
385 CONVERT_EXPR_VBASE_PATH (expr) = true;
386 goto indout;
387 }
388
389 /* Do we need to check for a null pointer? */
390 if (want_pointer && !nonnull)
391 {
392 /* If we know the conversion will not actually change the value
393 of EXPR, then we can avoid testing the expression for NULL.
394 We have to avoid generating a COMPONENT_REF for a base class
395 field, because other parts of the compiler know that such
396 expressions are always non-NULL. */
397 if (!virtual_access && integer_zerop (offset))
398 return build_nop (ptr_target_type, expr);
399 null_test = error_mark_node;
400 }
401
402 /* Protect against multiple evaluation if necessary. */
403 if (TREE_SIDE_EFFECTS (expr) && (null_test || virtual_access))
404 expr = save_expr (expr);
405
406 /* Now that we've saved expr, build the real null test. */
407 if (null_test)
408 {
409 tree zero = cp_convert (TREE_TYPE (expr), nullptr_node, complain);
410 null_test = fold_build2_loc (input_location, NE_EXPR, boolean_type_node,
411 expr, zero);
412 }
413
414 /* If this is a simple base reference, express it as a COMPONENT_REF. */
415 if (code == PLUS_EXPR && !virtual_access
416 /* We don't build base fields for empty bases, and they aren't very
417 interesting to the optimizers anyway. */
418 && !has_empty)
419 {
420 expr = cp_build_indirect_ref (expr, RO_NULL, complain);
421 expr = build_simple_base_path (expr, binfo);
422 if (rvalue)
423 expr = move (expr);
424 if (want_pointer)
425 expr = build_address (expr);
426 target_type = TREE_TYPE (expr);
427 goto out;
428 }
429
430 if (virtual_access)
431 {
432 /* Going via virtual base V_BINFO. We need the static offset
433 from V_BINFO to BINFO, and the dynamic offset from D_BINFO to
434 V_BINFO. That offset is an entry in D_BINFO's vtable. */
435 tree v_offset;
436
437 if (fixed_type_p < 0 && in_base_initializer)
438 {
439 /* In a base member initializer, we cannot rely on the
440 vtable being set up. We have to indirect via the
441 vtt_parm. */
442 tree t;
443
444 t = TREE_TYPE (TYPE_VFIELD (current_class_type));
445 t = build_pointer_type (t);
446 v_offset = convert (t, current_vtt_parm);
447 v_offset = cp_build_indirect_ref (v_offset, RO_NULL, complain);
448 }
449 else
450 {
451 tree t = expr;
452 if ((flag_sanitize & SANITIZE_VPTR) && fixed_type_p == 0)
453 {
454 t = cp_ubsan_maybe_instrument_cast_to_vbase (input_location,
455 probe, expr);
456 if (t == NULL_TREE)
457 t = expr;
458 }
459 v_offset = build_vfield_ref (cp_build_indirect_ref (t, RO_NULL,
460 complain),
461 TREE_TYPE (TREE_TYPE (expr)));
462 }
463
464 if (v_offset == error_mark_node)
465 return error_mark_node;
466
467 v_offset = fold_build_pointer_plus (v_offset, BINFO_VPTR_FIELD (v_binfo));
468 v_offset = build1 (NOP_EXPR,
469 build_pointer_type (ptrdiff_type_node),
470 v_offset);
471 v_offset = cp_build_indirect_ref (v_offset, RO_NULL, complain);
472 TREE_CONSTANT (v_offset) = 1;
473
474 offset = convert_to_integer (ptrdiff_type_node,
475 size_diffop_loc (input_location, offset,
476 BINFO_OFFSET (v_binfo)));
477
478 if (!integer_zerop (offset))
479 v_offset = build2 (code, ptrdiff_type_node, v_offset, offset);
480
481 if (fixed_type_p < 0)
482 /* Negative fixed_type_p means this is a constructor or destructor;
483 virtual base layout is fixed in in-charge [cd]tors, but not in
484 base [cd]tors. */
485 offset = build3 (COND_EXPR, ptrdiff_type_node,
486 build2 (EQ_EXPR, boolean_type_node,
487 current_in_charge_parm, integer_zero_node),
488 v_offset,
489 convert_to_integer (ptrdiff_type_node,
490 BINFO_OFFSET (binfo)));
491 else
492 offset = v_offset;
493 }
494
495 if (want_pointer)
496 target_type = ptr_target_type;
497
498 expr = build1 (NOP_EXPR, ptr_target_type, expr);
499
500 if (!integer_zerop (offset))
501 {
502 offset = fold_convert (sizetype, offset);
503 if (code == MINUS_EXPR)
504 offset = fold_build1_loc (input_location, NEGATE_EXPR, sizetype, offset);
505 expr = fold_build_pointer_plus (expr, offset);
506 }
507 else
508 null_test = NULL;
509
510 indout:
511 if (!want_pointer)
512 {
513 expr = cp_build_indirect_ref (expr, RO_NULL, complain);
514 if (rvalue)
515 expr = move (expr);
516 }
517
518 out:
519 if (null_test)
520 expr = fold_build3_loc (input_location, COND_EXPR, target_type, null_test, expr,
521 build_zero_cst (target_type));
522
523 return expr;
524 }
525
526 /* Subroutine of build_base_path; EXPR and BINFO are as in that function.
527 Perform a derived-to-base conversion by recursively building up a
528 sequence of COMPONENT_REFs to the appropriate base fields. */
529
530 static tree
531 build_simple_base_path (tree expr, tree binfo)
532 {
533 tree type = BINFO_TYPE (binfo);
534 tree d_binfo = BINFO_INHERITANCE_CHAIN (binfo);
535 tree field;
536
537 if (d_binfo == NULL_TREE)
538 {
539 tree temp;
540
541 gcc_assert (TYPE_MAIN_VARIANT (TREE_TYPE (expr)) == type);
542
543 /* Transform `(a, b).x' into `(*(a, &b)).x', `(a ? b : c).x'
544 into `(*(a ? &b : &c)).x', and so on. A COND_EXPR is only
545 an lvalue in the front end; only _DECLs and _REFs are lvalues
546 in the back end. */
547 temp = unary_complex_lvalue (ADDR_EXPR, expr);
548 if (temp)
549 expr = cp_build_indirect_ref (temp, RO_NULL, tf_warning_or_error);
550
551 return expr;
552 }
553
554 /* Recurse. */
555 expr = build_simple_base_path (expr, d_binfo);
556
557 for (field = TYPE_FIELDS (BINFO_TYPE (d_binfo));
558 field; field = DECL_CHAIN (field))
559 /* Is this the base field created by build_base_field? */
560 if (TREE_CODE (field) == FIELD_DECL
561 && DECL_FIELD_IS_BASE (field)
562 && TREE_TYPE (field) == type
563 /* If we're looking for a field in the most-derived class,
564 also check the field offset; we can have two base fields
565 of the same type if one is an indirect virtual base and one
566 is a direct non-virtual base. */
567 && (BINFO_INHERITANCE_CHAIN (d_binfo)
568 || tree_int_cst_equal (byte_position (field),
569 BINFO_OFFSET (binfo))))
570 {
571 /* We don't use build_class_member_access_expr here, as that
572 has unnecessary checks, and more importantly results in
573 recursive calls to dfs_walk_once. */
574 int type_quals = cp_type_quals (TREE_TYPE (expr));
575
576 expr = build3 (COMPONENT_REF,
577 cp_build_qualified_type (type, type_quals),
578 expr, field, NULL_TREE);
579 expr = fold_if_not_in_template (expr);
580
581 /* Mark the expression const or volatile, as appropriate.
582 Even though we've dealt with the type above, we still have
583 to mark the expression itself. */
584 if (type_quals & TYPE_QUAL_CONST)
585 TREE_READONLY (expr) = 1;
586 if (type_quals & TYPE_QUAL_VOLATILE)
587 TREE_THIS_VOLATILE (expr) = 1;
588
589 return expr;
590 }
591
592 /* Didn't find the base field?!? */
593 gcc_unreachable ();
594 }
595
596 /* Convert OBJECT to the base TYPE. OBJECT is an expression whose
597 type is a class type or a pointer to a class type. In the former
598 case, TYPE is also a class type; in the latter it is another
599 pointer type. If CHECK_ACCESS is true, an error message is emitted
600 if TYPE is inaccessible. If OBJECT has pointer type, the value is
601 assumed to be non-NULL. */
602
603 tree
604 convert_to_base (tree object, tree type, bool check_access, bool nonnull,
605 tsubst_flags_t complain)
606 {
607 tree binfo;
608 tree object_type;
609
610 if (TYPE_PTR_P (TREE_TYPE (object)))
611 {
612 object_type = TREE_TYPE (TREE_TYPE (object));
613 type = TREE_TYPE (type);
614 }
615 else
616 object_type = TREE_TYPE (object);
617
618 binfo = lookup_base (object_type, type, check_access ? ba_check : ba_unique,
619 NULL, complain);
620 if (!binfo || binfo == error_mark_node)
621 return error_mark_node;
622
623 return build_base_path (PLUS_EXPR, object, binfo, nonnull, complain);
624 }
625
626 /* EXPR is an expression with unqualified class type. BASE is a base
627 binfo of that class type. Returns EXPR, converted to the BASE
628 type. This function assumes that EXPR is the most derived class;
629 therefore virtual bases can be found at their static offsets. */
630
631 tree
632 convert_to_base_statically (tree expr, tree base)
633 {
634 tree expr_type;
635
636 expr_type = TREE_TYPE (expr);
637 if (!SAME_BINFO_TYPE_P (BINFO_TYPE (base), expr_type))
638 {
639 /* If this is a non-empty base, use a COMPONENT_REF. */
640 if (!is_empty_class (BINFO_TYPE (base)))
641 return build_simple_base_path (expr, base);
642
643 /* We use fold_build2 and fold_convert below to simplify the trees
644 provided to the optimizers. It is not safe to call these functions
645 when processing a template because they do not handle C++-specific
646 trees. */
647 gcc_assert (!processing_template_decl);
648 expr = cp_build_addr_expr (expr, tf_warning_or_error);
649 if (!integer_zerop (BINFO_OFFSET (base)))
650 expr = fold_build_pointer_plus_loc (input_location,
651 expr, BINFO_OFFSET (base));
652 expr = fold_convert (build_pointer_type (BINFO_TYPE (base)), expr);
653 expr = build_fold_indirect_ref_loc (input_location, expr);
654 }
655
656 return expr;
657 }
658
659 \f
660 tree
661 build_vfield_ref (tree datum, tree type)
662 {
663 tree vfield, vcontext;
664
665 if (datum == error_mark_node
666 /* Can happen in case of duplicate base types (c++/59082). */
667 || !TYPE_VFIELD (type))
668 return error_mark_node;
669
670 /* First, convert to the requested type. */
671 if (!same_type_ignoring_top_level_qualifiers_p (TREE_TYPE (datum), type))
672 datum = convert_to_base (datum, type, /*check_access=*/false,
673 /*nonnull=*/true, tf_warning_or_error);
674
675 /* Second, the requested type may not be the owner of its own vptr.
676 If not, convert to the base class that owns it. We cannot use
677 convert_to_base here, because VCONTEXT may appear more than once
678 in the inheritance hierarchy of TYPE, and thus direct conversion
679 between the types may be ambiguous. Following the path back up
680 one step at a time via primary bases avoids the problem. */
681 vfield = TYPE_VFIELD (type);
682 vcontext = DECL_CONTEXT (vfield);
683 while (!same_type_ignoring_top_level_qualifiers_p (vcontext, type))
684 {
685 datum = build_simple_base_path (datum, CLASSTYPE_PRIMARY_BINFO (type));
686 type = TREE_TYPE (datum);
687 }
688
689 return build3 (COMPONENT_REF, TREE_TYPE (vfield), datum, vfield, NULL_TREE);
690 }
691
692 /* Given an object INSTANCE, return an expression which yields the
693 vtable element corresponding to INDEX. There are many special
694 cases for INSTANCE which we take care of here, mainly to avoid
695 creating extra tree nodes when we don't have to. */
696
697 static tree
698 build_vtbl_ref_1 (tree instance, tree idx)
699 {
700 tree aref;
701 tree vtbl = NULL_TREE;
702
703 /* Try to figure out what a reference refers to, and
704 access its virtual function table directly. */
705
706 int cdtorp = 0;
707 tree fixed_type = fixed_type_or_null (instance, NULL, &cdtorp);
708
709 tree basetype = non_reference (TREE_TYPE (instance));
710
711 if (fixed_type && !cdtorp)
712 {
713 tree binfo = lookup_base (fixed_type, basetype,
714 ba_unique, NULL, tf_none);
715 if (binfo && binfo != error_mark_node)
716 vtbl = unshare_expr (BINFO_VTABLE (binfo));
717 }
718
719 if (!vtbl)
720 vtbl = build_vfield_ref (instance, basetype);
721
722 aref = build_array_ref (input_location, vtbl, idx);
723 TREE_CONSTANT (aref) |= TREE_CONSTANT (vtbl) && TREE_CONSTANT (idx);
724
725 return aref;
726 }
727
728 tree
729 build_vtbl_ref (tree instance, tree idx)
730 {
731 tree aref = build_vtbl_ref_1 (instance, idx);
732
733 return aref;
734 }
735
736 /* Given a stable object pointer INSTANCE_PTR, return an expression which
737 yields a function pointer corresponding to vtable element INDEX. */
738
739 tree
740 build_vfn_ref (tree instance_ptr, tree idx)
741 {
742 tree aref;
743
744 aref = build_vtbl_ref_1 (cp_build_indirect_ref (instance_ptr, RO_NULL,
745 tf_warning_or_error),
746 idx);
747
748 /* When using function descriptors, the address of the
749 vtable entry is treated as a function pointer. */
750 if (TARGET_VTABLE_USES_DESCRIPTORS)
751 aref = build1 (NOP_EXPR, TREE_TYPE (aref),
752 cp_build_addr_expr (aref, tf_warning_or_error));
753
754 /* Remember this as a method reference, for later devirtualization. */
755 aref = build3 (OBJ_TYPE_REF, TREE_TYPE (aref), aref, instance_ptr, idx);
756
757 return aref;
758 }
759
760 /* Return the name of the virtual function table (as an IDENTIFIER_NODE)
761 for the given TYPE. */
762
763 static tree
764 get_vtable_name (tree type)
765 {
766 return mangle_vtbl_for_type (type);
767 }
768
769 /* DECL is an entity associated with TYPE, like a virtual table or an
770 implicitly generated constructor. Determine whether or not DECL
771 should have external or internal linkage at the object file
772 level. This routine does not deal with COMDAT linkage and other
773 similar complexities; it simply sets TREE_PUBLIC if it possible for
774 entities in other translation units to contain copies of DECL, in
775 the abstract. */
776
777 void
778 set_linkage_according_to_type (tree /*type*/, tree decl)
779 {
780 TREE_PUBLIC (decl) = 1;
781 determine_visibility (decl);
782 }
783
784 /* Create a VAR_DECL for a primary or secondary vtable for CLASS_TYPE.
785 (For a secondary vtable for B-in-D, CLASS_TYPE should be D, not B.)
786 Use NAME for the name of the vtable, and VTABLE_TYPE for its type. */
787
788 static tree
789 build_vtable (tree class_type, tree name, tree vtable_type)
790 {
791 tree decl;
792
793 decl = build_lang_decl (VAR_DECL, name, vtable_type);
794 /* vtable names are already mangled; give them their DECL_ASSEMBLER_NAME
795 now to avoid confusion in mangle_decl. */
796 SET_DECL_ASSEMBLER_NAME (decl, name);
797 DECL_CONTEXT (decl) = class_type;
798 DECL_ARTIFICIAL (decl) = 1;
799 TREE_STATIC (decl) = 1;
800 TREE_READONLY (decl) = 1;
801 DECL_VIRTUAL_P (decl) = 1;
802 DECL_ALIGN (decl) = TARGET_VTABLE_ENTRY_ALIGN;
803 DECL_USER_ALIGN (decl) = true;
804 DECL_VTABLE_OR_VTT_P (decl) = 1;
805 set_linkage_according_to_type (class_type, decl);
806 /* The vtable has not been defined -- yet. */
807 DECL_EXTERNAL (decl) = 1;
808 DECL_NOT_REALLY_EXTERN (decl) = 1;
809
810 /* Mark the VAR_DECL node representing the vtable itself as a
811 "gratuitous" one, thereby forcing dwarfout.c to ignore it. It
812 is rather important that such things be ignored because any
813 effort to actually generate DWARF for them will run into
814 trouble when/if we encounter code like:
815
816 #pragma interface
817 struct S { virtual void member (); };
818
819 because the artificial declaration of the vtable itself (as
820 manufactured by the g++ front end) will say that the vtable is
821 a static member of `S' but only *after* the debug output for
822 the definition of `S' has already been output. This causes
823 grief because the DWARF entry for the definition of the vtable
824 will try to refer back to an earlier *declaration* of the
825 vtable as a static member of `S' and there won't be one. We
826 might be able to arrange to have the "vtable static member"
827 attached to the member list for `S' before the debug info for
828 `S' get written (which would solve the problem) but that would
829 require more intrusive changes to the g++ front end. */
830 DECL_IGNORED_P (decl) = 1;
831
832 return decl;
833 }
834
835 /* Get the VAR_DECL of the vtable for TYPE. TYPE need not be polymorphic,
836 or even complete. If this does not exist, create it. If COMPLETE is
837 nonzero, then complete the definition of it -- that will render it
838 impossible to actually build the vtable, but is useful to get at those
839 which are known to exist in the runtime. */
840
841 tree
842 get_vtable_decl (tree type, int complete)
843 {
844 tree decl;
845
846 if (CLASSTYPE_VTABLES (type))
847 return CLASSTYPE_VTABLES (type);
848
849 decl = build_vtable (type, get_vtable_name (type), vtbl_type_node);
850 CLASSTYPE_VTABLES (type) = decl;
851
852 if (complete)
853 {
854 DECL_EXTERNAL (decl) = 1;
855 cp_finish_decl (decl, NULL_TREE, false, NULL_TREE, 0);
856 }
857
858 return decl;
859 }
860
861 /* Build the primary virtual function table for TYPE. If BINFO is
862 non-NULL, build the vtable starting with the initial approximation
863 that it is the same as the one which is the head of the association
864 list. Returns a nonzero value if a new vtable is actually
865 created. */
866
867 static int
868 build_primary_vtable (tree binfo, tree type)
869 {
870 tree decl;
871 tree virtuals;
872
873 decl = get_vtable_decl (type, /*complete=*/0);
874
875 if (binfo)
876 {
877 if (BINFO_NEW_VTABLE_MARKED (binfo))
878 /* We have already created a vtable for this base, so there's
879 no need to do it again. */
880 return 0;
881
882 virtuals = copy_list (BINFO_VIRTUALS (binfo));
883 TREE_TYPE (decl) = TREE_TYPE (get_vtbl_decl_for_binfo (binfo));
884 DECL_SIZE (decl) = TYPE_SIZE (TREE_TYPE (decl));
885 DECL_SIZE_UNIT (decl) = TYPE_SIZE_UNIT (TREE_TYPE (decl));
886 }
887 else
888 {
889 gcc_assert (TREE_TYPE (decl) == vtbl_type_node);
890 virtuals = NULL_TREE;
891 }
892
893 if (GATHER_STATISTICS)
894 {
895 n_vtables += 1;
896 n_vtable_elems += list_length (virtuals);
897 }
898
899 /* Initialize the association list for this type, based
900 on our first approximation. */
901 BINFO_VTABLE (TYPE_BINFO (type)) = decl;
902 BINFO_VIRTUALS (TYPE_BINFO (type)) = virtuals;
903 SET_BINFO_NEW_VTABLE_MARKED (TYPE_BINFO (type));
904 return 1;
905 }
906
907 /* Give BINFO a new virtual function table which is initialized
908 with a skeleton-copy of its original initialization. The only
909 entry that changes is the `delta' entry, so we can really
910 share a lot of structure.
911
912 FOR_TYPE is the most derived type which caused this table to
913 be needed.
914
915 Returns nonzero if we haven't met BINFO before.
916
917 The order in which vtables are built (by calling this function) for
918 an object must remain the same, otherwise a binary incompatibility
919 can result. */
920
921 static int
922 build_secondary_vtable (tree binfo)
923 {
924 if (BINFO_NEW_VTABLE_MARKED (binfo))
925 /* We already created a vtable for this base. There's no need to
926 do it again. */
927 return 0;
928
929 /* Remember that we've created a vtable for this BINFO, so that we
930 don't try to do so again. */
931 SET_BINFO_NEW_VTABLE_MARKED (binfo);
932
933 /* Make fresh virtual list, so we can smash it later. */
934 BINFO_VIRTUALS (binfo) = copy_list (BINFO_VIRTUALS (binfo));
935
936 /* Secondary vtables are laid out as part of the same structure as
937 the primary vtable. */
938 BINFO_VTABLE (binfo) = NULL_TREE;
939 return 1;
940 }
941
942 /* Create a new vtable for BINFO which is the hierarchy dominated by
943 T. Return nonzero if we actually created a new vtable. */
944
945 static int
946 make_new_vtable (tree t, tree binfo)
947 {
948 if (binfo == TYPE_BINFO (t))
949 /* In this case, it is *type*'s vtable we are modifying. We start
950 with the approximation that its vtable is that of the
951 immediate base class. */
952 return build_primary_vtable (binfo, t);
953 else
954 /* This is our very own copy of `basetype' to play with. Later,
955 we will fill in all the virtual functions that override the
956 virtual functions in these base classes which are not defined
957 by the current type. */
958 return build_secondary_vtable (binfo);
959 }
960
961 /* Make *VIRTUALS, an entry on the BINFO_VIRTUALS list for BINFO
962 (which is in the hierarchy dominated by T) list FNDECL as its
963 BV_FN. DELTA is the required constant adjustment from the `this'
964 pointer where the vtable entry appears to the `this' required when
965 the function is actually called. */
966
967 static void
968 modify_vtable_entry (tree t,
969 tree binfo,
970 tree fndecl,
971 tree delta,
972 tree *virtuals)
973 {
974 tree v;
975
976 v = *virtuals;
977
978 if (fndecl != BV_FN (v)
979 || !tree_int_cst_equal (delta, BV_DELTA (v)))
980 {
981 /* We need a new vtable for BINFO. */
982 if (make_new_vtable (t, binfo))
983 {
984 /* If we really did make a new vtable, we also made a copy
985 of the BINFO_VIRTUALS list. Now, we have to find the
986 corresponding entry in that list. */
987 *virtuals = BINFO_VIRTUALS (binfo);
988 while (BV_FN (*virtuals) != BV_FN (v))
989 *virtuals = TREE_CHAIN (*virtuals);
990 v = *virtuals;
991 }
992
993 BV_DELTA (v) = delta;
994 BV_VCALL_INDEX (v) = NULL_TREE;
995 BV_FN (v) = fndecl;
996 }
997 }
998
999 \f
1000 /* Add method METHOD to class TYPE. If USING_DECL is non-null, it is
1001 the USING_DECL naming METHOD. Returns true if the method could be
1002 added to the method vec. */
1003
1004 bool
1005 add_method (tree type, tree method, tree using_decl)
1006 {
1007 unsigned slot;
1008 tree overload;
1009 bool template_conv_p = false;
1010 bool conv_p;
1011 vec<tree, va_gc> *method_vec;
1012 bool complete_p;
1013 bool insert_p = false;
1014 tree current_fns;
1015 tree fns;
1016
1017 if (method == error_mark_node)
1018 return false;
1019
1020 complete_p = COMPLETE_TYPE_P (type);
1021 conv_p = DECL_CONV_FN_P (method);
1022 if (conv_p)
1023 template_conv_p = (TREE_CODE (method) == TEMPLATE_DECL
1024 && DECL_TEMPLATE_CONV_FN_P (method));
1025
1026 method_vec = CLASSTYPE_METHOD_VEC (type);
1027 if (!method_vec)
1028 {
1029 /* Make a new method vector. We start with 8 entries. We must
1030 allocate at least two (for constructors and destructors), and
1031 we're going to end up with an assignment operator at some
1032 point as well. */
1033 vec_alloc (method_vec, 8);
1034 /* Create slots for constructors and destructors. */
1035 method_vec->quick_push (NULL_TREE);
1036 method_vec->quick_push (NULL_TREE);
1037 CLASSTYPE_METHOD_VEC (type) = method_vec;
1038 }
1039
1040 /* Maintain TYPE_HAS_USER_CONSTRUCTOR, etc. */
1041 grok_special_member_properties (method);
1042
1043 /* Constructors and destructors go in special slots. */
1044 if (DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P (method))
1045 slot = CLASSTYPE_CONSTRUCTOR_SLOT;
1046 else if (DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P (method))
1047 {
1048 slot = CLASSTYPE_DESTRUCTOR_SLOT;
1049
1050 if (TYPE_FOR_JAVA (type))
1051 {
1052 if (!DECL_ARTIFICIAL (method))
1053 error ("Java class %qT cannot have a destructor", type);
1054 else if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type))
1055 error ("Java class %qT cannot have an implicit non-trivial "
1056 "destructor",
1057 type);
1058 }
1059 }
1060 else
1061 {
1062 tree m;
1063
1064 insert_p = true;
1065 /* See if we already have an entry with this name. */
1066 for (slot = CLASSTYPE_FIRST_CONVERSION_SLOT;
1067 vec_safe_iterate (method_vec, slot, &m);
1068 ++slot)
1069 {
1070 m = OVL_CURRENT (m);
1071 if (template_conv_p)
1072 {
1073 if (TREE_CODE (m) == TEMPLATE_DECL
1074 && DECL_TEMPLATE_CONV_FN_P (m))
1075 insert_p = false;
1076 break;
1077 }
1078 if (conv_p && !DECL_CONV_FN_P (m))
1079 break;
1080 if (DECL_NAME (m) == DECL_NAME (method))
1081 {
1082 insert_p = false;
1083 break;
1084 }
1085 if (complete_p
1086 && !DECL_CONV_FN_P (m)
1087 && DECL_NAME (m) > DECL_NAME (method))
1088 break;
1089 }
1090 }
1091 current_fns = insert_p ? NULL_TREE : (*method_vec)[slot];
1092
1093 /* Check to see if we've already got this method. */
1094 for (fns = current_fns; fns; fns = OVL_NEXT (fns))
1095 {
1096 tree fn = OVL_CURRENT (fns);
1097 tree fn_type;
1098 tree method_type;
1099 tree parms1;
1100 tree parms2;
1101
1102 if (TREE_CODE (fn) != TREE_CODE (method))
1103 continue;
1104
1105 /* [over.load] Member function declarations with the
1106 same name and the same parameter types cannot be
1107 overloaded if any of them is a static member
1108 function declaration.
1109
1110 [over.load] Member function declarations with the same name and
1111 the same parameter-type-list as well as member function template
1112 declarations with the same name, the same parameter-type-list, and
1113 the same template parameter lists cannot be overloaded if any of
1114 them, but not all, have a ref-qualifier.
1115
1116 [namespace.udecl] When a using-declaration brings names
1117 from a base class into a derived class scope, member
1118 functions in the derived class override and/or hide member
1119 functions with the same name and parameter types in a base
1120 class (rather than conflicting). */
1121 fn_type = TREE_TYPE (fn);
1122 method_type = TREE_TYPE (method);
1123 parms1 = TYPE_ARG_TYPES (fn_type);
1124 parms2 = TYPE_ARG_TYPES (method_type);
1125
1126 /* Compare the quals on the 'this' parm. Don't compare
1127 the whole types, as used functions are treated as
1128 coming from the using class in overload resolution. */
1129 if (! DECL_STATIC_FUNCTION_P (fn)
1130 && ! DECL_STATIC_FUNCTION_P (method)
1131 /* Either both or neither need to be ref-qualified for
1132 differing quals to allow overloading. */
1133 && (FUNCTION_REF_QUALIFIED (fn_type)
1134 == FUNCTION_REF_QUALIFIED (method_type))
1135 && (type_memfn_quals (fn_type) != type_memfn_quals (method_type)
1136 || type_memfn_rqual (fn_type) != type_memfn_rqual (method_type)))
1137 continue;
1138
1139 /* For templates, the return type and template parameters
1140 must be identical. */
1141 if (TREE_CODE (fn) == TEMPLATE_DECL
1142 && (!same_type_p (TREE_TYPE (fn_type),
1143 TREE_TYPE (method_type))
1144 || !comp_template_parms (DECL_TEMPLATE_PARMS (fn),
1145 DECL_TEMPLATE_PARMS (method))))
1146 continue;
1147
1148 if (! DECL_STATIC_FUNCTION_P (fn))
1149 parms1 = TREE_CHAIN (parms1);
1150 if (! DECL_STATIC_FUNCTION_P (method))
1151 parms2 = TREE_CHAIN (parms2);
1152
1153 if (compparms (parms1, parms2)
1154 && (!DECL_CONV_FN_P (fn)
1155 || same_type_p (TREE_TYPE (fn_type),
1156 TREE_TYPE (method_type))))
1157 {
1158 /* For function versions, their parms and types match
1159 but they are not duplicates. Record function versions
1160 as and when they are found. extern "C" functions are
1161 not treated as versions. */
1162 if (TREE_CODE (fn) == FUNCTION_DECL
1163 && TREE_CODE (method) == FUNCTION_DECL
1164 && !DECL_EXTERN_C_P (fn)
1165 && !DECL_EXTERN_C_P (method)
1166 && targetm.target_option.function_versions (fn, method))
1167 {
1168 /* Mark functions as versions if necessary. Modify the mangled
1169 decl name if necessary. */
1170 if (!DECL_FUNCTION_VERSIONED (fn))
1171 {
1172 DECL_FUNCTION_VERSIONED (fn) = 1;
1173 if (DECL_ASSEMBLER_NAME_SET_P (fn))
1174 mangle_decl (fn);
1175 }
1176 if (!DECL_FUNCTION_VERSIONED (method))
1177 {
1178 DECL_FUNCTION_VERSIONED (method) = 1;
1179 if (DECL_ASSEMBLER_NAME_SET_P (method))
1180 mangle_decl (method);
1181 }
1182 cgraph_node::record_function_versions (fn, method);
1183 continue;
1184 }
1185 if (DECL_INHERITED_CTOR_BASE (method))
1186 {
1187 if (DECL_INHERITED_CTOR_BASE (fn))
1188 {
1189 error_at (DECL_SOURCE_LOCATION (method),
1190 "%q#D inherited from %qT", method,
1191 DECL_INHERITED_CTOR_BASE (method));
1192 error_at (DECL_SOURCE_LOCATION (fn),
1193 "conflicts with version inherited from %qT",
1194 DECL_INHERITED_CTOR_BASE (fn));
1195 }
1196 /* Otherwise defer to the other function. */
1197 return false;
1198 }
1199 if (using_decl)
1200 {
1201 if (DECL_CONTEXT (fn) == type)
1202 /* Defer to the local function. */
1203 return false;
1204 }
1205 else
1206 {
1207 error ("%q+#D cannot be overloaded", method);
1208 error ("with %q+#D", fn);
1209 }
1210
1211 /* We don't call duplicate_decls here to merge the
1212 declarations because that will confuse things if the
1213 methods have inline definitions. In particular, we
1214 will crash while processing the definitions. */
1215 return false;
1216 }
1217 }
1218
1219 /* A class should never have more than one destructor. */
1220 if (current_fns && DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P (method))
1221 return false;
1222
1223 /* Add the new binding. */
1224 if (using_decl)
1225 {
1226 overload = ovl_cons (method, current_fns);
1227 OVL_USED (overload) = true;
1228 }
1229 else
1230 overload = build_overload (method, current_fns);
1231
1232 if (conv_p)
1233 TYPE_HAS_CONVERSION (type) = 1;
1234 else if (slot >= CLASSTYPE_FIRST_CONVERSION_SLOT && !complete_p)
1235 push_class_level_binding (DECL_NAME (method), overload);
1236
1237 if (insert_p)
1238 {
1239 bool reallocated;
1240
1241 /* We only expect to add few methods in the COMPLETE_P case, so
1242 just make room for one more method in that case. */
1243 if (complete_p)
1244 reallocated = vec_safe_reserve_exact (method_vec, 1);
1245 else
1246 reallocated = vec_safe_reserve (method_vec, 1);
1247 if (reallocated)
1248 CLASSTYPE_METHOD_VEC (type) = method_vec;
1249 if (slot == method_vec->length ())
1250 method_vec->quick_push (overload);
1251 else
1252 method_vec->quick_insert (slot, overload);
1253 }
1254 else
1255 /* Replace the current slot. */
1256 (*method_vec)[slot] = overload;
1257 return true;
1258 }
1259
1260 /* Subroutines of finish_struct. */
1261
1262 /* Change the access of FDECL to ACCESS in T. Return 1 if change was
1263 legit, otherwise return 0. */
1264
1265 static int
1266 alter_access (tree t, tree fdecl, tree access)
1267 {
1268 tree elem;
1269
1270 if (!DECL_LANG_SPECIFIC (fdecl))
1271 retrofit_lang_decl (fdecl);
1272
1273 gcc_assert (!DECL_DISCRIMINATOR_P (fdecl));
1274
1275 elem = purpose_member (t, DECL_ACCESS (fdecl));
1276 if (elem)
1277 {
1278 if (TREE_VALUE (elem) != access)
1279 {
1280 if (TREE_CODE (TREE_TYPE (fdecl)) == FUNCTION_DECL)
1281 error ("conflicting access specifications for method"
1282 " %q+D, ignored", TREE_TYPE (fdecl));
1283 else
1284 error ("conflicting access specifications for field %qE, ignored",
1285 DECL_NAME (fdecl));
1286 }
1287 else
1288 {
1289 /* They're changing the access to the same thing they changed
1290 it to before. That's OK. */
1291 ;
1292 }
1293 }
1294 else
1295 {
1296 perform_or_defer_access_check (TYPE_BINFO (t), fdecl, fdecl,
1297 tf_warning_or_error);
1298 DECL_ACCESS (fdecl) = tree_cons (t, access, DECL_ACCESS (fdecl));
1299 return 1;
1300 }
1301 return 0;
1302 }
1303
1304 /* Process the USING_DECL, which is a member of T. */
1305
1306 static void
1307 handle_using_decl (tree using_decl, tree t)
1308 {
1309 tree decl = USING_DECL_DECLS (using_decl);
1310 tree name = DECL_NAME (using_decl);
1311 tree access
1312 = TREE_PRIVATE (using_decl) ? access_private_node
1313 : TREE_PROTECTED (using_decl) ? access_protected_node
1314 : access_public_node;
1315 tree flist = NULL_TREE;
1316 tree old_value;
1317
1318 gcc_assert (!processing_template_decl && decl);
1319
1320 old_value = lookup_member (t, name, /*protect=*/0, /*want_type=*/false,
1321 tf_warning_or_error);
1322 if (old_value)
1323 {
1324 if (is_overloaded_fn (old_value))
1325 old_value = OVL_CURRENT (old_value);
1326
1327 if (DECL_P (old_value) && DECL_CONTEXT (old_value) == t)
1328 /* OK */;
1329 else
1330 old_value = NULL_TREE;
1331 }
1332
1333 cp_emit_debug_info_for_using (decl, t);
1334
1335 if (is_overloaded_fn (decl))
1336 flist = decl;
1337
1338 if (! old_value)
1339 ;
1340 else if (is_overloaded_fn (old_value))
1341 {
1342 if (flist)
1343 /* It's OK to use functions from a base when there are functions with
1344 the same name already present in the current class. */;
1345 else
1346 {
1347 error ("%q+D invalid in %q#T", using_decl, t);
1348 error (" because of local method %q+#D with same name",
1349 OVL_CURRENT (old_value));
1350 return;
1351 }
1352 }
1353 else if (!DECL_ARTIFICIAL (old_value))
1354 {
1355 error ("%q+D invalid in %q#T", using_decl, t);
1356 error (" because of local member %q+#D with same name", old_value);
1357 return;
1358 }
1359
1360 /* Make type T see field decl FDECL with access ACCESS. */
1361 if (flist)
1362 for (; flist; flist = OVL_NEXT (flist))
1363 {
1364 add_method (t, OVL_CURRENT (flist), using_decl);
1365 alter_access (t, OVL_CURRENT (flist), access);
1366 }
1367 else
1368 alter_access (t, decl, access);
1369 }
1370 \f
1371 /* Data structure for find_abi_tags_r, below. */
1372
1373 struct abi_tag_data
1374 {
1375 tree t; // The type that we're checking for missing tags.
1376 tree subob; // The subobject of T that we're getting tags from.
1377 tree tags; // error_mark_node for diagnostics, or a list of missing tags.
1378 };
1379
1380 /* Subroutine of find_abi_tags_r. Handle a single TAG found on the class TP
1381 in the context of P. TAG can be either an identifier (the DECL_NAME of
1382 a tag NAMESPACE_DECL) or a STRING_CST (a tag attribute). */
1383
1384 static void
1385 check_tag (tree tag, tree id, tree *tp, abi_tag_data *p)
1386 {
1387 if (!IDENTIFIER_MARKED (id))
1388 {
1389 if (p->tags != error_mark_node)
1390 {
1391 /* We're collecting tags from template arguments or from
1392 the type of a variable or function return type. */
1393 p->tags = tree_cons (NULL_TREE, tag, p->tags);
1394
1395 /* Don't inherit this tag multiple times. */
1396 IDENTIFIER_MARKED (id) = true;
1397
1398 if (TYPE_P (p->t))
1399 {
1400 /* Tags inherited from type template arguments are only used
1401 to avoid warnings. */
1402 ABI_TAG_IMPLICIT (p->tags) = true;
1403 return;
1404 }
1405 /* For functions and variables we want to warn, too. */
1406 }
1407
1408 /* Otherwise we're diagnosing missing tags. */
1409 if (TREE_CODE (p->t) == FUNCTION_DECL)
1410 {
1411 if (warning (OPT_Wabi_tag, "%qD inherits the %E ABI tag "
1412 "that %qT (used in its return type) has",
1413 p->t, tag, *tp))
1414 inform (location_of (*tp), "%qT declared here", *tp);
1415 }
1416 else if (TREE_CODE (p->t) == VAR_DECL)
1417 {
1418 if (warning (OPT_Wabi_tag, "%qD inherits the %E ABI tag "
1419 "that %qT (used in its type) has", p->t, tag, *tp))
1420 inform (location_of (*tp), "%qT declared here", *tp);
1421 }
1422 else if (TYPE_P (p->subob))
1423 {
1424 if (warning (OPT_Wabi_tag, "%qT does not have the %E ABI tag "
1425 "that base %qT has", p->t, tag, p->subob))
1426 inform (location_of (p->subob), "%qT declared here",
1427 p->subob);
1428 }
1429 else
1430 {
1431 if (warning (OPT_Wabi_tag, "%qT does not have the %E ABI tag "
1432 "that %qT (used in the type of %qD) has",
1433 p->t, tag, *tp, p->subob))
1434 {
1435 inform (location_of (p->subob), "%qD declared here",
1436 p->subob);
1437 inform (location_of (*tp), "%qT declared here", *tp);
1438 }
1439 }
1440 }
1441 }
1442
1443 /* Find all the ABI tags in the attribute list ATTR and either call
1444 check_tag (if TP is non-null) or set IDENTIFIER_MARKED to val. */
1445
1446 static void
1447 mark_or_check_attr_tags (tree attr, tree *tp, abi_tag_data *p, bool val)
1448 {
1449 if (!attr)
1450 return;
1451 for (; (attr = lookup_attribute ("abi_tag", attr));
1452 attr = TREE_CHAIN (attr))
1453 for (tree list = TREE_VALUE (attr); list;
1454 list = TREE_CHAIN (list))
1455 {
1456 tree tag = TREE_VALUE (list);
1457 tree id = get_identifier (TREE_STRING_POINTER (tag));
1458 if (tp)
1459 check_tag (tag, id, tp, p);
1460 else
1461 IDENTIFIER_MARKED (id) = val;
1462 }
1463 }
1464
1465 /* Find all the ABI tags on T and its enclosing scopes and either call
1466 check_tag (if TP is non-null) or set IDENTIFIER_MARKED to val. */
1467
1468 static void
1469 mark_or_check_tags (tree t, tree *tp, abi_tag_data *p, bool val)
1470 {
1471 while (t != global_namespace)
1472 {
1473 tree attr;
1474 if (TYPE_P (t))
1475 {
1476 attr = TYPE_ATTRIBUTES (t);
1477 t = CP_TYPE_CONTEXT (t);
1478 }
1479 else
1480 {
1481 attr = DECL_ATTRIBUTES (t);
1482 t = CP_DECL_CONTEXT (t);
1483 }
1484 mark_or_check_attr_tags (attr, tp, p, val);
1485 }
1486 }
1487
1488 /* walk_tree callback for check_abi_tags: if the type at *TP involves any
1489 types with ABI tags, add the corresponding identifiers to the VEC in
1490 *DATA and set IDENTIFIER_MARKED. */
1491
1492 static tree
1493 find_abi_tags_r (tree *tp, int *walk_subtrees, void *data)
1494 {
1495 if (!OVERLOAD_TYPE_P (*tp))
1496 return NULL_TREE;
1497
1498 /* walk_tree shouldn't be walking into any subtrees of a RECORD_TYPE
1499 anyway, but let's make sure of it. */
1500 *walk_subtrees = false;
1501
1502 abi_tag_data *p = static_cast<struct abi_tag_data*>(data);
1503
1504 mark_or_check_tags (*tp, tp, p, false);
1505
1506 return NULL_TREE;
1507 }
1508
1509 /* walk_tree callback for mark_abi_tags: if *TP is a class, set
1510 IDENTIFIER_MARKED on its ABI tags. */
1511
1512 static tree
1513 mark_abi_tags_r (tree *tp, int *walk_subtrees, void *data)
1514 {
1515 if (!OVERLOAD_TYPE_P (*tp))
1516 return NULL_TREE;
1517
1518 /* walk_tree shouldn't be walking into any subtrees of a RECORD_TYPE
1519 anyway, but let's make sure of it. */
1520 *walk_subtrees = false;
1521
1522 bool *valp = static_cast<bool*>(data);
1523
1524 mark_or_check_tags (*tp, NULL, NULL, *valp);
1525
1526 return NULL_TREE;
1527 }
1528
1529 /* Set IDENTIFIER_MARKED on all the ABI tags on T and its enclosing
1530 scopes. */
1531
1532 static void
1533 mark_abi_tags (tree t, bool val)
1534 {
1535 mark_or_check_tags (t, NULL, NULL, val);
1536 if (DECL_P (t))
1537 {
1538 if (DECL_LANG_SPECIFIC (t) && DECL_USE_TEMPLATE (t)
1539 && PRIMARY_TEMPLATE_P (DECL_TI_TEMPLATE (t)))
1540 {
1541 /* Template arguments are part of the signature. */
1542 tree level = INNERMOST_TEMPLATE_ARGS (DECL_TI_ARGS (t));
1543 for (int j = 0; j < TREE_VEC_LENGTH (level); ++j)
1544 {
1545 tree arg = TREE_VEC_ELT (level, j);
1546 cp_walk_tree_without_duplicates (&arg, mark_abi_tags_r, &val);
1547 }
1548 }
1549 if (TREE_CODE (t) == FUNCTION_DECL)
1550 /* A function's parameter types are part of the signature, so
1551 we don't need to inherit any tags that are also in them. */
1552 for (tree arg = FUNCTION_FIRST_USER_PARMTYPE (t); arg;
1553 arg = TREE_CHAIN (arg))
1554 cp_walk_tree_without_duplicates (&TREE_VALUE (arg),
1555 mark_abi_tags_r, &val);
1556 }
1557 }
1558
1559 /* Check that T has all the ABI tags that subobject SUBOB has, or
1560 warn if not. If T is a (variable or function) declaration, also
1561 add any missing tags. */
1562
1563 static void
1564 check_abi_tags (tree t, tree subob)
1565 {
1566 bool inherit = DECL_P (t);
1567
1568 if (!inherit && !warn_abi_tag)
1569 return;
1570
1571 tree decl = TYPE_P (t) ? TYPE_NAME (t) : t;
1572 if (!TREE_PUBLIC (decl))
1573 /* No need to worry about things local to this TU. */
1574 return;
1575
1576 mark_abi_tags (t, true);
1577
1578 tree subtype = TYPE_P (subob) ? subob : TREE_TYPE (subob);
1579 struct abi_tag_data data = { t, subob, error_mark_node };
1580 if (inherit)
1581 data.tags = NULL_TREE;
1582
1583 cp_walk_tree_without_duplicates (&subtype, find_abi_tags_r, &data);
1584
1585 if (inherit && data.tags)
1586 {
1587 tree attr = lookup_attribute ("abi_tag", DECL_ATTRIBUTES (t));
1588 if (attr)
1589 TREE_VALUE (attr) = chainon (data.tags, TREE_VALUE (attr));
1590 else
1591 DECL_ATTRIBUTES (t)
1592 = tree_cons (get_identifier ("abi_tag"), data.tags,
1593 DECL_ATTRIBUTES (t));
1594 }
1595
1596 mark_abi_tags (t, false);
1597 }
1598
1599 /* Check that DECL has all the ABI tags that are used in parts of its type
1600 that are not reflected in its mangled name. */
1601
1602 void
1603 check_abi_tags (tree decl)
1604 {
1605 if (TREE_CODE (decl) == VAR_DECL)
1606 check_abi_tags (decl, TREE_TYPE (decl));
1607 else if (TREE_CODE (decl) == FUNCTION_DECL
1608 && !mangle_return_type_p (decl))
1609 check_abi_tags (decl, TREE_TYPE (TREE_TYPE (decl)));
1610 }
1611
1612 void
1613 inherit_targ_abi_tags (tree t)
1614 {
1615 if (!CLASS_TYPE_P (t)
1616 || CLASSTYPE_TEMPLATE_INFO (t) == NULL_TREE)
1617 return;
1618
1619 mark_abi_tags (t, true);
1620
1621 tree args = CLASSTYPE_TI_ARGS (t);
1622 struct abi_tag_data data = { t, NULL_TREE, NULL_TREE };
1623 for (int i = 0; i < TMPL_ARGS_DEPTH (args); ++i)
1624 {
1625 tree level = TMPL_ARGS_LEVEL (args, i+1);
1626 for (int j = 0; j < TREE_VEC_LENGTH (level); ++j)
1627 {
1628 tree arg = TREE_VEC_ELT (level, j);
1629 data.subob = arg;
1630 cp_walk_tree_without_duplicates (&arg, find_abi_tags_r, &data);
1631 }
1632 }
1633
1634 // If we found some tags on our template arguments, add them to our
1635 // abi_tag attribute.
1636 if (data.tags)
1637 {
1638 tree attr = lookup_attribute ("abi_tag", TYPE_ATTRIBUTES (t));
1639 if (attr)
1640 TREE_VALUE (attr) = chainon (data.tags, TREE_VALUE (attr));
1641 else
1642 TYPE_ATTRIBUTES (t)
1643 = tree_cons (get_identifier ("abi_tag"), data.tags,
1644 TYPE_ATTRIBUTES (t));
1645 }
1646
1647 mark_abi_tags (t, false);
1648 }
1649
1650 /* Return true, iff class T has a non-virtual destructor that is
1651 accessible from outside the class heirarchy (i.e. is public, or
1652 there's a suitable friend. */
1653
1654 static bool
1655 accessible_nvdtor_p (tree t)
1656 {
1657 tree dtor = CLASSTYPE_DESTRUCTORS (t);
1658
1659 /* An implicitly declared destructor is always public. And,
1660 if it were virtual, we would have created it by now. */
1661 if (!dtor)
1662 return true;
1663
1664 if (DECL_VINDEX (dtor))
1665 return false; /* Virtual */
1666
1667 if (!TREE_PRIVATE (dtor) && !TREE_PROTECTED (dtor))
1668 return true; /* Public */
1669
1670 if (CLASSTYPE_FRIEND_CLASSES (t)
1671 || DECL_FRIENDLIST (TYPE_MAIN_DECL (t)))
1672 return true; /* Has friends */
1673
1674 return false;
1675 }
1676
1677 /* Run through the base classes of T, updating CANT_HAVE_CONST_CTOR_P,
1678 and NO_CONST_ASN_REF_P. Also set flag bits in T based on
1679 properties of the bases. */
1680
1681 static void
1682 check_bases (tree t,
1683 int* cant_have_const_ctor_p,
1684 int* no_const_asn_ref_p)
1685 {
1686 int i;
1687 bool seen_non_virtual_nearly_empty_base_p = 0;
1688 int seen_tm_mask = 0;
1689 tree base_binfo;
1690 tree binfo;
1691 tree field = NULL_TREE;
1692
1693 if (!CLASSTYPE_NON_STD_LAYOUT (t))
1694 for (field = TYPE_FIELDS (t); field; field = DECL_CHAIN (field))
1695 if (TREE_CODE (field) == FIELD_DECL)
1696 break;
1697
1698 for (binfo = TYPE_BINFO (t), i = 0;
1699 BINFO_BASE_ITERATE (binfo, i, base_binfo); i++)
1700 {
1701 tree basetype = TREE_TYPE (base_binfo);
1702
1703 gcc_assert (COMPLETE_TYPE_P (basetype));
1704
1705 if (CLASSTYPE_FINAL (basetype))
1706 error ("cannot derive from %<final%> base %qT in derived type %qT",
1707 basetype, t);
1708
1709 /* If any base class is non-literal, so is the derived class. */
1710 if (!CLASSTYPE_LITERAL_P (basetype))
1711 CLASSTYPE_LITERAL_P (t) = false;
1712
1713 /* If the base class doesn't have copy constructors or
1714 assignment operators that take const references, then the
1715 derived class cannot have such a member automatically
1716 generated. */
1717 if (TYPE_HAS_COPY_CTOR (basetype)
1718 && ! TYPE_HAS_CONST_COPY_CTOR (basetype))
1719 *cant_have_const_ctor_p = 1;
1720 if (TYPE_HAS_COPY_ASSIGN (basetype)
1721 && !TYPE_HAS_CONST_COPY_ASSIGN (basetype))
1722 *no_const_asn_ref_p = 1;
1723
1724 if (BINFO_VIRTUAL_P (base_binfo))
1725 /* A virtual base does not effect nearly emptiness. */
1726 ;
1727 else if (CLASSTYPE_NEARLY_EMPTY_P (basetype))
1728 {
1729 if (seen_non_virtual_nearly_empty_base_p)
1730 /* And if there is more than one nearly empty base, then the
1731 derived class is not nearly empty either. */
1732 CLASSTYPE_NEARLY_EMPTY_P (t) = 0;
1733 else
1734 /* Remember we've seen one. */
1735 seen_non_virtual_nearly_empty_base_p = 1;
1736 }
1737 else if (!is_empty_class (basetype))
1738 /* If the base class is not empty or nearly empty, then this
1739 class cannot be nearly empty. */
1740 CLASSTYPE_NEARLY_EMPTY_P (t) = 0;
1741
1742 /* A lot of properties from the bases also apply to the derived
1743 class. */
1744 TYPE_NEEDS_CONSTRUCTING (t) |= TYPE_NEEDS_CONSTRUCTING (basetype);
1745 TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t)
1746 |= TYPE_HAS_NONTRIVIAL_DESTRUCTOR (basetype);
1747 TYPE_HAS_COMPLEX_COPY_ASSIGN (t)
1748 |= (TYPE_HAS_COMPLEX_COPY_ASSIGN (basetype)
1749 || !TYPE_HAS_COPY_ASSIGN (basetype));
1750 TYPE_HAS_COMPLEX_COPY_CTOR (t) |= (TYPE_HAS_COMPLEX_COPY_CTOR (basetype)
1751 || !TYPE_HAS_COPY_CTOR (basetype));
1752 TYPE_HAS_COMPLEX_MOVE_ASSIGN (t)
1753 |= TYPE_HAS_COMPLEX_MOVE_ASSIGN (basetype);
1754 TYPE_HAS_COMPLEX_MOVE_CTOR (t) |= TYPE_HAS_COMPLEX_MOVE_CTOR (basetype);
1755 TYPE_POLYMORPHIC_P (t) |= TYPE_POLYMORPHIC_P (basetype);
1756 CLASSTYPE_CONTAINS_EMPTY_CLASS_P (t)
1757 |= CLASSTYPE_CONTAINS_EMPTY_CLASS_P (basetype);
1758 TYPE_HAS_COMPLEX_DFLT (t) |= (!TYPE_HAS_DEFAULT_CONSTRUCTOR (basetype)
1759 || TYPE_HAS_COMPLEX_DFLT (basetype));
1760 SET_CLASSTYPE_READONLY_FIELDS_NEED_INIT
1761 (t, CLASSTYPE_READONLY_FIELDS_NEED_INIT (t)
1762 | CLASSTYPE_READONLY_FIELDS_NEED_INIT (basetype));
1763 SET_CLASSTYPE_REF_FIELDS_NEED_INIT
1764 (t, CLASSTYPE_REF_FIELDS_NEED_INIT (t)
1765 | CLASSTYPE_REF_FIELDS_NEED_INIT (basetype));
1766
1767 /* A standard-layout class is a class that:
1768 ...
1769 * has no non-standard-layout base classes, */
1770 CLASSTYPE_NON_STD_LAYOUT (t) |= CLASSTYPE_NON_STD_LAYOUT (basetype);
1771 if (!CLASSTYPE_NON_STD_LAYOUT (t))
1772 {
1773 tree basefield;
1774 /* ...has no base classes of the same type as the first non-static
1775 data member... */
1776 if (field && DECL_CONTEXT (field) == t
1777 && (same_type_ignoring_top_level_qualifiers_p
1778 (TREE_TYPE (field), basetype)))
1779 CLASSTYPE_NON_STD_LAYOUT (t) = 1;
1780 else
1781 /* ...either has no non-static data members in the most-derived
1782 class and at most one base class with non-static data
1783 members, or has no base classes with non-static data
1784 members */
1785 for (basefield = TYPE_FIELDS (basetype); basefield;
1786 basefield = DECL_CHAIN (basefield))
1787 if (TREE_CODE (basefield) == FIELD_DECL)
1788 {
1789 if (field)
1790 CLASSTYPE_NON_STD_LAYOUT (t) = 1;
1791 else
1792 field = basefield;
1793 break;
1794 }
1795 }
1796
1797 /* Don't bother collecting tm attributes if transactional memory
1798 support is not enabled. */
1799 if (flag_tm)
1800 {
1801 tree tm_attr = find_tm_attribute (TYPE_ATTRIBUTES (basetype));
1802 if (tm_attr)
1803 seen_tm_mask |= tm_attr_to_mask (tm_attr);
1804 }
1805
1806 check_abi_tags (t, basetype);
1807 }
1808
1809 /* If one of the base classes had TM attributes, and the current class
1810 doesn't define its own, then the current class inherits one. */
1811 if (seen_tm_mask && !find_tm_attribute (TYPE_ATTRIBUTES (t)))
1812 {
1813 tree tm_attr = tm_mask_to_attr (seen_tm_mask & -seen_tm_mask);
1814 TYPE_ATTRIBUTES (t) = tree_cons (tm_attr, NULL, TYPE_ATTRIBUTES (t));
1815 }
1816 }
1817
1818 /* Determine all the primary bases within T. Sets BINFO_PRIMARY_BASE_P for
1819 those that are primaries. Sets BINFO_LOST_PRIMARY_P for those
1820 that have had a nearly-empty virtual primary base stolen by some
1821 other base in the hierarchy. Determines CLASSTYPE_PRIMARY_BASE for
1822 T. */
1823
1824 static void
1825 determine_primary_bases (tree t)
1826 {
1827 unsigned i;
1828 tree primary = NULL_TREE;
1829 tree type_binfo = TYPE_BINFO (t);
1830 tree base_binfo;
1831
1832 /* Determine the primary bases of our bases. */
1833 for (base_binfo = TREE_CHAIN (type_binfo); base_binfo;
1834 base_binfo = TREE_CHAIN (base_binfo))
1835 {
1836 tree primary = CLASSTYPE_PRIMARY_BINFO (BINFO_TYPE (base_binfo));
1837
1838 /* See if we're the non-virtual primary of our inheritance
1839 chain. */
1840 if (!BINFO_VIRTUAL_P (base_binfo))
1841 {
1842 tree parent = BINFO_INHERITANCE_CHAIN (base_binfo);
1843 tree parent_primary = CLASSTYPE_PRIMARY_BINFO (BINFO_TYPE (parent));
1844
1845 if (parent_primary
1846 && SAME_BINFO_TYPE_P (BINFO_TYPE (base_binfo),
1847 BINFO_TYPE (parent_primary)))
1848 /* We are the primary binfo. */
1849 BINFO_PRIMARY_P (base_binfo) = 1;
1850 }
1851 /* Determine if we have a virtual primary base, and mark it so.
1852 */
1853 if (primary && BINFO_VIRTUAL_P (primary))
1854 {
1855 tree this_primary = copied_binfo (primary, base_binfo);
1856
1857 if (BINFO_PRIMARY_P (this_primary))
1858 /* Someone already claimed this base. */
1859 BINFO_LOST_PRIMARY_P (base_binfo) = 1;
1860 else
1861 {
1862 tree delta;
1863
1864 BINFO_PRIMARY_P (this_primary) = 1;
1865 BINFO_INHERITANCE_CHAIN (this_primary) = base_binfo;
1866
1867 /* A virtual binfo might have been copied from within
1868 another hierarchy. As we're about to use it as a
1869 primary base, make sure the offsets match. */
1870 delta = size_diffop_loc (input_location,
1871 convert (ssizetype,
1872 BINFO_OFFSET (base_binfo)),
1873 convert (ssizetype,
1874 BINFO_OFFSET (this_primary)));
1875
1876 propagate_binfo_offsets (this_primary, delta);
1877 }
1878 }
1879 }
1880
1881 /* First look for a dynamic direct non-virtual base. */
1882 for (i = 0; BINFO_BASE_ITERATE (type_binfo, i, base_binfo); i++)
1883 {
1884 tree basetype = BINFO_TYPE (base_binfo);
1885
1886 if (TYPE_CONTAINS_VPTR_P (basetype) && !BINFO_VIRTUAL_P (base_binfo))
1887 {
1888 primary = base_binfo;
1889 goto found;
1890 }
1891 }
1892
1893 /* A "nearly-empty" virtual base class can be the primary base
1894 class, if no non-virtual polymorphic base can be found. Look for
1895 a nearly-empty virtual dynamic base that is not already a primary
1896 base of something in the hierarchy. If there is no such base,
1897 just pick the first nearly-empty virtual base. */
1898
1899 for (base_binfo = TREE_CHAIN (type_binfo); base_binfo;
1900 base_binfo = TREE_CHAIN (base_binfo))
1901 if (BINFO_VIRTUAL_P (base_binfo)
1902 && CLASSTYPE_NEARLY_EMPTY_P (BINFO_TYPE (base_binfo)))
1903 {
1904 if (!BINFO_PRIMARY_P (base_binfo))
1905 {
1906 /* Found one that is not primary. */
1907 primary = base_binfo;
1908 goto found;
1909 }
1910 else if (!primary)
1911 /* Remember the first candidate. */
1912 primary = base_binfo;
1913 }
1914
1915 found:
1916 /* If we've got a primary base, use it. */
1917 if (primary)
1918 {
1919 tree basetype = BINFO_TYPE (primary);
1920
1921 CLASSTYPE_PRIMARY_BINFO (t) = primary;
1922 if (BINFO_PRIMARY_P (primary))
1923 /* We are stealing a primary base. */
1924 BINFO_LOST_PRIMARY_P (BINFO_INHERITANCE_CHAIN (primary)) = 1;
1925 BINFO_PRIMARY_P (primary) = 1;
1926 if (BINFO_VIRTUAL_P (primary))
1927 {
1928 tree delta;
1929
1930 BINFO_INHERITANCE_CHAIN (primary) = type_binfo;
1931 /* A virtual binfo might have been copied from within
1932 another hierarchy. As we're about to use it as a primary
1933 base, make sure the offsets match. */
1934 delta = size_diffop_loc (input_location, ssize_int (0),
1935 convert (ssizetype, BINFO_OFFSET (primary)));
1936
1937 propagate_binfo_offsets (primary, delta);
1938 }
1939
1940 primary = TYPE_BINFO (basetype);
1941
1942 TYPE_VFIELD (t) = TYPE_VFIELD (basetype);
1943 BINFO_VTABLE (type_binfo) = BINFO_VTABLE (primary);
1944 BINFO_VIRTUALS (type_binfo) = BINFO_VIRTUALS (primary);
1945 }
1946 }
1947
1948 /* Update the variant types of T. */
1949
1950 void
1951 fixup_type_variants (tree t)
1952 {
1953 tree variants;
1954
1955 if (!t)
1956 return;
1957
1958 for (variants = TYPE_NEXT_VARIANT (t);
1959 variants;
1960 variants = TYPE_NEXT_VARIANT (variants))
1961 {
1962 /* These fields are in the _TYPE part of the node, not in
1963 the TYPE_LANG_SPECIFIC component, so they are not shared. */
1964 TYPE_HAS_USER_CONSTRUCTOR (variants) = TYPE_HAS_USER_CONSTRUCTOR (t);
1965 TYPE_NEEDS_CONSTRUCTING (variants) = TYPE_NEEDS_CONSTRUCTING (t);
1966 TYPE_HAS_NONTRIVIAL_DESTRUCTOR (variants)
1967 = TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t);
1968
1969 TYPE_POLYMORPHIC_P (variants) = TYPE_POLYMORPHIC_P (t);
1970
1971 TYPE_BINFO (variants) = TYPE_BINFO (t);
1972
1973 /* Copy whatever these are holding today. */
1974 TYPE_VFIELD (variants) = TYPE_VFIELD (t);
1975 TYPE_METHODS (variants) = TYPE_METHODS (t);
1976 TYPE_FIELDS (variants) = TYPE_FIELDS (t);
1977 }
1978 }
1979
1980 /* Early variant fixups: we apply attributes at the beginning of the class
1981 definition, and we need to fix up any variants that have already been
1982 made via elaborated-type-specifier so that check_qualified_type works. */
1983
1984 void
1985 fixup_attribute_variants (tree t)
1986 {
1987 tree variants;
1988
1989 if (!t)
1990 return;
1991
1992 for (variants = TYPE_NEXT_VARIANT (t);
1993 variants;
1994 variants = TYPE_NEXT_VARIANT (variants))
1995 {
1996 /* These are the two fields that check_qualified_type looks at and
1997 are affected by attributes. */
1998 TYPE_ATTRIBUTES (variants) = TYPE_ATTRIBUTES (t);
1999 TYPE_ALIGN (variants) = TYPE_ALIGN (t);
2000 }
2001 }
2002 \f
2003 /* Set memoizing fields and bits of T (and its variants) for later
2004 use. */
2005
2006 static void
2007 finish_struct_bits (tree t)
2008 {
2009 /* Fix up variants (if any). */
2010 fixup_type_variants (t);
2011
2012 if (BINFO_N_BASE_BINFOS (TYPE_BINFO (t)) && TYPE_POLYMORPHIC_P (t))
2013 /* For a class w/o baseclasses, 'finish_struct' has set
2014 CLASSTYPE_PURE_VIRTUALS correctly (by definition).
2015 Similarly for a class whose base classes do not have vtables.
2016 When neither of these is true, we might have removed abstract
2017 virtuals (by providing a definition), added some (by declaring
2018 new ones), or redeclared ones from a base class. We need to
2019 recalculate what's really an abstract virtual at this point (by
2020 looking in the vtables). */
2021 get_pure_virtuals (t);
2022
2023 /* If this type has a copy constructor or a destructor, force its
2024 mode to be BLKmode, and force its TREE_ADDRESSABLE bit to be
2025 nonzero. This will cause it to be passed by invisible reference
2026 and prevent it from being returned in a register. */
2027 if (type_has_nontrivial_copy_init (t)
2028 || TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t))
2029 {
2030 tree variants;
2031 DECL_MODE (TYPE_MAIN_DECL (t)) = BLKmode;
2032 for (variants = t; variants; variants = TYPE_NEXT_VARIANT (variants))
2033 {
2034 SET_TYPE_MODE (variants, BLKmode);
2035 TREE_ADDRESSABLE (variants) = 1;
2036 }
2037 }
2038 }
2039
2040 /* Issue warnings about T having private constructors, but no friends,
2041 and so forth.
2042
2043 HAS_NONPRIVATE_METHOD is nonzero if T has any non-private methods or
2044 static members. HAS_NONPRIVATE_STATIC_FN is nonzero if T has any
2045 non-private static member functions. */
2046
2047 static void
2048 maybe_warn_about_overly_private_class (tree t)
2049 {
2050 int has_member_fn = 0;
2051 int has_nonprivate_method = 0;
2052 tree fn;
2053
2054 if (!warn_ctor_dtor_privacy
2055 /* If the class has friends, those entities might create and
2056 access instances, so we should not warn. */
2057 || (CLASSTYPE_FRIEND_CLASSES (t)
2058 || DECL_FRIENDLIST (TYPE_MAIN_DECL (t)))
2059 /* We will have warned when the template was declared; there's
2060 no need to warn on every instantiation. */
2061 || CLASSTYPE_TEMPLATE_INSTANTIATION (t))
2062 /* There's no reason to even consider warning about this
2063 class. */
2064 return;
2065
2066 /* We only issue one warning, if more than one applies, because
2067 otherwise, on code like:
2068
2069 class A {
2070 // Oops - forgot `public:'
2071 A();
2072 A(const A&);
2073 ~A();
2074 };
2075
2076 we warn several times about essentially the same problem. */
2077
2078 /* Check to see if all (non-constructor, non-destructor) member
2079 functions are private. (Since there are no friends or
2080 non-private statics, we can't ever call any of the private member
2081 functions.) */
2082 for (fn = TYPE_METHODS (t); fn; fn = DECL_CHAIN (fn))
2083 /* We're not interested in compiler-generated methods; they don't
2084 provide any way to call private members. */
2085 if (!DECL_ARTIFICIAL (fn))
2086 {
2087 if (!TREE_PRIVATE (fn))
2088 {
2089 if (DECL_STATIC_FUNCTION_P (fn))
2090 /* A non-private static member function is just like a
2091 friend; it can create and invoke private member
2092 functions, and be accessed without a class
2093 instance. */
2094 return;
2095
2096 has_nonprivate_method = 1;
2097 /* Keep searching for a static member function. */
2098 }
2099 else if (!DECL_CONSTRUCTOR_P (fn) && !DECL_DESTRUCTOR_P (fn))
2100 has_member_fn = 1;
2101 }
2102
2103 if (!has_nonprivate_method && has_member_fn)
2104 {
2105 /* There are no non-private methods, and there's at least one
2106 private member function that isn't a constructor or
2107 destructor. (If all the private members are
2108 constructors/destructors we want to use the code below that
2109 issues error messages specifically referring to
2110 constructors/destructors.) */
2111 unsigned i;
2112 tree binfo = TYPE_BINFO (t);
2113
2114 for (i = 0; i != BINFO_N_BASE_BINFOS (binfo); i++)
2115 if (BINFO_BASE_ACCESS (binfo, i) != access_private_node)
2116 {
2117 has_nonprivate_method = 1;
2118 break;
2119 }
2120 if (!has_nonprivate_method)
2121 {
2122 warning (OPT_Wctor_dtor_privacy,
2123 "all member functions in class %qT are private", t);
2124 return;
2125 }
2126 }
2127
2128 /* Even if some of the member functions are non-private, the class
2129 won't be useful for much if all the constructors or destructors
2130 are private: such an object can never be created or destroyed. */
2131 fn = CLASSTYPE_DESTRUCTORS (t);
2132 if (fn && TREE_PRIVATE (fn))
2133 {
2134 warning (OPT_Wctor_dtor_privacy,
2135 "%q#T only defines a private destructor and has no friends",
2136 t);
2137 return;
2138 }
2139
2140 /* Warn about classes that have private constructors and no friends. */
2141 if (TYPE_HAS_USER_CONSTRUCTOR (t)
2142 /* Implicitly generated constructors are always public. */
2143 && (!CLASSTYPE_LAZY_DEFAULT_CTOR (t)
2144 || !CLASSTYPE_LAZY_COPY_CTOR (t)))
2145 {
2146 int nonprivate_ctor = 0;
2147
2148 /* If a non-template class does not define a copy
2149 constructor, one is defined for it, enabling it to avoid
2150 this warning. For a template class, this does not
2151 happen, and so we would normally get a warning on:
2152
2153 template <class T> class C { private: C(); };
2154
2155 To avoid this asymmetry, we check TYPE_HAS_COPY_CTOR. All
2156 complete non-template or fully instantiated classes have this
2157 flag set. */
2158 if (!TYPE_HAS_COPY_CTOR (t))
2159 nonprivate_ctor = 1;
2160 else
2161 for (fn = CLASSTYPE_CONSTRUCTORS (t); fn; fn = OVL_NEXT (fn))
2162 {
2163 tree ctor = OVL_CURRENT (fn);
2164 /* Ideally, we wouldn't count copy constructors (or, in
2165 fact, any constructor that takes an argument of the
2166 class type as a parameter) because such things cannot
2167 be used to construct an instance of the class unless
2168 you already have one. But, for now at least, we're
2169 more generous. */
2170 if (! TREE_PRIVATE (ctor))
2171 {
2172 nonprivate_ctor = 1;
2173 break;
2174 }
2175 }
2176
2177 if (nonprivate_ctor == 0)
2178 {
2179 warning (OPT_Wctor_dtor_privacy,
2180 "%q#T only defines private constructors and has no friends",
2181 t);
2182 return;
2183 }
2184 }
2185 }
2186
2187 static struct {
2188 gt_pointer_operator new_value;
2189 void *cookie;
2190 } resort_data;
2191
2192 /* Comparison function to compare two TYPE_METHOD_VEC entries by name. */
2193
2194 static int
2195 method_name_cmp (const void* m1_p, const void* m2_p)
2196 {
2197 const tree *const m1 = (const tree *) m1_p;
2198 const tree *const m2 = (const tree *) m2_p;
2199
2200 if (*m1 == NULL_TREE && *m2 == NULL_TREE)
2201 return 0;
2202 if (*m1 == NULL_TREE)
2203 return -1;
2204 if (*m2 == NULL_TREE)
2205 return 1;
2206 if (DECL_NAME (OVL_CURRENT (*m1)) < DECL_NAME (OVL_CURRENT (*m2)))
2207 return -1;
2208 return 1;
2209 }
2210
2211 /* This routine compares two fields like method_name_cmp but using the
2212 pointer operator in resort_field_decl_data. */
2213
2214 static int
2215 resort_method_name_cmp (const void* m1_p, const void* m2_p)
2216 {
2217 const tree *const m1 = (const tree *) m1_p;
2218 const tree *const m2 = (const tree *) m2_p;
2219 if (*m1 == NULL_TREE && *m2 == NULL_TREE)
2220 return 0;
2221 if (*m1 == NULL_TREE)
2222 return -1;
2223 if (*m2 == NULL_TREE)
2224 return 1;
2225 {
2226 tree d1 = DECL_NAME (OVL_CURRENT (*m1));
2227 tree d2 = DECL_NAME (OVL_CURRENT (*m2));
2228 resort_data.new_value (&d1, resort_data.cookie);
2229 resort_data.new_value (&d2, resort_data.cookie);
2230 if (d1 < d2)
2231 return -1;
2232 }
2233 return 1;
2234 }
2235
2236 /* Resort TYPE_METHOD_VEC because pointers have been reordered. */
2237
2238 void
2239 resort_type_method_vec (void* obj,
2240 void* /*orig_obj*/,
2241 gt_pointer_operator new_value,
2242 void* cookie)
2243 {
2244 vec<tree, va_gc> *method_vec = (vec<tree, va_gc> *) obj;
2245 int len = vec_safe_length (method_vec);
2246 size_t slot;
2247 tree fn;
2248
2249 /* The type conversion ops have to live at the front of the vec, so we
2250 can't sort them. */
2251 for (slot = CLASSTYPE_FIRST_CONVERSION_SLOT;
2252 vec_safe_iterate (method_vec, slot, &fn);
2253 ++slot)
2254 if (!DECL_CONV_FN_P (OVL_CURRENT (fn)))
2255 break;
2256
2257 if (len - slot > 1)
2258 {
2259 resort_data.new_value = new_value;
2260 resort_data.cookie = cookie;
2261 qsort (method_vec->address () + slot, len - slot, sizeof (tree),
2262 resort_method_name_cmp);
2263 }
2264 }
2265
2266 /* Warn about duplicate methods in fn_fields.
2267
2268 Sort methods that are not special (i.e., constructors, destructors,
2269 and type conversion operators) so that we can find them faster in
2270 search. */
2271
2272 static void
2273 finish_struct_methods (tree t)
2274 {
2275 tree fn_fields;
2276 vec<tree, va_gc> *method_vec;
2277 int slot, len;
2278
2279 method_vec = CLASSTYPE_METHOD_VEC (t);
2280 if (!method_vec)
2281 return;
2282
2283 len = method_vec->length ();
2284
2285 /* Clear DECL_IN_AGGR_P for all functions. */
2286 for (fn_fields = TYPE_METHODS (t); fn_fields;
2287 fn_fields = DECL_CHAIN (fn_fields))
2288 DECL_IN_AGGR_P (fn_fields) = 0;
2289
2290 /* Issue warnings about private constructors and such. If there are
2291 no methods, then some public defaults are generated. */
2292 maybe_warn_about_overly_private_class (t);
2293
2294 /* The type conversion ops have to live at the front of the vec, so we
2295 can't sort them. */
2296 for (slot = CLASSTYPE_FIRST_CONVERSION_SLOT;
2297 method_vec->iterate (slot, &fn_fields);
2298 ++slot)
2299 if (!DECL_CONV_FN_P (OVL_CURRENT (fn_fields)))
2300 break;
2301 if (len - slot > 1)
2302 qsort (method_vec->address () + slot,
2303 len-slot, sizeof (tree), method_name_cmp);
2304 }
2305
2306 /* Make BINFO's vtable have N entries, including RTTI entries,
2307 vbase and vcall offsets, etc. Set its type and call the back end
2308 to lay it out. */
2309
2310 static void
2311 layout_vtable_decl (tree binfo, int n)
2312 {
2313 tree atype;
2314 tree vtable;
2315
2316 atype = build_array_of_n_type (vtable_entry_type, n);
2317 layout_type (atype);
2318
2319 /* We may have to grow the vtable. */
2320 vtable = get_vtbl_decl_for_binfo (binfo);
2321 if (!same_type_p (TREE_TYPE (vtable), atype))
2322 {
2323 TREE_TYPE (vtable) = atype;
2324 DECL_SIZE (vtable) = DECL_SIZE_UNIT (vtable) = NULL_TREE;
2325 layout_decl (vtable, 0);
2326 }
2327 }
2328
2329 /* True iff FNDECL and BASE_FNDECL (both non-static member functions)
2330 have the same signature. */
2331
2332 int
2333 same_signature_p (const_tree fndecl, const_tree base_fndecl)
2334 {
2335 /* One destructor overrides another if they are the same kind of
2336 destructor. */
2337 if (DECL_DESTRUCTOR_P (base_fndecl) && DECL_DESTRUCTOR_P (fndecl)
2338 && special_function_p (base_fndecl) == special_function_p (fndecl))
2339 return 1;
2340 /* But a non-destructor never overrides a destructor, nor vice
2341 versa, nor do different kinds of destructors override
2342 one-another. For example, a complete object destructor does not
2343 override a deleting destructor. */
2344 if (DECL_DESTRUCTOR_P (base_fndecl) || DECL_DESTRUCTOR_P (fndecl))
2345 return 0;
2346
2347 if (DECL_NAME (fndecl) == DECL_NAME (base_fndecl)
2348 || (DECL_CONV_FN_P (fndecl)
2349 && DECL_CONV_FN_P (base_fndecl)
2350 && same_type_p (DECL_CONV_FN_TYPE (fndecl),
2351 DECL_CONV_FN_TYPE (base_fndecl))))
2352 {
2353 tree fntype = TREE_TYPE (fndecl);
2354 tree base_fntype = TREE_TYPE (base_fndecl);
2355 if (type_memfn_quals (fntype) == type_memfn_quals (base_fntype)
2356 && type_memfn_rqual (fntype) == type_memfn_rqual (base_fntype)
2357 && compparms (FUNCTION_FIRST_USER_PARMTYPE (fndecl),
2358 FUNCTION_FIRST_USER_PARMTYPE (base_fndecl)))
2359 return 1;
2360 }
2361 return 0;
2362 }
2363
2364 /* Returns TRUE if DERIVED is a binfo containing the binfo BASE as a
2365 subobject. */
2366
2367 static bool
2368 base_derived_from (tree derived, tree base)
2369 {
2370 tree probe;
2371
2372 for (probe = base; probe; probe = BINFO_INHERITANCE_CHAIN (probe))
2373 {
2374 if (probe == derived)
2375 return true;
2376 else if (BINFO_VIRTUAL_P (probe))
2377 /* If we meet a virtual base, we can't follow the inheritance
2378 any more. See if the complete type of DERIVED contains
2379 such a virtual base. */
2380 return (binfo_for_vbase (BINFO_TYPE (probe), BINFO_TYPE (derived))
2381 != NULL_TREE);
2382 }
2383 return false;
2384 }
2385
2386 typedef struct find_final_overrider_data_s {
2387 /* The function for which we are trying to find a final overrider. */
2388 tree fn;
2389 /* The base class in which the function was declared. */
2390 tree declaring_base;
2391 /* The candidate overriders. */
2392 tree candidates;
2393 /* Path to most derived. */
2394 vec<tree> path;
2395 } find_final_overrider_data;
2396
2397 /* Add the overrider along the current path to FFOD->CANDIDATES.
2398 Returns true if an overrider was found; false otherwise. */
2399
2400 static bool
2401 dfs_find_final_overrider_1 (tree binfo,
2402 find_final_overrider_data *ffod,
2403 unsigned depth)
2404 {
2405 tree method;
2406
2407 /* If BINFO is not the most derived type, try a more derived class.
2408 A definition there will overrider a definition here. */
2409 if (depth)
2410 {
2411 depth--;
2412 if (dfs_find_final_overrider_1
2413 (ffod->path[depth], ffod, depth))
2414 return true;
2415 }
2416
2417 method = look_for_overrides_here (BINFO_TYPE (binfo), ffod->fn);
2418 if (method)
2419 {
2420 tree *candidate = &ffod->candidates;
2421
2422 /* Remove any candidates overridden by this new function. */
2423 while (*candidate)
2424 {
2425 /* If *CANDIDATE overrides METHOD, then METHOD
2426 cannot override anything else on the list. */
2427 if (base_derived_from (TREE_VALUE (*candidate), binfo))
2428 return true;
2429 /* If METHOD overrides *CANDIDATE, remove *CANDIDATE. */
2430 if (base_derived_from (binfo, TREE_VALUE (*candidate)))
2431 *candidate = TREE_CHAIN (*candidate);
2432 else
2433 candidate = &TREE_CHAIN (*candidate);
2434 }
2435
2436 /* Add the new function. */
2437 ffod->candidates = tree_cons (method, binfo, ffod->candidates);
2438 return true;
2439 }
2440
2441 return false;
2442 }
2443
2444 /* Called from find_final_overrider via dfs_walk. */
2445
2446 static tree
2447 dfs_find_final_overrider_pre (tree binfo, void *data)
2448 {
2449 find_final_overrider_data *ffod = (find_final_overrider_data *) data;
2450
2451 if (binfo == ffod->declaring_base)
2452 dfs_find_final_overrider_1 (binfo, ffod, ffod->path.length ());
2453 ffod->path.safe_push (binfo);
2454
2455 return NULL_TREE;
2456 }
2457
2458 static tree
2459 dfs_find_final_overrider_post (tree /*binfo*/, void *data)
2460 {
2461 find_final_overrider_data *ffod = (find_final_overrider_data *) data;
2462 ffod->path.pop ();
2463
2464 return NULL_TREE;
2465 }
2466
2467 /* Returns a TREE_LIST whose TREE_PURPOSE is the final overrider for
2468 FN and whose TREE_VALUE is the binfo for the base where the
2469 overriding occurs. BINFO (in the hierarchy dominated by the binfo
2470 DERIVED) is the base object in which FN is declared. */
2471
2472 static tree
2473 find_final_overrider (tree derived, tree binfo, tree fn)
2474 {
2475 find_final_overrider_data ffod;
2476
2477 /* Getting this right is a little tricky. This is valid:
2478
2479 struct S { virtual void f (); };
2480 struct T { virtual void f (); };
2481 struct U : public S, public T { };
2482
2483 even though calling `f' in `U' is ambiguous. But,
2484
2485 struct R { virtual void f(); };
2486 struct S : virtual public R { virtual void f (); };
2487 struct T : virtual public R { virtual void f (); };
2488 struct U : public S, public T { };
2489
2490 is not -- there's no way to decide whether to put `S::f' or
2491 `T::f' in the vtable for `R'.
2492
2493 The solution is to look at all paths to BINFO. If we find
2494 different overriders along any two, then there is a problem. */
2495 if (DECL_THUNK_P (fn))
2496 fn = THUNK_TARGET (fn);
2497
2498 /* Determine the depth of the hierarchy. */
2499 ffod.fn = fn;
2500 ffod.declaring_base = binfo;
2501 ffod.candidates = NULL_TREE;
2502 ffod.path.create (30);
2503
2504 dfs_walk_all (derived, dfs_find_final_overrider_pre,
2505 dfs_find_final_overrider_post, &ffod);
2506
2507 ffod.path.release ();
2508
2509 /* If there was no winner, issue an error message. */
2510 if (!ffod.candidates || TREE_CHAIN (ffod.candidates))
2511 return error_mark_node;
2512
2513 return ffod.candidates;
2514 }
2515
2516 /* Return the index of the vcall offset for FN when TYPE is used as a
2517 virtual base. */
2518
2519 static tree
2520 get_vcall_index (tree fn, tree type)
2521 {
2522 vec<tree_pair_s, va_gc> *indices = CLASSTYPE_VCALL_INDICES (type);
2523 tree_pair_p p;
2524 unsigned ix;
2525
2526 FOR_EACH_VEC_SAFE_ELT (indices, ix, p)
2527 if ((DECL_DESTRUCTOR_P (fn) && DECL_DESTRUCTOR_P (p->purpose))
2528 || same_signature_p (fn, p->purpose))
2529 return p->value;
2530
2531 /* There should always be an appropriate index. */
2532 gcc_unreachable ();
2533 }
2534
2535 /* Update an entry in the vtable for BINFO, which is in the hierarchy
2536 dominated by T. FN is the old function; VIRTUALS points to the
2537 corresponding position in the new BINFO_VIRTUALS list. IX is the index
2538 of that entry in the list. */
2539
2540 static void
2541 update_vtable_entry_for_fn (tree t, tree binfo, tree fn, tree* virtuals,
2542 unsigned ix)
2543 {
2544 tree b;
2545 tree overrider;
2546 tree delta;
2547 tree virtual_base;
2548 tree first_defn;
2549 tree overrider_fn, overrider_target;
2550 tree target_fn = DECL_THUNK_P (fn) ? THUNK_TARGET (fn) : fn;
2551 tree over_return, base_return;
2552 bool lost = false;
2553
2554 /* Find the nearest primary base (possibly binfo itself) which defines
2555 this function; this is the class the caller will convert to when
2556 calling FN through BINFO. */
2557 for (b = binfo; ; b = get_primary_binfo (b))
2558 {
2559 gcc_assert (b);
2560 if (look_for_overrides_here (BINFO_TYPE (b), target_fn))
2561 break;
2562
2563 /* The nearest definition is from a lost primary. */
2564 if (BINFO_LOST_PRIMARY_P (b))
2565 lost = true;
2566 }
2567 first_defn = b;
2568
2569 /* Find the final overrider. */
2570 overrider = find_final_overrider (TYPE_BINFO (t), b, target_fn);
2571 if (overrider == error_mark_node)
2572 {
2573 error ("no unique final overrider for %qD in %qT", target_fn, t);
2574 return;
2575 }
2576 overrider_target = overrider_fn = TREE_PURPOSE (overrider);
2577
2578 /* Check for adjusting covariant return types. */
2579 over_return = TREE_TYPE (TREE_TYPE (overrider_target));
2580 base_return = TREE_TYPE (TREE_TYPE (target_fn));
2581
2582 if (POINTER_TYPE_P (over_return)
2583 && TREE_CODE (over_return) == TREE_CODE (base_return)
2584 && CLASS_TYPE_P (TREE_TYPE (over_return))
2585 && CLASS_TYPE_P (TREE_TYPE (base_return))
2586 /* If the overrider is invalid, don't even try. */
2587 && !DECL_INVALID_OVERRIDER_P (overrider_target))
2588 {
2589 /* If FN is a covariant thunk, we must figure out the adjustment
2590 to the final base FN was converting to. As OVERRIDER_TARGET might
2591 also be converting to the return type of FN, we have to
2592 combine the two conversions here. */
2593 tree fixed_offset, virtual_offset;
2594
2595 over_return = TREE_TYPE (over_return);
2596 base_return = TREE_TYPE (base_return);
2597
2598 if (DECL_THUNK_P (fn))
2599 {
2600 gcc_assert (DECL_RESULT_THUNK_P (fn));
2601 fixed_offset = ssize_int (THUNK_FIXED_OFFSET (fn));
2602 virtual_offset = THUNK_VIRTUAL_OFFSET (fn);
2603 }
2604 else
2605 fixed_offset = virtual_offset = NULL_TREE;
2606
2607 if (virtual_offset)
2608 /* Find the equivalent binfo within the return type of the
2609 overriding function. We will want the vbase offset from
2610 there. */
2611 virtual_offset = binfo_for_vbase (BINFO_TYPE (virtual_offset),
2612 over_return);
2613 else if (!same_type_ignoring_top_level_qualifiers_p
2614 (over_return, base_return))
2615 {
2616 /* There was no existing virtual thunk (which takes
2617 precedence). So find the binfo of the base function's
2618 return type within the overriding function's return type.
2619 We cannot call lookup base here, because we're inside a
2620 dfs_walk, and will therefore clobber the BINFO_MARKED
2621 flags. Fortunately we know the covariancy is valid (it
2622 has already been checked), so we can just iterate along
2623 the binfos, which have been chained in inheritance graph
2624 order. Of course it is lame that we have to repeat the
2625 search here anyway -- we should really be caching pieces
2626 of the vtable and avoiding this repeated work. */
2627 tree thunk_binfo, base_binfo;
2628
2629 /* Find the base binfo within the overriding function's
2630 return type. We will always find a thunk_binfo, except
2631 when the covariancy is invalid (which we will have
2632 already diagnosed). */
2633 for (base_binfo = TYPE_BINFO (base_return),
2634 thunk_binfo = TYPE_BINFO (over_return);
2635 thunk_binfo;
2636 thunk_binfo = TREE_CHAIN (thunk_binfo))
2637 if (SAME_BINFO_TYPE_P (BINFO_TYPE (thunk_binfo),
2638 BINFO_TYPE (base_binfo)))
2639 break;
2640
2641 /* See if virtual inheritance is involved. */
2642 for (virtual_offset = thunk_binfo;
2643 virtual_offset;
2644 virtual_offset = BINFO_INHERITANCE_CHAIN (virtual_offset))
2645 if (BINFO_VIRTUAL_P (virtual_offset))
2646 break;
2647
2648 if (virtual_offset
2649 || (thunk_binfo && !BINFO_OFFSET_ZEROP (thunk_binfo)))
2650 {
2651 tree offset = convert (ssizetype, BINFO_OFFSET (thunk_binfo));
2652
2653 if (virtual_offset)
2654 {
2655 /* We convert via virtual base. Adjust the fixed
2656 offset to be from there. */
2657 offset =
2658 size_diffop (offset,
2659 convert (ssizetype,
2660 BINFO_OFFSET (virtual_offset)));
2661 }
2662 if (fixed_offset)
2663 /* There was an existing fixed offset, this must be
2664 from the base just converted to, and the base the
2665 FN was thunking to. */
2666 fixed_offset = size_binop (PLUS_EXPR, fixed_offset, offset);
2667 else
2668 fixed_offset = offset;
2669 }
2670 }
2671
2672 if (fixed_offset || virtual_offset)
2673 /* Replace the overriding function with a covariant thunk. We
2674 will emit the overriding function in its own slot as
2675 well. */
2676 overrider_fn = make_thunk (overrider_target, /*this_adjusting=*/0,
2677 fixed_offset, virtual_offset);
2678 }
2679 else
2680 gcc_assert (DECL_INVALID_OVERRIDER_P (overrider_target) ||
2681 !DECL_THUNK_P (fn));
2682
2683 /* If we need a covariant thunk, then we may need to adjust first_defn.
2684 The ABI specifies that the thunks emitted with a function are
2685 determined by which bases the function overrides, so we need to be
2686 sure that we're using a thunk for some overridden base; even if we
2687 know that the necessary this adjustment is zero, there may not be an
2688 appropriate zero-this-adjusment thunk for us to use since thunks for
2689 overriding virtual bases always use the vcall offset.
2690
2691 Furthermore, just choosing any base that overrides this function isn't
2692 quite right, as this slot won't be used for calls through a type that
2693 puts a covariant thunk here. Calling the function through such a type
2694 will use a different slot, and that slot is the one that determines
2695 the thunk emitted for that base.
2696
2697 So, keep looking until we find the base that we're really overriding
2698 in this slot: the nearest primary base that doesn't use a covariant
2699 thunk in this slot. */
2700 if (overrider_target != overrider_fn)
2701 {
2702 if (BINFO_TYPE (b) == DECL_CONTEXT (overrider_target))
2703 /* We already know that the overrider needs a covariant thunk. */
2704 b = get_primary_binfo (b);
2705 for (; ; b = get_primary_binfo (b))
2706 {
2707 tree main_binfo = TYPE_BINFO (BINFO_TYPE (b));
2708 tree bv = chain_index (ix, BINFO_VIRTUALS (main_binfo));
2709 if (!DECL_THUNK_P (TREE_VALUE (bv)))
2710 break;
2711 if (BINFO_LOST_PRIMARY_P (b))
2712 lost = true;
2713 }
2714 first_defn = b;
2715 }
2716
2717 /* Assume that we will produce a thunk that convert all the way to
2718 the final overrider, and not to an intermediate virtual base. */
2719 virtual_base = NULL_TREE;
2720
2721 /* See if we can convert to an intermediate virtual base first, and then
2722 use the vcall offset located there to finish the conversion. */
2723 for (; b; b = BINFO_INHERITANCE_CHAIN (b))
2724 {
2725 /* If we find the final overrider, then we can stop
2726 walking. */
2727 if (SAME_BINFO_TYPE_P (BINFO_TYPE (b),
2728 BINFO_TYPE (TREE_VALUE (overrider))))
2729 break;
2730
2731 /* If we find a virtual base, and we haven't yet found the
2732 overrider, then there is a virtual base between the
2733 declaring base (first_defn) and the final overrider. */
2734 if (BINFO_VIRTUAL_P (b))
2735 {
2736 virtual_base = b;
2737 break;
2738 }
2739 }
2740
2741 /* Compute the constant adjustment to the `this' pointer. The
2742 `this' pointer, when this function is called, will point at BINFO
2743 (or one of its primary bases, which are at the same offset). */
2744 if (virtual_base)
2745 /* The `this' pointer needs to be adjusted from the declaration to
2746 the nearest virtual base. */
2747 delta = size_diffop_loc (input_location,
2748 convert (ssizetype, BINFO_OFFSET (virtual_base)),
2749 convert (ssizetype, BINFO_OFFSET (first_defn)));
2750 else if (lost)
2751 /* If the nearest definition is in a lost primary, we don't need an
2752 entry in our vtable. Except possibly in a constructor vtable,
2753 if we happen to get our primary back. In that case, the offset
2754 will be zero, as it will be a primary base. */
2755 delta = size_zero_node;
2756 else
2757 /* The `this' pointer needs to be adjusted from pointing to
2758 BINFO to pointing at the base where the final overrider
2759 appears. */
2760 delta = size_diffop_loc (input_location,
2761 convert (ssizetype,
2762 BINFO_OFFSET (TREE_VALUE (overrider))),
2763 convert (ssizetype, BINFO_OFFSET (binfo)));
2764
2765 modify_vtable_entry (t, binfo, overrider_fn, delta, virtuals);
2766
2767 if (virtual_base)
2768 BV_VCALL_INDEX (*virtuals)
2769 = get_vcall_index (overrider_target, BINFO_TYPE (virtual_base));
2770 else
2771 BV_VCALL_INDEX (*virtuals) = NULL_TREE;
2772
2773 BV_LOST_PRIMARY (*virtuals) = lost;
2774 }
2775
2776 /* Called from modify_all_vtables via dfs_walk. */
2777
2778 static tree
2779 dfs_modify_vtables (tree binfo, void* data)
2780 {
2781 tree t = (tree) data;
2782 tree virtuals;
2783 tree old_virtuals;
2784 unsigned ix;
2785
2786 if (!TYPE_CONTAINS_VPTR_P (BINFO_TYPE (binfo)))
2787 /* A base without a vtable needs no modification, and its bases
2788 are uninteresting. */
2789 return dfs_skip_bases;
2790
2791 if (SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), t)
2792 && !CLASSTYPE_HAS_PRIMARY_BASE_P (t))
2793 /* Don't do the primary vtable, if it's new. */
2794 return NULL_TREE;
2795
2796 if (BINFO_PRIMARY_P (binfo) && !BINFO_VIRTUAL_P (binfo))
2797 /* There's no need to modify the vtable for a non-virtual primary
2798 base; we're not going to use that vtable anyhow. We do still
2799 need to do this for virtual primary bases, as they could become
2800 non-primary in a construction vtable. */
2801 return NULL_TREE;
2802
2803 make_new_vtable (t, binfo);
2804
2805 /* Now, go through each of the virtual functions in the virtual
2806 function table for BINFO. Find the final overrider, and update
2807 the BINFO_VIRTUALS list appropriately. */
2808 for (ix = 0, virtuals = BINFO_VIRTUALS (binfo),
2809 old_virtuals = BINFO_VIRTUALS (TYPE_BINFO (BINFO_TYPE (binfo)));
2810 virtuals;
2811 ix++, virtuals = TREE_CHAIN (virtuals),
2812 old_virtuals = TREE_CHAIN (old_virtuals))
2813 update_vtable_entry_for_fn (t,
2814 binfo,
2815 BV_FN (old_virtuals),
2816 &virtuals, ix);
2817
2818 return NULL_TREE;
2819 }
2820
2821 /* Update all of the primary and secondary vtables for T. Create new
2822 vtables as required, and initialize their RTTI information. Each
2823 of the functions in VIRTUALS is declared in T and may override a
2824 virtual function from a base class; find and modify the appropriate
2825 entries to point to the overriding functions. Returns a list, in
2826 declaration order, of the virtual functions that are declared in T,
2827 but do not appear in the primary base class vtable, and which
2828 should therefore be appended to the end of the vtable for T. */
2829
2830 static tree
2831 modify_all_vtables (tree t, tree virtuals)
2832 {
2833 tree binfo = TYPE_BINFO (t);
2834 tree *fnsp;
2835
2836 /* Mangle the vtable name before entering dfs_walk (c++/51884). */
2837 if (TYPE_CONTAINS_VPTR_P (t))
2838 get_vtable_decl (t, false);
2839
2840 /* Update all of the vtables. */
2841 dfs_walk_once (binfo, dfs_modify_vtables, NULL, t);
2842
2843 /* Add virtual functions not already in our primary vtable. These
2844 will be both those introduced by this class, and those overridden
2845 from secondary bases. It does not include virtuals merely
2846 inherited from secondary bases. */
2847 for (fnsp = &virtuals; *fnsp; )
2848 {
2849 tree fn = TREE_VALUE (*fnsp);
2850
2851 if (!value_member (fn, BINFO_VIRTUALS (binfo))
2852 || DECL_VINDEX (fn) == error_mark_node)
2853 {
2854 /* We don't need to adjust the `this' pointer when
2855 calling this function. */
2856 BV_DELTA (*fnsp) = integer_zero_node;
2857 BV_VCALL_INDEX (*fnsp) = NULL_TREE;
2858
2859 /* This is a function not already in our vtable. Keep it. */
2860 fnsp = &TREE_CHAIN (*fnsp);
2861 }
2862 else
2863 /* We've already got an entry for this function. Skip it. */
2864 *fnsp = TREE_CHAIN (*fnsp);
2865 }
2866
2867 return virtuals;
2868 }
2869
2870 /* Get the base virtual function declarations in T that have the
2871 indicated NAME. */
2872
2873 static void
2874 get_basefndecls (tree name, tree t, vec<tree> *base_fndecls)
2875 {
2876 tree methods;
2877 int n_baseclasses = BINFO_N_BASE_BINFOS (TYPE_BINFO (t));
2878 int i;
2879
2880 /* Find virtual functions in T with the indicated NAME. */
2881 i = lookup_fnfields_1 (t, name);
2882 bool found_decls = false;
2883 if (i != -1)
2884 for (methods = (*CLASSTYPE_METHOD_VEC (t))[i];
2885 methods;
2886 methods = OVL_NEXT (methods))
2887 {
2888 tree method = OVL_CURRENT (methods);
2889
2890 if (TREE_CODE (method) == FUNCTION_DECL
2891 && DECL_VINDEX (method))
2892 {
2893 base_fndecls->safe_push (method);
2894 found_decls = true;
2895 }
2896 }
2897
2898 if (found_decls)
2899 return;
2900
2901 for (i = 0; i < n_baseclasses; i++)
2902 {
2903 tree basetype = BINFO_TYPE (BINFO_BASE_BINFO (TYPE_BINFO (t), i));
2904 get_basefndecls (name, basetype, base_fndecls);
2905 }
2906 }
2907
2908 /* If this declaration supersedes the declaration of
2909 a method declared virtual in the base class, then
2910 mark this field as being virtual as well. */
2911
2912 void
2913 check_for_override (tree decl, tree ctype)
2914 {
2915 bool overrides_found = false;
2916 if (TREE_CODE (decl) == TEMPLATE_DECL)
2917 /* In [temp.mem] we have:
2918
2919 A specialization of a member function template does not
2920 override a virtual function from a base class. */
2921 return;
2922 if ((DECL_DESTRUCTOR_P (decl)
2923 || IDENTIFIER_VIRTUAL_P (DECL_NAME (decl))
2924 || DECL_CONV_FN_P (decl))
2925 && look_for_overrides (ctype, decl)
2926 && !DECL_STATIC_FUNCTION_P (decl))
2927 /* Set DECL_VINDEX to a value that is neither an INTEGER_CST nor
2928 the error_mark_node so that we know it is an overriding
2929 function. */
2930 {
2931 DECL_VINDEX (decl) = decl;
2932 overrides_found = true;
2933 if (warn_override && !DECL_OVERRIDE_P (decl)
2934 && !DECL_DESTRUCTOR_P (decl))
2935 warning_at (DECL_SOURCE_LOCATION (decl), OPT_Wsuggest_override,
2936 "%q+D can be marked override", decl);
2937 }
2938
2939 if (DECL_VIRTUAL_P (decl))
2940 {
2941 if (!DECL_VINDEX (decl))
2942 DECL_VINDEX (decl) = error_mark_node;
2943 IDENTIFIER_VIRTUAL_P (DECL_NAME (decl)) = 1;
2944 if (DECL_DESTRUCTOR_P (decl))
2945 TYPE_HAS_NONTRIVIAL_DESTRUCTOR (ctype) = true;
2946 }
2947 else if (DECL_FINAL_P (decl))
2948 error ("%q+#D marked %<final%>, but is not virtual", decl);
2949 if (DECL_OVERRIDE_P (decl) && !overrides_found)
2950 error ("%q+#D marked %<override%>, but does not override", decl);
2951 }
2952
2953 /* Warn about hidden virtual functions that are not overridden in t.
2954 We know that constructors and destructors don't apply. */
2955
2956 static void
2957 warn_hidden (tree t)
2958 {
2959 vec<tree, va_gc> *method_vec = CLASSTYPE_METHOD_VEC (t);
2960 tree fns;
2961 size_t i;
2962
2963 /* We go through each separately named virtual function. */
2964 for (i = CLASSTYPE_FIRST_CONVERSION_SLOT;
2965 vec_safe_iterate (method_vec, i, &fns);
2966 ++i)
2967 {
2968 tree fn;
2969 tree name;
2970 tree fndecl;
2971 tree base_binfo;
2972 tree binfo;
2973 int j;
2974
2975 /* All functions in this slot in the CLASSTYPE_METHOD_VEC will
2976 have the same name. Figure out what name that is. */
2977 name = DECL_NAME (OVL_CURRENT (fns));
2978 /* There are no possibly hidden functions yet. */
2979 auto_vec<tree, 20> base_fndecls;
2980 /* Iterate through all of the base classes looking for possibly
2981 hidden functions. */
2982 for (binfo = TYPE_BINFO (t), j = 0;
2983 BINFO_BASE_ITERATE (binfo, j, base_binfo); j++)
2984 {
2985 tree basetype = BINFO_TYPE (base_binfo);
2986 get_basefndecls (name, basetype, &base_fndecls);
2987 }
2988
2989 /* If there are no functions to hide, continue. */
2990 if (base_fndecls.is_empty ())
2991 continue;
2992
2993 /* Remove any overridden functions. */
2994 for (fn = fns; fn; fn = OVL_NEXT (fn))
2995 {
2996 fndecl = OVL_CURRENT (fn);
2997 if (TREE_CODE (fndecl) == FUNCTION_DECL
2998 && DECL_VINDEX (fndecl))
2999 {
3000 /* If the method from the base class has the same
3001 signature as the method from the derived class, it
3002 has been overridden. */
3003 for (size_t k = 0; k < base_fndecls.length (); k++)
3004 if (base_fndecls[k]
3005 && same_signature_p (fndecl, base_fndecls[k]))
3006 base_fndecls[k] = NULL_TREE;
3007 }
3008 }
3009
3010 /* Now give a warning for all base functions without overriders,
3011 as they are hidden. */
3012 size_t k;
3013 tree base_fndecl;
3014 FOR_EACH_VEC_ELT (base_fndecls, k, base_fndecl)
3015 if (base_fndecl)
3016 {
3017 /* Here we know it is a hider, and no overrider exists. */
3018 warning (OPT_Woverloaded_virtual, "%q+D was hidden", base_fndecl);
3019 warning (OPT_Woverloaded_virtual, " by %q+D", fns);
3020 }
3021 }
3022 }
3023
3024 /* Recursive helper for finish_struct_anon. */
3025
3026 static void
3027 finish_struct_anon_r (tree field, bool complain)
3028 {
3029 bool is_union = TREE_CODE (TREE_TYPE (field)) == UNION_TYPE;
3030 tree elt = TYPE_FIELDS (TREE_TYPE (field));
3031 for (; elt; elt = DECL_CHAIN (elt))
3032 {
3033 /* We're generally only interested in entities the user
3034 declared, but we also find nested classes by noticing
3035 the TYPE_DECL that we create implicitly. You're
3036 allowed to put one anonymous union inside another,
3037 though, so we explicitly tolerate that. We use
3038 TYPE_ANONYMOUS_P rather than ANON_AGGR_TYPE_P so that
3039 we also allow unnamed types used for defining fields. */
3040 if (DECL_ARTIFICIAL (elt)
3041 && (!DECL_IMPLICIT_TYPEDEF_P (elt)
3042 || TYPE_ANONYMOUS_P (TREE_TYPE (elt))))
3043 continue;
3044
3045 if (TREE_CODE (elt) != FIELD_DECL)
3046 {
3047 /* We already complained about static data members in
3048 finish_static_data_member_decl. */
3049 if (complain && TREE_CODE (elt) != VAR_DECL)
3050 {
3051 if (is_union)
3052 permerror (input_location,
3053 "%q+#D invalid; an anonymous union can "
3054 "only have non-static data members", elt);
3055 else
3056 permerror (input_location,
3057 "%q+#D invalid; an anonymous struct can "
3058 "only have non-static data members", elt);
3059 }
3060 continue;
3061 }
3062
3063 if (complain)
3064 {
3065 if (TREE_PRIVATE (elt))
3066 {
3067 if (is_union)
3068 permerror (input_location,
3069 "private member %q+#D in anonymous union", elt);
3070 else
3071 permerror (input_location,
3072 "private member %q+#D in anonymous struct", elt);
3073 }
3074 else if (TREE_PROTECTED (elt))
3075 {
3076 if (is_union)
3077 permerror (input_location,
3078 "protected member %q+#D in anonymous union", elt);
3079 else
3080 permerror (input_location,
3081 "protected member %q+#D in anonymous struct", elt);
3082 }
3083 }
3084
3085 TREE_PRIVATE (elt) = TREE_PRIVATE (field);
3086 TREE_PROTECTED (elt) = TREE_PROTECTED (field);
3087
3088 /* Recurse into the anonymous aggregates to handle correctly
3089 access control (c++/24926):
3090
3091 class A {
3092 union {
3093 union {
3094 int i;
3095 };
3096 };
3097 };
3098
3099 int j=A().i; */
3100 if (DECL_NAME (elt) == NULL_TREE
3101 && ANON_AGGR_TYPE_P (TREE_TYPE (elt)))
3102 finish_struct_anon_r (elt, /*complain=*/false);
3103 }
3104 }
3105
3106 /* Check for things that are invalid. There are probably plenty of other
3107 things we should check for also. */
3108
3109 static void
3110 finish_struct_anon (tree t)
3111 {
3112 for (tree field = TYPE_FIELDS (t); field; field = DECL_CHAIN (field))
3113 {
3114 if (TREE_STATIC (field))
3115 continue;
3116 if (TREE_CODE (field) != FIELD_DECL)
3117 continue;
3118
3119 if (DECL_NAME (field) == NULL_TREE
3120 && ANON_AGGR_TYPE_P (TREE_TYPE (field)))
3121 finish_struct_anon_r (field, /*complain=*/true);
3122 }
3123 }
3124
3125 /* Add T to CLASSTYPE_DECL_LIST of current_class_type which
3126 will be used later during class template instantiation.
3127 When FRIEND_P is zero, T can be a static member data (VAR_DECL),
3128 a non-static member data (FIELD_DECL), a member function
3129 (FUNCTION_DECL), a nested type (RECORD_TYPE, ENUM_TYPE),
3130 a typedef (TYPE_DECL) or a member class template (TEMPLATE_DECL)
3131 When FRIEND_P is nonzero, T is either a friend class
3132 (RECORD_TYPE, TEMPLATE_DECL) or a friend function
3133 (FUNCTION_DECL, TEMPLATE_DECL). */
3134
3135 void
3136 maybe_add_class_template_decl_list (tree type, tree t, int friend_p)
3137 {
3138 /* Save some memory by not creating TREE_LIST if TYPE is not template. */
3139 if (CLASSTYPE_TEMPLATE_INFO (type))
3140 CLASSTYPE_DECL_LIST (type)
3141 = tree_cons (friend_p ? NULL_TREE : type,
3142 t, CLASSTYPE_DECL_LIST (type));
3143 }
3144
3145 /* This function is called from declare_virt_assop_and_dtor via
3146 dfs_walk_all.
3147
3148 DATA is a type that direcly or indirectly inherits the base
3149 represented by BINFO. If BINFO contains a virtual assignment [copy
3150 assignment or move assigment] operator or a virtual constructor,
3151 declare that function in DATA if it hasn't been already declared. */
3152
3153 static tree
3154 dfs_declare_virt_assop_and_dtor (tree binfo, void *data)
3155 {
3156 tree bv, fn, t = (tree)data;
3157 tree opname = ansi_assopname (NOP_EXPR);
3158
3159 gcc_assert (t && CLASS_TYPE_P (t));
3160 gcc_assert (binfo && TREE_CODE (binfo) == TREE_BINFO);
3161
3162 if (!TYPE_CONTAINS_VPTR_P (BINFO_TYPE (binfo)))
3163 /* A base without a vtable needs no modification, and its bases
3164 are uninteresting. */
3165 return dfs_skip_bases;
3166
3167 if (BINFO_PRIMARY_P (binfo))
3168 /* If this is a primary base, then we have already looked at the
3169 virtual functions of its vtable. */
3170 return NULL_TREE;
3171
3172 for (bv = BINFO_VIRTUALS (binfo); bv; bv = TREE_CHAIN (bv))
3173 {
3174 fn = BV_FN (bv);
3175
3176 if (DECL_NAME (fn) == opname)
3177 {
3178 if (CLASSTYPE_LAZY_COPY_ASSIGN (t))
3179 lazily_declare_fn (sfk_copy_assignment, t);
3180 if (CLASSTYPE_LAZY_MOVE_ASSIGN (t))
3181 lazily_declare_fn (sfk_move_assignment, t);
3182 }
3183 else if (DECL_DESTRUCTOR_P (fn)
3184 && CLASSTYPE_LAZY_DESTRUCTOR (t))
3185 lazily_declare_fn (sfk_destructor, t);
3186 }
3187
3188 return NULL_TREE;
3189 }
3190
3191 /* If the class type T has a direct or indirect base that contains a
3192 virtual assignment operator or a virtual destructor, declare that
3193 function in T if it hasn't been already declared. */
3194
3195 static void
3196 declare_virt_assop_and_dtor (tree t)
3197 {
3198 if (!(TYPE_POLYMORPHIC_P (t)
3199 && (CLASSTYPE_LAZY_COPY_ASSIGN (t)
3200 || CLASSTYPE_LAZY_MOVE_ASSIGN (t)
3201 || CLASSTYPE_LAZY_DESTRUCTOR (t))))
3202 return;
3203
3204 dfs_walk_all (TYPE_BINFO (t),
3205 dfs_declare_virt_assop_and_dtor,
3206 NULL, t);
3207 }
3208
3209 /* Declare the inheriting constructor for class T inherited from base
3210 constructor CTOR with the parameter array PARMS of size NPARMS. */
3211
3212 static void
3213 one_inheriting_sig (tree t, tree ctor, tree *parms, int nparms)
3214 {
3215 /* We don't declare an inheriting ctor that would be a default,
3216 copy or move ctor for derived or base. */
3217 if (nparms == 0)
3218 return;
3219 if (nparms == 1
3220 && TREE_CODE (parms[0]) == REFERENCE_TYPE)
3221 {
3222 tree parm = TYPE_MAIN_VARIANT (TREE_TYPE (parms[0]));
3223 if (parm == t || parm == DECL_CONTEXT (ctor))
3224 return;
3225 }
3226
3227 tree parmlist = void_list_node;
3228 for (int i = nparms - 1; i >= 0; i--)
3229 parmlist = tree_cons (NULL_TREE, parms[i], parmlist);
3230 tree fn = implicitly_declare_fn (sfk_inheriting_constructor,
3231 t, false, ctor, parmlist);
3232 if (add_method (t, fn, NULL_TREE))
3233 {
3234 DECL_CHAIN (fn) = TYPE_METHODS (t);
3235 TYPE_METHODS (t) = fn;
3236 }
3237 }
3238
3239 /* Declare all the inheriting constructors for class T inherited from base
3240 constructor CTOR. */
3241
3242 static void
3243 one_inherited_ctor (tree ctor, tree t)
3244 {
3245 tree parms = FUNCTION_FIRST_USER_PARMTYPE (ctor);
3246
3247 tree *new_parms = XALLOCAVEC (tree, list_length (parms));
3248 int i = 0;
3249 for (; parms && parms != void_list_node; parms = TREE_CHAIN (parms))
3250 {
3251 if (TREE_PURPOSE (parms))
3252 one_inheriting_sig (t, ctor, new_parms, i);
3253 new_parms[i++] = TREE_VALUE (parms);
3254 }
3255 one_inheriting_sig (t, ctor, new_parms, i);
3256 if (parms == NULL_TREE)
3257 {
3258 if (warning (OPT_Winherited_variadic_ctor,
3259 "the ellipsis in %qD is not inherited", ctor))
3260 inform (DECL_SOURCE_LOCATION (ctor), "%qD declared here", ctor);
3261 }
3262 }
3263
3264 /* Create default constructors, assignment operators, and so forth for
3265 the type indicated by T, if they are needed. CANT_HAVE_CONST_CTOR,
3266 and CANT_HAVE_CONST_ASSIGNMENT are nonzero if, for whatever reason,
3267 the class cannot have a default constructor, copy constructor
3268 taking a const reference argument, or an assignment operator taking
3269 a const reference, respectively. */
3270
3271 static void
3272 add_implicitly_declared_members (tree t, tree* access_decls,
3273 int cant_have_const_cctor,
3274 int cant_have_const_assignment)
3275 {
3276 bool move_ok = false;
3277
3278 if (cxx_dialect >= cxx11 && !CLASSTYPE_DESTRUCTORS (t)
3279 && !TYPE_HAS_COPY_CTOR (t) && !TYPE_HAS_COPY_ASSIGN (t)
3280 && !type_has_move_constructor (t) && !type_has_move_assign (t))
3281 move_ok = true;
3282
3283 /* Destructor. */
3284 if (!CLASSTYPE_DESTRUCTORS (t))
3285 {
3286 /* In general, we create destructors lazily. */
3287 CLASSTYPE_LAZY_DESTRUCTOR (t) = 1;
3288
3289 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t)
3290 && TYPE_FOR_JAVA (t))
3291 /* But if this is a Java class, any non-trivial destructor is
3292 invalid, even if compiler-generated. Therefore, if the
3293 destructor is non-trivial we create it now. */
3294 lazily_declare_fn (sfk_destructor, t);
3295 }
3296
3297 /* [class.ctor]
3298
3299 If there is no user-declared constructor for a class, a default
3300 constructor is implicitly declared. */
3301 if (! TYPE_HAS_USER_CONSTRUCTOR (t))
3302 {
3303 TYPE_HAS_DEFAULT_CONSTRUCTOR (t) = 1;
3304 CLASSTYPE_LAZY_DEFAULT_CTOR (t) = 1;
3305 if (cxx_dialect >= cxx11)
3306 TYPE_HAS_CONSTEXPR_CTOR (t)
3307 /* This might force the declaration. */
3308 = type_has_constexpr_default_constructor (t);
3309 }
3310
3311 /* [class.ctor]
3312
3313 If a class definition does not explicitly declare a copy
3314 constructor, one is declared implicitly. */
3315 if (! TYPE_HAS_COPY_CTOR (t) && ! TYPE_FOR_JAVA (t))
3316 {
3317 TYPE_HAS_COPY_CTOR (t) = 1;
3318 TYPE_HAS_CONST_COPY_CTOR (t) = !cant_have_const_cctor;
3319 CLASSTYPE_LAZY_COPY_CTOR (t) = 1;
3320 if (move_ok)
3321 CLASSTYPE_LAZY_MOVE_CTOR (t) = 1;
3322 }
3323
3324 /* If there is no assignment operator, one will be created if and
3325 when it is needed. For now, just record whether or not the type
3326 of the parameter to the assignment operator will be a const or
3327 non-const reference. */
3328 if (!TYPE_HAS_COPY_ASSIGN (t) && !TYPE_FOR_JAVA (t))
3329 {
3330 TYPE_HAS_COPY_ASSIGN (t) = 1;
3331 TYPE_HAS_CONST_COPY_ASSIGN (t) = !cant_have_const_assignment;
3332 CLASSTYPE_LAZY_COPY_ASSIGN (t) = 1;
3333 if (move_ok && !LAMBDA_TYPE_P (t))
3334 CLASSTYPE_LAZY_MOVE_ASSIGN (t) = 1;
3335 }
3336
3337 /* We can't be lazy about declaring functions that might override
3338 a virtual function from a base class. */
3339 declare_virt_assop_and_dtor (t);
3340
3341 while (*access_decls)
3342 {
3343 tree using_decl = TREE_VALUE (*access_decls);
3344 tree decl = USING_DECL_DECLS (using_decl);
3345 if (DECL_NAME (using_decl) == ctor_identifier)
3346 {
3347 /* declare, then remove the decl */
3348 tree ctor_list = decl;
3349 location_t loc = input_location;
3350 input_location = DECL_SOURCE_LOCATION (using_decl);
3351 if (ctor_list)
3352 for (; ctor_list; ctor_list = OVL_NEXT (ctor_list))
3353 one_inherited_ctor (OVL_CURRENT (ctor_list), t);
3354 *access_decls = TREE_CHAIN (*access_decls);
3355 input_location = loc;
3356 }
3357 else
3358 access_decls = &TREE_CHAIN (*access_decls);
3359 }
3360 }
3361
3362 /* Subroutine of insert_into_classtype_sorted_fields. Recursively
3363 count the number of fields in TYPE, including anonymous union
3364 members. */
3365
3366 static int
3367 count_fields (tree fields)
3368 {
3369 tree x;
3370 int n_fields = 0;
3371 for (x = fields; x; x = DECL_CHAIN (x))
3372 {
3373 if (TREE_CODE (x) == FIELD_DECL && ANON_AGGR_TYPE_P (TREE_TYPE (x)))
3374 n_fields += count_fields (TYPE_FIELDS (TREE_TYPE (x)));
3375 else
3376 n_fields += 1;
3377 }
3378 return n_fields;
3379 }
3380
3381 /* Subroutine of insert_into_classtype_sorted_fields. Recursively add
3382 all the fields in the TREE_LIST FIELDS to the SORTED_FIELDS_TYPE
3383 elts, starting at offset IDX. */
3384
3385 static int
3386 add_fields_to_record_type (tree fields, struct sorted_fields_type *field_vec, int idx)
3387 {
3388 tree x;
3389 for (x = fields; x; x = DECL_CHAIN (x))
3390 {
3391 if (TREE_CODE (x) == FIELD_DECL && ANON_AGGR_TYPE_P (TREE_TYPE (x)))
3392 idx = add_fields_to_record_type (TYPE_FIELDS (TREE_TYPE (x)), field_vec, idx);
3393 else
3394 field_vec->elts[idx++] = x;
3395 }
3396 return idx;
3397 }
3398
3399 /* Add all of the enum values of ENUMTYPE, to the FIELD_VEC elts,
3400 starting at offset IDX. */
3401
3402 static int
3403 add_enum_fields_to_record_type (tree enumtype,
3404 struct sorted_fields_type *field_vec,
3405 int idx)
3406 {
3407 tree values;
3408 for (values = TYPE_VALUES (enumtype); values; values = TREE_CHAIN (values))
3409 field_vec->elts[idx++] = TREE_VALUE (values);
3410 return idx;
3411 }
3412
3413 /* FIELD is a bit-field. We are finishing the processing for its
3414 enclosing type. Issue any appropriate messages and set appropriate
3415 flags. Returns false if an error has been diagnosed. */
3416
3417 static bool
3418 check_bitfield_decl (tree field)
3419 {
3420 tree type = TREE_TYPE (field);
3421 tree w;
3422
3423 /* Extract the declared width of the bitfield, which has been
3424 temporarily stashed in DECL_INITIAL. */
3425 w = DECL_INITIAL (field);
3426 gcc_assert (w != NULL_TREE);
3427 /* Remove the bit-field width indicator so that the rest of the
3428 compiler does not treat that value as an initializer. */
3429 DECL_INITIAL (field) = NULL_TREE;
3430
3431 /* Detect invalid bit-field type. */
3432 if (!INTEGRAL_OR_ENUMERATION_TYPE_P (type))
3433 {
3434 error ("bit-field %q+#D with non-integral type", field);
3435 w = error_mark_node;
3436 }
3437 else
3438 {
3439 location_t loc = input_location;
3440 /* Avoid the non_lvalue wrapper added by fold for PLUS_EXPRs. */
3441 STRIP_NOPS (w);
3442
3443 /* detect invalid field size. */
3444 input_location = DECL_SOURCE_LOCATION (field);
3445 w = cxx_constant_value (w);
3446 input_location = loc;
3447
3448 if (TREE_CODE (w) != INTEGER_CST)
3449 {
3450 error ("bit-field %q+D width not an integer constant", field);
3451 w = error_mark_node;
3452 }
3453 else if (tree_int_cst_sgn (w) < 0)
3454 {
3455 error ("negative width in bit-field %q+D", field);
3456 w = error_mark_node;
3457 }
3458 else if (integer_zerop (w) && DECL_NAME (field) != 0)
3459 {
3460 error ("zero width for bit-field %q+D", field);
3461 w = error_mark_node;
3462 }
3463 else if ((TREE_CODE (type) != ENUMERAL_TYPE
3464 && TREE_CODE (type) != BOOLEAN_TYPE
3465 && compare_tree_int (w, TYPE_PRECISION (type)) > 0)
3466 || ((TREE_CODE (type) == ENUMERAL_TYPE
3467 || TREE_CODE (type) == BOOLEAN_TYPE)
3468 && tree_int_cst_lt (TYPE_SIZE (type), w)))
3469 warning (0, "width of %q+D exceeds its type", field);
3470 else if (TREE_CODE (type) == ENUMERAL_TYPE
3471 && (0 > (compare_tree_int
3472 (w, TYPE_PRECISION (ENUM_UNDERLYING_TYPE (type))))))
3473 warning (0, "%q+D is too small to hold all values of %q#T", field, type);
3474 }
3475
3476 if (w != error_mark_node)
3477 {
3478 DECL_SIZE (field) = convert (bitsizetype, w);
3479 DECL_BIT_FIELD (field) = 1;
3480 return true;
3481 }
3482 else
3483 {
3484 /* Non-bit-fields are aligned for their type. */
3485 DECL_BIT_FIELD (field) = 0;
3486 CLEAR_DECL_C_BIT_FIELD (field);
3487 return false;
3488 }
3489 }
3490
3491 /* FIELD is a non bit-field. We are finishing the processing for its
3492 enclosing type T. Issue any appropriate messages and set appropriate
3493 flags. */
3494
3495 static void
3496 check_field_decl (tree field,
3497 tree t,
3498 int* cant_have_const_ctor,
3499 int* no_const_asn_ref,
3500 int* any_default_members)
3501 {
3502 tree type = strip_array_types (TREE_TYPE (field));
3503
3504 /* In C++98 an anonymous union cannot contain any fields which would change
3505 the settings of CANT_HAVE_CONST_CTOR and friends. */
3506 if (ANON_UNION_TYPE_P (type) && cxx_dialect < cxx11)
3507 ;
3508 /* And, we don't set TYPE_HAS_CONST_COPY_CTOR, etc., for anonymous
3509 structs. So, we recurse through their fields here. */
3510 else if (ANON_AGGR_TYPE_P (type))
3511 {
3512 tree fields;
3513
3514 for (fields = TYPE_FIELDS (type); fields; fields = DECL_CHAIN (fields))
3515 if (TREE_CODE (fields) == FIELD_DECL && !DECL_C_BIT_FIELD (field))
3516 check_field_decl (fields, t, cant_have_const_ctor,
3517 no_const_asn_ref, any_default_members);
3518 }
3519 /* Check members with class type for constructors, destructors,
3520 etc. */
3521 else if (CLASS_TYPE_P (type))
3522 {
3523 /* Never let anything with uninheritable virtuals
3524 make it through without complaint. */
3525 abstract_virtuals_error (field, type);
3526
3527 if (TREE_CODE (t) == UNION_TYPE && cxx_dialect < cxx11)
3528 {
3529 static bool warned;
3530 int oldcount = errorcount;
3531 if (TYPE_NEEDS_CONSTRUCTING (type))
3532 error ("member %q+#D with constructor not allowed in union",
3533 field);
3534 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type))
3535 error ("member %q+#D with destructor not allowed in union", field);
3536 if (TYPE_HAS_COMPLEX_COPY_ASSIGN (type))
3537 error ("member %q+#D with copy assignment operator not allowed in union",
3538 field);
3539 if (!warned && errorcount > oldcount)
3540 {
3541 inform (DECL_SOURCE_LOCATION (field), "unrestricted unions "
3542 "only available with -std=c++11 or -std=gnu++11");
3543 warned = true;
3544 }
3545 }
3546 else
3547 {
3548 TYPE_NEEDS_CONSTRUCTING (t) |= TYPE_NEEDS_CONSTRUCTING (type);
3549 TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t)
3550 |= TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type);
3551 TYPE_HAS_COMPLEX_COPY_ASSIGN (t)
3552 |= (TYPE_HAS_COMPLEX_COPY_ASSIGN (type)
3553 || !TYPE_HAS_COPY_ASSIGN (type));
3554 TYPE_HAS_COMPLEX_COPY_CTOR (t) |= (TYPE_HAS_COMPLEX_COPY_CTOR (type)
3555 || !TYPE_HAS_COPY_CTOR (type));
3556 TYPE_HAS_COMPLEX_MOVE_ASSIGN (t) |= TYPE_HAS_COMPLEX_MOVE_ASSIGN (type);
3557 TYPE_HAS_COMPLEX_MOVE_CTOR (t) |= TYPE_HAS_COMPLEX_MOVE_CTOR (type);
3558 TYPE_HAS_COMPLEX_DFLT (t) |= (!TYPE_HAS_DEFAULT_CONSTRUCTOR (type)
3559 || TYPE_HAS_COMPLEX_DFLT (type));
3560 }
3561
3562 if (TYPE_HAS_COPY_CTOR (type)
3563 && !TYPE_HAS_CONST_COPY_CTOR (type))
3564 *cant_have_const_ctor = 1;
3565
3566 if (TYPE_HAS_COPY_ASSIGN (type)
3567 && !TYPE_HAS_CONST_COPY_ASSIGN (type))
3568 *no_const_asn_ref = 1;
3569 }
3570
3571 check_abi_tags (t, field);
3572
3573 if (DECL_INITIAL (field) != NULL_TREE)
3574 {
3575 /* `build_class_init_list' does not recognize
3576 non-FIELD_DECLs. */
3577 if (TREE_CODE (t) == UNION_TYPE && *any_default_members != 0)
3578 error ("multiple fields in union %qT initialized", t);
3579 *any_default_members = 1;
3580 }
3581 }
3582
3583 /* Check the data members (both static and non-static), class-scoped
3584 typedefs, etc., appearing in the declaration of T. Issue
3585 appropriate diagnostics. Sets ACCESS_DECLS to a list (in
3586 declaration order) of access declarations; each TREE_VALUE in this
3587 list is a USING_DECL.
3588
3589 In addition, set the following flags:
3590
3591 EMPTY_P
3592 The class is empty, i.e., contains no non-static data members.
3593
3594 CANT_HAVE_CONST_CTOR_P
3595 This class cannot have an implicitly generated copy constructor
3596 taking a const reference.
3597
3598 CANT_HAVE_CONST_ASN_REF
3599 This class cannot have an implicitly generated assignment
3600 operator taking a const reference.
3601
3602 All of these flags should be initialized before calling this
3603 function.
3604
3605 Returns a pointer to the end of the TYPE_FIELDs chain; additional
3606 fields can be added by adding to this chain. */
3607
3608 static void
3609 check_field_decls (tree t, tree *access_decls,
3610 int *cant_have_const_ctor_p,
3611 int *no_const_asn_ref_p)
3612 {
3613 tree *field;
3614 tree *next;
3615 bool has_pointers;
3616 int any_default_members;
3617 int cant_pack = 0;
3618 int field_access = -1;
3619
3620 /* Assume there are no access declarations. */
3621 *access_decls = NULL_TREE;
3622 /* Assume this class has no pointer members. */
3623 has_pointers = false;
3624 /* Assume none of the members of this class have default
3625 initializations. */
3626 any_default_members = 0;
3627
3628 for (field = &TYPE_FIELDS (t); *field; field = next)
3629 {
3630 tree x = *field;
3631 tree type = TREE_TYPE (x);
3632 int this_field_access;
3633
3634 next = &DECL_CHAIN (x);
3635
3636 if (TREE_CODE (x) == USING_DECL)
3637 {
3638 /* Save the access declarations for our caller. */
3639 *access_decls = tree_cons (NULL_TREE, x, *access_decls);
3640 continue;
3641 }
3642
3643 if (TREE_CODE (x) == TYPE_DECL
3644 || TREE_CODE (x) == TEMPLATE_DECL)
3645 continue;
3646
3647 /* If we've gotten this far, it's a data member, possibly static,
3648 or an enumerator. */
3649 if (TREE_CODE (x) != CONST_DECL)
3650 DECL_CONTEXT (x) = t;
3651
3652 /* When this goes into scope, it will be a non-local reference. */
3653 DECL_NONLOCAL (x) = 1;
3654
3655 if (TREE_CODE (t) == UNION_TYPE
3656 && cxx_dialect < cxx11)
3657 {
3658 /* [class.union] (C++98)
3659
3660 If a union contains a static data member, or a member of
3661 reference type, the program is ill-formed.
3662
3663 In C++11 this limitation doesn't exist anymore. */
3664 if (VAR_P (x))
3665 {
3666 error ("in C++98 %q+D may not be static because it is "
3667 "a member of a union", x);
3668 continue;
3669 }
3670 if (TREE_CODE (type) == REFERENCE_TYPE)
3671 {
3672 error ("in C++98 %q+D may not have reference type %qT "
3673 "because it is a member of a union", x, type);
3674 continue;
3675 }
3676 }
3677
3678 /* Perform error checking that did not get done in
3679 grokdeclarator. */
3680 if (TREE_CODE (type) == FUNCTION_TYPE)
3681 {
3682 error ("field %q+D invalidly declared function type", x);
3683 type = build_pointer_type (type);
3684 TREE_TYPE (x) = type;
3685 }
3686 else if (TREE_CODE (type) == METHOD_TYPE)
3687 {
3688 error ("field %q+D invalidly declared method type", x);
3689 type = build_pointer_type (type);
3690 TREE_TYPE (x) = type;
3691 }
3692
3693 if (type == error_mark_node)
3694 continue;
3695
3696 if (TREE_CODE (x) == CONST_DECL || VAR_P (x))
3697 continue;
3698
3699 /* Now it can only be a FIELD_DECL. */
3700
3701 if (TREE_PRIVATE (x) || TREE_PROTECTED (x))
3702 CLASSTYPE_NON_AGGREGATE (t) = 1;
3703
3704 /* If at least one non-static data member is non-literal, the whole
3705 class becomes non-literal. Per Core/1453, volatile non-static
3706 data members and base classes are also not allowed.
3707 Note: if the type is incomplete we will complain later on. */
3708 if (COMPLETE_TYPE_P (type)
3709 && (!literal_type_p (type) || CP_TYPE_VOLATILE_P (type)))
3710 CLASSTYPE_LITERAL_P (t) = false;
3711
3712 /* A standard-layout class is a class that:
3713 ...
3714 has the same access control (Clause 11) for all non-static data members,
3715 ... */
3716 this_field_access = TREE_PROTECTED (x) ? 1 : TREE_PRIVATE (x) ? 2 : 0;
3717 if (field_access == -1)
3718 field_access = this_field_access;
3719 else if (this_field_access != field_access)
3720 CLASSTYPE_NON_STD_LAYOUT (t) = 1;
3721
3722 /* If this is of reference type, check if it needs an init. */
3723 if (TREE_CODE (type) == REFERENCE_TYPE)
3724 {
3725 CLASSTYPE_NON_LAYOUT_POD_P (t) = 1;
3726 CLASSTYPE_NON_STD_LAYOUT (t) = 1;
3727 if (DECL_INITIAL (x) == NULL_TREE)
3728 SET_CLASSTYPE_REF_FIELDS_NEED_INIT (t, 1);
3729 if (cxx_dialect < cxx11)
3730 {
3731 /* ARM $12.6.2: [A member initializer list] (or, for an
3732 aggregate, initialization by a brace-enclosed list) is the
3733 only way to initialize nonstatic const and reference
3734 members. */
3735 TYPE_HAS_COMPLEX_COPY_ASSIGN (t) = 1;
3736 TYPE_HAS_COMPLEX_MOVE_ASSIGN (t) = 1;
3737 }
3738 }
3739
3740 type = strip_array_types (type);
3741
3742 if (TYPE_PACKED (t))
3743 {
3744 if (!layout_pod_type_p (type) && !TYPE_PACKED (type))
3745 {
3746 warning
3747 (0,
3748 "ignoring packed attribute because of unpacked non-POD field %q+#D",
3749 x);
3750 cant_pack = 1;
3751 }
3752 else if (DECL_C_BIT_FIELD (x)
3753 || TYPE_ALIGN (TREE_TYPE (x)) > BITS_PER_UNIT)
3754 DECL_PACKED (x) = 1;
3755 }
3756
3757 if (DECL_C_BIT_FIELD (x) && integer_zerop (DECL_INITIAL (x)))
3758 /* We don't treat zero-width bitfields as making a class
3759 non-empty. */
3760 ;
3761 else
3762 {
3763 /* The class is non-empty. */
3764 CLASSTYPE_EMPTY_P (t) = 0;
3765 /* The class is not even nearly empty. */
3766 CLASSTYPE_NEARLY_EMPTY_P (t) = 0;
3767 /* If one of the data members contains an empty class,
3768 so does T. */
3769 if (CLASS_TYPE_P (type)
3770 && CLASSTYPE_CONTAINS_EMPTY_CLASS_P (type))
3771 CLASSTYPE_CONTAINS_EMPTY_CLASS_P (t) = 1;
3772 }
3773
3774 /* This is used by -Weffc++ (see below). Warn only for pointers
3775 to members which might hold dynamic memory. So do not warn
3776 for pointers to functions or pointers to members. */
3777 if (TYPE_PTR_P (type)
3778 && !TYPE_PTRFN_P (type))
3779 has_pointers = true;
3780
3781 if (CLASS_TYPE_P (type))
3782 {
3783 if (CLASSTYPE_REF_FIELDS_NEED_INIT (type))
3784 SET_CLASSTYPE_REF_FIELDS_NEED_INIT (t, 1);
3785 if (CLASSTYPE_READONLY_FIELDS_NEED_INIT (type))
3786 SET_CLASSTYPE_READONLY_FIELDS_NEED_INIT (t, 1);
3787 }
3788
3789 if (DECL_MUTABLE_P (x) || TYPE_HAS_MUTABLE_P (type))
3790 CLASSTYPE_HAS_MUTABLE (t) = 1;
3791
3792 if (DECL_MUTABLE_P (x))
3793 {
3794 if (CP_TYPE_CONST_P (type))
3795 {
3796 error ("member %q+D cannot be declared both %<const%> "
3797 "and %<mutable%>", x);
3798 continue;
3799 }
3800 if (TREE_CODE (type) == REFERENCE_TYPE)
3801 {
3802 error ("member %q+D cannot be declared as a %<mutable%> "
3803 "reference", x);
3804 continue;
3805 }
3806 }
3807
3808 if (! layout_pod_type_p (type))
3809 /* DR 148 now allows pointers to members (which are POD themselves),
3810 to be allowed in POD structs. */
3811 CLASSTYPE_NON_LAYOUT_POD_P (t) = 1;
3812
3813 if (!std_layout_type_p (type))
3814 CLASSTYPE_NON_STD_LAYOUT (t) = 1;
3815
3816 if (! zero_init_p (type))
3817 CLASSTYPE_NON_ZERO_INIT_P (t) = 1;
3818
3819 /* We set DECL_C_BIT_FIELD in grokbitfield.
3820 If the type and width are valid, we'll also set DECL_BIT_FIELD. */
3821 if (! DECL_C_BIT_FIELD (x) || ! check_bitfield_decl (x))
3822 check_field_decl (x, t,
3823 cant_have_const_ctor_p,
3824 no_const_asn_ref_p,
3825 &any_default_members);
3826
3827 /* Now that we've removed bit-field widths from DECL_INITIAL,
3828 anything left in DECL_INITIAL is an NSDMI that makes the class
3829 non-aggregate in C++11. */
3830 if (DECL_INITIAL (x) && cxx_dialect < cxx14)
3831 CLASSTYPE_NON_AGGREGATE (t) = true;
3832
3833 /* If any field is const, the structure type is pseudo-const. */
3834 if (CP_TYPE_CONST_P (type))
3835 {
3836 C_TYPE_FIELDS_READONLY (t) = 1;
3837 if (DECL_INITIAL (x) == NULL_TREE)
3838 SET_CLASSTYPE_READONLY_FIELDS_NEED_INIT (t, 1);
3839 if (cxx_dialect < cxx11)
3840 {
3841 /* ARM $12.6.2: [A member initializer list] (or, for an
3842 aggregate, initialization by a brace-enclosed list) is the
3843 only way to initialize nonstatic const and reference
3844 members. */
3845 TYPE_HAS_COMPLEX_COPY_ASSIGN (t) = 1;
3846 TYPE_HAS_COMPLEX_MOVE_ASSIGN (t) = 1;
3847 }
3848 }
3849 /* A field that is pseudo-const makes the structure likewise. */
3850 else if (CLASS_TYPE_P (type))
3851 {
3852 C_TYPE_FIELDS_READONLY (t) |= C_TYPE_FIELDS_READONLY (type);
3853 SET_CLASSTYPE_READONLY_FIELDS_NEED_INIT (t,
3854 CLASSTYPE_READONLY_FIELDS_NEED_INIT (t)
3855 | CLASSTYPE_READONLY_FIELDS_NEED_INIT (type));
3856 }
3857
3858 /* Core issue 80: A nonstatic data member is required to have a
3859 different name from the class iff the class has a
3860 user-declared constructor. */
3861 if (constructor_name_p (DECL_NAME (x), t)
3862 && TYPE_HAS_USER_CONSTRUCTOR (t))
3863 permerror (input_location, "field %q+#D with same name as class", x);
3864 }
3865
3866 /* Effective C++ rule 11: if a class has dynamic memory held by pointers,
3867 it should also define a copy constructor and an assignment operator to
3868 implement the correct copy semantic (deep vs shallow, etc.). As it is
3869 not feasible to check whether the constructors do allocate dynamic memory
3870 and store it within members, we approximate the warning like this:
3871
3872 -- Warn only if there are members which are pointers
3873 -- Warn only if there is a non-trivial constructor (otherwise,
3874 there cannot be memory allocated).
3875 -- Warn only if there is a non-trivial destructor. We assume that the
3876 user at least implemented the cleanup correctly, and a destructor
3877 is needed to free dynamic memory.
3878
3879 This seems enough for practical purposes. */
3880 if (warn_ecpp
3881 && has_pointers
3882 && TYPE_HAS_USER_CONSTRUCTOR (t)
3883 && TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t)
3884 && !(TYPE_HAS_COPY_CTOR (t) && TYPE_HAS_COPY_ASSIGN (t)))
3885 {
3886 warning (OPT_Weffc__, "%q#T has pointer data members", t);
3887
3888 if (! TYPE_HAS_COPY_CTOR (t))
3889 {
3890 warning (OPT_Weffc__,
3891 " but does not override %<%T(const %T&)%>", t, t);
3892 if (!TYPE_HAS_COPY_ASSIGN (t))
3893 warning (OPT_Weffc__, " or %<operator=(const %T&)%>", t);
3894 }
3895 else if (! TYPE_HAS_COPY_ASSIGN (t))
3896 warning (OPT_Weffc__,
3897 " but does not override %<operator=(const %T&)%>", t);
3898 }
3899
3900 /* Non-static data member initializers make the default constructor
3901 non-trivial. */
3902 if (any_default_members)
3903 {
3904 TYPE_NEEDS_CONSTRUCTING (t) = true;
3905 TYPE_HAS_COMPLEX_DFLT (t) = true;
3906 }
3907
3908 /* If any of the fields couldn't be packed, unset TYPE_PACKED. */
3909 if (cant_pack)
3910 TYPE_PACKED (t) = 0;
3911
3912 /* Check anonymous struct/anonymous union fields. */
3913 finish_struct_anon (t);
3914
3915 /* We've built up the list of access declarations in reverse order.
3916 Fix that now. */
3917 *access_decls = nreverse (*access_decls);
3918 }
3919
3920 /* If TYPE is an empty class type, records its OFFSET in the table of
3921 OFFSETS. */
3922
3923 static int
3924 record_subobject_offset (tree type, tree offset, splay_tree offsets)
3925 {
3926 splay_tree_node n;
3927
3928 if (!is_empty_class (type))
3929 return 0;
3930
3931 /* Record the location of this empty object in OFFSETS. */
3932 n = splay_tree_lookup (offsets, (splay_tree_key) offset);
3933 if (!n)
3934 n = splay_tree_insert (offsets,
3935 (splay_tree_key) offset,
3936 (splay_tree_value) NULL_TREE);
3937 n->value = ((splay_tree_value)
3938 tree_cons (NULL_TREE,
3939 type,
3940 (tree) n->value));
3941
3942 return 0;
3943 }
3944
3945 /* Returns nonzero if TYPE is an empty class type and there is
3946 already an entry in OFFSETS for the same TYPE as the same OFFSET. */
3947
3948 static int
3949 check_subobject_offset (tree type, tree offset, splay_tree offsets)
3950 {
3951 splay_tree_node n;
3952 tree t;
3953
3954 if (!is_empty_class (type))
3955 return 0;
3956
3957 /* Record the location of this empty object in OFFSETS. */
3958 n = splay_tree_lookup (offsets, (splay_tree_key) offset);
3959 if (!n)
3960 return 0;
3961
3962 for (t = (tree) n->value; t; t = TREE_CHAIN (t))
3963 if (same_type_p (TREE_VALUE (t), type))
3964 return 1;
3965
3966 return 0;
3967 }
3968
3969 /* Walk through all the subobjects of TYPE (located at OFFSET). Call
3970 F for every subobject, passing it the type, offset, and table of
3971 OFFSETS. If VBASES_P is one, then virtual non-primary bases should
3972 be traversed.
3973
3974 If MAX_OFFSET is non-NULL, then subobjects with an offset greater
3975 than MAX_OFFSET will not be walked.
3976
3977 If F returns a nonzero value, the traversal ceases, and that value
3978 is returned. Otherwise, returns zero. */
3979
3980 static int
3981 walk_subobject_offsets (tree type,
3982 subobject_offset_fn f,
3983 tree offset,
3984 splay_tree offsets,
3985 tree max_offset,
3986 int vbases_p)
3987 {
3988 int r = 0;
3989 tree type_binfo = NULL_TREE;
3990
3991 /* If this OFFSET is bigger than the MAX_OFFSET, then we should
3992 stop. */
3993 if (max_offset && tree_int_cst_lt (max_offset, offset))
3994 return 0;
3995
3996 if (type == error_mark_node)
3997 return 0;
3998
3999 if (!TYPE_P (type))
4000 {
4001 type_binfo = type;
4002 type = BINFO_TYPE (type);
4003 }
4004
4005 if (CLASS_TYPE_P (type))
4006 {
4007 tree field;
4008 tree binfo;
4009 int i;
4010
4011 /* Avoid recursing into objects that are not interesting. */
4012 if (!CLASSTYPE_CONTAINS_EMPTY_CLASS_P (type))
4013 return 0;
4014
4015 /* Record the location of TYPE. */
4016 r = (*f) (type, offset, offsets);
4017 if (r)
4018 return r;
4019
4020 /* Iterate through the direct base classes of TYPE. */
4021 if (!type_binfo)
4022 type_binfo = TYPE_BINFO (type);
4023 for (i = 0; BINFO_BASE_ITERATE (type_binfo, i, binfo); i++)
4024 {
4025 tree binfo_offset;
4026
4027 if (BINFO_VIRTUAL_P (binfo))
4028 continue;
4029
4030 tree orig_binfo;
4031 /* We cannot rely on BINFO_OFFSET being set for the base
4032 class yet, but the offsets for direct non-virtual
4033 bases can be calculated by going back to the TYPE. */
4034 orig_binfo = BINFO_BASE_BINFO (TYPE_BINFO (type), i);
4035 binfo_offset = size_binop (PLUS_EXPR,
4036 offset,
4037 BINFO_OFFSET (orig_binfo));
4038
4039 r = walk_subobject_offsets (binfo,
4040 f,
4041 binfo_offset,
4042 offsets,
4043 max_offset,
4044 /*vbases_p=*/0);
4045 if (r)
4046 return r;
4047 }
4048
4049 if (CLASSTYPE_VBASECLASSES (type))
4050 {
4051 unsigned ix;
4052 vec<tree, va_gc> *vbases;
4053
4054 /* Iterate through the virtual base classes of TYPE. In G++
4055 3.2, we included virtual bases in the direct base class
4056 loop above, which results in incorrect results; the
4057 correct offsets for virtual bases are only known when
4058 working with the most derived type. */
4059 if (vbases_p)
4060 for (vbases = CLASSTYPE_VBASECLASSES (type), ix = 0;
4061 vec_safe_iterate (vbases, ix, &binfo); ix++)
4062 {
4063 r = walk_subobject_offsets (binfo,
4064 f,
4065 size_binop (PLUS_EXPR,
4066 offset,
4067 BINFO_OFFSET (binfo)),
4068 offsets,
4069 max_offset,
4070 /*vbases_p=*/0);
4071 if (r)
4072 return r;
4073 }
4074 else
4075 {
4076 /* We still have to walk the primary base, if it is
4077 virtual. (If it is non-virtual, then it was walked
4078 above.) */
4079 tree vbase = get_primary_binfo (type_binfo);
4080
4081 if (vbase && BINFO_VIRTUAL_P (vbase)
4082 && BINFO_PRIMARY_P (vbase)
4083 && BINFO_INHERITANCE_CHAIN (vbase) == type_binfo)
4084 {
4085 r = (walk_subobject_offsets
4086 (vbase, f, offset,
4087 offsets, max_offset, /*vbases_p=*/0));
4088 if (r)
4089 return r;
4090 }
4091 }
4092 }
4093
4094 /* Iterate through the fields of TYPE. */
4095 for (field = TYPE_FIELDS (type); field; field = DECL_CHAIN (field))
4096 if (TREE_CODE (field) == FIELD_DECL
4097 && TREE_TYPE (field) != error_mark_node
4098 && !DECL_ARTIFICIAL (field))
4099 {
4100 tree field_offset;
4101
4102 field_offset = byte_position (field);
4103
4104 r = walk_subobject_offsets (TREE_TYPE (field),
4105 f,
4106 size_binop (PLUS_EXPR,
4107 offset,
4108 field_offset),
4109 offsets,
4110 max_offset,
4111 /*vbases_p=*/1);
4112 if (r)
4113 return r;
4114 }
4115 }
4116 else if (TREE_CODE (type) == ARRAY_TYPE)
4117 {
4118 tree element_type = strip_array_types (type);
4119 tree domain = TYPE_DOMAIN (type);
4120 tree index;
4121
4122 /* Avoid recursing into objects that are not interesting. */
4123 if (!CLASS_TYPE_P (element_type)
4124 || !CLASSTYPE_CONTAINS_EMPTY_CLASS_P (element_type))
4125 return 0;
4126
4127 /* Step through each of the elements in the array. */
4128 for (index = size_zero_node;
4129 !tree_int_cst_lt (TYPE_MAX_VALUE (domain), index);
4130 index = size_binop (PLUS_EXPR, index, size_one_node))
4131 {
4132 r = walk_subobject_offsets (TREE_TYPE (type),
4133 f,
4134 offset,
4135 offsets,
4136 max_offset,
4137 /*vbases_p=*/1);
4138 if (r)
4139 return r;
4140 offset = size_binop (PLUS_EXPR, offset,
4141 TYPE_SIZE_UNIT (TREE_TYPE (type)));
4142 /* If this new OFFSET is bigger than the MAX_OFFSET, then
4143 there's no point in iterating through the remaining
4144 elements of the array. */
4145 if (max_offset && tree_int_cst_lt (max_offset, offset))
4146 break;
4147 }
4148 }
4149
4150 return 0;
4151 }
4152
4153 /* Record all of the empty subobjects of TYPE (either a type or a
4154 binfo). If IS_DATA_MEMBER is true, then a non-static data member
4155 is being placed at OFFSET; otherwise, it is a base class that is
4156 being placed at OFFSET. */
4157
4158 static void
4159 record_subobject_offsets (tree type,
4160 tree offset,
4161 splay_tree offsets,
4162 bool is_data_member)
4163 {
4164 tree max_offset;
4165 /* If recording subobjects for a non-static data member or a
4166 non-empty base class , we do not need to record offsets beyond
4167 the size of the biggest empty class. Additional data members
4168 will go at the end of the class. Additional base classes will go
4169 either at offset zero (if empty, in which case they cannot
4170 overlap with offsets past the size of the biggest empty class) or
4171 at the end of the class.
4172
4173 However, if we are placing an empty base class, then we must record
4174 all offsets, as either the empty class is at offset zero (where
4175 other empty classes might later be placed) or at the end of the
4176 class (where other objects might then be placed, so other empty
4177 subobjects might later overlap). */
4178 if (is_data_member
4179 || !is_empty_class (BINFO_TYPE (type)))
4180 max_offset = sizeof_biggest_empty_class;
4181 else
4182 max_offset = NULL_TREE;
4183 walk_subobject_offsets (type, record_subobject_offset, offset,
4184 offsets, max_offset, is_data_member);
4185 }
4186
4187 /* Returns nonzero if any of the empty subobjects of TYPE (located at
4188 OFFSET) conflict with entries in OFFSETS. If VBASES_P is nonzero,
4189 virtual bases of TYPE are examined. */
4190
4191 static int
4192 layout_conflict_p (tree type,
4193 tree offset,
4194 splay_tree offsets,
4195 int vbases_p)
4196 {
4197 splay_tree_node max_node;
4198
4199 /* Get the node in OFFSETS that indicates the maximum offset where
4200 an empty subobject is located. */
4201 max_node = splay_tree_max (offsets);
4202 /* If there aren't any empty subobjects, then there's no point in
4203 performing this check. */
4204 if (!max_node)
4205 return 0;
4206
4207 return walk_subobject_offsets (type, check_subobject_offset, offset,
4208 offsets, (tree) (max_node->key),
4209 vbases_p);
4210 }
4211
4212 /* DECL is a FIELD_DECL corresponding either to a base subobject of a
4213 non-static data member of the type indicated by RLI. BINFO is the
4214 binfo corresponding to the base subobject, OFFSETS maps offsets to
4215 types already located at those offsets. This function determines
4216 the position of the DECL. */
4217
4218 static void
4219 layout_nonempty_base_or_field (record_layout_info rli,
4220 tree decl,
4221 tree binfo,
4222 splay_tree offsets)
4223 {
4224 tree offset = NULL_TREE;
4225 bool field_p;
4226 tree type;
4227
4228 if (binfo)
4229 {
4230 /* For the purposes of determining layout conflicts, we want to
4231 use the class type of BINFO; TREE_TYPE (DECL) will be the
4232 CLASSTYPE_AS_BASE version, which does not contain entries for
4233 zero-sized bases. */
4234 type = TREE_TYPE (binfo);
4235 field_p = false;
4236 }
4237 else
4238 {
4239 type = TREE_TYPE (decl);
4240 field_p = true;
4241 }
4242
4243 /* Try to place the field. It may take more than one try if we have
4244 a hard time placing the field without putting two objects of the
4245 same type at the same address. */
4246 while (1)
4247 {
4248 struct record_layout_info_s old_rli = *rli;
4249
4250 /* Place this field. */
4251 place_field (rli, decl);
4252 offset = byte_position (decl);
4253
4254 /* We have to check to see whether or not there is already
4255 something of the same type at the offset we're about to use.
4256 For example, consider:
4257
4258 struct S {};
4259 struct T : public S { int i; };
4260 struct U : public S, public T {};
4261
4262 Here, we put S at offset zero in U. Then, we can't put T at
4263 offset zero -- its S component would be at the same address
4264 as the S we already allocated. So, we have to skip ahead.
4265 Since all data members, including those whose type is an
4266 empty class, have nonzero size, any overlap can happen only
4267 with a direct or indirect base-class -- it can't happen with
4268 a data member. */
4269 /* In a union, overlap is permitted; all members are placed at
4270 offset zero. */
4271 if (TREE_CODE (rli->t) == UNION_TYPE)
4272 break;
4273 if (layout_conflict_p (field_p ? type : binfo, offset,
4274 offsets, field_p))
4275 {
4276 /* Strip off the size allocated to this field. That puts us
4277 at the first place we could have put the field with
4278 proper alignment. */
4279 *rli = old_rli;
4280
4281 /* Bump up by the alignment required for the type. */
4282 rli->bitpos
4283 = size_binop (PLUS_EXPR, rli->bitpos,
4284 bitsize_int (binfo
4285 ? CLASSTYPE_ALIGN (type)
4286 : TYPE_ALIGN (type)));
4287 normalize_rli (rli);
4288 }
4289 else
4290 /* There was no conflict. We're done laying out this field. */
4291 break;
4292 }
4293
4294 /* Now that we know where it will be placed, update its
4295 BINFO_OFFSET. */
4296 if (binfo && CLASS_TYPE_P (BINFO_TYPE (binfo)))
4297 /* Indirect virtual bases may have a nonzero BINFO_OFFSET at
4298 this point because their BINFO_OFFSET is copied from another
4299 hierarchy. Therefore, we may not need to add the entire
4300 OFFSET. */
4301 propagate_binfo_offsets (binfo,
4302 size_diffop_loc (input_location,
4303 convert (ssizetype, offset),
4304 convert (ssizetype,
4305 BINFO_OFFSET (binfo))));
4306 }
4307
4308 /* Returns true if TYPE is empty and OFFSET is nonzero. */
4309
4310 static int
4311 empty_base_at_nonzero_offset_p (tree type,
4312 tree offset,
4313 splay_tree /*offsets*/)
4314 {
4315 return is_empty_class (type) && !integer_zerop (offset);
4316 }
4317
4318 /* Layout the empty base BINFO. EOC indicates the byte currently just
4319 past the end of the class, and should be correctly aligned for a
4320 class of the type indicated by BINFO; OFFSETS gives the offsets of
4321 the empty bases allocated so far. T is the most derived
4322 type. Return nonzero iff we added it at the end. */
4323
4324 static bool
4325 layout_empty_base (record_layout_info rli, tree binfo,
4326 tree eoc, splay_tree offsets)
4327 {
4328 tree alignment;
4329 tree basetype = BINFO_TYPE (binfo);
4330 bool atend = false;
4331
4332 /* This routine should only be used for empty classes. */
4333 gcc_assert (is_empty_class (basetype));
4334 alignment = ssize_int (CLASSTYPE_ALIGN_UNIT (basetype));
4335
4336 if (!integer_zerop (BINFO_OFFSET (binfo)))
4337 propagate_binfo_offsets
4338 (binfo, size_diffop_loc (input_location,
4339 size_zero_node, BINFO_OFFSET (binfo)));
4340
4341 /* This is an empty base class. We first try to put it at offset
4342 zero. */
4343 if (layout_conflict_p (binfo,
4344 BINFO_OFFSET (binfo),
4345 offsets,
4346 /*vbases_p=*/0))
4347 {
4348 /* That didn't work. Now, we move forward from the next
4349 available spot in the class. */
4350 atend = true;
4351 propagate_binfo_offsets (binfo, convert (ssizetype, eoc));
4352 while (1)
4353 {
4354 if (!layout_conflict_p (binfo,
4355 BINFO_OFFSET (binfo),
4356 offsets,
4357 /*vbases_p=*/0))
4358 /* We finally found a spot where there's no overlap. */
4359 break;
4360
4361 /* There's overlap here, too. Bump along to the next spot. */
4362 propagate_binfo_offsets (binfo, alignment);
4363 }
4364 }
4365
4366 if (CLASSTYPE_USER_ALIGN (basetype))
4367 {
4368 rli->record_align = MAX (rli->record_align, CLASSTYPE_ALIGN (basetype));
4369 if (warn_packed)
4370 rli->unpacked_align = MAX (rli->unpacked_align, CLASSTYPE_ALIGN (basetype));
4371 TYPE_USER_ALIGN (rli->t) = 1;
4372 }
4373
4374 return atend;
4375 }
4376
4377 /* Layout the base given by BINFO in the class indicated by RLI.
4378 *BASE_ALIGN is a running maximum of the alignments of
4379 any base class. OFFSETS gives the location of empty base
4380 subobjects. T is the most derived type. Return nonzero if the new
4381 object cannot be nearly-empty. A new FIELD_DECL is inserted at
4382 *NEXT_FIELD, unless BINFO is for an empty base class.
4383
4384 Returns the location at which the next field should be inserted. */
4385
4386 static tree *
4387 build_base_field (record_layout_info rli, tree binfo,
4388 splay_tree offsets, tree *next_field)
4389 {
4390 tree t = rli->t;
4391 tree basetype = BINFO_TYPE (binfo);
4392
4393 if (!COMPLETE_TYPE_P (basetype))
4394 /* This error is now reported in xref_tag, thus giving better
4395 location information. */
4396 return next_field;
4397
4398 /* Place the base class. */
4399 if (!is_empty_class (basetype))
4400 {
4401 tree decl;
4402
4403 /* The containing class is non-empty because it has a non-empty
4404 base class. */
4405 CLASSTYPE_EMPTY_P (t) = 0;
4406
4407 /* Create the FIELD_DECL. */
4408 decl = build_decl (input_location,
4409 FIELD_DECL, NULL_TREE, CLASSTYPE_AS_BASE (basetype));
4410 DECL_ARTIFICIAL (decl) = 1;
4411 DECL_IGNORED_P (decl) = 1;
4412 DECL_FIELD_CONTEXT (decl) = t;
4413 if (CLASSTYPE_AS_BASE (basetype))
4414 {
4415 DECL_SIZE (decl) = CLASSTYPE_SIZE (basetype);
4416 DECL_SIZE_UNIT (decl) = CLASSTYPE_SIZE_UNIT (basetype);
4417 DECL_ALIGN (decl) = CLASSTYPE_ALIGN (basetype);
4418 DECL_USER_ALIGN (decl) = CLASSTYPE_USER_ALIGN (basetype);
4419 DECL_MODE (decl) = TYPE_MODE (basetype);
4420 DECL_FIELD_IS_BASE (decl) = 1;
4421
4422 /* Try to place the field. It may take more than one try if we
4423 have a hard time placing the field without putting two
4424 objects of the same type at the same address. */
4425 layout_nonempty_base_or_field (rli, decl, binfo, offsets);
4426 /* Add the new FIELD_DECL to the list of fields for T. */
4427 DECL_CHAIN (decl) = *next_field;
4428 *next_field = decl;
4429 next_field = &DECL_CHAIN (decl);
4430 }
4431 }
4432 else
4433 {
4434 tree eoc;
4435 bool atend;
4436
4437 /* On some platforms (ARM), even empty classes will not be
4438 byte-aligned. */
4439 eoc = round_up_loc (input_location,
4440 rli_size_unit_so_far (rli),
4441 CLASSTYPE_ALIGN_UNIT (basetype));
4442 atend = layout_empty_base (rli, binfo, eoc, offsets);
4443 /* A nearly-empty class "has no proper base class that is empty,
4444 not morally virtual, and at an offset other than zero." */
4445 if (!BINFO_VIRTUAL_P (binfo) && CLASSTYPE_NEARLY_EMPTY_P (t))
4446 {
4447 if (atend)
4448 CLASSTYPE_NEARLY_EMPTY_P (t) = 0;
4449 /* The check above (used in G++ 3.2) is insufficient because
4450 an empty class placed at offset zero might itself have an
4451 empty base at a nonzero offset. */
4452 else if (walk_subobject_offsets (basetype,
4453 empty_base_at_nonzero_offset_p,
4454 size_zero_node,
4455 /*offsets=*/NULL,
4456 /*max_offset=*/NULL_TREE,
4457 /*vbases_p=*/true))
4458 CLASSTYPE_NEARLY_EMPTY_P (t) = 0;
4459 }
4460
4461 /* We do not create a FIELD_DECL for empty base classes because
4462 it might overlap some other field. We want to be able to
4463 create CONSTRUCTORs for the class by iterating over the
4464 FIELD_DECLs, and the back end does not handle overlapping
4465 FIELD_DECLs. */
4466
4467 /* An empty virtual base causes a class to be non-empty
4468 -- but in that case we do not need to clear CLASSTYPE_EMPTY_P
4469 here because that was already done when the virtual table
4470 pointer was created. */
4471 }
4472
4473 /* Record the offsets of BINFO and its base subobjects. */
4474 record_subobject_offsets (binfo,
4475 BINFO_OFFSET (binfo),
4476 offsets,
4477 /*is_data_member=*/false);
4478
4479 return next_field;
4480 }
4481
4482 /* Layout all of the non-virtual base classes. Record empty
4483 subobjects in OFFSETS. T is the most derived type. Return nonzero
4484 if the type cannot be nearly empty. The fields created
4485 corresponding to the base classes will be inserted at
4486 *NEXT_FIELD. */
4487
4488 static void
4489 build_base_fields (record_layout_info rli,
4490 splay_tree offsets, tree *next_field)
4491 {
4492 /* Chain to hold all the new FIELD_DECLs which stand in for base class
4493 subobjects. */
4494 tree t = rli->t;
4495 int n_baseclasses = BINFO_N_BASE_BINFOS (TYPE_BINFO (t));
4496 int i;
4497
4498 /* The primary base class is always allocated first. */
4499 if (CLASSTYPE_HAS_PRIMARY_BASE_P (t))
4500 next_field = build_base_field (rli, CLASSTYPE_PRIMARY_BINFO (t),
4501 offsets, next_field);
4502
4503 /* Now allocate the rest of the bases. */
4504 for (i = 0; i < n_baseclasses; ++i)
4505 {
4506 tree base_binfo;
4507
4508 base_binfo = BINFO_BASE_BINFO (TYPE_BINFO (t), i);
4509
4510 /* The primary base was already allocated above, so we don't
4511 need to allocate it again here. */
4512 if (base_binfo == CLASSTYPE_PRIMARY_BINFO (t))
4513 continue;
4514
4515 /* Virtual bases are added at the end (a primary virtual base
4516 will have already been added). */
4517 if (BINFO_VIRTUAL_P (base_binfo))
4518 continue;
4519
4520 next_field = build_base_field (rli, base_binfo,
4521 offsets, next_field);
4522 }
4523 }
4524
4525 /* Go through the TYPE_METHODS of T issuing any appropriate
4526 diagnostics, figuring out which methods override which other
4527 methods, and so forth. */
4528
4529 static void
4530 check_methods (tree t)
4531 {
4532 tree x;
4533
4534 for (x = TYPE_METHODS (t); x; x = DECL_CHAIN (x))
4535 {
4536 check_for_override (x, t);
4537 if (DECL_PURE_VIRTUAL_P (x) && (TREE_CODE (x) != FUNCTION_DECL || ! DECL_VINDEX (x)))
4538 error ("initializer specified for non-virtual method %q+D", x);
4539 /* The name of the field is the original field name
4540 Save this in auxiliary field for later overloading. */
4541 if (TREE_CODE (x) == FUNCTION_DECL && DECL_VINDEX (x))
4542 {
4543 TYPE_POLYMORPHIC_P (t) = 1;
4544 if (DECL_PURE_VIRTUAL_P (x))
4545 vec_safe_push (CLASSTYPE_PURE_VIRTUALS (t), x);
4546 }
4547 /* All user-provided destructors are non-trivial.
4548 Constructors and assignment ops are handled in
4549 grok_special_member_properties. */
4550 if (DECL_DESTRUCTOR_P (x) && user_provided_p (x))
4551 TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t) = 1;
4552 }
4553 }
4554
4555 /* FN is a constructor or destructor. Clone the declaration to create
4556 a specialized in-charge or not-in-charge version, as indicated by
4557 NAME. */
4558
4559 static tree
4560 build_clone (tree fn, tree name)
4561 {
4562 tree parms;
4563 tree clone;
4564
4565 /* Copy the function. */
4566 clone = copy_decl (fn);
4567 /* Reset the function name. */
4568 DECL_NAME (clone) = name;
4569 /* Remember where this function came from. */
4570 DECL_ABSTRACT_ORIGIN (clone) = fn;
4571 /* Make it easy to find the CLONE given the FN. */
4572 DECL_CHAIN (clone) = DECL_CHAIN (fn);
4573 DECL_CHAIN (fn) = clone;
4574
4575 /* If this is a template, do the rest on the DECL_TEMPLATE_RESULT. */
4576 if (TREE_CODE (clone) == TEMPLATE_DECL)
4577 {
4578 tree result = build_clone (DECL_TEMPLATE_RESULT (clone), name);
4579 DECL_TEMPLATE_RESULT (clone) = result;
4580 DECL_TEMPLATE_INFO (result) = copy_node (DECL_TEMPLATE_INFO (result));
4581 DECL_TI_TEMPLATE (result) = clone;
4582 TREE_TYPE (clone) = TREE_TYPE (result);
4583 return clone;
4584 }
4585
4586 SET_DECL_ASSEMBLER_NAME (clone, NULL_TREE);
4587 DECL_CLONED_FUNCTION (clone) = fn;
4588 /* There's no pending inline data for this function. */
4589 DECL_PENDING_INLINE_INFO (clone) = NULL;
4590 DECL_PENDING_INLINE_P (clone) = 0;
4591
4592 /* The base-class destructor is not virtual. */
4593 if (name == base_dtor_identifier)
4594 {
4595 DECL_VIRTUAL_P (clone) = 0;
4596 if (TREE_CODE (clone) != TEMPLATE_DECL)
4597 DECL_VINDEX (clone) = NULL_TREE;
4598 }
4599
4600 /* If there was an in-charge parameter, drop it from the function
4601 type. */
4602 if (DECL_HAS_IN_CHARGE_PARM_P (clone))
4603 {
4604 tree basetype;
4605 tree parmtypes;
4606 tree exceptions;
4607
4608 exceptions = TYPE_RAISES_EXCEPTIONS (TREE_TYPE (clone));
4609 basetype = TYPE_METHOD_BASETYPE (TREE_TYPE (clone));
4610 parmtypes = TYPE_ARG_TYPES (TREE_TYPE (clone));
4611 /* Skip the `this' parameter. */
4612 parmtypes = TREE_CHAIN (parmtypes);
4613 /* Skip the in-charge parameter. */
4614 parmtypes = TREE_CHAIN (parmtypes);
4615 /* And the VTT parm, in a complete [cd]tor. */
4616 if (DECL_HAS_VTT_PARM_P (fn)
4617 && ! DECL_NEEDS_VTT_PARM_P (clone))
4618 parmtypes = TREE_CHAIN (parmtypes);
4619 /* If this is subobject constructor or destructor, add the vtt
4620 parameter. */
4621 TREE_TYPE (clone)
4622 = build_method_type_directly (basetype,
4623 TREE_TYPE (TREE_TYPE (clone)),
4624 parmtypes);
4625 if (exceptions)
4626 TREE_TYPE (clone) = build_exception_variant (TREE_TYPE (clone),
4627 exceptions);
4628 TREE_TYPE (clone)
4629 = cp_build_type_attribute_variant (TREE_TYPE (clone),
4630 TYPE_ATTRIBUTES (TREE_TYPE (fn)));
4631 }
4632
4633 /* Copy the function parameters. */
4634 DECL_ARGUMENTS (clone) = copy_list (DECL_ARGUMENTS (clone));
4635 /* Remove the in-charge parameter. */
4636 if (DECL_HAS_IN_CHARGE_PARM_P (clone))
4637 {
4638 DECL_CHAIN (DECL_ARGUMENTS (clone))
4639 = DECL_CHAIN (DECL_CHAIN (DECL_ARGUMENTS (clone)));
4640 DECL_HAS_IN_CHARGE_PARM_P (clone) = 0;
4641 }
4642 /* And the VTT parm, in a complete [cd]tor. */
4643 if (DECL_HAS_VTT_PARM_P (fn))
4644 {
4645 if (DECL_NEEDS_VTT_PARM_P (clone))
4646 DECL_HAS_VTT_PARM_P (clone) = 1;
4647 else
4648 {
4649 DECL_CHAIN (DECL_ARGUMENTS (clone))
4650 = DECL_CHAIN (DECL_CHAIN (DECL_ARGUMENTS (clone)));
4651 DECL_HAS_VTT_PARM_P (clone) = 0;
4652 }
4653 }
4654
4655 for (parms = DECL_ARGUMENTS (clone); parms; parms = DECL_CHAIN (parms))
4656 {
4657 DECL_CONTEXT (parms) = clone;
4658 cxx_dup_lang_specific_decl (parms);
4659 }
4660
4661 /* Create the RTL for this function. */
4662 SET_DECL_RTL (clone, NULL);
4663 rest_of_decl_compilation (clone, /*top_level=*/1, at_eof);
4664
4665 if (pch_file)
4666 note_decl_for_pch (clone);
4667
4668 return clone;
4669 }
4670
4671 /* Implementation of DECL_CLONED_FUNCTION and DECL_CLONED_FUNCTION_P, do
4672 not invoke this function directly.
4673
4674 For a non-thunk function, returns the address of the slot for storing
4675 the function it is a clone of. Otherwise returns NULL_TREE.
4676
4677 If JUST_TESTING, looks through TEMPLATE_DECL and returns NULL if
4678 cloned_function is unset. This is to support the separate
4679 DECL_CLONED_FUNCTION and DECL_CLONED_FUNCTION_P modes; using the latter
4680 on a template makes sense, but not the former. */
4681
4682 tree *
4683 decl_cloned_function_p (const_tree decl, bool just_testing)
4684 {
4685 tree *ptr;
4686 if (just_testing)
4687 decl = STRIP_TEMPLATE (decl);
4688
4689 if (TREE_CODE (decl) != FUNCTION_DECL
4690 || !DECL_LANG_SPECIFIC (decl)
4691 || DECL_LANG_SPECIFIC (decl)->u.fn.thunk_p)
4692 {
4693 #if defined ENABLE_TREE_CHECKING && (GCC_VERSION >= 2007)
4694 if (!just_testing)
4695 lang_check_failed (__FILE__, __LINE__, __FUNCTION__);
4696 else
4697 #endif
4698 return NULL;
4699 }
4700
4701 ptr = &DECL_LANG_SPECIFIC (decl)->u.fn.u5.cloned_function;
4702 if (just_testing && *ptr == NULL_TREE)
4703 return NULL;
4704 else
4705 return ptr;
4706 }
4707
4708 /* Produce declarations for all appropriate clones of FN. If
4709 UPDATE_METHOD_VEC_P is nonzero, the clones are added to the
4710 CLASTYPE_METHOD_VEC as well. */
4711
4712 void
4713 clone_function_decl (tree fn, int update_method_vec_p)
4714 {
4715 tree clone;
4716
4717 /* Avoid inappropriate cloning. */
4718 if (DECL_CHAIN (fn)
4719 && DECL_CLONED_FUNCTION_P (DECL_CHAIN (fn)))
4720 return;
4721
4722 if (DECL_MAYBE_IN_CHARGE_CONSTRUCTOR_P (fn))
4723 {
4724 /* For each constructor, we need two variants: an in-charge version
4725 and a not-in-charge version. */
4726 clone = build_clone (fn, complete_ctor_identifier);
4727 if (update_method_vec_p)
4728 add_method (DECL_CONTEXT (clone), clone, NULL_TREE);
4729 clone = build_clone (fn, base_ctor_identifier);
4730 if (update_method_vec_p)
4731 add_method (DECL_CONTEXT (clone), clone, NULL_TREE);
4732 }
4733 else
4734 {
4735 gcc_assert (DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P (fn));
4736
4737 /* For each destructor, we need three variants: an in-charge
4738 version, a not-in-charge version, and an in-charge deleting
4739 version. We clone the deleting version first because that
4740 means it will go second on the TYPE_METHODS list -- and that
4741 corresponds to the correct layout order in the virtual
4742 function table.
4743
4744 For a non-virtual destructor, we do not build a deleting
4745 destructor. */
4746 if (DECL_VIRTUAL_P (fn))
4747 {
4748 clone = build_clone (fn, deleting_dtor_identifier);
4749 if (update_method_vec_p)
4750 add_method (DECL_CONTEXT (clone), clone, NULL_TREE);
4751 }
4752 clone = build_clone (fn, complete_dtor_identifier);
4753 if (update_method_vec_p)
4754 add_method (DECL_CONTEXT (clone), clone, NULL_TREE);
4755 clone = build_clone (fn, base_dtor_identifier);
4756 if (update_method_vec_p)
4757 add_method (DECL_CONTEXT (clone), clone, NULL_TREE);
4758 }
4759
4760 /* Note that this is an abstract function that is never emitted. */
4761 DECL_ABSTRACT_P (fn) = true;
4762 }
4763
4764 /* DECL is an in charge constructor, which is being defined. This will
4765 have had an in class declaration, from whence clones were
4766 declared. An out-of-class definition can specify additional default
4767 arguments. As it is the clones that are involved in overload
4768 resolution, we must propagate the information from the DECL to its
4769 clones. */
4770
4771 void
4772 adjust_clone_args (tree decl)
4773 {
4774 tree clone;
4775
4776 for (clone = DECL_CHAIN (decl); clone && DECL_CLONED_FUNCTION_P (clone);
4777 clone = DECL_CHAIN (clone))
4778 {
4779 tree orig_clone_parms = TYPE_ARG_TYPES (TREE_TYPE (clone));
4780 tree orig_decl_parms = TYPE_ARG_TYPES (TREE_TYPE (decl));
4781 tree decl_parms, clone_parms;
4782
4783 clone_parms = orig_clone_parms;
4784
4785 /* Skip the 'this' parameter. */
4786 orig_clone_parms = TREE_CHAIN (orig_clone_parms);
4787 orig_decl_parms = TREE_CHAIN (orig_decl_parms);
4788
4789 if (DECL_HAS_IN_CHARGE_PARM_P (decl))
4790 orig_decl_parms = TREE_CHAIN (orig_decl_parms);
4791 if (DECL_HAS_VTT_PARM_P (decl))
4792 orig_decl_parms = TREE_CHAIN (orig_decl_parms);
4793
4794 clone_parms = orig_clone_parms;
4795 if (DECL_HAS_VTT_PARM_P (clone))
4796 clone_parms = TREE_CHAIN (clone_parms);
4797
4798 for (decl_parms = orig_decl_parms; decl_parms;
4799 decl_parms = TREE_CHAIN (decl_parms),
4800 clone_parms = TREE_CHAIN (clone_parms))
4801 {
4802 gcc_assert (same_type_p (TREE_TYPE (decl_parms),
4803 TREE_TYPE (clone_parms)));
4804
4805 if (TREE_PURPOSE (decl_parms) && !TREE_PURPOSE (clone_parms))
4806 {
4807 /* A default parameter has been added. Adjust the
4808 clone's parameters. */
4809 tree exceptions = TYPE_RAISES_EXCEPTIONS (TREE_TYPE (clone));
4810 tree attrs = TYPE_ATTRIBUTES (TREE_TYPE (clone));
4811 tree basetype = TYPE_METHOD_BASETYPE (TREE_TYPE (clone));
4812 tree type;
4813
4814 clone_parms = orig_decl_parms;
4815
4816 if (DECL_HAS_VTT_PARM_P (clone))
4817 {
4818 clone_parms = tree_cons (TREE_PURPOSE (orig_clone_parms),
4819 TREE_VALUE (orig_clone_parms),
4820 clone_parms);
4821 TREE_TYPE (clone_parms) = TREE_TYPE (orig_clone_parms);
4822 }
4823 type = build_method_type_directly (basetype,
4824 TREE_TYPE (TREE_TYPE (clone)),
4825 clone_parms);
4826 if (exceptions)
4827 type = build_exception_variant (type, exceptions);
4828 if (attrs)
4829 type = cp_build_type_attribute_variant (type, attrs);
4830 TREE_TYPE (clone) = type;
4831
4832 clone_parms = NULL_TREE;
4833 break;
4834 }
4835 }
4836 gcc_assert (!clone_parms);
4837 }
4838 }
4839
4840 /* For each of the constructors and destructors in T, create an
4841 in-charge and not-in-charge variant. */
4842
4843 static void
4844 clone_constructors_and_destructors (tree t)
4845 {
4846 tree fns;
4847
4848 /* If for some reason we don't have a CLASSTYPE_METHOD_VEC, we bail
4849 out now. */
4850 if (!CLASSTYPE_METHOD_VEC (t))
4851 return;
4852
4853 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
4854 clone_function_decl (OVL_CURRENT (fns), /*update_method_vec_p=*/1);
4855 for (fns = CLASSTYPE_DESTRUCTORS (t); fns; fns = OVL_NEXT (fns))
4856 clone_function_decl (OVL_CURRENT (fns), /*update_method_vec_p=*/1);
4857 }
4858
4859 /* Deduce noexcept for a destructor DTOR. */
4860
4861 void
4862 deduce_noexcept_on_destructor (tree dtor)
4863 {
4864 if (!TYPE_RAISES_EXCEPTIONS (TREE_TYPE (dtor)))
4865 {
4866 tree eh_spec = unevaluated_noexcept_spec ();
4867 TREE_TYPE (dtor) = build_exception_variant (TREE_TYPE (dtor), eh_spec);
4868 }
4869 }
4870
4871 /* For each destructor in T, deduce noexcept:
4872
4873 12.4/3: A declaration of a destructor that does not have an
4874 exception-specification is implicitly considered to have the
4875 same exception-specification as an implicit declaration (15.4). */
4876
4877 static void
4878 deduce_noexcept_on_destructors (tree t)
4879 {
4880 /* If for some reason we don't have a CLASSTYPE_METHOD_VEC, we bail
4881 out now. */
4882 if (!CLASSTYPE_METHOD_VEC (t))
4883 return;
4884
4885 for (tree fns = CLASSTYPE_DESTRUCTORS (t); fns; fns = OVL_NEXT (fns))
4886 deduce_noexcept_on_destructor (OVL_CURRENT (fns));
4887 }
4888
4889 /* Subroutine of set_one_vmethod_tm_attributes. Search base classes
4890 of TYPE for virtual functions which FNDECL overrides. Return a
4891 mask of the tm attributes found therein. */
4892
4893 static int
4894 look_for_tm_attr_overrides (tree type, tree fndecl)
4895 {
4896 tree binfo = TYPE_BINFO (type);
4897 tree base_binfo;
4898 int ix, found = 0;
4899
4900 for (ix = 0; BINFO_BASE_ITERATE (binfo, ix, base_binfo); ++ix)
4901 {
4902 tree o, basetype = BINFO_TYPE (base_binfo);
4903
4904 if (!TYPE_POLYMORPHIC_P (basetype))
4905 continue;
4906
4907 o = look_for_overrides_here (basetype, fndecl);
4908 if (o)
4909 found |= tm_attr_to_mask (find_tm_attribute
4910 (TYPE_ATTRIBUTES (TREE_TYPE (o))));
4911 else
4912 found |= look_for_tm_attr_overrides (basetype, fndecl);
4913 }
4914
4915 return found;
4916 }
4917
4918 /* Subroutine of set_method_tm_attributes. Handle the checks and
4919 inheritance for one virtual method FNDECL. */
4920
4921 static void
4922 set_one_vmethod_tm_attributes (tree type, tree fndecl)
4923 {
4924 tree tm_attr;
4925 int found, have;
4926
4927 found = look_for_tm_attr_overrides (type, fndecl);
4928
4929 /* If FNDECL doesn't actually override anything (i.e. T is the
4930 class that first declares FNDECL virtual), then we're done. */
4931 if (found == 0)
4932 return;
4933
4934 tm_attr = find_tm_attribute (TYPE_ATTRIBUTES (TREE_TYPE (fndecl)));
4935 have = tm_attr_to_mask (tm_attr);
4936
4937 /* Intel STM Language Extension 3.0, Section 4.2 table 4:
4938 tm_pure must match exactly, otherwise no weakening of
4939 tm_safe > tm_callable > nothing. */
4940 /* ??? The tm_pure attribute didn't make the transition to the
4941 multivendor language spec. */
4942 if (have == TM_ATTR_PURE)
4943 {
4944 if (found != TM_ATTR_PURE)
4945 {
4946 found &= -found;
4947 goto err_override;
4948 }
4949 }
4950 /* If the overridden function is tm_pure, then FNDECL must be. */
4951 else if (found == TM_ATTR_PURE && tm_attr)
4952 goto err_override;
4953 /* Look for base class combinations that cannot be satisfied. */
4954 else if (found != TM_ATTR_PURE && (found & TM_ATTR_PURE))
4955 {
4956 found &= ~TM_ATTR_PURE;
4957 found &= -found;
4958 error_at (DECL_SOURCE_LOCATION (fndecl),
4959 "method overrides both %<transaction_pure%> and %qE methods",
4960 tm_mask_to_attr (found));
4961 }
4962 /* If FNDECL did not declare an attribute, then inherit the most
4963 restrictive one. */
4964 else if (tm_attr == NULL)
4965 {
4966 apply_tm_attr (fndecl, tm_mask_to_attr (found & -found));
4967 }
4968 /* Otherwise validate that we're not weaker than a function
4969 that is being overridden. */
4970 else
4971 {
4972 found &= -found;
4973 if (found <= TM_ATTR_CALLABLE && have > found)
4974 goto err_override;
4975 }
4976 return;
4977
4978 err_override:
4979 error_at (DECL_SOURCE_LOCATION (fndecl),
4980 "method declared %qE overriding %qE method",
4981 tm_attr, tm_mask_to_attr (found));
4982 }
4983
4984 /* For each of the methods in T, propagate a class-level tm attribute. */
4985
4986 static void
4987 set_method_tm_attributes (tree t)
4988 {
4989 tree class_tm_attr, fndecl;
4990
4991 /* Don't bother collecting tm attributes if transactional memory
4992 support is not enabled. */
4993 if (!flag_tm)
4994 return;
4995
4996 /* Process virtual methods first, as they inherit directly from the
4997 base virtual function and also require validation of new attributes. */
4998 if (TYPE_CONTAINS_VPTR_P (t))
4999 {
5000 tree vchain;
5001 for (vchain = BINFO_VIRTUALS (TYPE_BINFO (t)); vchain;
5002 vchain = TREE_CHAIN (vchain))
5003 {
5004 fndecl = BV_FN (vchain);
5005 if (DECL_THUNK_P (fndecl))
5006 fndecl = THUNK_TARGET (fndecl);
5007 set_one_vmethod_tm_attributes (t, fndecl);
5008 }
5009 }
5010
5011 /* If the class doesn't have an attribute, nothing more to do. */
5012 class_tm_attr = find_tm_attribute (TYPE_ATTRIBUTES (t));
5013 if (class_tm_attr == NULL)
5014 return;
5015
5016 /* Any method that does not yet have a tm attribute inherits
5017 the one from the class. */
5018 for (fndecl = TYPE_METHODS (t); fndecl; fndecl = TREE_CHAIN (fndecl))
5019 {
5020 if (!find_tm_attribute (TYPE_ATTRIBUTES (TREE_TYPE (fndecl))))
5021 apply_tm_attr (fndecl, class_tm_attr);
5022 }
5023 }
5024
5025 /* Returns true iff class T has a user-defined constructor other than
5026 the default constructor. */
5027
5028 bool
5029 type_has_user_nondefault_constructor (tree t)
5030 {
5031 tree fns;
5032
5033 if (!TYPE_HAS_USER_CONSTRUCTOR (t))
5034 return false;
5035
5036 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
5037 {
5038 tree fn = OVL_CURRENT (fns);
5039 if (!DECL_ARTIFICIAL (fn)
5040 && (TREE_CODE (fn) == TEMPLATE_DECL
5041 || (skip_artificial_parms_for (fn, DECL_ARGUMENTS (fn))
5042 != NULL_TREE)))
5043 return true;
5044 }
5045
5046 return false;
5047 }
5048
5049 /* Returns the defaulted constructor if T has one. Otherwise, returns
5050 NULL_TREE. */
5051
5052 tree
5053 in_class_defaulted_default_constructor (tree t)
5054 {
5055 tree fns, args;
5056
5057 if (!TYPE_HAS_USER_CONSTRUCTOR (t))
5058 return NULL_TREE;
5059
5060 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
5061 {
5062 tree fn = OVL_CURRENT (fns);
5063
5064 if (DECL_DEFAULTED_IN_CLASS_P (fn))
5065 {
5066 args = FUNCTION_FIRST_USER_PARMTYPE (fn);
5067 while (args && TREE_PURPOSE (args))
5068 args = TREE_CHAIN (args);
5069 if (!args || args == void_list_node)
5070 return fn;
5071 }
5072 }
5073
5074 return NULL_TREE;
5075 }
5076
5077 /* Returns true iff FN is a user-provided function, i.e. user-declared
5078 and not defaulted at its first declaration; or explicit, private,
5079 protected, or non-const. */
5080
5081 bool
5082 user_provided_p (tree fn)
5083 {
5084 if (TREE_CODE (fn) == TEMPLATE_DECL)
5085 return true;
5086 else
5087 return (!DECL_ARTIFICIAL (fn)
5088 && !(DECL_INITIALIZED_IN_CLASS_P (fn)
5089 && (DECL_DEFAULTED_FN (fn) || DECL_DELETED_FN (fn))));
5090 }
5091
5092 /* Returns true iff class T has a user-provided constructor. */
5093
5094 bool
5095 type_has_user_provided_constructor (tree t)
5096 {
5097 tree fns;
5098
5099 if (!CLASS_TYPE_P (t))
5100 return false;
5101
5102 if (!TYPE_HAS_USER_CONSTRUCTOR (t))
5103 return false;
5104
5105 /* This can happen in error cases; avoid crashing. */
5106 if (!CLASSTYPE_METHOD_VEC (t))
5107 return false;
5108
5109 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
5110 if (user_provided_p (OVL_CURRENT (fns)))
5111 return true;
5112
5113 return false;
5114 }
5115
5116 /* Returns true iff class T has a non-user-provided (i.e. implicitly
5117 declared or explicitly defaulted in the class body) default
5118 constructor. */
5119
5120 bool
5121 type_has_non_user_provided_default_constructor (tree t)
5122 {
5123 tree fns;
5124
5125 if (!TYPE_HAS_DEFAULT_CONSTRUCTOR (t))
5126 return false;
5127 if (CLASSTYPE_LAZY_DEFAULT_CTOR (t))
5128 return true;
5129
5130 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
5131 {
5132 tree fn = OVL_CURRENT (fns);
5133 if (TREE_CODE (fn) == FUNCTION_DECL
5134 && !user_provided_p (fn)
5135 && sufficient_parms_p (FUNCTION_FIRST_USER_PARMTYPE (fn)))
5136 return true;
5137 }
5138
5139 return false;
5140 }
5141
5142 /* TYPE is being used as a virtual base, and has a non-trivial move
5143 assignment. Return true if this is due to there being a user-provided
5144 move assignment in TYPE or one of its subobjects; if there isn't, then
5145 multiple move assignment can't cause any harm. */
5146
5147 bool
5148 vbase_has_user_provided_move_assign (tree type)
5149 {
5150 /* Does the type itself have a user-provided move assignment operator? */
5151 for (tree fns
5152 = lookup_fnfields_slot_nolazy (type, ansi_assopname (NOP_EXPR));
5153 fns; fns = OVL_NEXT (fns))
5154 {
5155 tree fn = OVL_CURRENT (fns);
5156 if (move_fn_p (fn) && user_provided_p (fn))
5157 return true;
5158 }
5159
5160 /* Do any of its bases? */
5161 tree binfo = TYPE_BINFO (type);
5162 tree base_binfo;
5163 for (int i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
5164 if (vbase_has_user_provided_move_assign (BINFO_TYPE (base_binfo)))
5165 return true;
5166
5167 /* Or non-static data members? */
5168 for (tree field = TYPE_FIELDS (type); field; field = DECL_CHAIN (field))
5169 {
5170 if (TREE_CODE (field) == FIELD_DECL
5171 && CLASS_TYPE_P (TREE_TYPE (field))
5172 && vbase_has_user_provided_move_assign (TREE_TYPE (field)))
5173 return true;
5174 }
5175
5176 /* Seems not. */
5177 return false;
5178 }
5179
5180 /* If default-initialization leaves part of TYPE uninitialized, returns
5181 a DECL for the field or TYPE itself (DR 253). */
5182
5183 tree
5184 default_init_uninitialized_part (tree type)
5185 {
5186 tree t, r, binfo;
5187 int i;
5188
5189 type = strip_array_types (type);
5190 if (!CLASS_TYPE_P (type))
5191 return type;
5192 if (!type_has_non_user_provided_default_constructor (type))
5193 return NULL_TREE;
5194 for (binfo = TYPE_BINFO (type), i = 0;
5195 BINFO_BASE_ITERATE (binfo, i, t); ++i)
5196 {
5197 r = default_init_uninitialized_part (BINFO_TYPE (t));
5198 if (r)
5199 return r;
5200 }
5201 for (t = TYPE_FIELDS (type); t; t = DECL_CHAIN (t))
5202 if (TREE_CODE (t) == FIELD_DECL
5203 && !DECL_ARTIFICIAL (t)
5204 && !DECL_INITIAL (t))
5205 {
5206 r = default_init_uninitialized_part (TREE_TYPE (t));
5207 if (r)
5208 return DECL_P (r) ? r : t;
5209 }
5210
5211 return NULL_TREE;
5212 }
5213
5214 /* Returns true iff for class T, a trivial synthesized default constructor
5215 would be constexpr. */
5216
5217 bool
5218 trivial_default_constructor_is_constexpr (tree t)
5219 {
5220 /* A defaulted trivial default constructor is constexpr
5221 if there is nothing to initialize. */
5222 gcc_assert (!TYPE_HAS_COMPLEX_DFLT (t));
5223 return is_really_empty_class (t);
5224 }
5225
5226 /* Returns true iff class T has a constexpr default constructor. */
5227
5228 bool
5229 type_has_constexpr_default_constructor (tree t)
5230 {
5231 tree fns;
5232
5233 if (!CLASS_TYPE_P (t))
5234 {
5235 /* The caller should have stripped an enclosing array. */
5236 gcc_assert (TREE_CODE (t) != ARRAY_TYPE);
5237 return false;
5238 }
5239 if (CLASSTYPE_LAZY_DEFAULT_CTOR (t))
5240 {
5241 if (!TYPE_HAS_COMPLEX_DFLT (t))
5242 return trivial_default_constructor_is_constexpr (t);
5243 /* Non-trivial, we need to check subobject constructors. */
5244 lazily_declare_fn (sfk_constructor, t);
5245 }
5246 fns = locate_ctor (t);
5247 return (fns && DECL_DECLARED_CONSTEXPR_P (fns));
5248 }
5249
5250 /* Returns true iff class TYPE has a virtual destructor. */
5251
5252 bool
5253 type_has_virtual_destructor (tree type)
5254 {
5255 tree dtor;
5256
5257 if (!CLASS_TYPE_P (type))
5258 return false;
5259
5260 gcc_assert (COMPLETE_TYPE_P (type));
5261 dtor = CLASSTYPE_DESTRUCTORS (type);
5262 return (dtor && DECL_VIRTUAL_P (dtor));
5263 }
5264
5265 /* Returns true iff class T has a move constructor. */
5266
5267 bool
5268 type_has_move_constructor (tree t)
5269 {
5270 tree fns;
5271
5272 if (CLASSTYPE_LAZY_MOVE_CTOR (t))
5273 {
5274 gcc_assert (COMPLETE_TYPE_P (t));
5275 lazily_declare_fn (sfk_move_constructor, t);
5276 }
5277
5278 if (!CLASSTYPE_METHOD_VEC (t))
5279 return false;
5280
5281 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
5282 if (move_fn_p (OVL_CURRENT (fns)))
5283 return true;
5284
5285 return false;
5286 }
5287
5288 /* Returns true iff class T has a move assignment operator. */
5289
5290 bool
5291 type_has_move_assign (tree t)
5292 {
5293 tree fns;
5294
5295 if (CLASSTYPE_LAZY_MOVE_ASSIGN (t))
5296 {
5297 gcc_assert (COMPLETE_TYPE_P (t));
5298 lazily_declare_fn (sfk_move_assignment, t);
5299 }
5300
5301 for (fns = lookup_fnfields_slot_nolazy (t, ansi_assopname (NOP_EXPR));
5302 fns; fns = OVL_NEXT (fns))
5303 if (move_fn_p (OVL_CURRENT (fns)))
5304 return true;
5305
5306 return false;
5307 }
5308
5309 /* Returns true iff class T has a move constructor that was explicitly
5310 declared in the class body. Note that this is different from
5311 "user-provided", which doesn't include functions that are defaulted in
5312 the class. */
5313
5314 bool
5315 type_has_user_declared_move_constructor (tree t)
5316 {
5317 tree fns;
5318
5319 if (CLASSTYPE_LAZY_MOVE_CTOR (t))
5320 return false;
5321
5322 if (!CLASSTYPE_METHOD_VEC (t))
5323 return false;
5324
5325 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
5326 {
5327 tree fn = OVL_CURRENT (fns);
5328 if (move_fn_p (fn) && !DECL_ARTIFICIAL (fn))
5329 return true;
5330 }
5331
5332 return false;
5333 }
5334
5335 /* Returns true iff class T has a move assignment operator that was
5336 explicitly declared in the class body. */
5337
5338 bool
5339 type_has_user_declared_move_assign (tree t)
5340 {
5341 tree fns;
5342
5343 if (CLASSTYPE_LAZY_MOVE_ASSIGN (t))
5344 return false;
5345
5346 for (fns = lookup_fnfields_slot_nolazy (t, ansi_assopname (NOP_EXPR));
5347 fns; fns = OVL_NEXT (fns))
5348 {
5349 tree fn = OVL_CURRENT (fns);
5350 if (move_fn_p (fn) && !DECL_ARTIFICIAL (fn))
5351 return true;
5352 }
5353
5354 return false;
5355 }
5356
5357 /* Nonzero if we need to build up a constructor call when initializing an
5358 object of this class, either because it has a user-declared constructor
5359 or because it doesn't have a default constructor (so we need to give an
5360 error if no initializer is provided). Use TYPE_NEEDS_CONSTRUCTING when
5361 what you care about is whether or not an object can be produced by a
5362 constructor (e.g. so we don't set TREE_READONLY on const variables of
5363 such type); use this function when what you care about is whether or not
5364 to try to call a constructor to create an object. The latter case is
5365 the former plus some cases of constructors that cannot be called. */
5366
5367 bool
5368 type_build_ctor_call (tree t)
5369 {
5370 tree inner;
5371 if (TYPE_NEEDS_CONSTRUCTING (t))
5372 return true;
5373 inner = strip_array_types (t);
5374 if (!CLASS_TYPE_P (inner) || ANON_AGGR_TYPE_P (inner))
5375 return false;
5376 if (!TYPE_HAS_DEFAULT_CONSTRUCTOR (inner))
5377 return true;
5378 if (cxx_dialect < cxx11)
5379 return false;
5380 /* A user-declared constructor might be private, and a constructor might
5381 be trivial but deleted. */
5382 for (tree fns = lookup_fnfields_slot (inner, complete_ctor_identifier);
5383 fns; fns = OVL_NEXT (fns))
5384 {
5385 tree fn = OVL_CURRENT (fns);
5386 if (!DECL_ARTIFICIAL (fn)
5387 || DECL_DELETED_FN (fn))
5388 return true;
5389 }
5390 return false;
5391 }
5392
5393 /* Like type_build_ctor_call, but for destructors. */
5394
5395 bool
5396 type_build_dtor_call (tree t)
5397 {
5398 tree inner;
5399 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t))
5400 return true;
5401 inner = strip_array_types (t);
5402 if (!CLASS_TYPE_P (inner) || ANON_AGGR_TYPE_P (inner)
5403 || !COMPLETE_TYPE_P (inner))
5404 return false;
5405 if (cxx_dialect < cxx11)
5406 return false;
5407 /* A user-declared destructor might be private, and a destructor might
5408 be trivial but deleted. */
5409 for (tree fns = lookup_fnfields_slot (inner, complete_dtor_identifier);
5410 fns; fns = OVL_NEXT (fns))
5411 {
5412 tree fn = OVL_CURRENT (fns);
5413 if (!DECL_ARTIFICIAL (fn)
5414 || DECL_DELETED_FN (fn))
5415 return true;
5416 }
5417 return false;
5418 }
5419
5420 /* Remove all zero-width bit-fields from T. */
5421
5422 static void
5423 remove_zero_width_bit_fields (tree t)
5424 {
5425 tree *fieldsp;
5426
5427 fieldsp = &TYPE_FIELDS (t);
5428 while (*fieldsp)
5429 {
5430 if (TREE_CODE (*fieldsp) == FIELD_DECL
5431 && DECL_C_BIT_FIELD (*fieldsp)
5432 /* We should not be confused by the fact that grokbitfield
5433 temporarily sets the width of the bit field into
5434 DECL_INITIAL (*fieldsp).
5435 check_bitfield_decl eventually sets DECL_SIZE (*fieldsp)
5436 to that width. */
5437 && integer_zerop (DECL_SIZE (*fieldsp)))
5438 *fieldsp = DECL_CHAIN (*fieldsp);
5439 else
5440 fieldsp = &DECL_CHAIN (*fieldsp);
5441 }
5442 }
5443
5444 /* Returns TRUE iff we need a cookie when dynamically allocating an
5445 array whose elements have the indicated class TYPE. */
5446
5447 static bool
5448 type_requires_array_cookie (tree type)
5449 {
5450 tree fns;
5451 bool has_two_argument_delete_p = false;
5452
5453 gcc_assert (CLASS_TYPE_P (type));
5454
5455 /* If there's a non-trivial destructor, we need a cookie. In order
5456 to iterate through the array calling the destructor for each
5457 element, we'll have to know how many elements there are. */
5458 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (type))
5459 return true;
5460
5461 /* If the usual deallocation function is a two-argument whose second
5462 argument is of type `size_t', then we have to pass the size of
5463 the array to the deallocation function, so we will need to store
5464 a cookie. */
5465 fns = lookup_fnfields (TYPE_BINFO (type),
5466 ansi_opname (VEC_DELETE_EXPR),
5467 /*protect=*/0);
5468 /* If there are no `operator []' members, or the lookup is
5469 ambiguous, then we don't need a cookie. */
5470 if (!fns || fns == error_mark_node)
5471 return false;
5472 /* Loop through all of the functions. */
5473 for (fns = BASELINK_FUNCTIONS (fns); fns; fns = OVL_NEXT (fns))
5474 {
5475 tree fn;
5476 tree second_parm;
5477
5478 /* Select the current function. */
5479 fn = OVL_CURRENT (fns);
5480 /* See if this function is a one-argument delete function. If
5481 it is, then it will be the usual deallocation function. */
5482 second_parm = TREE_CHAIN (TYPE_ARG_TYPES (TREE_TYPE (fn)));
5483 if (second_parm == void_list_node)
5484 return false;
5485 /* Do not consider this function if its second argument is an
5486 ellipsis. */
5487 if (!second_parm)
5488 continue;
5489 /* Otherwise, if we have a two-argument function and the second
5490 argument is `size_t', it will be the usual deallocation
5491 function -- unless there is one-argument function, too. */
5492 if (TREE_CHAIN (second_parm) == void_list_node
5493 && same_type_p (TREE_VALUE (second_parm), size_type_node))
5494 has_two_argument_delete_p = true;
5495 }
5496
5497 return has_two_argument_delete_p;
5498 }
5499
5500 /* Finish computing the `literal type' property of class type T.
5501
5502 At this point, we have already processed base classes and
5503 non-static data members. We need to check whether the copy
5504 constructor is trivial, the destructor is trivial, and there
5505 is a trivial default constructor or at least one constexpr
5506 constructor other than the copy constructor. */
5507
5508 static void
5509 finalize_literal_type_property (tree t)
5510 {
5511 tree fn;
5512
5513 if (cxx_dialect < cxx11
5514 || TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t))
5515 CLASSTYPE_LITERAL_P (t) = false;
5516 else if (CLASSTYPE_LITERAL_P (t) && !TYPE_HAS_TRIVIAL_DFLT (t)
5517 && CLASSTYPE_NON_AGGREGATE (t)
5518 && !TYPE_HAS_CONSTEXPR_CTOR (t))
5519 CLASSTYPE_LITERAL_P (t) = false;
5520
5521 if (!CLASSTYPE_LITERAL_P (t))
5522 for (fn = TYPE_METHODS (t); fn; fn = DECL_CHAIN (fn))
5523 if (DECL_DECLARED_CONSTEXPR_P (fn)
5524 && TREE_CODE (fn) != TEMPLATE_DECL
5525 && DECL_NONSTATIC_MEMBER_FUNCTION_P (fn)
5526 && !DECL_CONSTRUCTOR_P (fn))
5527 {
5528 DECL_DECLARED_CONSTEXPR_P (fn) = false;
5529 if (!DECL_GENERATED_P (fn))
5530 {
5531 error ("enclosing class of constexpr non-static member "
5532 "function %q+#D is not a literal type", fn);
5533 explain_non_literal_class (t);
5534 }
5535 }
5536 }
5537
5538 /* T is a non-literal type used in a context which requires a constant
5539 expression. Explain why it isn't literal. */
5540
5541 void
5542 explain_non_literal_class (tree t)
5543 {
5544 static hash_set<tree> *diagnosed;
5545
5546 if (!CLASS_TYPE_P (t))
5547 return;
5548 t = TYPE_MAIN_VARIANT (t);
5549
5550 if (diagnosed == NULL)
5551 diagnosed = new hash_set<tree>;
5552 if (diagnosed->add (t))
5553 /* Already explained. */
5554 return;
5555
5556 inform (0, "%q+T is not literal because:", t);
5557 if (TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t))
5558 inform (0, " %q+T has a non-trivial destructor", t);
5559 else if (CLASSTYPE_NON_AGGREGATE (t)
5560 && !TYPE_HAS_TRIVIAL_DFLT (t)
5561 && !TYPE_HAS_CONSTEXPR_CTOR (t))
5562 {
5563 inform (0, " %q+T is not an aggregate, does not have a trivial "
5564 "default constructor, and has no constexpr constructor that "
5565 "is not a copy or move constructor", t);
5566 if (type_has_non_user_provided_default_constructor (t))
5567 {
5568 /* Note that we can't simply call locate_ctor because when the
5569 constructor is deleted it just returns NULL_TREE. */
5570 tree fns;
5571 for (fns = CLASSTYPE_CONSTRUCTORS (t); fns; fns = OVL_NEXT (fns))
5572 {
5573 tree fn = OVL_CURRENT (fns);
5574 tree parms = TYPE_ARG_TYPES (TREE_TYPE (fn));
5575
5576 parms = skip_artificial_parms_for (fn, parms);
5577
5578 if (sufficient_parms_p (parms))
5579 {
5580 if (DECL_DELETED_FN (fn))
5581 maybe_explain_implicit_delete (fn);
5582 else
5583 explain_invalid_constexpr_fn (fn);
5584 break;
5585 }
5586 }
5587 }
5588 }
5589 else
5590 {
5591 tree binfo, base_binfo, field; int i;
5592 for (binfo = TYPE_BINFO (t), i = 0;
5593 BINFO_BASE_ITERATE (binfo, i, base_binfo); i++)
5594 {
5595 tree basetype = TREE_TYPE (base_binfo);
5596 if (!CLASSTYPE_LITERAL_P (basetype))
5597 {
5598 inform (0, " base class %qT of %q+T is non-literal",
5599 basetype, t);
5600 explain_non_literal_class (basetype);
5601 return;
5602 }
5603 }
5604 for (field = TYPE_FIELDS (t); field; field = TREE_CHAIN (field))
5605 {
5606 tree ftype;
5607 if (TREE_CODE (field) != FIELD_DECL)
5608 continue;
5609 ftype = TREE_TYPE (field);
5610 if (!literal_type_p (ftype))
5611 {
5612 inform (0, " non-static data member %q+D has "
5613 "non-literal type", field);
5614 if (CLASS_TYPE_P (ftype))
5615 explain_non_literal_class (ftype);
5616 }
5617 if (CP_TYPE_VOLATILE_P (ftype))
5618 inform (0, " non-static data member %q+D has "
5619 "volatile type", field);
5620 }
5621 }
5622 }
5623
5624 /* Check the validity of the bases and members declared in T. Add any
5625 implicitly-generated functions (like copy-constructors and
5626 assignment operators). Compute various flag bits (like
5627 CLASSTYPE_NON_LAYOUT_POD_T) for T. This routine works purely at the C++
5628 level: i.e., independently of the ABI in use. */
5629
5630 static void
5631 check_bases_and_members (tree t)
5632 {
5633 /* Nonzero if the implicitly generated copy constructor should take
5634 a non-const reference argument. */
5635 int cant_have_const_ctor;
5636 /* Nonzero if the implicitly generated assignment operator
5637 should take a non-const reference argument. */
5638 int no_const_asn_ref;
5639 tree access_decls;
5640 bool saved_complex_asn_ref;
5641 bool saved_nontrivial_dtor;
5642 tree fn;
5643
5644 /* By default, we use const reference arguments and generate default
5645 constructors. */
5646 cant_have_const_ctor = 0;
5647 no_const_asn_ref = 0;
5648
5649 /* Check all the base-classes. */
5650 check_bases (t, &cant_have_const_ctor,
5651 &no_const_asn_ref);
5652
5653 /* Deduce noexcept on destructors. This needs to happen after we've set
5654 triviality flags appropriately for our bases. */
5655 if (cxx_dialect >= cxx11)
5656 deduce_noexcept_on_destructors (t);
5657
5658 /* Check all the method declarations. */
5659 check_methods (t);
5660
5661 /* Save the initial values of these flags which only indicate whether
5662 or not the class has user-provided functions. As we analyze the
5663 bases and members we can set these flags for other reasons. */
5664 saved_complex_asn_ref = TYPE_HAS_COMPLEX_COPY_ASSIGN (t);
5665 saved_nontrivial_dtor = TYPE_HAS_NONTRIVIAL_DESTRUCTOR (t);
5666
5667 /* Check all the data member declarations. We cannot call
5668 check_field_decls until we have called check_bases check_methods,
5669 as check_field_decls depends on TYPE_HAS_NONTRIVIAL_DESTRUCTOR
5670 being set appropriately. */
5671 check_field_decls (t, &access_decls,
5672 &cant_have_const_ctor,
5673 &no_const_asn_ref);
5674
5675 /* A nearly-empty class has to be vptr-containing; a nearly empty
5676 class contains just a vptr. */
5677 if (!TYPE_CONTAINS_VPTR_P (t))
5678 CLASSTYPE_NEARLY_EMPTY_P (t) = 0;
5679
5680 /* Do some bookkeeping that will guide the generation of implicitly
5681 declared member functions. */
5682 TYPE_HAS_COMPLEX_COPY_CTOR (t) |= TYPE_CONTAINS_VPTR_P (t);
5683 TYPE_HAS_COMPLEX_MOVE_CTOR (t) |= TYPE_CONTAINS_VPTR_P (t);
5684 /* We need to call a constructor for this class if it has a
5685 user-provided constructor, or if the default constructor is going
5686 to initialize the vptr. (This is not an if-and-only-if;
5687 TYPE_NEEDS_CONSTRUCTING is set elsewhere if bases or members
5688 themselves need constructing.) */
5689 TYPE_NEEDS_CONSTRUCTING (t)
5690 |= (type_has_user_provided_constructor (t) || TYPE_CONTAINS_VPTR_P (t));
5691 /* [dcl.init.aggr]
5692
5693 An aggregate is an array or a class with no user-provided
5694 constructors ... and no virtual functions.
5695
5696 Again, other conditions for being an aggregate are checked
5697 elsewhere. */
5698 CLASSTYPE_NON_AGGREGATE (t)
5699 |= (type_has_user_provided_constructor (t) || TYPE_POLYMORPHIC_P (t));
5700 /* This is the C++98/03 definition of POD; it changed in C++0x, but we
5701 retain the old definition internally for ABI reasons. */
5702 CLASSTYPE_NON_LAYOUT_POD_P (t)
5703 |= (CLASSTYPE_NON_AGGREGATE (t)
5704 || saved_nontrivial_dtor || saved_complex_asn_ref);
5705 CLASSTYPE_NON_STD_LAYOUT (t) |= TYPE_CONTAINS_VPTR_P (t);
5706 TYPE_HAS_COMPLEX_COPY_ASSIGN (t) |= TYPE_CONTAINS_VPTR_P (t);
5707 TYPE_HAS_COMPLEX_MOVE_ASSIGN (t) |= TYPE_CONTAINS_VPTR_P (t);
5708 TYPE_HAS_COMPLEX_DFLT (t) |= TYPE_CONTAINS_VPTR_P (t);
5709
5710 /* If the only explicitly declared default constructor is user-provided,
5711 set TYPE_HAS_COMPLEX_DFLT. */
5712 if (!TYPE_HAS_COMPLEX_DFLT (t)
5713 && TYPE_HAS_DEFAULT_CONSTRUCTOR (t)
5714 && !type_has_non_user_provided_default_constructor (t))
5715 TYPE_HAS_COMPLEX_DFLT (t) = true;
5716
5717 /* Warn if a public base of a polymorphic type has an accessible
5718 non-virtual destructor. It is only now that we know the class is
5719 polymorphic. Although a polymorphic base will have a already
5720 been diagnosed during its definition, we warn on use too. */
5721 if (TYPE_POLYMORPHIC_P (t) && warn_nonvdtor)
5722 {
5723 tree binfo = TYPE_BINFO (t);
5724 vec<tree, va_gc> *accesses = BINFO_BASE_ACCESSES (binfo);
5725 tree base_binfo;
5726 unsigned i;
5727
5728 for (i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); i++)
5729 {
5730 tree basetype = TREE_TYPE (base_binfo);
5731
5732 if ((*accesses)[i] == access_public_node
5733 && (TYPE_POLYMORPHIC_P (basetype) || warn_ecpp)
5734 && accessible_nvdtor_p (basetype))
5735 warning (OPT_Wnon_virtual_dtor,
5736 "base class %q#T has accessible non-virtual destructor",
5737 basetype);
5738 }
5739 }
5740
5741 /* If the class has no user-declared constructor, but does have
5742 non-static const or reference data members that can never be
5743 initialized, issue a warning. */
5744 if (warn_uninitialized
5745 /* Classes with user-declared constructors are presumed to
5746 initialize these members. */
5747 && !TYPE_HAS_USER_CONSTRUCTOR (t)
5748 /* Aggregates can be initialized with brace-enclosed
5749 initializers. */
5750 && CLASSTYPE_NON_AGGREGATE (t))
5751 {
5752 tree field;
5753
5754 for (field = TYPE_FIELDS (t); field; field = DECL_CHAIN (field))
5755 {
5756 tree type;
5757
5758 if (TREE_CODE (field) != FIELD_DECL
5759 || DECL_INITIAL (field) != NULL_TREE)
5760 continue;
5761
5762 type = TREE_TYPE (field);
5763 if (TREE_CODE (type) == REFERENCE_TYPE)
5764 warning (OPT_Wuninitialized, "non-static reference %q+#D "
5765 "in class without a constructor", field);
5766 else if (CP_TYPE_CONST_P (type)
5767 && (!CLASS_TYPE_P (type)
5768 || !TYPE_HAS_DEFAULT_CONSTRUCTOR (type)))
5769 warning (OPT_Wuninitialized, "non-static const member %q+#D "
5770 "in class without a constructor", field);
5771 }
5772 }
5773
5774 /* Synthesize any needed methods. */
5775 add_implicitly_declared_members (t, &access_decls,
5776 cant_have_const_ctor,
5777 no_const_asn_ref);
5778
5779 /* Check defaulted declarations here so we have cant_have_const_ctor
5780 and don't need to worry about clones. */
5781 for (fn = TYPE_METHODS (t); fn; fn = DECL_CHAIN (fn))
5782 if (!DECL_ARTIFICIAL (fn) && DECL_DEFAULTED_IN_CLASS_P (fn))
5783 {
5784 int copy = copy_fn_p (fn);
5785 if (copy > 0)
5786 {
5787 bool imp_const_p
5788 = (DECL_CONSTRUCTOR_P (fn) ? !cant_have_const_ctor
5789 : !no_const_asn_ref);
5790 bool fn_const_p = (copy == 2);
5791
5792 if (fn_const_p && !imp_const_p)
5793 /* If the function is defaulted outside the class, we just
5794 give the synthesis error. */
5795 error ("%q+D declared to take const reference, but implicit "
5796 "declaration would take non-const", fn);
5797 }
5798 defaulted_late_check (fn);
5799 }
5800
5801 if (LAMBDA_TYPE_P (t))
5802 {
5803 /* "This class type is not an aggregate." */
5804 CLASSTYPE_NON_AGGREGATE (t) = 1;
5805 }
5806
5807 /* Compute the 'literal type' property before we
5808 do anything with non-static member functions. */
5809 finalize_literal_type_property (t);
5810
5811 /* Create the in-charge and not-in-charge variants of constructors
5812 and destructors. */
5813 clone_constructors_and_destructors (t);
5814
5815 /* Process the using-declarations. */
5816 for (; access_decls; access_decls = TREE_CHAIN (access_decls))
5817 handle_using_decl (TREE_VALUE (access_decls), t);
5818
5819 /* Build and sort the CLASSTYPE_METHOD_VEC. */
5820 finish_struct_methods (t);
5821
5822 /* Figure out whether or not we will need a cookie when dynamically
5823 allocating an array of this type. */
5824 TYPE_LANG_SPECIFIC (t)->u.c.vec_new_uses_cookie
5825 = type_requires_array_cookie (t);
5826 }
5827
5828 /* If T needs a pointer to its virtual function table, set TYPE_VFIELD
5829 accordingly. If a new vfield was created (because T doesn't have a
5830 primary base class), then the newly created field is returned. It
5831 is not added to the TYPE_FIELDS list; it is the caller's
5832 responsibility to do that. Accumulate declared virtual functions
5833 on VIRTUALS_P. */
5834
5835 static tree
5836 create_vtable_ptr (tree t, tree* virtuals_p)
5837 {
5838 tree fn;
5839
5840 /* Collect the virtual functions declared in T. */
5841 for (fn = TYPE_METHODS (t); fn; fn = DECL_CHAIN (fn))
5842 if (TREE_CODE (fn) == FUNCTION_DECL
5843 && DECL_VINDEX (fn) && !DECL_MAYBE_IN_CHARGE_DESTRUCTOR_P (fn)
5844 && TREE_CODE (DECL_VINDEX (fn)) != INTEGER_CST)
5845 {
5846 tree new_virtual = make_node (TREE_LIST);
5847
5848 BV_FN (new_virtual) = fn;
5849 BV_DELTA (new_virtual) = integer_zero_node;
5850 BV_VCALL_INDEX (new_virtual) = NULL_TREE;
5851
5852 TREE_CHAIN (new_virtual) = *virtuals_p;
5853 *virtuals_p = new_virtual;
5854 }
5855
5856 /* If we couldn't find an appropriate base class, create a new field
5857 here. Even if there weren't any new virtual functions, we might need a
5858 new virtual function table if we're supposed to include vptrs in
5859 all classes that need them. */
5860 if (!TYPE_VFIELD (t) && (*virtuals_p || TYPE_CONTAINS_VPTR_P (t)))
5861 {
5862 /* We build this decl with vtbl_ptr_type_node, which is a
5863 `vtable_entry_type*'. It might seem more precise to use
5864 `vtable_entry_type (*)[N]' where N is the number of virtual
5865 functions. However, that would require the vtable pointer in
5866 base classes to have a different type than the vtable pointer
5867 in derived classes. We could make that happen, but that
5868 still wouldn't solve all the problems. In particular, the
5869 type-based alias analysis code would decide that assignments
5870 to the base class vtable pointer can't alias assignments to
5871 the derived class vtable pointer, since they have different
5872 types. Thus, in a derived class destructor, where the base
5873 class constructor was inlined, we could generate bad code for
5874 setting up the vtable pointer.
5875
5876 Therefore, we use one type for all vtable pointers. We still
5877 use a type-correct type; it's just doesn't indicate the array
5878 bounds. That's better than using `void*' or some such; it's
5879 cleaner, and it let's the alias analysis code know that these
5880 stores cannot alias stores to void*! */
5881 tree field;
5882
5883 field = build_decl (input_location,
5884 FIELD_DECL, get_vfield_name (t), vtbl_ptr_type_node);
5885 DECL_VIRTUAL_P (field) = 1;
5886 DECL_ARTIFICIAL (field) = 1;
5887 DECL_FIELD_CONTEXT (field) = t;
5888 DECL_FCONTEXT (field) = t;
5889 if (TYPE_PACKED (t))
5890 DECL_PACKED (field) = 1;
5891
5892 TYPE_VFIELD (t) = field;
5893
5894 /* This class is non-empty. */
5895 CLASSTYPE_EMPTY_P (t) = 0;
5896
5897 return field;
5898 }
5899
5900 return NULL_TREE;
5901 }
5902
5903 /* Add OFFSET to all base types of BINFO which is a base in the
5904 hierarchy dominated by T.
5905
5906 OFFSET, which is a type offset, is number of bytes. */
5907
5908 static void
5909 propagate_binfo_offsets (tree binfo, tree offset)
5910 {
5911 int i;
5912 tree primary_binfo;
5913 tree base_binfo;
5914
5915 /* Update BINFO's offset. */
5916 BINFO_OFFSET (binfo)
5917 = convert (sizetype,
5918 size_binop (PLUS_EXPR,
5919 convert (ssizetype, BINFO_OFFSET (binfo)),
5920 offset));
5921
5922 /* Find the primary base class. */
5923 primary_binfo = get_primary_binfo (binfo);
5924
5925 if (primary_binfo && BINFO_INHERITANCE_CHAIN (primary_binfo) == binfo)
5926 propagate_binfo_offsets (primary_binfo, offset);
5927
5928 /* Scan all of the bases, pushing the BINFO_OFFSET adjust
5929 downwards. */
5930 for (i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
5931 {
5932 /* Don't do the primary base twice. */
5933 if (base_binfo == primary_binfo)
5934 continue;
5935
5936 if (BINFO_VIRTUAL_P (base_binfo))
5937 continue;
5938
5939 propagate_binfo_offsets (base_binfo, offset);
5940 }
5941 }
5942
5943 /* Set BINFO_OFFSET for all of the virtual bases for RLI->T. Update
5944 TYPE_ALIGN and TYPE_SIZE for T. OFFSETS gives the location of
5945 empty subobjects of T. */
5946
5947 static void
5948 layout_virtual_bases (record_layout_info rli, splay_tree offsets)
5949 {
5950 tree vbase;
5951 tree t = rli->t;
5952 tree *next_field;
5953
5954 if (BINFO_N_BASE_BINFOS (TYPE_BINFO (t)) == 0)
5955 return;
5956
5957 /* Find the last field. The artificial fields created for virtual
5958 bases will go after the last extant field to date. */
5959 next_field = &TYPE_FIELDS (t);
5960 while (*next_field)
5961 next_field = &DECL_CHAIN (*next_field);
5962
5963 /* Go through the virtual bases, allocating space for each virtual
5964 base that is not already a primary base class. These are
5965 allocated in inheritance graph order. */
5966 for (vbase = TYPE_BINFO (t); vbase; vbase = TREE_CHAIN (vbase))
5967 {
5968 if (!BINFO_VIRTUAL_P (vbase))
5969 continue;
5970
5971 if (!BINFO_PRIMARY_P (vbase))
5972 {
5973 /* This virtual base is not a primary base of any class in the
5974 hierarchy, so we have to add space for it. */
5975 next_field = build_base_field (rli, vbase,
5976 offsets, next_field);
5977 }
5978 }
5979 }
5980
5981 /* Returns the offset of the byte just past the end of the base class
5982 BINFO. */
5983
5984 static tree
5985 end_of_base (tree binfo)
5986 {
5987 tree size;
5988
5989 if (!CLASSTYPE_AS_BASE (BINFO_TYPE (binfo)))
5990 size = TYPE_SIZE_UNIT (char_type_node);
5991 else if (is_empty_class (BINFO_TYPE (binfo)))
5992 /* An empty class has zero CLASSTYPE_SIZE_UNIT, but we need to
5993 allocate some space for it. It cannot have virtual bases, so
5994 TYPE_SIZE_UNIT is fine. */
5995 size = TYPE_SIZE_UNIT (BINFO_TYPE (binfo));
5996 else
5997 size = CLASSTYPE_SIZE_UNIT (BINFO_TYPE (binfo));
5998
5999 return size_binop (PLUS_EXPR, BINFO_OFFSET (binfo), size);
6000 }
6001
6002 /* Returns the offset of the byte just past the end of the base class
6003 with the highest offset in T. If INCLUDE_VIRTUALS_P is zero, then
6004 only non-virtual bases are included. */
6005
6006 static tree
6007 end_of_class (tree t, int include_virtuals_p)
6008 {
6009 tree result = size_zero_node;
6010 vec<tree, va_gc> *vbases;
6011 tree binfo;
6012 tree base_binfo;
6013 tree offset;
6014 int i;
6015
6016 for (binfo = TYPE_BINFO (t), i = 0;
6017 BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
6018 {
6019 if (!include_virtuals_p
6020 && BINFO_VIRTUAL_P (base_binfo)
6021 && (!BINFO_PRIMARY_P (base_binfo)
6022 || BINFO_INHERITANCE_CHAIN (base_binfo) != TYPE_BINFO (t)))
6023 continue;
6024
6025 offset = end_of_base (base_binfo);
6026 if (tree_int_cst_lt (result, offset))
6027 result = offset;
6028 }
6029
6030 if (include_virtuals_p)
6031 for (vbases = CLASSTYPE_VBASECLASSES (t), i = 0;
6032 vec_safe_iterate (vbases, i, &base_binfo); i++)
6033 {
6034 offset = end_of_base (base_binfo);
6035 if (tree_int_cst_lt (result, offset))
6036 result = offset;
6037 }
6038
6039 return result;
6040 }
6041
6042 /* Warn about bases of T that are inaccessible because they are
6043 ambiguous. For example:
6044
6045 struct S {};
6046 struct T : public S {};
6047 struct U : public S, public T {};
6048
6049 Here, `(S*) new U' is not allowed because there are two `S'
6050 subobjects of U. */
6051
6052 static void
6053 warn_about_ambiguous_bases (tree t)
6054 {
6055 int i;
6056 vec<tree, va_gc> *vbases;
6057 tree basetype;
6058 tree binfo;
6059 tree base_binfo;
6060
6061 /* If there are no repeated bases, nothing can be ambiguous. */
6062 if (!CLASSTYPE_REPEATED_BASE_P (t))
6063 return;
6064
6065 /* Check direct bases. */
6066 for (binfo = TYPE_BINFO (t), i = 0;
6067 BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
6068 {
6069 basetype = BINFO_TYPE (base_binfo);
6070
6071 if (!uniquely_derived_from_p (basetype, t))
6072 warning (0, "direct base %qT inaccessible in %qT due to ambiguity",
6073 basetype, t);
6074 }
6075
6076 /* Check for ambiguous virtual bases. */
6077 if (extra_warnings)
6078 for (vbases = CLASSTYPE_VBASECLASSES (t), i = 0;
6079 vec_safe_iterate (vbases, i, &binfo); i++)
6080 {
6081 basetype = BINFO_TYPE (binfo);
6082
6083 if (!uniquely_derived_from_p (basetype, t))
6084 warning (OPT_Wextra, "virtual base %qT inaccessible in %qT due "
6085 "to ambiguity", basetype, t);
6086 }
6087 }
6088
6089 /* Compare two INTEGER_CSTs K1 and K2. */
6090
6091 static int
6092 splay_tree_compare_integer_csts (splay_tree_key k1, splay_tree_key k2)
6093 {
6094 return tree_int_cst_compare ((tree) k1, (tree) k2);
6095 }
6096
6097 /* Increase the size indicated in RLI to account for empty classes
6098 that are "off the end" of the class. */
6099
6100 static void
6101 include_empty_classes (record_layout_info rli)
6102 {
6103 tree eoc;
6104 tree rli_size;
6105
6106 /* It might be the case that we grew the class to allocate a
6107 zero-sized base class. That won't be reflected in RLI, yet,
6108 because we are willing to overlay multiple bases at the same
6109 offset. However, now we need to make sure that RLI is big enough
6110 to reflect the entire class. */
6111 eoc = end_of_class (rli->t,
6112 CLASSTYPE_AS_BASE (rli->t) != NULL_TREE);
6113 rli_size = rli_size_unit_so_far (rli);
6114 if (TREE_CODE (rli_size) == INTEGER_CST
6115 && tree_int_cst_lt (rli_size, eoc))
6116 {
6117 /* The size should have been rounded to a whole byte. */
6118 gcc_assert (tree_int_cst_equal
6119 (rli->bitpos, round_down (rli->bitpos, BITS_PER_UNIT)));
6120 rli->bitpos
6121 = size_binop (PLUS_EXPR,
6122 rli->bitpos,
6123 size_binop (MULT_EXPR,
6124 convert (bitsizetype,
6125 size_binop (MINUS_EXPR,
6126 eoc, rli_size)),
6127 bitsize_int (BITS_PER_UNIT)));
6128 normalize_rli (rli);
6129 }
6130 }
6131
6132 /* Calculate the TYPE_SIZE, TYPE_ALIGN, etc for T. Calculate
6133 BINFO_OFFSETs for all of the base-classes. Position the vtable
6134 pointer. Accumulate declared virtual functions on VIRTUALS_P. */
6135
6136 static void
6137 layout_class_type (tree t, tree *virtuals_p)
6138 {
6139 tree non_static_data_members;
6140 tree field;
6141 tree vptr;
6142 record_layout_info rli;
6143 /* Maps offsets (represented as INTEGER_CSTs) to a TREE_LIST of
6144 types that appear at that offset. */
6145 splay_tree empty_base_offsets;
6146 /* True if the last field laid out was a bit-field. */
6147 bool last_field_was_bitfield = false;
6148 /* The location at which the next field should be inserted. */
6149 tree *next_field;
6150 /* T, as a base class. */
6151 tree base_t;
6152
6153 /* Keep track of the first non-static data member. */
6154 non_static_data_members = TYPE_FIELDS (t);
6155
6156 /* Start laying out the record. */
6157 rli = start_record_layout (t);
6158
6159 /* Mark all the primary bases in the hierarchy. */
6160 determine_primary_bases (t);
6161
6162 /* Create a pointer to our virtual function table. */
6163 vptr = create_vtable_ptr (t, virtuals_p);
6164
6165 /* The vptr is always the first thing in the class. */
6166 if (vptr)
6167 {
6168 DECL_CHAIN (vptr) = TYPE_FIELDS (t);
6169 TYPE_FIELDS (t) = vptr;
6170 next_field = &DECL_CHAIN (vptr);
6171 place_field (rli, vptr);
6172 }
6173 else
6174 next_field = &TYPE_FIELDS (t);
6175
6176 /* Build FIELD_DECLs for all of the non-virtual base-types. */
6177 empty_base_offsets = splay_tree_new (splay_tree_compare_integer_csts,
6178 NULL, NULL);
6179 build_base_fields (rli, empty_base_offsets, next_field);
6180
6181 /* Layout the non-static data members. */
6182 for (field = non_static_data_members; field; field = DECL_CHAIN (field))
6183 {
6184 tree type;
6185 tree padding;
6186
6187 /* We still pass things that aren't non-static data members to
6188 the back end, in case it wants to do something with them. */
6189 if (TREE_CODE (field) != FIELD_DECL)
6190 {
6191 place_field (rli, field);
6192 /* If the static data member has incomplete type, keep track
6193 of it so that it can be completed later. (The handling
6194 of pending statics in finish_record_layout is
6195 insufficient; consider:
6196
6197 struct S1;
6198 struct S2 { static S1 s1; };
6199
6200 At this point, finish_record_layout will be called, but
6201 S1 is still incomplete.) */
6202 if (VAR_P (field))
6203 {
6204 maybe_register_incomplete_var (field);
6205 /* The visibility of static data members is determined
6206 at their point of declaration, not their point of
6207 definition. */
6208 determine_visibility (field);
6209 }
6210 continue;
6211 }
6212
6213 type = TREE_TYPE (field);
6214 if (type == error_mark_node)
6215 continue;
6216
6217 padding = NULL_TREE;
6218
6219 /* If this field is a bit-field whose width is greater than its
6220 type, then there are some special rules for allocating
6221 it. */
6222 if (DECL_C_BIT_FIELD (field)
6223 && tree_int_cst_lt (TYPE_SIZE (type), DECL_SIZE (field)))
6224 {
6225 unsigned int itk;
6226 tree integer_type;
6227 bool was_unnamed_p = false;
6228 /* We must allocate the bits as if suitably aligned for the
6229 longest integer type that fits in this many bits. type
6230 of the field. Then, we are supposed to use the left over
6231 bits as additional padding. */
6232 for (itk = itk_char; itk != itk_none; ++itk)
6233 if (integer_types[itk] != NULL_TREE
6234 && (tree_int_cst_lt (size_int (MAX_FIXED_MODE_SIZE),
6235 TYPE_SIZE (integer_types[itk]))
6236 || tree_int_cst_lt (DECL_SIZE (field),
6237 TYPE_SIZE (integer_types[itk]))))
6238 break;
6239
6240 /* ITK now indicates a type that is too large for the
6241 field. We have to back up by one to find the largest
6242 type that fits. */
6243 do
6244 {
6245 --itk;
6246 integer_type = integer_types[itk];
6247 } while (itk > 0 && integer_type == NULL_TREE);
6248
6249 /* Figure out how much additional padding is required. */
6250 if (tree_int_cst_lt (TYPE_SIZE (integer_type), DECL_SIZE (field)))
6251 {
6252 if (TREE_CODE (t) == UNION_TYPE)
6253 /* In a union, the padding field must have the full width
6254 of the bit-field; all fields start at offset zero. */
6255 padding = DECL_SIZE (field);
6256 else
6257 padding = size_binop (MINUS_EXPR, DECL_SIZE (field),
6258 TYPE_SIZE (integer_type));
6259 }
6260 #ifdef PCC_BITFIELD_TYPE_MATTERS
6261 /* An unnamed bitfield does not normally affect the
6262 alignment of the containing class on a target where
6263 PCC_BITFIELD_TYPE_MATTERS. But, the C++ ABI does not
6264 make any exceptions for unnamed bitfields when the
6265 bitfields are longer than their types. Therefore, we
6266 temporarily give the field a name. */
6267 if (PCC_BITFIELD_TYPE_MATTERS && !DECL_NAME (field))
6268 {
6269 was_unnamed_p = true;
6270 DECL_NAME (field) = make_anon_name ();
6271 }
6272 #endif
6273 DECL_SIZE (field) = TYPE_SIZE (integer_type);
6274 DECL_ALIGN (field) = TYPE_ALIGN (integer_type);
6275 DECL_USER_ALIGN (field) = TYPE_USER_ALIGN (integer_type);
6276 layout_nonempty_base_or_field (rli, field, NULL_TREE,
6277 empty_base_offsets);
6278 if (was_unnamed_p)
6279 DECL_NAME (field) = NULL_TREE;
6280 /* Now that layout has been performed, set the size of the
6281 field to the size of its declared type; the rest of the
6282 field is effectively invisible. */
6283 DECL_SIZE (field) = TYPE_SIZE (type);
6284 /* We must also reset the DECL_MODE of the field. */
6285 DECL_MODE (field) = TYPE_MODE (type);
6286 }
6287 else
6288 layout_nonempty_base_or_field (rli, field, NULL_TREE,
6289 empty_base_offsets);
6290
6291 /* Remember the location of any empty classes in FIELD. */
6292 record_subobject_offsets (TREE_TYPE (field),
6293 byte_position(field),
6294 empty_base_offsets,
6295 /*is_data_member=*/true);
6296
6297 /* If a bit-field does not immediately follow another bit-field,
6298 and yet it starts in the middle of a byte, we have failed to
6299 comply with the ABI. */
6300 if (warn_abi
6301 && DECL_C_BIT_FIELD (field)
6302 /* The TREE_NO_WARNING flag gets set by Objective-C when
6303 laying out an Objective-C class. The ObjC ABI differs
6304 from the C++ ABI, and so we do not want a warning
6305 here. */
6306 && !TREE_NO_WARNING (field)
6307 && !last_field_was_bitfield
6308 && !integer_zerop (size_binop (TRUNC_MOD_EXPR,
6309 DECL_FIELD_BIT_OFFSET (field),
6310 bitsize_unit_node)))
6311 warning (OPT_Wabi, "offset of %q+D is not ABI-compliant and may "
6312 "change in a future version of GCC", field);
6313
6314 /* The middle end uses the type of expressions to determine the
6315 possible range of expression values. In order to optimize
6316 "x.i > 7" to "false" for a 2-bit bitfield "i", the middle end
6317 must be made aware of the width of "i", via its type.
6318
6319 Because C++ does not have integer types of arbitrary width,
6320 we must (for the purposes of the front end) convert from the
6321 type assigned here to the declared type of the bitfield
6322 whenever a bitfield expression is used as an rvalue.
6323 Similarly, when assigning a value to a bitfield, the value
6324 must be converted to the type given the bitfield here. */
6325 if (DECL_C_BIT_FIELD (field))
6326 {
6327 unsigned HOST_WIDE_INT width;
6328 tree ftype = TREE_TYPE (field);
6329 width = tree_to_uhwi (DECL_SIZE (field));
6330 if (width != TYPE_PRECISION (ftype))
6331 {
6332 TREE_TYPE (field)
6333 = c_build_bitfield_integer_type (width,
6334 TYPE_UNSIGNED (ftype));
6335 TREE_TYPE (field)
6336 = cp_build_qualified_type (TREE_TYPE (field),
6337 cp_type_quals (ftype));
6338 }
6339 }
6340
6341 /* If we needed additional padding after this field, add it
6342 now. */
6343 if (padding)
6344 {
6345 tree padding_field;
6346
6347 padding_field = build_decl (input_location,
6348 FIELD_DECL,
6349 NULL_TREE,
6350 char_type_node);
6351 DECL_BIT_FIELD (padding_field) = 1;
6352 DECL_SIZE (padding_field) = padding;
6353 DECL_CONTEXT (padding_field) = t;
6354 DECL_ARTIFICIAL (padding_field) = 1;
6355 DECL_IGNORED_P (padding_field) = 1;
6356 layout_nonempty_base_or_field (rli, padding_field,
6357 NULL_TREE,
6358 empty_base_offsets);
6359 }
6360
6361 last_field_was_bitfield = DECL_C_BIT_FIELD (field);
6362 }
6363
6364 if (!integer_zerop (rli->bitpos))
6365 {
6366 /* Make sure that we are on a byte boundary so that the size of
6367 the class without virtual bases will always be a round number
6368 of bytes. */
6369 rli->bitpos = round_up_loc (input_location, rli->bitpos, BITS_PER_UNIT);
6370 normalize_rli (rli);
6371 }
6372
6373 /* Delete all zero-width bit-fields from the list of fields. Now
6374 that the type is laid out they are no longer important. */
6375 remove_zero_width_bit_fields (t);
6376
6377 /* Create the version of T used for virtual bases. We do not use
6378 make_class_type for this version; this is an artificial type. For
6379 a POD type, we just reuse T. */
6380 if (CLASSTYPE_NON_LAYOUT_POD_P (t) || CLASSTYPE_EMPTY_P (t))
6381 {
6382 base_t = make_node (TREE_CODE (t));
6383
6384 /* Set the size and alignment for the new type. */
6385 tree eoc;
6386
6387 /* If the ABI version is not at least two, and the last
6388 field was a bit-field, RLI may not be on a byte
6389 boundary. In particular, rli_size_unit_so_far might
6390 indicate the last complete byte, while rli_size_so_far
6391 indicates the total number of bits used. Therefore,
6392 rli_size_so_far, rather than rli_size_unit_so_far, is
6393 used to compute TYPE_SIZE_UNIT. */
6394 eoc = end_of_class (t, /*include_virtuals_p=*/0);
6395 TYPE_SIZE_UNIT (base_t)
6396 = size_binop (MAX_EXPR,
6397 convert (sizetype,
6398 size_binop (CEIL_DIV_EXPR,
6399 rli_size_so_far (rli),
6400 bitsize_int (BITS_PER_UNIT))),
6401 eoc);
6402 TYPE_SIZE (base_t)
6403 = size_binop (MAX_EXPR,
6404 rli_size_so_far (rli),
6405 size_binop (MULT_EXPR,
6406 convert (bitsizetype, eoc),
6407 bitsize_int (BITS_PER_UNIT)));
6408 TYPE_ALIGN (base_t) = rli->record_align;
6409 TYPE_USER_ALIGN (base_t) = TYPE_USER_ALIGN (t);
6410
6411 /* Copy the fields from T. */
6412 next_field = &TYPE_FIELDS (base_t);
6413 for (field = TYPE_FIELDS (t); field; field = DECL_CHAIN (field))
6414 if (TREE_CODE (field) == FIELD_DECL)
6415 {
6416 *next_field = build_decl (input_location,
6417 FIELD_DECL,
6418 DECL_NAME (field),
6419 TREE_TYPE (field));
6420 DECL_CONTEXT (*next_field) = base_t;
6421 DECL_FIELD_OFFSET (*next_field) = DECL_FIELD_OFFSET (field);
6422 DECL_FIELD_BIT_OFFSET (*next_field)
6423 = DECL_FIELD_BIT_OFFSET (field);
6424 DECL_SIZE (*next_field) = DECL_SIZE (field);
6425 DECL_MODE (*next_field) = DECL_MODE (field);
6426 next_field = &DECL_CHAIN (*next_field);
6427 }
6428
6429 /* Record the base version of the type. */
6430 CLASSTYPE_AS_BASE (t) = base_t;
6431 TYPE_CONTEXT (base_t) = t;
6432 }
6433 else
6434 CLASSTYPE_AS_BASE (t) = t;
6435
6436 /* Every empty class contains an empty class. */
6437 if (CLASSTYPE_EMPTY_P (t))
6438 CLASSTYPE_CONTAINS_EMPTY_CLASS_P (t) = 1;
6439
6440 /* Set the TYPE_DECL for this type to contain the right
6441 value for DECL_OFFSET, so that we can use it as part
6442 of a COMPONENT_REF for multiple inheritance. */
6443 layout_decl (TYPE_MAIN_DECL (t), 0);
6444
6445 /* Now fix up any virtual base class types that we left lying
6446 around. We must get these done before we try to lay out the
6447 virtual function table. As a side-effect, this will remove the
6448 base subobject fields. */
6449 layout_virtual_bases (rli, empty_base_offsets);
6450
6451 /* Make sure that empty classes are reflected in RLI at this
6452 point. */
6453 include_empty_classes(rli);
6454
6455 /* Make sure not to create any structures with zero size. */
6456 if (integer_zerop (rli_size_unit_so_far (rli)) && CLASSTYPE_EMPTY_P (t))
6457 place_field (rli,
6458 build_decl (input_location,
6459 FIELD_DECL, NULL_TREE, char_type_node));
6460
6461 /* If this is a non-POD, declaring it packed makes a difference to how it
6462 can be used as a field; don't let finalize_record_size undo it. */
6463 if (TYPE_PACKED (t) && !layout_pod_type_p (t))
6464 rli->packed_maybe_necessary = true;
6465
6466 /* Let the back end lay out the type. */
6467 finish_record_layout (rli, /*free_p=*/true);
6468
6469 if (TYPE_SIZE_UNIT (t)
6470 && TREE_CODE (TYPE_SIZE_UNIT (t)) == INTEGER_CST
6471 && !TREE_OVERFLOW (TYPE_SIZE_UNIT (t))
6472 && !valid_constant_size_p (TYPE_SIZE_UNIT (t)))
6473 error ("type %qT is too large", t);
6474
6475 /* Warn about bases that can't be talked about due to ambiguity. */
6476 warn_about_ambiguous_bases (t);
6477
6478 /* Now that we're done with layout, give the base fields the real types. */
6479 for (field = TYPE_FIELDS (t); field; field = DECL_CHAIN (field))
6480 if (DECL_ARTIFICIAL (field) && IS_FAKE_BASE_TYPE (TREE_TYPE (field)))
6481 TREE_TYPE (field) = TYPE_CONTEXT (TREE_TYPE (field));
6482
6483 /* Clean up. */
6484 splay_tree_delete (empty_base_offsets);
6485
6486 if (CLASSTYPE_EMPTY_P (t)
6487 && tree_int_cst_lt (sizeof_biggest_empty_class,
6488 TYPE_SIZE_UNIT (t)))
6489 sizeof_biggest_empty_class = TYPE_SIZE_UNIT (t);
6490 }
6491
6492 /* Determine the "key method" for the class type indicated by TYPE,
6493 and set CLASSTYPE_KEY_METHOD accordingly. */
6494
6495 void
6496 determine_key_method (tree type)
6497 {
6498 tree method;
6499
6500 if (TYPE_FOR_JAVA (type)
6501 || processing_template_decl
6502 || CLASSTYPE_TEMPLATE_INSTANTIATION (type)
6503 || CLASSTYPE_INTERFACE_KNOWN (type))
6504 return;
6505
6506 /* The key method is the first non-pure virtual function that is not
6507 inline at the point of class definition. On some targets the
6508 key function may not be inline; those targets should not call
6509 this function until the end of the translation unit. */
6510 for (method = TYPE_METHODS (type); method != NULL_TREE;
6511 method = DECL_CHAIN (method))
6512 if (TREE_CODE (method) == FUNCTION_DECL
6513 && DECL_VINDEX (method) != NULL_TREE
6514 && ! DECL_DECLARED_INLINE_P (method)
6515 && ! DECL_PURE_VIRTUAL_P (method))
6516 {
6517 CLASSTYPE_KEY_METHOD (type) = method;
6518 break;
6519 }
6520
6521 return;
6522 }
6523
6524
6525 /* Allocate and return an instance of struct sorted_fields_type with
6526 N fields. */
6527
6528 static struct sorted_fields_type *
6529 sorted_fields_type_new (int n)
6530 {
6531 struct sorted_fields_type *sft;
6532 sft = (sorted_fields_type *) ggc_internal_alloc (sizeof (sorted_fields_type)
6533 + n * sizeof (tree));
6534 sft->len = n;
6535
6536 return sft;
6537 }
6538
6539
6540 /* Perform processing required when the definition of T (a class type)
6541 is complete. */
6542
6543 void
6544 finish_struct_1 (tree t)
6545 {
6546 tree x;
6547 /* A TREE_LIST. The TREE_VALUE of each node is a FUNCTION_DECL. */
6548 tree virtuals = NULL_TREE;
6549
6550 if (COMPLETE_TYPE_P (t))
6551 {
6552 gcc_assert (MAYBE_CLASS_TYPE_P (t));
6553 error ("redefinition of %q#T", t);
6554 popclass ();
6555 return;
6556 }
6557
6558 /* If this type was previously laid out as a forward reference,
6559 make sure we lay it out again. */
6560 TYPE_SIZE (t) = NULL_TREE;
6561 CLASSTYPE_PRIMARY_BINFO (t) = NULL_TREE;
6562
6563 /* Make assumptions about the class; we'll reset the flags if
6564 necessary. */
6565 CLASSTYPE_EMPTY_P (t) = 1;
6566 CLASSTYPE_NEARLY_EMPTY_P (t) = 1;
6567 CLASSTYPE_CONTAINS_EMPTY_CLASS_P (t) = 0;
6568 CLASSTYPE_LITERAL_P (t) = true;
6569
6570 /* Do end-of-class semantic processing: checking the validity of the
6571 bases and members and add implicitly generated methods. */
6572 check_bases_and_members (t);
6573
6574 /* Find the key method. */
6575 if (TYPE_CONTAINS_VPTR_P (t))
6576 {
6577 /* The Itanium C++ ABI permits the key method to be chosen when
6578 the class is defined -- even though the key method so
6579 selected may later turn out to be an inline function. On
6580 some systems (such as ARM Symbian OS) the key method cannot
6581 be determined until the end of the translation unit. On such
6582 systems, we leave CLASSTYPE_KEY_METHOD set to NULL, which
6583 will cause the class to be added to KEYED_CLASSES. Then, in
6584 finish_file we will determine the key method. */
6585 if (targetm.cxx.key_method_may_be_inline ())
6586 determine_key_method (t);
6587
6588 /* If a polymorphic class has no key method, we may emit the vtable
6589 in every translation unit where the class definition appears. If
6590 we're devirtualizing, we can look into the vtable even if we
6591 aren't emitting it. */
6592 if (CLASSTYPE_KEY_METHOD (t) == NULL_TREE)
6593 keyed_classes = tree_cons (NULL_TREE, t, keyed_classes);
6594 }
6595
6596 /* Layout the class itself. */
6597 layout_class_type (t, &virtuals);
6598 if (CLASSTYPE_AS_BASE (t) != t)
6599 /* We use the base type for trivial assignments, and hence it
6600 needs a mode. */
6601 compute_record_mode (CLASSTYPE_AS_BASE (t));
6602
6603 virtuals = modify_all_vtables (t, nreverse (virtuals));
6604
6605 /* If necessary, create the primary vtable for this class. */
6606 if (virtuals || TYPE_CONTAINS_VPTR_P (t))
6607 {
6608 /* We must enter these virtuals into the table. */
6609 if (!CLASSTYPE_HAS_PRIMARY_BASE_P (t))
6610 build_primary_vtable (NULL_TREE, t);
6611 else if (! BINFO_NEW_VTABLE_MARKED (TYPE_BINFO (t)))
6612 /* Here we know enough to change the type of our virtual
6613 function table, but we will wait until later this function. */
6614 build_primary_vtable (CLASSTYPE_PRIMARY_BINFO (t), t);
6615
6616 /* If we're warning about ABI tags, check the types of the new
6617 virtual functions. */
6618 if (warn_abi_tag)
6619 for (tree v = virtuals; v; v = TREE_CHAIN (v))
6620 check_abi_tags (t, TREE_VALUE (v));
6621 }
6622
6623 if (TYPE_CONTAINS_VPTR_P (t))
6624 {
6625 int vindex;
6626 tree fn;
6627
6628 if (BINFO_VTABLE (TYPE_BINFO (t)))
6629 gcc_assert (DECL_VIRTUAL_P (BINFO_VTABLE (TYPE_BINFO (t))));
6630 if (!CLASSTYPE_HAS_PRIMARY_BASE_P (t))
6631 gcc_assert (BINFO_VIRTUALS (TYPE_BINFO (t)) == NULL_TREE);
6632
6633 /* Add entries for virtual functions introduced by this class. */
6634 BINFO_VIRTUALS (TYPE_BINFO (t))
6635 = chainon (BINFO_VIRTUALS (TYPE_BINFO (t)), virtuals);
6636
6637 /* Set DECL_VINDEX for all functions declared in this class. */
6638 for (vindex = 0, fn = BINFO_VIRTUALS (TYPE_BINFO (t));
6639 fn;
6640 fn = TREE_CHAIN (fn),
6641 vindex += (TARGET_VTABLE_USES_DESCRIPTORS
6642 ? TARGET_VTABLE_USES_DESCRIPTORS : 1))
6643 {
6644 tree fndecl = BV_FN (fn);
6645
6646 if (DECL_THUNK_P (fndecl))
6647 /* A thunk. We should never be calling this entry directly
6648 from this vtable -- we'd use the entry for the non
6649 thunk base function. */
6650 DECL_VINDEX (fndecl) = NULL_TREE;
6651 else if (TREE_CODE (DECL_VINDEX (fndecl)) != INTEGER_CST)
6652 DECL_VINDEX (fndecl) = build_int_cst (NULL_TREE, vindex);
6653 }
6654 }
6655
6656 finish_struct_bits (t);
6657 set_method_tm_attributes (t);
6658
6659 /* Complete the rtl for any static member objects of the type we're
6660 working on. */
6661 for (x = TYPE_FIELDS (t); x; x = DECL_CHAIN (x))
6662 if (VAR_P (x) && TREE_STATIC (x)
6663 && TREE_TYPE (x) != error_mark_node
6664 && same_type_p (TYPE_MAIN_VARIANT (TREE_TYPE (x)), t))
6665 DECL_MODE (x) = TYPE_MODE (t);
6666
6667 /* Done with FIELDS...now decide whether to sort these for
6668 faster lookups later.
6669
6670 We use a small number because most searches fail (succeeding
6671 ultimately as the search bores through the inheritance
6672 hierarchy), and we want this failure to occur quickly. */
6673
6674 insert_into_classtype_sorted_fields (TYPE_FIELDS (t), t, 8);
6675
6676 /* Complain if one of the field types requires lower visibility. */
6677 constrain_class_visibility (t);
6678
6679 /* Make the rtl for any new vtables we have created, and unmark
6680 the base types we marked. */
6681 finish_vtbls (t);
6682
6683 /* Build the VTT for T. */
6684 build_vtt (t);
6685
6686 /* This warning does not make sense for Java classes, since they
6687 cannot have destructors. */
6688 if (!TYPE_FOR_JAVA (t) && warn_nonvdtor
6689 && TYPE_POLYMORPHIC_P (t) && accessible_nvdtor_p (t)
6690 && !CLASSTYPE_FINAL (t))
6691 warning (OPT_Wnon_virtual_dtor,
6692 "%q#T has virtual functions and accessible"
6693 " non-virtual destructor", t);
6694
6695 complete_vars (t);
6696
6697 if (warn_overloaded_virtual)
6698 warn_hidden (t);
6699
6700 /* Class layout, assignment of virtual table slots, etc., is now
6701 complete. Give the back end a chance to tweak the visibility of
6702 the class or perform any other required target modifications. */
6703 targetm.cxx.adjust_class_at_definition (t);
6704
6705 maybe_suppress_debug_info (t);
6706
6707 if (flag_vtable_verify)
6708 vtv_save_class_info (t);
6709
6710 dump_class_hierarchy (t);
6711
6712 /* Finish debugging output for this type. */
6713 rest_of_type_compilation (t, ! LOCAL_CLASS_P (t));
6714
6715 if (TYPE_TRANSPARENT_AGGR (t))
6716 {
6717 tree field = first_field (t);
6718 if (field == NULL_TREE || error_operand_p (field))
6719 {
6720 error ("type transparent %q#T does not have any fields", t);
6721 TYPE_TRANSPARENT_AGGR (t) = 0;
6722 }
6723 else if (DECL_ARTIFICIAL (field))
6724 {
6725 if (DECL_FIELD_IS_BASE (field))
6726 error ("type transparent class %qT has base classes", t);
6727 else
6728 {
6729 gcc_checking_assert (DECL_VIRTUAL_P (field));
6730 error ("type transparent class %qT has virtual functions", t);
6731 }
6732 TYPE_TRANSPARENT_AGGR (t) = 0;
6733 }
6734 else if (TYPE_MODE (t) != DECL_MODE (field))
6735 {
6736 error ("type transparent %q#T cannot be made transparent because "
6737 "the type of the first field has a different ABI from the "
6738 "class overall", t);
6739 TYPE_TRANSPARENT_AGGR (t) = 0;
6740 }
6741 }
6742 }
6743
6744 /* Insert FIELDS into T for the sorted case if the FIELDS count is
6745 equal to THRESHOLD or greater than THRESHOLD. */
6746
6747 static void
6748 insert_into_classtype_sorted_fields (tree fields, tree t, int threshold)
6749 {
6750 int n_fields = count_fields (fields);
6751 if (n_fields >= threshold)
6752 {
6753 struct sorted_fields_type *field_vec = sorted_fields_type_new (n_fields);
6754 add_fields_to_record_type (fields, field_vec, 0);
6755 qsort (field_vec->elts, n_fields, sizeof (tree), field_decl_cmp);
6756 CLASSTYPE_SORTED_FIELDS (t) = field_vec;
6757 }
6758 }
6759
6760 /* Insert lately defined enum ENUMTYPE into T for the sorted case. */
6761
6762 void
6763 insert_late_enum_def_into_classtype_sorted_fields (tree enumtype, tree t)
6764 {
6765 struct sorted_fields_type *sorted_fields = CLASSTYPE_SORTED_FIELDS (t);
6766 if (sorted_fields)
6767 {
6768 int i;
6769 int n_fields
6770 = list_length (TYPE_VALUES (enumtype)) + sorted_fields->len;
6771 struct sorted_fields_type *field_vec = sorted_fields_type_new (n_fields);
6772
6773 for (i = 0; i < sorted_fields->len; ++i)
6774 field_vec->elts[i] = sorted_fields->elts[i];
6775
6776 add_enum_fields_to_record_type (enumtype, field_vec,
6777 sorted_fields->len);
6778 qsort (field_vec->elts, n_fields, sizeof (tree), field_decl_cmp);
6779 CLASSTYPE_SORTED_FIELDS (t) = field_vec;
6780 }
6781 }
6782
6783 /* When T was built up, the member declarations were added in reverse
6784 order. Rearrange them to declaration order. */
6785
6786 void
6787 unreverse_member_declarations (tree t)
6788 {
6789 tree next;
6790 tree prev;
6791 tree x;
6792
6793 /* The following lists are all in reverse order. Put them in
6794 declaration order now. */
6795 TYPE_METHODS (t) = nreverse (TYPE_METHODS (t));
6796 CLASSTYPE_DECL_LIST (t) = nreverse (CLASSTYPE_DECL_LIST (t));
6797
6798 /* Actually, for the TYPE_FIELDS, only the non TYPE_DECLs are in
6799 reverse order, so we can't just use nreverse. */
6800 prev = NULL_TREE;
6801 for (x = TYPE_FIELDS (t);
6802 x && TREE_CODE (x) != TYPE_DECL;
6803 x = next)
6804 {
6805 next = DECL_CHAIN (x);
6806 DECL_CHAIN (x) = prev;
6807 prev = x;
6808 }
6809 if (prev)
6810 {
6811 DECL_CHAIN (TYPE_FIELDS (t)) = x;
6812 if (prev)
6813 TYPE_FIELDS (t) = prev;
6814 }
6815 }
6816
6817 tree
6818 finish_struct (tree t, tree attributes)
6819 {
6820 location_t saved_loc = input_location;
6821
6822 /* Now that we've got all the field declarations, reverse everything
6823 as necessary. */
6824 unreverse_member_declarations (t);
6825
6826 cplus_decl_attributes (&t, attributes, (int) ATTR_FLAG_TYPE_IN_PLACE);
6827
6828 /* Nadger the current location so that diagnostics point to the start of
6829 the struct, not the end. */
6830 input_location = DECL_SOURCE_LOCATION (TYPE_NAME (t));
6831
6832 if (processing_template_decl)
6833 {
6834 tree x;
6835
6836 finish_struct_methods (t);
6837 TYPE_SIZE (t) = bitsize_zero_node;
6838 TYPE_SIZE_UNIT (t) = size_zero_node;
6839
6840 /* We need to emit an error message if this type was used as a parameter
6841 and it is an abstract type, even if it is a template. We construct
6842 a simple CLASSTYPE_PURE_VIRTUALS list without taking bases into
6843 account and we call complete_vars with this type, which will check
6844 the PARM_DECLS. Note that while the type is being defined,
6845 CLASSTYPE_PURE_VIRTUALS contains the list of the inline friends
6846 (see CLASSTYPE_INLINE_FRIENDS) so we need to clear it. */
6847 CLASSTYPE_PURE_VIRTUALS (t) = NULL;
6848 for (x = TYPE_METHODS (t); x; x = DECL_CHAIN (x))
6849 if (DECL_PURE_VIRTUAL_P (x))
6850 vec_safe_push (CLASSTYPE_PURE_VIRTUALS (t), x);
6851 complete_vars (t);
6852 /* We need to add the target functions to the CLASSTYPE_METHOD_VEC if
6853 an enclosing scope is a template class, so that this function be
6854 found by lookup_fnfields_1 when the using declaration is not
6855 instantiated yet. */
6856 for (x = TYPE_FIELDS (t); x; x = DECL_CHAIN (x))
6857 if (TREE_CODE (x) == USING_DECL)
6858 {
6859 tree fn = strip_using_decl (x);
6860 if (is_overloaded_fn (fn))
6861 for (; fn; fn = OVL_NEXT (fn))
6862 add_method (t, OVL_CURRENT (fn), x);
6863 }
6864
6865 /* Remember current #pragma pack value. */
6866 TYPE_PRECISION (t) = maximum_field_alignment;
6867
6868 /* Fix up any variants we've already built. */
6869 for (x = TYPE_NEXT_VARIANT (t); x; x = TYPE_NEXT_VARIANT (x))
6870 {
6871 TYPE_SIZE (x) = TYPE_SIZE (t);
6872 TYPE_SIZE_UNIT (x) = TYPE_SIZE_UNIT (t);
6873 TYPE_FIELDS (x) = TYPE_FIELDS (t);
6874 TYPE_METHODS (x) = TYPE_METHODS (t);
6875 }
6876 }
6877 else
6878 finish_struct_1 (t);
6879
6880 if (is_std_init_list (t))
6881 {
6882 /* People keep complaining that the compiler crashes on an invalid
6883 definition of initializer_list, so I guess we should explicitly
6884 reject it. What the compiler internals care about is that it's a
6885 template and has a pointer field followed by an integer field. */
6886 bool ok = false;
6887 if (processing_template_decl)
6888 {
6889 tree f = next_initializable_field (TYPE_FIELDS (t));
6890 if (f && TREE_CODE (TREE_TYPE (f)) == POINTER_TYPE)
6891 {
6892 f = next_initializable_field (DECL_CHAIN (f));
6893 if (f && TREE_CODE (TREE_TYPE (f)) == INTEGER_TYPE)
6894 ok = true;
6895 }
6896 }
6897 if (!ok)
6898 fatal_error (input_location,
6899 "definition of std::initializer_list does not match "
6900 "#include <initializer_list>");
6901 }
6902
6903 input_location = saved_loc;
6904
6905 TYPE_BEING_DEFINED (t) = 0;
6906
6907 if (current_class_type)
6908 popclass ();
6909 else
6910 error ("trying to finish struct, but kicked out due to previous parse errors");
6911
6912 if (processing_template_decl && at_function_scope_p ()
6913 /* Lambdas are defined by the LAMBDA_EXPR. */
6914 && !LAMBDA_TYPE_P (t))
6915 add_stmt (build_min (TAG_DEFN, t));
6916
6917 return t;
6918 }
6919 \f
6920 /* Hash table to avoid endless recursion when handling references. */
6921 static hash_table<pointer_hash<tree_node> > *fixed_type_or_null_ref_ht;
6922
6923 /* Return the dynamic type of INSTANCE, if known.
6924 Used to determine whether the virtual function table is needed
6925 or not.
6926
6927 *NONNULL is set iff INSTANCE can be known to be nonnull, regardless
6928 of our knowledge of its type. *NONNULL should be initialized
6929 before this function is called. */
6930
6931 static tree
6932 fixed_type_or_null (tree instance, int *nonnull, int *cdtorp)
6933 {
6934 #define RECUR(T) fixed_type_or_null((T), nonnull, cdtorp)
6935
6936 switch (TREE_CODE (instance))
6937 {
6938 case INDIRECT_REF:
6939 if (POINTER_TYPE_P (TREE_TYPE (instance)))
6940 return NULL_TREE;
6941 else
6942 return RECUR (TREE_OPERAND (instance, 0));
6943
6944 case CALL_EXPR:
6945 /* This is a call to a constructor, hence it's never zero. */
6946 if (TREE_HAS_CONSTRUCTOR (instance))
6947 {
6948 if (nonnull)
6949 *nonnull = 1;
6950 return TREE_TYPE (instance);
6951 }
6952 return NULL_TREE;
6953
6954 case SAVE_EXPR:
6955 /* This is a call to a constructor, hence it's never zero. */
6956 if (TREE_HAS_CONSTRUCTOR (instance))
6957 {
6958 if (nonnull)
6959 *nonnull = 1;
6960 return TREE_TYPE (instance);
6961 }
6962 return RECUR (TREE_OPERAND (instance, 0));
6963
6964 case POINTER_PLUS_EXPR:
6965 case PLUS_EXPR:
6966 case MINUS_EXPR:
6967 if (TREE_CODE (TREE_OPERAND (instance, 0)) == ADDR_EXPR)
6968 return RECUR (TREE_OPERAND (instance, 0));
6969 if (TREE_CODE (TREE_OPERAND (instance, 1)) == INTEGER_CST)
6970 /* Propagate nonnull. */
6971 return RECUR (TREE_OPERAND (instance, 0));
6972
6973 return NULL_TREE;
6974
6975 CASE_CONVERT:
6976 return RECUR (TREE_OPERAND (instance, 0));
6977
6978 case ADDR_EXPR:
6979 instance = TREE_OPERAND (instance, 0);
6980 if (nonnull)
6981 {
6982 /* Just because we see an ADDR_EXPR doesn't mean we're dealing
6983 with a real object -- given &p->f, p can still be null. */
6984 tree t = get_base_address (instance);
6985 /* ??? Probably should check DECL_WEAK here. */
6986 if (t && DECL_P (t))
6987 *nonnull = 1;
6988 }
6989 return RECUR (instance);
6990
6991 case COMPONENT_REF:
6992 /* If this component is really a base class reference, then the field
6993 itself isn't definitive. */
6994 if (DECL_FIELD_IS_BASE (TREE_OPERAND (instance, 1)))
6995 return RECUR (TREE_OPERAND (instance, 0));
6996 return RECUR (TREE_OPERAND (instance, 1));
6997
6998 case VAR_DECL:
6999 case FIELD_DECL:
7000 if (TREE_CODE (TREE_TYPE (instance)) == ARRAY_TYPE
7001 && MAYBE_CLASS_TYPE_P (TREE_TYPE (TREE_TYPE (instance))))
7002 {
7003 if (nonnull)
7004 *nonnull = 1;
7005 return TREE_TYPE (TREE_TYPE (instance));
7006 }
7007 /* fall through... */
7008 case TARGET_EXPR:
7009 case PARM_DECL:
7010 case RESULT_DECL:
7011 if (MAYBE_CLASS_TYPE_P (TREE_TYPE (instance)))
7012 {
7013 if (nonnull)
7014 *nonnull = 1;
7015 return TREE_TYPE (instance);
7016 }
7017 else if (instance == current_class_ptr)
7018 {
7019 if (nonnull)
7020 *nonnull = 1;
7021
7022 /* if we're in a ctor or dtor, we know our type. If
7023 current_class_ptr is set but we aren't in a function, we're in
7024 an NSDMI (and therefore a constructor). */
7025 if (current_scope () != current_function_decl
7026 || (DECL_LANG_SPECIFIC (current_function_decl)
7027 && (DECL_CONSTRUCTOR_P (current_function_decl)
7028 || DECL_DESTRUCTOR_P (current_function_decl))))
7029 {
7030 if (cdtorp)
7031 *cdtorp = 1;
7032 return TREE_TYPE (TREE_TYPE (instance));
7033 }
7034 }
7035 else if (TREE_CODE (TREE_TYPE (instance)) == REFERENCE_TYPE)
7036 {
7037 /* We only need one hash table because it is always left empty. */
7038 if (!fixed_type_or_null_ref_ht)
7039 fixed_type_or_null_ref_ht
7040 = new hash_table<pointer_hash<tree_node> > (37);
7041
7042 /* Reference variables should be references to objects. */
7043 if (nonnull)
7044 *nonnull = 1;
7045
7046 /* Enter the INSTANCE in a table to prevent recursion; a
7047 variable's initializer may refer to the variable
7048 itself. */
7049 if (VAR_P (instance)
7050 && DECL_INITIAL (instance)
7051 && !type_dependent_expression_p_push (DECL_INITIAL (instance))
7052 && !fixed_type_or_null_ref_ht->find (instance))
7053 {
7054 tree type;
7055 tree_node **slot;
7056
7057 slot = fixed_type_or_null_ref_ht->find_slot (instance, INSERT);
7058 *slot = instance;
7059 type = RECUR (DECL_INITIAL (instance));
7060 fixed_type_or_null_ref_ht->remove_elt (instance);
7061
7062 return type;
7063 }
7064 }
7065 return NULL_TREE;
7066
7067 default:
7068 return NULL_TREE;
7069 }
7070 #undef RECUR
7071 }
7072
7073 /* Return nonzero if the dynamic type of INSTANCE is known, and
7074 equivalent to the static type. We also handle the case where
7075 INSTANCE is really a pointer. Return negative if this is a
7076 ctor/dtor. There the dynamic type is known, but this might not be
7077 the most derived base of the original object, and hence virtual
7078 bases may not be laid out according to this type.
7079
7080 Used to determine whether the virtual function table is needed
7081 or not.
7082
7083 *NONNULL is set iff INSTANCE can be known to be nonnull, regardless
7084 of our knowledge of its type. *NONNULL should be initialized
7085 before this function is called. */
7086
7087 int
7088 resolves_to_fixed_type_p (tree instance, int* nonnull)
7089 {
7090 tree t = TREE_TYPE (instance);
7091 int cdtorp = 0;
7092 tree fixed;
7093
7094 /* processing_template_decl can be false in a template if we're in
7095 instantiate_non_dependent_expr, but we still want to suppress
7096 this check. */
7097 if (in_template_function ())
7098 {
7099 /* In a template we only care about the type of the result. */
7100 if (nonnull)
7101 *nonnull = true;
7102 return true;
7103 }
7104
7105 fixed = fixed_type_or_null (instance, nonnull, &cdtorp);
7106 if (fixed == NULL_TREE)
7107 return 0;
7108 if (POINTER_TYPE_P (t))
7109 t = TREE_TYPE (t);
7110 if (!same_type_ignoring_top_level_qualifiers_p (t, fixed))
7111 return 0;
7112 return cdtorp ? -1 : 1;
7113 }
7114
7115 \f
7116 void
7117 init_class_processing (void)
7118 {
7119 current_class_depth = 0;
7120 current_class_stack_size = 10;
7121 current_class_stack
7122 = XNEWVEC (struct class_stack_node, current_class_stack_size);
7123 vec_alloc (local_classes, 8);
7124 sizeof_biggest_empty_class = size_zero_node;
7125
7126 ridpointers[(int) RID_PUBLIC] = access_public_node;
7127 ridpointers[(int) RID_PRIVATE] = access_private_node;
7128 ridpointers[(int) RID_PROTECTED] = access_protected_node;
7129 }
7130
7131 /* Restore the cached PREVIOUS_CLASS_LEVEL. */
7132
7133 static void
7134 restore_class_cache (void)
7135 {
7136 tree type;
7137
7138 /* We are re-entering the same class we just left, so we don't
7139 have to search the whole inheritance matrix to find all the
7140 decls to bind again. Instead, we install the cached
7141 class_shadowed list and walk through it binding names. */
7142 push_binding_level (previous_class_level);
7143 class_binding_level = previous_class_level;
7144 /* Restore IDENTIFIER_TYPE_VALUE. */
7145 for (type = class_binding_level->type_shadowed;
7146 type;
7147 type = TREE_CHAIN (type))
7148 SET_IDENTIFIER_TYPE_VALUE (TREE_PURPOSE (type), TREE_TYPE (type));
7149 }
7150
7151 /* Set global variables CURRENT_CLASS_NAME and CURRENT_CLASS_TYPE as
7152 appropriate for TYPE.
7153
7154 So that we may avoid calls to lookup_name, we cache the _TYPE
7155 nodes of local TYPE_DECLs in the TREE_TYPE field of the name.
7156
7157 For multiple inheritance, we perform a two-pass depth-first search
7158 of the type lattice. */
7159
7160 void
7161 pushclass (tree type)
7162 {
7163 class_stack_node_t csn;
7164
7165 type = TYPE_MAIN_VARIANT (type);
7166
7167 /* Make sure there is enough room for the new entry on the stack. */
7168 if (current_class_depth + 1 >= current_class_stack_size)
7169 {
7170 current_class_stack_size *= 2;
7171 current_class_stack
7172 = XRESIZEVEC (struct class_stack_node, current_class_stack,
7173 current_class_stack_size);
7174 }
7175
7176 /* Insert a new entry on the class stack. */
7177 csn = current_class_stack + current_class_depth;
7178 csn->name = current_class_name;
7179 csn->type = current_class_type;
7180 csn->access = current_access_specifier;
7181 csn->names_used = 0;
7182 csn->hidden = 0;
7183 current_class_depth++;
7184
7185 /* Now set up the new type. */
7186 current_class_name = TYPE_NAME (type);
7187 if (TREE_CODE (current_class_name) == TYPE_DECL)
7188 current_class_name = DECL_NAME (current_class_name);
7189 current_class_type = type;
7190
7191 /* By default, things in classes are private, while things in
7192 structures or unions are public. */
7193 current_access_specifier = (CLASSTYPE_DECLARED_CLASS (type)
7194 ? access_private_node
7195 : access_public_node);
7196
7197 if (previous_class_level
7198 && type != previous_class_level->this_entity
7199 && current_class_depth == 1)
7200 {
7201 /* Forcibly remove any old class remnants. */
7202 invalidate_class_lookup_cache ();
7203 }
7204
7205 if (!previous_class_level
7206 || type != previous_class_level->this_entity
7207 || current_class_depth > 1)
7208 pushlevel_class ();
7209 else
7210 restore_class_cache ();
7211 }
7212
7213 /* When we exit a toplevel class scope, we save its binding level so
7214 that we can restore it quickly. Here, we've entered some other
7215 class, so we must invalidate our cache. */
7216
7217 void
7218 invalidate_class_lookup_cache (void)
7219 {
7220 previous_class_level = NULL;
7221 }
7222
7223 /* Get out of the current class scope. If we were in a class scope
7224 previously, that is the one popped to. */
7225
7226 void
7227 popclass (void)
7228 {
7229 poplevel_class ();
7230
7231 current_class_depth--;
7232 current_class_name = current_class_stack[current_class_depth].name;
7233 current_class_type = current_class_stack[current_class_depth].type;
7234 current_access_specifier = current_class_stack[current_class_depth].access;
7235 if (current_class_stack[current_class_depth].names_used)
7236 splay_tree_delete (current_class_stack[current_class_depth].names_used);
7237 }
7238
7239 /* Mark the top of the class stack as hidden. */
7240
7241 void
7242 push_class_stack (void)
7243 {
7244 if (current_class_depth)
7245 ++current_class_stack[current_class_depth - 1].hidden;
7246 }
7247
7248 /* Mark the top of the class stack as un-hidden. */
7249
7250 void
7251 pop_class_stack (void)
7252 {
7253 if (current_class_depth)
7254 --current_class_stack[current_class_depth - 1].hidden;
7255 }
7256
7257 /* Returns 1 if the class type currently being defined is either T or
7258 a nested type of T. */
7259
7260 bool
7261 currently_open_class (tree t)
7262 {
7263 int i;
7264
7265 if (!CLASS_TYPE_P (t))
7266 return false;
7267
7268 t = TYPE_MAIN_VARIANT (t);
7269
7270 /* We start looking from 1 because entry 0 is from global scope,
7271 and has no type. */
7272 for (i = current_class_depth; i > 0; --i)
7273 {
7274 tree c;
7275 if (i == current_class_depth)
7276 c = current_class_type;
7277 else
7278 {
7279 if (current_class_stack[i].hidden)
7280 break;
7281 c = current_class_stack[i].type;
7282 }
7283 if (!c)
7284 continue;
7285 if (same_type_p (c, t))
7286 return true;
7287 }
7288 return false;
7289 }
7290
7291 /* If either current_class_type or one of its enclosing classes are derived
7292 from T, return the appropriate type. Used to determine how we found
7293 something via unqualified lookup. */
7294
7295 tree
7296 currently_open_derived_class (tree t)
7297 {
7298 int i;
7299
7300 /* The bases of a dependent type are unknown. */
7301 if (dependent_type_p (t))
7302 return NULL_TREE;
7303
7304 if (!current_class_type)
7305 return NULL_TREE;
7306
7307 if (DERIVED_FROM_P (t, current_class_type))
7308 return current_class_type;
7309
7310 for (i = current_class_depth - 1; i > 0; --i)
7311 {
7312 if (current_class_stack[i].hidden)
7313 break;
7314 if (DERIVED_FROM_P (t, current_class_stack[i].type))
7315 return current_class_stack[i].type;
7316 }
7317
7318 return NULL_TREE;
7319 }
7320
7321 /* Return the outermost enclosing class type that is still open, or
7322 NULL_TREE. */
7323
7324 tree
7325 outermost_open_class (void)
7326 {
7327 if (!current_class_type)
7328 return NULL_TREE;
7329 tree r = NULL_TREE;
7330 if (TYPE_BEING_DEFINED (current_class_type))
7331 r = current_class_type;
7332 for (int i = current_class_depth - 1; i > 0; --i)
7333 {
7334 if (current_class_stack[i].hidden)
7335 break;
7336 tree t = current_class_stack[i].type;
7337 if (!TYPE_BEING_DEFINED (t))
7338 break;
7339 r = t;
7340 }
7341 return r;
7342 }
7343
7344 /* Returns the innermost class type which is not a lambda closure type. */
7345
7346 tree
7347 current_nonlambda_class_type (void)
7348 {
7349 int i;
7350
7351 /* We start looking from 1 because entry 0 is from global scope,
7352 and has no type. */
7353 for (i = current_class_depth; i > 0; --i)
7354 {
7355 tree c;
7356 if (i == current_class_depth)
7357 c = current_class_type;
7358 else
7359 {
7360 if (current_class_stack[i].hidden)
7361 break;
7362 c = current_class_stack[i].type;
7363 }
7364 if (!c)
7365 continue;
7366 if (!LAMBDA_TYPE_P (c))
7367 return c;
7368 }
7369 return NULL_TREE;
7370 }
7371
7372 /* When entering a class scope, all enclosing class scopes' names with
7373 static meaning (static variables, static functions, types and
7374 enumerators) have to be visible. This recursive function calls
7375 pushclass for all enclosing class contexts until global or a local
7376 scope is reached. TYPE is the enclosed class. */
7377
7378 void
7379 push_nested_class (tree type)
7380 {
7381 /* A namespace might be passed in error cases, like A::B:C. */
7382 if (type == NULL_TREE
7383 || !CLASS_TYPE_P (type))
7384 return;
7385
7386 push_nested_class (DECL_CONTEXT (TYPE_MAIN_DECL (type)));
7387
7388 pushclass (type);
7389 }
7390
7391 /* Undoes a push_nested_class call. */
7392
7393 void
7394 pop_nested_class (void)
7395 {
7396 tree context = DECL_CONTEXT (TYPE_MAIN_DECL (current_class_type));
7397
7398 popclass ();
7399 if (context && CLASS_TYPE_P (context))
7400 pop_nested_class ();
7401 }
7402
7403 /* Returns the number of extern "LANG" blocks we are nested within. */
7404
7405 int
7406 current_lang_depth (void)
7407 {
7408 return vec_safe_length (current_lang_base);
7409 }
7410
7411 /* Set global variables CURRENT_LANG_NAME to appropriate value
7412 so that behavior of name-mangling machinery is correct. */
7413
7414 void
7415 push_lang_context (tree name)
7416 {
7417 vec_safe_push (current_lang_base, current_lang_name);
7418
7419 if (name == lang_name_cplusplus)
7420 {
7421 current_lang_name = name;
7422 }
7423 else if (name == lang_name_java)
7424 {
7425 current_lang_name = name;
7426 /* DECL_IGNORED_P is initially set for these types, to avoid clutter.
7427 (See record_builtin_java_type in decl.c.) However, that causes
7428 incorrect debug entries if these types are actually used.
7429 So we re-enable debug output after extern "Java". */
7430 DECL_IGNORED_P (TYPE_NAME (java_byte_type_node)) = 0;
7431 DECL_IGNORED_P (TYPE_NAME (java_short_type_node)) = 0;
7432 DECL_IGNORED_P (TYPE_NAME (java_int_type_node)) = 0;
7433 DECL_IGNORED_P (TYPE_NAME (java_long_type_node)) = 0;
7434 DECL_IGNORED_P (TYPE_NAME (java_float_type_node)) = 0;
7435 DECL_IGNORED_P (TYPE_NAME (java_double_type_node)) = 0;
7436 DECL_IGNORED_P (TYPE_NAME (java_char_type_node)) = 0;
7437 DECL_IGNORED_P (TYPE_NAME (java_boolean_type_node)) = 0;
7438 }
7439 else if (name == lang_name_c)
7440 {
7441 current_lang_name = name;
7442 }
7443 else
7444 error ("language string %<\"%E\"%> not recognized", name);
7445 }
7446
7447 /* Get out of the current language scope. */
7448
7449 void
7450 pop_lang_context (void)
7451 {
7452 current_lang_name = current_lang_base->pop ();
7453 }
7454 \f
7455 /* Type instantiation routines. */
7456
7457 /* Given an OVERLOAD and a TARGET_TYPE, return the function that
7458 matches the TARGET_TYPE. If there is no satisfactory match, return
7459 error_mark_node, and issue an error & warning messages under
7460 control of FLAGS. Permit pointers to member function if FLAGS
7461 permits. If TEMPLATE_ONLY, the name of the overloaded function was
7462 a template-id, and EXPLICIT_TARGS are the explicitly provided
7463 template arguments.
7464
7465 If OVERLOAD is for one or more member functions, then ACCESS_PATH
7466 is the base path used to reference those member functions. If
7467 the address is resolved to a member function, access checks will be
7468 performed and errors issued if appropriate. */
7469
7470 static tree
7471 resolve_address_of_overloaded_function (tree target_type,
7472 tree overload,
7473 tsubst_flags_t flags,
7474 bool template_only,
7475 tree explicit_targs,
7476 tree access_path)
7477 {
7478 /* Here's what the standard says:
7479
7480 [over.over]
7481
7482 If the name is a function template, template argument deduction
7483 is done, and if the argument deduction succeeds, the deduced
7484 arguments are used to generate a single template function, which
7485 is added to the set of overloaded functions considered.
7486
7487 Non-member functions and static member functions match targets of
7488 type "pointer-to-function" or "reference-to-function." Nonstatic
7489 member functions match targets of type "pointer-to-member
7490 function;" the function type of the pointer to member is used to
7491 select the member function from the set of overloaded member
7492 functions. If a nonstatic member function is selected, the
7493 reference to the overloaded function name is required to have the
7494 form of a pointer to member as described in 5.3.1.
7495
7496 If more than one function is selected, any template functions in
7497 the set are eliminated if the set also contains a non-template
7498 function, and any given template function is eliminated if the
7499 set contains a second template function that is more specialized
7500 than the first according to the partial ordering rules 14.5.5.2.
7501 After such eliminations, if any, there shall remain exactly one
7502 selected function. */
7503
7504 int is_ptrmem = 0;
7505 /* We store the matches in a TREE_LIST rooted here. The functions
7506 are the TREE_PURPOSE, not the TREE_VALUE, in this list, for easy
7507 interoperability with most_specialized_instantiation. */
7508 tree matches = NULL_TREE;
7509 tree fn;
7510 tree target_fn_type;
7511
7512 /* By the time we get here, we should be seeing only real
7513 pointer-to-member types, not the internal POINTER_TYPE to
7514 METHOD_TYPE representation. */
7515 gcc_assert (!TYPE_PTR_P (target_type)
7516 || TREE_CODE (TREE_TYPE (target_type)) != METHOD_TYPE);
7517
7518 gcc_assert (is_overloaded_fn (overload));
7519
7520 /* Check that the TARGET_TYPE is reasonable. */
7521 if (TYPE_PTRFN_P (target_type)
7522 || TYPE_REFFN_P (target_type))
7523 /* This is OK. */;
7524 else if (TYPE_PTRMEMFUNC_P (target_type))
7525 /* This is OK, too. */
7526 is_ptrmem = 1;
7527 else if (TREE_CODE (target_type) == FUNCTION_TYPE)
7528 /* This is OK, too. This comes from a conversion to reference
7529 type. */
7530 target_type = build_reference_type (target_type);
7531 else
7532 {
7533 if (flags & tf_error)
7534 error ("cannot resolve overloaded function %qD based on"
7535 " conversion to type %qT",
7536 DECL_NAME (OVL_FUNCTION (overload)), target_type);
7537 return error_mark_node;
7538 }
7539
7540 /* Non-member functions and static member functions match targets of type
7541 "pointer-to-function" or "reference-to-function." Nonstatic member
7542 functions match targets of type "pointer-to-member-function;" the
7543 function type of the pointer to member is used to select the member
7544 function from the set of overloaded member functions.
7545
7546 So figure out the FUNCTION_TYPE that we want to match against. */
7547 target_fn_type = static_fn_type (target_type);
7548
7549 /* If we can find a non-template function that matches, we can just
7550 use it. There's no point in generating template instantiations
7551 if we're just going to throw them out anyhow. But, of course, we
7552 can only do this when we don't *need* a template function. */
7553 if (!template_only)
7554 {
7555 tree fns;
7556
7557 for (fns = overload; fns; fns = OVL_NEXT (fns))
7558 {
7559 tree fn = OVL_CURRENT (fns);
7560
7561 if (TREE_CODE (fn) == TEMPLATE_DECL)
7562 /* We're not looking for templates just yet. */
7563 continue;
7564
7565 if ((TREE_CODE (TREE_TYPE (fn)) == METHOD_TYPE)
7566 != is_ptrmem)
7567 /* We're looking for a non-static member, and this isn't
7568 one, or vice versa. */
7569 continue;
7570
7571 /* Ignore functions which haven't been explicitly
7572 declared. */
7573 if (DECL_ANTICIPATED (fn))
7574 continue;
7575
7576 /* See if there's a match. */
7577 if (same_type_p (target_fn_type, static_fn_type (fn)))
7578 matches = tree_cons (fn, NULL_TREE, matches);
7579 }
7580 }
7581
7582 /* Now, if we've already got a match (or matches), there's no need
7583 to proceed to the template functions. But, if we don't have a
7584 match we need to look at them, too. */
7585 if (!matches)
7586 {
7587 tree target_arg_types;
7588 tree target_ret_type;
7589 tree fns;
7590 tree *args;
7591 unsigned int nargs, ia;
7592 tree arg;
7593
7594 target_arg_types = TYPE_ARG_TYPES (target_fn_type);
7595 target_ret_type = TREE_TYPE (target_fn_type);
7596
7597 nargs = list_length (target_arg_types);
7598 args = XALLOCAVEC (tree, nargs);
7599 for (arg = target_arg_types, ia = 0;
7600 arg != NULL_TREE && arg != void_list_node;
7601 arg = TREE_CHAIN (arg), ++ia)
7602 args[ia] = TREE_VALUE (arg);
7603 nargs = ia;
7604
7605 for (fns = overload; fns; fns = OVL_NEXT (fns))
7606 {
7607 tree fn = OVL_CURRENT (fns);
7608 tree instantiation;
7609 tree targs;
7610
7611 if (TREE_CODE (fn) != TEMPLATE_DECL)
7612 /* We're only looking for templates. */
7613 continue;
7614
7615 if ((TREE_CODE (TREE_TYPE (fn)) == METHOD_TYPE)
7616 != is_ptrmem)
7617 /* We're not looking for a non-static member, and this is
7618 one, or vice versa. */
7619 continue;
7620
7621 tree ret = target_ret_type;
7622
7623 /* If the template has a deduced return type, don't expose it to
7624 template argument deduction. */
7625 if (undeduced_auto_decl (fn))
7626 ret = NULL_TREE;
7627
7628 /* Try to do argument deduction. */
7629 targs = make_tree_vec (DECL_NTPARMS (fn));
7630 instantiation = fn_type_unification (fn, explicit_targs, targs, args,
7631 nargs, ret,
7632 DEDUCE_EXACT, LOOKUP_NORMAL,
7633 false, false);
7634 if (instantiation == error_mark_node)
7635 /* Instantiation failed. */
7636 continue;
7637
7638 /* And now force instantiation to do return type deduction. */
7639 if (undeduced_auto_decl (instantiation))
7640 {
7641 ++function_depth;
7642 instantiate_decl (instantiation, /*defer*/false, /*class*/false);
7643 --function_depth;
7644
7645 require_deduced_type (instantiation);
7646 }
7647
7648 /* See if there's a match. */
7649 if (same_type_p (target_fn_type, static_fn_type (instantiation)))
7650 matches = tree_cons (instantiation, fn, matches);
7651 }
7652
7653 /* Now, remove all but the most specialized of the matches. */
7654 if (matches)
7655 {
7656 tree match = most_specialized_instantiation (matches);
7657
7658 if (match != error_mark_node)
7659 matches = tree_cons (TREE_PURPOSE (match),
7660 NULL_TREE,
7661 NULL_TREE);
7662 }
7663 }
7664
7665 /* Now we should have exactly one function in MATCHES. */
7666 if (matches == NULL_TREE)
7667 {
7668 /* There were *no* matches. */
7669 if (flags & tf_error)
7670 {
7671 error ("no matches converting function %qD to type %q#T",
7672 DECL_NAME (OVL_CURRENT (overload)),
7673 target_type);
7674
7675 print_candidates (overload);
7676 }
7677 return error_mark_node;
7678 }
7679 else if (TREE_CHAIN (matches))
7680 {
7681 /* There were too many matches. First check if they're all
7682 the same function. */
7683 tree match = NULL_TREE;
7684
7685 fn = TREE_PURPOSE (matches);
7686
7687 /* For multi-versioned functions, more than one match is just fine and
7688 decls_match will return false as they are different. */
7689 for (match = TREE_CHAIN (matches); match; match = TREE_CHAIN (match))
7690 if (!decls_match (fn, TREE_PURPOSE (match))
7691 && !targetm.target_option.function_versions
7692 (fn, TREE_PURPOSE (match)))
7693 break;
7694
7695 if (match)
7696 {
7697 if (flags & tf_error)
7698 {
7699 error ("converting overloaded function %qD to type %q#T is ambiguous",
7700 DECL_NAME (OVL_FUNCTION (overload)),
7701 target_type);
7702
7703 /* Since print_candidates expects the functions in the
7704 TREE_VALUE slot, we flip them here. */
7705 for (match = matches; match; match = TREE_CHAIN (match))
7706 TREE_VALUE (match) = TREE_PURPOSE (match);
7707
7708 print_candidates (matches);
7709 }
7710
7711 return error_mark_node;
7712 }
7713 }
7714
7715 /* Good, exactly one match. Now, convert it to the correct type. */
7716 fn = TREE_PURPOSE (matches);
7717
7718 if (DECL_NONSTATIC_MEMBER_FUNCTION_P (fn)
7719 && !(flags & tf_ptrmem_ok) && !flag_ms_extensions)
7720 {
7721 static int explained;
7722
7723 if (!(flags & tf_error))
7724 return error_mark_node;
7725
7726 permerror (input_location, "assuming pointer to member %qD", fn);
7727 if (!explained)
7728 {
7729 inform (input_location, "(a pointer to member can only be formed with %<&%E%>)", fn);
7730 explained = 1;
7731 }
7732 }
7733
7734 /* If a pointer to a function that is multi-versioned is requested, the
7735 pointer to the dispatcher function is returned instead. This works
7736 well because indirectly calling the function will dispatch the right
7737 function version at run-time. */
7738 if (DECL_FUNCTION_VERSIONED (fn))
7739 {
7740 fn = get_function_version_dispatcher (fn);
7741 if (fn == NULL)
7742 return error_mark_node;
7743 /* Mark all the versions corresponding to the dispatcher as used. */
7744 if (!(flags & tf_conv))
7745 mark_versions_used (fn);
7746 }
7747
7748 /* If we're doing overload resolution purely for the purpose of
7749 determining conversion sequences, we should not consider the
7750 function used. If this conversion sequence is selected, the
7751 function will be marked as used at this point. */
7752 if (!(flags & tf_conv))
7753 {
7754 /* Make =delete work with SFINAE. */
7755 if (DECL_DELETED_FN (fn) && !(flags & tf_error))
7756 return error_mark_node;
7757
7758 mark_used (fn);
7759 }
7760
7761 /* We could not check access to member functions when this
7762 expression was originally created since we did not know at that
7763 time to which function the expression referred. */
7764 if (DECL_FUNCTION_MEMBER_P (fn))
7765 {
7766 gcc_assert (access_path);
7767 perform_or_defer_access_check (access_path, fn, fn, flags);
7768 }
7769
7770 if (TYPE_PTRFN_P (target_type) || TYPE_PTRMEMFUNC_P (target_type))
7771 return cp_build_addr_expr (fn, flags);
7772 else
7773 {
7774 /* The target must be a REFERENCE_TYPE. Above, cp_build_unary_op
7775 will mark the function as addressed, but here we must do it
7776 explicitly. */
7777 cxx_mark_addressable (fn);
7778
7779 return fn;
7780 }
7781 }
7782
7783 /* This function will instantiate the type of the expression given in
7784 RHS to match the type of LHSTYPE. If errors exist, then return
7785 error_mark_node. FLAGS is a bit mask. If TF_ERROR is set, then
7786 we complain on errors. If we are not complaining, never modify rhs,
7787 as overload resolution wants to try many possible instantiations, in
7788 the hope that at least one will work.
7789
7790 For non-recursive calls, LHSTYPE should be a function, pointer to
7791 function, or a pointer to member function. */
7792
7793 tree
7794 instantiate_type (tree lhstype, tree rhs, tsubst_flags_t flags)
7795 {
7796 tsubst_flags_t flags_in = flags;
7797 tree access_path = NULL_TREE;
7798
7799 flags &= ~tf_ptrmem_ok;
7800
7801 if (lhstype == unknown_type_node)
7802 {
7803 if (flags & tf_error)
7804 error ("not enough type information");
7805 return error_mark_node;
7806 }
7807
7808 if (TREE_TYPE (rhs) != NULL_TREE && ! (type_unknown_p (rhs)))
7809 {
7810 tree fntype = non_reference (lhstype);
7811 if (same_type_p (fntype, TREE_TYPE (rhs)))
7812 return rhs;
7813 if (flag_ms_extensions
7814 && TYPE_PTRMEMFUNC_P (fntype)
7815 && !TYPE_PTRMEMFUNC_P (TREE_TYPE (rhs)))
7816 /* Microsoft allows `A::f' to be resolved to a
7817 pointer-to-member. */
7818 ;
7819 else
7820 {
7821 if (flags & tf_error)
7822 error ("cannot convert %qE from type %qT to type %qT",
7823 rhs, TREE_TYPE (rhs), fntype);
7824 return error_mark_node;
7825 }
7826 }
7827
7828 if (BASELINK_P (rhs))
7829 {
7830 access_path = BASELINK_ACCESS_BINFO (rhs);
7831 rhs = BASELINK_FUNCTIONS (rhs);
7832 }
7833
7834 /* If we are in a template, and have a NON_DEPENDENT_EXPR, we cannot
7835 deduce any type information. */
7836 if (TREE_CODE (rhs) == NON_DEPENDENT_EXPR)
7837 {
7838 if (flags & tf_error)
7839 error ("not enough type information");
7840 return error_mark_node;
7841 }
7842
7843 /* There only a few kinds of expressions that may have a type
7844 dependent on overload resolution. */
7845 gcc_assert (TREE_CODE (rhs) == ADDR_EXPR
7846 || TREE_CODE (rhs) == COMPONENT_REF
7847 || is_overloaded_fn (rhs)
7848 || (flag_ms_extensions && TREE_CODE (rhs) == FUNCTION_DECL));
7849
7850 /* This should really only be used when attempting to distinguish
7851 what sort of a pointer to function we have. For now, any
7852 arithmetic operation which is not supported on pointers
7853 is rejected as an error. */
7854
7855 switch (TREE_CODE (rhs))
7856 {
7857 case COMPONENT_REF:
7858 {
7859 tree member = TREE_OPERAND (rhs, 1);
7860
7861 member = instantiate_type (lhstype, member, flags);
7862 if (member != error_mark_node
7863 && TREE_SIDE_EFFECTS (TREE_OPERAND (rhs, 0)))
7864 /* Do not lose object's side effects. */
7865 return build2 (COMPOUND_EXPR, TREE_TYPE (member),
7866 TREE_OPERAND (rhs, 0), member);
7867 return member;
7868 }
7869
7870 case OFFSET_REF:
7871 rhs = TREE_OPERAND (rhs, 1);
7872 if (BASELINK_P (rhs))
7873 return instantiate_type (lhstype, rhs, flags_in);
7874
7875 /* This can happen if we are forming a pointer-to-member for a
7876 member template. */
7877 gcc_assert (TREE_CODE (rhs) == TEMPLATE_ID_EXPR);
7878
7879 /* Fall through. */
7880
7881 case TEMPLATE_ID_EXPR:
7882 {
7883 tree fns = TREE_OPERAND (rhs, 0);
7884 tree args = TREE_OPERAND (rhs, 1);
7885
7886 return
7887 resolve_address_of_overloaded_function (lhstype, fns, flags_in,
7888 /*template_only=*/true,
7889 args, access_path);
7890 }
7891
7892 case OVERLOAD:
7893 case FUNCTION_DECL:
7894 return
7895 resolve_address_of_overloaded_function (lhstype, rhs, flags_in,
7896 /*template_only=*/false,
7897 /*explicit_targs=*/NULL_TREE,
7898 access_path);
7899
7900 case ADDR_EXPR:
7901 {
7902 if (PTRMEM_OK_P (rhs))
7903 flags |= tf_ptrmem_ok;
7904
7905 return instantiate_type (lhstype, TREE_OPERAND (rhs, 0), flags);
7906 }
7907
7908 case ERROR_MARK:
7909 return error_mark_node;
7910
7911 default:
7912 gcc_unreachable ();
7913 }
7914 return error_mark_node;
7915 }
7916 \f
7917 /* Return the name of the virtual function pointer field
7918 (as an IDENTIFIER_NODE) for the given TYPE. Note that
7919 this may have to look back through base types to find the
7920 ultimate field name. (For single inheritance, these could
7921 all be the same name. Who knows for multiple inheritance). */
7922
7923 static tree
7924 get_vfield_name (tree type)
7925 {
7926 tree binfo, base_binfo;
7927 char *buf;
7928
7929 for (binfo = TYPE_BINFO (type);
7930 BINFO_N_BASE_BINFOS (binfo);
7931 binfo = base_binfo)
7932 {
7933 base_binfo = BINFO_BASE_BINFO (binfo, 0);
7934
7935 if (BINFO_VIRTUAL_P (base_binfo)
7936 || !TYPE_CONTAINS_VPTR_P (BINFO_TYPE (base_binfo)))
7937 break;
7938 }
7939
7940 type = BINFO_TYPE (binfo);
7941 buf = (char *) alloca (sizeof (VFIELD_NAME_FORMAT)
7942 + TYPE_NAME_LENGTH (type) + 2);
7943 sprintf (buf, VFIELD_NAME_FORMAT,
7944 IDENTIFIER_POINTER (constructor_name (type)));
7945 return get_identifier (buf);
7946 }
7947
7948 void
7949 print_class_statistics (void)
7950 {
7951 if (! GATHER_STATISTICS)
7952 return;
7953
7954 fprintf (stderr, "convert_harshness = %d\n", n_convert_harshness);
7955 fprintf (stderr, "compute_conversion_costs = %d\n", n_compute_conversion_costs);
7956 if (n_vtables)
7957 {
7958 fprintf (stderr, "vtables = %d; vtable searches = %d\n",
7959 n_vtables, n_vtable_searches);
7960 fprintf (stderr, "vtable entries = %d; vtable elems = %d\n",
7961 n_vtable_entries, n_vtable_elems);
7962 }
7963 }
7964
7965 /* Build a dummy reference to ourselves so Derived::Base (and A::A) works,
7966 according to [class]:
7967 The class-name is also inserted
7968 into the scope of the class itself. For purposes of access checking,
7969 the inserted class name is treated as if it were a public member name. */
7970
7971 void
7972 build_self_reference (void)
7973 {
7974 tree name = constructor_name (current_class_type);
7975 tree value = build_lang_decl (TYPE_DECL, name, current_class_type);
7976 tree saved_cas;
7977
7978 DECL_NONLOCAL (value) = 1;
7979 DECL_CONTEXT (value) = current_class_type;
7980 DECL_ARTIFICIAL (value) = 1;
7981 SET_DECL_SELF_REFERENCE_P (value);
7982 set_underlying_type (value);
7983
7984 if (processing_template_decl)
7985 value = push_template_decl (value);
7986
7987 saved_cas = current_access_specifier;
7988 current_access_specifier = access_public_node;
7989 finish_member_declaration (value);
7990 current_access_specifier = saved_cas;
7991 }
7992
7993 /* Returns 1 if TYPE contains only padding bytes. */
7994
7995 int
7996 is_empty_class (tree type)
7997 {
7998 if (type == error_mark_node)
7999 return 0;
8000
8001 if (! CLASS_TYPE_P (type))
8002 return 0;
8003
8004 return CLASSTYPE_EMPTY_P (type);
8005 }
8006
8007 /* Returns true if TYPE contains no actual data, just various
8008 possible combinations of empty classes and possibly a vptr. */
8009
8010 bool
8011 is_really_empty_class (tree type)
8012 {
8013 if (CLASS_TYPE_P (type))
8014 {
8015 tree field;
8016 tree binfo;
8017 tree base_binfo;
8018 int i;
8019
8020 /* CLASSTYPE_EMPTY_P isn't set properly until the class is actually laid
8021 out, but we'd like to be able to check this before then. */
8022 if (COMPLETE_TYPE_P (type) && is_empty_class (type))
8023 return true;
8024
8025 for (binfo = TYPE_BINFO (type), i = 0;
8026 BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
8027 if (!is_really_empty_class (BINFO_TYPE (base_binfo)))
8028 return false;
8029 for (field = TYPE_FIELDS (type); field; field = DECL_CHAIN (field))
8030 if (TREE_CODE (field) == FIELD_DECL
8031 && !DECL_ARTIFICIAL (field)
8032 && !is_really_empty_class (TREE_TYPE (field)))
8033 return false;
8034 return true;
8035 }
8036 else if (TREE_CODE (type) == ARRAY_TYPE)
8037 return is_really_empty_class (TREE_TYPE (type));
8038 return false;
8039 }
8040
8041 /* Note that NAME was looked up while the current class was being
8042 defined and that the result of that lookup was DECL. */
8043
8044 void
8045 maybe_note_name_used_in_class (tree name, tree decl)
8046 {
8047 splay_tree names_used;
8048
8049 /* If we're not defining a class, there's nothing to do. */
8050 if (!(innermost_scope_kind() == sk_class
8051 && TYPE_BEING_DEFINED (current_class_type)
8052 && !LAMBDA_TYPE_P (current_class_type)))
8053 return;
8054
8055 /* If there's already a binding for this NAME, then we don't have
8056 anything to worry about. */
8057 if (lookup_member (current_class_type, name,
8058 /*protect=*/0, /*want_type=*/false, tf_warning_or_error))
8059 return;
8060
8061 if (!current_class_stack[current_class_depth - 1].names_used)
8062 current_class_stack[current_class_depth - 1].names_used
8063 = splay_tree_new (splay_tree_compare_pointers, 0, 0);
8064 names_used = current_class_stack[current_class_depth - 1].names_used;
8065
8066 splay_tree_insert (names_used,
8067 (splay_tree_key) name,
8068 (splay_tree_value) decl);
8069 }
8070
8071 /* Note that NAME was declared (as DECL) in the current class. Check
8072 to see that the declaration is valid. */
8073
8074 void
8075 note_name_declared_in_class (tree name, tree decl)
8076 {
8077 splay_tree names_used;
8078 splay_tree_node n;
8079
8080 /* Look to see if we ever used this name. */
8081 names_used
8082 = current_class_stack[current_class_depth - 1].names_used;
8083 if (!names_used)
8084 return;
8085 /* The C language allows members to be declared with a type of the same
8086 name, and the C++ standard says this diagnostic is not required. So
8087 allow it in extern "C" blocks unless predantic is specified.
8088 Allow it in all cases if -ms-extensions is specified. */
8089 if ((!pedantic && current_lang_name == lang_name_c)
8090 || flag_ms_extensions)
8091 return;
8092 n = splay_tree_lookup (names_used, (splay_tree_key) name);
8093 if (n)
8094 {
8095 /* [basic.scope.class]
8096
8097 A name N used in a class S shall refer to the same declaration
8098 in its context and when re-evaluated in the completed scope of
8099 S. */
8100 permerror (input_location, "declaration of %q#D", decl);
8101 permerror (input_location, "changes meaning of %qD from %q+#D",
8102 DECL_NAME (OVL_CURRENT (decl)), (tree) n->value);
8103 }
8104 }
8105
8106 /* Returns the VAR_DECL for the complete vtable associated with BINFO.
8107 Secondary vtables are merged with primary vtables; this function
8108 will return the VAR_DECL for the primary vtable. */
8109
8110 tree
8111 get_vtbl_decl_for_binfo (tree binfo)
8112 {
8113 tree decl;
8114
8115 decl = BINFO_VTABLE (binfo);
8116 if (decl && TREE_CODE (decl) == POINTER_PLUS_EXPR)
8117 {
8118 gcc_assert (TREE_CODE (TREE_OPERAND (decl, 0)) == ADDR_EXPR);
8119 decl = TREE_OPERAND (TREE_OPERAND (decl, 0), 0);
8120 }
8121 if (decl)
8122 gcc_assert (VAR_P (decl));
8123 return decl;
8124 }
8125
8126
8127 /* Returns the binfo for the primary base of BINFO. If the resulting
8128 BINFO is a virtual base, and it is inherited elsewhere in the
8129 hierarchy, then the returned binfo might not be the primary base of
8130 BINFO in the complete object. Check BINFO_PRIMARY_P or
8131 BINFO_LOST_PRIMARY_P to be sure. */
8132
8133 static tree
8134 get_primary_binfo (tree binfo)
8135 {
8136 tree primary_base;
8137
8138 primary_base = CLASSTYPE_PRIMARY_BINFO (BINFO_TYPE (binfo));
8139 if (!primary_base)
8140 return NULL_TREE;
8141
8142 return copied_binfo (primary_base, binfo);
8143 }
8144
8145 /* If INDENTED_P is zero, indent to INDENT. Return nonzero. */
8146
8147 static int
8148 maybe_indent_hierarchy (FILE * stream, int indent, int indented_p)
8149 {
8150 if (!indented_p)
8151 fprintf (stream, "%*s", indent, "");
8152 return 1;
8153 }
8154
8155 /* Dump the offsets of all the bases rooted at BINFO to STREAM.
8156 INDENT should be zero when called from the top level; it is
8157 incremented recursively. IGO indicates the next expected BINFO in
8158 inheritance graph ordering. */
8159
8160 static tree
8161 dump_class_hierarchy_r (FILE *stream,
8162 int flags,
8163 tree binfo,
8164 tree igo,
8165 int indent)
8166 {
8167 int indented = 0;
8168 tree base_binfo;
8169 int i;
8170
8171 indented = maybe_indent_hierarchy (stream, indent, 0);
8172 fprintf (stream, "%s (0x" HOST_WIDE_INT_PRINT_HEX ") ",
8173 type_as_string (BINFO_TYPE (binfo), TFF_PLAIN_IDENTIFIER),
8174 (HOST_WIDE_INT) (uintptr_t) binfo);
8175 if (binfo != igo)
8176 {
8177 fprintf (stream, "alternative-path\n");
8178 return igo;
8179 }
8180 igo = TREE_CHAIN (binfo);
8181
8182 fprintf (stream, HOST_WIDE_INT_PRINT_DEC,
8183 tree_to_shwi (BINFO_OFFSET (binfo)));
8184 if (is_empty_class (BINFO_TYPE (binfo)))
8185 fprintf (stream, " empty");
8186 else if (CLASSTYPE_NEARLY_EMPTY_P (BINFO_TYPE (binfo)))
8187 fprintf (stream, " nearly-empty");
8188 if (BINFO_VIRTUAL_P (binfo))
8189 fprintf (stream, " virtual");
8190 fprintf (stream, "\n");
8191
8192 indented = 0;
8193 if (BINFO_PRIMARY_P (binfo))
8194 {
8195 indented = maybe_indent_hierarchy (stream, indent + 3, indented);
8196 fprintf (stream, " primary-for %s (0x" HOST_WIDE_INT_PRINT_HEX ")",
8197 type_as_string (BINFO_TYPE (BINFO_INHERITANCE_CHAIN (binfo)),
8198 TFF_PLAIN_IDENTIFIER),
8199 (HOST_WIDE_INT) (uintptr_t) BINFO_INHERITANCE_CHAIN (binfo));
8200 }
8201 if (BINFO_LOST_PRIMARY_P (binfo))
8202 {
8203 indented = maybe_indent_hierarchy (stream, indent + 3, indented);
8204 fprintf (stream, " lost-primary");
8205 }
8206 if (indented)
8207 fprintf (stream, "\n");
8208
8209 if (!(flags & TDF_SLIM))
8210 {
8211 int indented = 0;
8212
8213 if (BINFO_SUBVTT_INDEX (binfo))
8214 {
8215 indented = maybe_indent_hierarchy (stream, indent + 3, indented);
8216 fprintf (stream, " subvttidx=%s",
8217 expr_as_string (BINFO_SUBVTT_INDEX (binfo),
8218 TFF_PLAIN_IDENTIFIER));
8219 }
8220 if (BINFO_VPTR_INDEX (binfo))
8221 {
8222 indented = maybe_indent_hierarchy (stream, indent + 3, indented);
8223 fprintf (stream, " vptridx=%s",
8224 expr_as_string (BINFO_VPTR_INDEX (binfo),
8225 TFF_PLAIN_IDENTIFIER));
8226 }
8227 if (BINFO_VPTR_FIELD (binfo))
8228 {
8229 indented = maybe_indent_hierarchy (stream, indent + 3, indented);
8230 fprintf (stream, " vbaseoffset=%s",
8231 expr_as_string (BINFO_VPTR_FIELD (binfo),
8232 TFF_PLAIN_IDENTIFIER));
8233 }
8234 if (BINFO_VTABLE (binfo))
8235 {
8236 indented = maybe_indent_hierarchy (stream, indent + 3, indented);
8237 fprintf (stream, " vptr=%s",
8238 expr_as_string (BINFO_VTABLE (binfo),
8239 TFF_PLAIN_IDENTIFIER));
8240 }
8241
8242 if (indented)
8243 fprintf (stream, "\n");
8244 }
8245
8246 for (i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); i++)
8247 igo = dump_class_hierarchy_r (stream, flags, base_binfo, igo, indent + 2);
8248
8249 return igo;
8250 }
8251
8252 /* Dump the BINFO hierarchy for T. */
8253
8254 static void
8255 dump_class_hierarchy_1 (FILE *stream, int flags, tree t)
8256 {
8257 fprintf (stream, "Class %s\n", type_as_string (t, TFF_PLAIN_IDENTIFIER));
8258 fprintf (stream, " size=%lu align=%lu\n",
8259 (unsigned long)(tree_to_shwi (TYPE_SIZE (t)) / BITS_PER_UNIT),
8260 (unsigned long)(TYPE_ALIGN (t) / BITS_PER_UNIT));
8261 fprintf (stream, " base size=%lu base align=%lu\n",
8262 (unsigned long)(tree_to_shwi (TYPE_SIZE (CLASSTYPE_AS_BASE (t)))
8263 / BITS_PER_UNIT),
8264 (unsigned long)(TYPE_ALIGN (CLASSTYPE_AS_BASE (t))
8265 / BITS_PER_UNIT));
8266 dump_class_hierarchy_r (stream, flags, TYPE_BINFO (t), TYPE_BINFO (t), 0);
8267 fprintf (stream, "\n");
8268 }
8269
8270 /* Debug interface to hierarchy dumping. */
8271
8272 void
8273 debug_class (tree t)
8274 {
8275 dump_class_hierarchy_1 (stderr, TDF_SLIM, t);
8276 }
8277
8278 static void
8279 dump_class_hierarchy (tree t)
8280 {
8281 int flags;
8282 FILE *stream = get_dump_info (TDI_class, &flags);
8283
8284 if (stream)
8285 {
8286 dump_class_hierarchy_1 (stream, flags, t);
8287 }
8288 }
8289
8290 static void
8291 dump_array (FILE * stream, tree decl)
8292 {
8293 tree value;
8294 unsigned HOST_WIDE_INT ix;
8295 HOST_WIDE_INT elt;
8296 tree size = TYPE_MAX_VALUE (TYPE_DOMAIN (TREE_TYPE (decl)));
8297
8298 elt = (tree_to_shwi (TYPE_SIZE (TREE_TYPE (TREE_TYPE (decl))))
8299 / BITS_PER_UNIT);
8300 fprintf (stream, "%s:", decl_as_string (decl, TFF_PLAIN_IDENTIFIER));
8301 fprintf (stream, " %s entries",
8302 expr_as_string (size_binop (PLUS_EXPR, size, size_one_node),
8303 TFF_PLAIN_IDENTIFIER));
8304 fprintf (stream, "\n");
8305
8306 FOR_EACH_CONSTRUCTOR_VALUE (CONSTRUCTOR_ELTS (DECL_INITIAL (decl)),
8307 ix, value)
8308 fprintf (stream, "%-4ld %s\n", (long)(ix * elt),
8309 expr_as_string (value, TFF_PLAIN_IDENTIFIER));
8310 }
8311
8312 static void
8313 dump_vtable (tree t, tree binfo, tree vtable)
8314 {
8315 int flags;
8316 FILE *stream = get_dump_info (TDI_class, &flags);
8317
8318 if (!stream)
8319 return;
8320
8321 if (!(flags & TDF_SLIM))
8322 {
8323 int ctor_vtbl_p = TYPE_BINFO (t) != binfo;
8324
8325 fprintf (stream, "%s for %s",
8326 ctor_vtbl_p ? "Construction vtable" : "Vtable",
8327 type_as_string (BINFO_TYPE (binfo), TFF_PLAIN_IDENTIFIER));
8328 if (ctor_vtbl_p)
8329 {
8330 if (!BINFO_VIRTUAL_P (binfo))
8331 fprintf (stream, " (0x" HOST_WIDE_INT_PRINT_HEX " instance)",
8332 (HOST_WIDE_INT) (uintptr_t) binfo);
8333 fprintf (stream, " in %s", type_as_string (t, TFF_PLAIN_IDENTIFIER));
8334 }
8335 fprintf (stream, "\n");
8336 dump_array (stream, vtable);
8337 fprintf (stream, "\n");
8338 }
8339 }
8340
8341 static void
8342 dump_vtt (tree t, tree vtt)
8343 {
8344 int flags;
8345 FILE *stream = get_dump_info (TDI_class, &flags);
8346
8347 if (!stream)
8348 return;
8349
8350 if (!(flags & TDF_SLIM))
8351 {
8352 fprintf (stream, "VTT for %s\n",
8353 type_as_string (t, TFF_PLAIN_IDENTIFIER));
8354 dump_array (stream, vtt);
8355 fprintf (stream, "\n");
8356 }
8357 }
8358
8359 /* Dump a function or thunk and its thunkees. */
8360
8361 static void
8362 dump_thunk (FILE *stream, int indent, tree thunk)
8363 {
8364 static const char spaces[] = " ";
8365 tree name = DECL_NAME (thunk);
8366 tree thunks;
8367
8368 fprintf (stream, "%.*s%p %s %s", indent, spaces,
8369 (void *)thunk,
8370 !DECL_THUNK_P (thunk) ? "function"
8371 : DECL_THIS_THUNK_P (thunk) ? "this-thunk" : "covariant-thunk",
8372 name ? IDENTIFIER_POINTER (name) : "<unset>");
8373 if (DECL_THUNK_P (thunk))
8374 {
8375 HOST_WIDE_INT fixed_adjust = THUNK_FIXED_OFFSET (thunk);
8376 tree virtual_adjust = THUNK_VIRTUAL_OFFSET (thunk);
8377
8378 fprintf (stream, " fixed=" HOST_WIDE_INT_PRINT_DEC, fixed_adjust);
8379 if (!virtual_adjust)
8380 /*NOP*/;
8381 else if (DECL_THIS_THUNK_P (thunk))
8382 fprintf (stream, " vcall=" HOST_WIDE_INT_PRINT_DEC,
8383 tree_to_shwi (virtual_adjust));
8384 else
8385 fprintf (stream, " vbase=" HOST_WIDE_INT_PRINT_DEC "(%s)",
8386 tree_to_shwi (BINFO_VPTR_FIELD (virtual_adjust)),
8387 type_as_string (BINFO_TYPE (virtual_adjust), TFF_SCOPE));
8388 if (THUNK_ALIAS (thunk))
8389 fprintf (stream, " alias to %p", (void *)THUNK_ALIAS (thunk));
8390 }
8391 fprintf (stream, "\n");
8392 for (thunks = DECL_THUNKS (thunk); thunks; thunks = TREE_CHAIN (thunks))
8393 dump_thunk (stream, indent + 2, thunks);
8394 }
8395
8396 /* Dump the thunks for FN. */
8397
8398 void
8399 debug_thunks (tree fn)
8400 {
8401 dump_thunk (stderr, 0, fn);
8402 }
8403
8404 /* Virtual function table initialization. */
8405
8406 /* Create all the necessary vtables for T and its base classes. */
8407
8408 static void
8409 finish_vtbls (tree t)
8410 {
8411 tree vbase;
8412 vec<constructor_elt, va_gc> *v = NULL;
8413 tree vtable = BINFO_VTABLE (TYPE_BINFO (t));
8414
8415 /* We lay out the primary and secondary vtables in one contiguous
8416 vtable. The primary vtable is first, followed by the non-virtual
8417 secondary vtables in inheritance graph order. */
8418 accumulate_vtbl_inits (TYPE_BINFO (t), TYPE_BINFO (t), TYPE_BINFO (t),
8419 vtable, t, &v);
8420
8421 /* Then come the virtual bases, also in inheritance graph order. */
8422 for (vbase = TYPE_BINFO (t); vbase; vbase = TREE_CHAIN (vbase))
8423 {
8424 if (!BINFO_VIRTUAL_P (vbase))
8425 continue;
8426 accumulate_vtbl_inits (vbase, vbase, TYPE_BINFO (t), vtable, t, &v);
8427 }
8428
8429 if (BINFO_VTABLE (TYPE_BINFO (t)))
8430 initialize_vtable (TYPE_BINFO (t), v);
8431 }
8432
8433 /* Initialize the vtable for BINFO with the INITS. */
8434
8435 static void
8436 initialize_vtable (tree binfo, vec<constructor_elt, va_gc> *inits)
8437 {
8438 tree decl;
8439
8440 layout_vtable_decl (binfo, vec_safe_length (inits));
8441 decl = get_vtbl_decl_for_binfo (binfo);
8442 initialize_artificial_var (decl, inits);
8443 dump_vtable (BINFO_TYPE (binfo), binfo, decl);
8444 }
8445
8446 /* Build the VTT (virtual table table) for T.
8447 A class requires a VTT if it has virtual bases.
8448
8449 This holds
8450 1 - primary virtual pointer for complete object T
8451 2 - secondary VTTs for each direct non-virtual base of T which requires a
8452 VTT
8453 3 - secondary virtual pointers for each direct or indirect base of T which
8454 has virtual bases or is reachable via a virtual path from T.
8455 4 - secondary VTTs for each direct or indirect virtual base of T.
8456
8457 Secondary VTTs look like complete object VTTs without part 4. */
8458
8459 static void
8460 build_vtt (tree t)
8461 {
8462 tree type;
8463 tree vtt;
8464 tree index;
8465 vec<constructor_elt, va_gc> *inits;
8466
8467 /* Build up the initializers for the VTT. */
8468 inits = NULL;
8469 index = size_zero_node;
8470 build_vtt_inits (TYPE_BINFO (t), t, &inits, &index);
8471
8472 /* If we didn't need a VTT, we're done. */
8473 if (!inits)
8474 return;
8475
8476 /* Figure out the type of the VTT. */
8477 type = build_array_of_n_type (const_ptr_type_node,
8478 inits->length ());
8479
8480 /* Now, build the VTT object itself. */
8481 vtt = build_vtable (t, mangle_vtt_for_type (t), type);
8482 initialize_artificial_var (vtt, inits);
8483 /* Add the VTT to the vtables list. */
8484 DECL_CHAIN (vtt) = DECL_CHAIN (CLASSTYPE_VTABLES (t));
8485 DECL_CHAIN (CLASSTYPE_VTABLES (t)) = vtt;
8486
8487 dump_vtt (t, vtt);
8488 }
8489
8490 /* When building a secondary VTT, BINFO_VTABLE is set to a TREE_LIST with
8491 PURPOSE the RTTI_BINFO, VALUE the real vtable pointer for this binfo,
8492 and CHAIN the vtable pointer for this binfo after construction is
8493 complete. VALUE can also be another BINFO, in which case we recurse. */
8494
8495 static tree
8496 binfo_ctor_vtable (tree binfo)
8497 {
8498 tree vt;
8499
8500 while (1)
8501 {
8502 vt = BINFO_VTABLE (binfo);
8503 if (TREE_CODE (vt) == TREE_LIST)
8504 vt = TREE_VALUE (vt);
8505 if (TREE_CODE (vt) == TREE_BINFO)
8506 binfo = vt;
8507 else
8508 break;
8509 }
8510
8511 return vt;
8512 }
8513
8514 /* Data for secondary VTT initialization. */
8515 typedef struct secondary_vptr_vtt_init_data_s
8516 {
8517 /* Is this the primary VTT? */
8518 bool top_level_p;
8519
8520 /* Current index into the VTT. */
8521 tree index;
8522
8523 /* Vector of initializers built up. */
8524 vec<constructor_elt, va_gc> *inits;
8525
8526 /* The type being constructed by this secondary VTT. */
8527 tree type_being_constructed;
8528 } secondary_vptr_vtt_init_data;
8529
8530 /* Recursively build the VTT-initializer for BINFO (which is in the
8531 hierarchy dominated by T). INITS points to the end of the initializer
8532 list to date. INDEX is the VTT index where the next element will be
8533 replaced. Iff BINFO is the binfo for T, this is the top level VTT (i.e.
8534 not a subvtt for some base of T). When that is so, we emit the sub-VTTs
8535 for virtual bases of T. When it is not so, we build the constructor
8536 vtables for the BINFO-in-T variant. */
8537
8538 static void
8539 build_vtt_inits (tree binfo, tree t, vec<constructor_elt, va_gc> **inits,
8540 tree *index)
8541 {
8542 int i;
8543 tree b;
8544 tree init;
8545 secondary_vptr_vtt_init_data data;
8546 int top_level_p = SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), t);
8547
8548 /* We only need VTTs for subobjects with virtual bases. */
8549 if (!CLASSTYPE_VBASECLASSES (BINFO_TYPE (binfo)))
8550 return;
8551
8552 /* We need to use a construction vtable if this is not the primary
8553 VTT. */
8554 if (!top_level_p)
8555 {
8556 build_ctor_vtbl_group (binfo, t);
8557
8558 /* Record the offset in the VTT where this sub-VTT can be found. */
8559 BINFO_SUBVTT_INDEX (binfo) = *index;
8560 }
8561
8562 /* Add the address of the primary vtable for the complete object. */
8563 init = binfo_ctor_vtable (binfo);
8564 CONSTRUCTOR_APPEND_ELT (*inits, NULL_TREE, init);
8565 if (top_level_p)
8566 {
8567 gcc_assert (!BINFO_VPTR_INDEX (binfo));
8568 BINFO_VPTR_INDEX (binfo) = *index;
8569 }
8570 *index = size_binop (PLUS_EXPR, *index, TYPE_SIZE_UNIT (ptr_type_node));
8571
8572 /* Recursively add the secondary VTTs for non-virtual bases. */
8573 for (i = 0; BINFO_BASE_ITERATE (binfo, i, b); ++i)
8574 if (!BINFO_VIRTUAL_P (b))
8575 build_vtt_inits (b, t, inits, index);
8576
8577 /* Add secondary virtual pointers for all subobjects of BINFO with
8578 either virtual bases or reachable along a virtual path, except
8579 subobjects that are non-virtual primary bases. */
8580 data.top_level_p = top_level_p;
8581 data.index = *index;
8582 data.inits = *inits;
8583 data.type_being_constructed = BINFO_TYPE (binfo);
8584
8585 dfs_walk_once (binfo, dfs_build_secondary_vptr_vtt_inits, NULL, &data);
8586
8587 *index = data.index;
8588
8589 /* data.inits might have grown as we added secondary virtual pointers.
8590 Make sure our caller knows about the new vector. */
8591 *inits = data.inits;
8592
8593 if (top_level_p)
8594 /* Add the secondary VTTs for virtual bases in inheritance graph
8595 order. */
8596 for (b = TYPE_BINFO (BINFO_TYPE (binfo)); b; b = TREE_CHAIN (b))
8597 {
8598 if (!BINFO_VIRTUAL_P (b))
8599 continue;
8600
8601 build_vtt_inits (b, t, inits, index);
8602 }
8603 else
8604 /* Remove the ctor vtables we created. */
8605 dfs_walk_all (binfo, dfs_fixup_binfo_vtbls, NULL, binfo);
8606 }
8607
8608 /* Called from build_vtt_inits via dfs_walk. BINFO is the binfo for the base
8609 in most derived. DATA is a SECONDARY_VPTR_VTT_INIT_DATA structure. */
8610
8611 static tree
8612 dfs_build_secondary_vptr_vtt_inits (tree binfo, void *data_)
8613 {
8614 secondary_vptr_vtt_init_data *data = (secondary_vptr_vtt_init_data *)data_;
8615
8616 /* We don't care about bases that don't have vtables. */
8617 if (!TYPE_VFIELD (BINFO_TYPE (binfo)))
8618 return dfs_skip_bases;
8619
8620 /* We're only interested in proper subobjects of the type being
8621 constructed. */
8622 if (SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), data->type_being_constructed))
8623 return NULL_TREE;
8624
8625 /* We're only interested in bases with virtual bases or reachable
8626 via a virtual path from the type being constructed. */
8627 if (!(CLASSTYPE_VBASECLASSES (BINFO_TYPE (binfo))
8628 || binfo_via_virtual (binfo, data->type_being_constructed)))
8629 return dfs_skip_bases;
8630
8631 /* We're not interested in non-virtual primary bases. */
8632 if (!BINFO_VIRTUAL_P (binfo) && BINFO_PRIMARY_P (binfo))
8633 return NULL_TREE;
8634
8635 /* Record the index where this secondary vptr can be found. */
8636 if (data->top_level_p)
8637 {
8638 gcc_assert (!BINFO_VPTR_INDEX (binfo));
8639 BINFO_VPTR_INDEX (binfo) = data->index;
8640
8641 if (BINFO_VIRTUAL_P (binfo))
8642 {
8643 /* It's a primary virtual base, and this is not a
8644 construction vtable. Find the base this is primary of in
8645 the inheritance graph, and use that base's vtable
8646 now. */
8647 while (BINFO_PRIMARY_P (binfo))
8648 binfo = BINFO_INHERITANCE_CHAIN (binfo);
8649 }
8650 }
8651
8652 /* Add the initializer for the secondary vptr itself. */
8653 CONSTRUCTOR_APPEND_ELT (data->inits, NULL_TREE, binfo_ctor_vtable (binfo));
8654
8655 /* Advance the vtt index. */
8656 data->index = size_binop (PLUS_EXPR, data->index,
8657 TYPE_SIZE_UNIT (ptr_type_node));
8658
8659 return NULL_TREE;
8660 }
8661
8662 /* Called from build_vtt_inits via dfs_walk. After building
8663 constructor vtables and generating the sub-vtt from them, we need
8664 to restore the BINFO_VTABLES that were scribbled on. DATA is the
8665 binfo of the base whose sub vtt was generated. */
8666
8667 static tree
8668 dfs_fixup_binfo_vtbls (tree binfo, void* data)
8669 {
8670 tree vtable = BINFO_VTABLE (binfo);
8671
8672 if (!TYPE_CONTAINS_VPTR_P (BINFO_TYPE (binfo)))
8673 /* If this class has no vtable, none of its bases do. */
8674 return dfs_skip_bases;
8675
8676 if (!vtable)
8677 /* This might be a primary base, so have no vtable in this
8678 hierarchy. */
8679 return NULL_TREE;
8680
8681 /* If we scribbled the construction vtable vptr into BINFO, clear it
8682 out now. */
8683 if (TREE_CODE (vtable) == TREE_LIST
8684 && (TREE_PURPOSE (vtable) == (tree) data))
8685 BINFO_VTABLE (binfo) = TREE_CHAIN (vtable);
8686
8687 return NULL_TREE;
8688 }
8689
8690 /* Build the construction vtable group for BINFO which is in the
8691 hierarchy dominated by T. */
8692
8693 static void
8694 build_ctor_vtbl_group (tree binfo, tree t)
8695 {
8696 tree type;
8697 tree vtbl;
8698 tree id;
8699 tree vbase;
8700 vec<constructor_elt, va_gc> *v;
8701
8702 /* See if we've already created this construction vtable group. */
8703 id = mangle_ctor_vtbl_for_type (t, binfo);
8704 if (IDENTIFIER_GLOBAL_VALUE (id))
8705 return;
8706
8707 gcc_assert (!SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), t));
8708 /* Build a version of VTBL (with the wrong type) for use in
8709 constructing the addresses of secondary vtables in the
8710 construction vtable group. */
8711 vtbl = build_vtable (t, id, ptr_type_node);
8712 DECL_CONSTRUCTION_VTABLE_P (vtbl) = 1;
8713 /* Don't export construction vtables from shared libraries. Even on
8714 targets that don't support hidden visibility, this tells
8715 can_refer_decl_in_current_unit_p not to assume that it's safe to
8716 access from a different compilation unit (bz 54314). */
8717 DECL_VISIBILITY (vtbl) = VISIBILITY_HIDDEN;
8718 DECL_VISIBILITY_SPECIFIED (vtbl) = true;
8719
8720 v = NULL;
8721 accumulate_vtbl_inits (binfo, TYPE_BINFO (TREE_TYPE (binfo)),
8722 binfo, vtbl, t, &v);
8723
8724 /* Add the vtables for each of our virtual bases using the vbase in T
8725 binfo. */
8726 for (vbase = TYPE_BINFO (BINFO_TYPE (binfo));
8727 vbase;
8728 vbase = TREE_CHAIN (vbase))
8729 {
8730 tree b;
8731
8732 if (!BINFO_VIRTUAL_P (vbase))
8733 continue;
8734 b = copied_binfo (vbase, binfo);
8735
8736 accumulate_vtbl_inits (b, vbase, binfo, vtbl, t, &v);
8737 }
8738
8739 /* Figure out the type of the construction vtable. */
8740 type = build_array_of_n_type (vtable_entry_type, v->length ());
8741 layout_type (type);
8742 TREE_TYPE (vtbl) = type;
8743 DECL_SIZE (vtbl) = DECL_SIZE_UNIT (vtbl) = NULL_TREE;
8744 layout_decl (vtbl, 0);
8745
8746 /* Initialize the construction vtable. */
8747 CLASSTYPE_VTABLES (t) = chainon (CLASSTYPE_VTABLES (t), vtbl);
8748 initialize_artificial_var (vtbl, v);
8749 dump_vtable (t, binfo, vtbl);
8750 }
8751
8752 /* Add the vtbl initializers for BINFO (and its bases other than
8753 non-virtual primaries) to the list of INITS. BINFO is in the
8754 hierarchy dominated by T. RTTI_BINFO is the binfo within T of
8755 the constructor the vtbl inits should be accumulated for. (If this
8756 is the complete object vtbl then RTTI_BINFO will be TYPE_BINFO (T).)
8757 ORIG_BINFO is the binfo for this object within BINFO_TYPE (RTTI_BINFO).
8758 BINFO is the active base equivalent of ORIG_BINFO in the inheritance
8759 graph of T. Both BINFO and ORIG_BINFO will have the same BINFO_TYPE,
8760 but are not necessarily the same in terms of layout. */
8761
8762 static void
8763 accumulate_vtbl_inits (tree binfo,
8764 tree orig_binfo,
8765 tree rtti_binfo,
8766 tree vtbl,
8767 tree t,
8768 vec<constructor_elt, va_gc> **inits)
8769 {
8770 int i;
8771 tree base_binfo;
8772 int ctor_vtbl_p = !SAME_BINFO_TYPE_P (BINFO_TYPE (rtti_binfo), t);
8773
8774 gcc_assert (SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), BINFO_TYPE (orig_binfo)));
8775
8776 /* If it doesn't have a vptr, we don't do anything. */
8777 if (!TYPE_CONTAINS_VPTR_P (BINFO_TYPE (binfo)))
8778 return;
8779
8780 /* If we're building a construction vtable, we're not interested in
8781 subobjects that don't require construction vtables. */
8782 if (ctor_vtbl_p
8783 && !CLASSTYPE_VBASECLASSES (BINFO_TYPE (binfo))
8784 && !binfo_via_virtual (orig_binfo, BINFO_TYPE (rtti_binfo)))
8785 return;
8786
8787 /* Build the initializers for the BINFO-in-T vtable. */
8788 dfs_accumulate_vtbl_inits (binfo, orig_binfo, rtti_binfo, vtbl, t, inits);
8789
8790 /* Walk the BINFO and its bases. We walk in preorder so that as we
8791 initialize each vtable we can figure out at what offset the
8792 secondary vtable lies from the primary vtable. We can't use
8793 dfs_walk here because we need to iterate through bases of BINFO
8794 and RTTI_BINFO simultaneously. */
8795 for (i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
8796 {
8797 /* Skip virtual bases. */
8798 if (BINFO_VIRTUAL_P (base_binfo))
8799 continue;
8800 accumulate_vtbl_inits (base_binfo,
8801 BINFO_BASE_BINFO (orig_binfo, i),
8802 rtti_binfo, vtbl, t,
8803 inits);
8804 }
8805 }
8806
8807 /* Called from accumulate_vtbl_inits. Adds the initializers for the
8808 BINFO vtable to L. */
8809
8810 static void
8811 dfs_accumulate_vtbl_inits (tree binfo,
8812 tree orig_binfo,
8813 tree rtti_binfo,
8814 tree orig_vtbl,
8815 tree t,
8816 vec<constructor_elt, va_gc> **l)
8817 {
8818 tree vtbl = NULL_TREE;
8819 int ctor_vtbl_p = !SAME_BINFO_TYPE_P (BINFO_TYPE (rtti_binfo), t);
8820 int n_inits;
8821
8822 if (ctor_vtbl_p
8823 && BINFO_VIRTUAL_P (orig_binfo) && BINFO_PRIMARY_P (orig_binfo))
8824 {
8825 /* In the hierarchy of BINFO_TYPE (RTTI_BINFO), this is a
8826 primary virtual base. If it is not the same primary in
8827 the hierarchy of T, we'll need to generate a ctor vtable
8828 for it, to place at its location in T. If it is the same
8829 primary, we still need a VTT entry for the vtable, but it
8830 should point to the ctor vtable for the base it is a
8831 primary for within the sub-hierarchy of RTTI_BINFO.
8832
8833 There are three possible cases:
8834
8835 1) We are in the same place.
8836 2) We are a primary base within a lost primary virtual base of
8837 RTTI_BINFO.
8838 3) We are primary to something not a base of RTTI_BINFO. */
8839
8840 tree b;
8841 tree last = NULL_TREE;
8842
8843 /* First, look through the bases we are primary to for RTTI_BINFO
8844 or a virtual base. */
8845 b = binfo;
8846 while (BINFO_PRIMARY_P (b))
8847 {
8848 b = BINFO_INHERITANCE_CHAIN (b);
8849 last = b;
8850 if (BINFO_VIRTUAL_P (b) || b == rtti_binfo)
8851 goto found;
8852 }
8853 /* If we run out of primary links, keep looking down our
8854 inheritance chain; we might be an indirect primary. */
8855 for (b = last; b; b = BINFO_INHERITANCE_CHAIN (b))
8856 if (BINFO_VIRTUAL_P (b) || b == rtti_binfo)
8857 break;
8858 found:
8859
8860 /* If we found RTTI_BINFO, this is case 1. If we found a virtual
8861 base B and it is a base of RTTI_BINFO, this is case 2. In
8862 either case, we share our vtable with LAST, i.e. the
8863 derived-most base within B of which we are a primary. */
8864 if (b == rtti_binfo
8865 || (b && binfo_for_vbase (BINFO_TYPE (b), BINFO_TYPE (rtti_binfo))))
8866 /* Just set our BINFO_VTABLE to point to LAST, as we may not have
8867 set LAST's BINFO_VTABLE yet. We'll extract the actual vptr in
8868 binfo_ctor_vtable after everything's been set up. */
8869 vtbl = last;
8870
8871 /* Otherwise, this is case 3 and we get our own. */
8872 }
8873 else if (!BINFO_NEW_VTABLE_MARKED (orig_binfo))
8874 return;
8875
8876 n_inits = vec_safe_length (*l);
8877
8878 if (!vtbl)
8879 {
8880 tree index;
8881 int non_fn_entries;
8882
8883 /* Add the initializer for this vtable. */
8884 build_vtbl_initializer (binfo, orig_binfo, t, rtti_binfo,
8885 &non_fn_entries, l);
8886
8887 /* Figure out the position to which the VPTR should point. */
8888 vtbl = build1 (ADDR_EXPR, vtbl_ptr_type_node, orig_vtbl);
8889 index = size_binop (MULT_EXPR,
8890 TYPE_SIZE_UNIT (vtable_entry_type),
8891 size_int (non_fn_entries + n_inits));
8892 vtbl = fold_build_pointer_plus (vtbl, index);
8893 }
8894
8895 if (ctor_vtbl_p)
8896 /* For a construction vtable, we can't overwrite BINFO_VTABLE.
8897 So, we make a TREE_LIST. Later, dfs_fixup_binfo_vtbls will
8898 straighten this out. */
8899 BINFO_VTABLE (binfo) = tree_cons (rtti_binfo, vtbl, BINFO_VTABLE (binfo));
8900 else if (BINFO_PRIMARY_P (binfo) && BINFO_VIRTUAL_P (binfo))
8901 /* Throw away any unneeded intializers. */
8902 (*l)->truncate (n_inits);
8903 else
8904 /* For an ordinary vtable, set BINFO_VTABLE. */
8905 BINFO_VTABLE (binfo) = vtbl;
8906 }
8907
8908 static GTY(()) tree abort_fndecl_addr;
8909
8910 /* Construct the initializer for BINFO's virtual function table. BINFO
8911 is part of the hierarchy dominated by T. If we're building a
8912 construction vtable, the ORIG_BINFO is the binfo we should use to
8913 find the actual function pointers to put in the vtable - but they
8914 can be overridden on the path to most-derived in the graph that
8915 ORIG_BINFO belongs. Otherwise,
8916 ORIG_BINFO should be the same as BINFO. The RTTI_BINFO is the
8917 BINFO that should be indicated by the RTTI information in the
8918 vtable; it will be a base class of T, rather than T itself, if we
8919 are building a construction vtable.
8920
8921 The value returned is a TREE_LIST suitable for wrapping in a
8922 CONSTRUCTOR to use as the DECL_INITIAL for a vtable. If
8923 NON_FN_ENTRIES_P is not NULL, *NON_FN_ENTRIES_P is set to the
8924 number of non-function entries in the vtable.
8925
8926 It might seem that this function should never be called with a
8927 BINFO for which BINFO_PRIMARY_P holds, the vtable for such a
8928 base is always subsumed by a derived class vtable. However, when
8929 we are building construction vtables, we do build vtables for
8930 primary bases; we need these while the primary base is being
8931 constructed. */
8932
8933 static void
8934 build_vtbl_initializer (tree binfo,
8935 tree orig_binfo,
8936 tree t,
8937 tree rtti_binfo,
8938 int* non_fn_entries_p,
8939 vec<constructor_elt, va_gc> **inits)
8940 {
8941 tree v;
8942 vtbl_init_data vid;
8943 unsigned ix, jx;
8944 tree vbinfo;
8945 vec<tree, va_gc> *vbases;
8946 constructor_elt *e;
8947
8948 /* Initialize VID. */
8949 memset (&vid, 0, sizeof (vid));
8950 vid.binfo = binfo;
8951 vid.derived = t;
8952 vid.rtti_binfo = rtti_binfo;
8953 vid.primary_vtbl_p = SAME_BINFO_TYPE_P (BINFO_TYPE (binfo), t);
8954 vid.ctor_vtbl_p = !SAME_BINFO_TYPE_P (BINFO_TYPE (rtti_binfo), t);
8955 vid.generate_vcall_entries = true;
8956 /* The first vbase or vcall offset is at index -3 in the vtable. */
8957 vid.index = ssize_int(-3 * TARGET_VTABLE_DATA_ENTRY_DISTANCE);
8958
8959 /* Add entries to the vtable for RTTI. */
8960 build_rtti_vtbl_entries (binfo, &vid);
8961
8962 /* Create an array for keeping track of the functions we've
8963 processed. When we see multiple functions with the same
8964 signature, we share the vcall offsets. */
8965 vec_alloc (vid.fns, 32);
8966 /* Add the vcall and vbase offset entries. */
8967 build_vcall_and_vbase_vtbl_entries (binfo, &vid);
8968
8969 /* Clear BINFO_VTABLE_PATH_MARKED; it's set by
8970 build_vbase_offset_vtbl_entries. */
8971 for (vbases = CLASSTYPE_VBASECLASSES (t), ix = 0;
8972 vec_safe_iterate (vbases, ix, &vbinfo); ix++)
8973 BINFO_VTABLE_PATH_MARKED (vbinfo) = 0;
8974
8975 /* If the target requires padding between data entries, add that now. */
8976 if (TARGET_VTABLE_DATA_ENTRY_DISTANCE > 1)
8977 {
8978 int n_entries = vec_safe_length (vid.inits);
8979
8980 vec_safe_grow (vid.inits, TARGET_VTABLE_DATA_ENTRY_DISTANCE * n_entries);
8981
8982 /* Move data entries into their new positions and add padding
8983 after the new positions. Iterate backwards so we don't
8984 overwrite entries that we would need to process later. */
8985 for (ix = n_entries - 1;
8986 vid.inits->iterate (ix, &e);
8987 ix--)
8988 {
8989 int j;
8990 int new_position = (TARGET_VTABLE_DATA_ENTRY_DISTANCE * ix
8991 + (TARGET_VTABLE_DATA_ENTRY_DISTANCE - 1));
8992
8993 (*vid.inits)[new_position] = *e;
8994
8995 for (j = 1; j < TARGET_VTABLE_DATA_ENTRY_DISTANCE; ++j)
8996 {
8997 constructor_elt *f = &(*vid.inits)[new_position - j];
8998 f->index = NULL_TREE;
8999 f->value = build1 (NOP_EXPR, vtable_entry_type,
9000 null_pointer_node);
9001 }
9002 }
9003 }
9004
9005 if (non_fn_entries_p)
9006 *non_fn_entries_p = vec_safe_length (vid.inits);
9007
9008 /* The initializers for virtual functions were built up in reverse
9009 order. Straighten them out and add them to the running list in one
9010 step. */
9011 jx = vec_safe_length (*inits);
9012 vec_safe_grow (*inits, jx + vid.inits->length ());
9013
9014 for (ix = vid.inits->length () - 1;
9015 vid.inits->iterate (ix, &e);
9016 ix--, jx++)
9017 (**inits)[jx] = *e;
9018
9019 /* Go through all the ordinary virtual functions, building up
9020 initializers. */
9021 for (v = BINFO_VIRTUALS (orig_binfo); v; v = TREE_CHAIN (v))
9022 {
9023 tree delta;
9024 tree vcall_index;
9025 tree fn, fn_original;
9026 tree init = NULL_TREE;
9027
9028 fn = BV_FN (v);
9029 fn_original = fn;
9030 if (DECL_THUNK_P (fn))
9031 {
9032 if (!DECL_NAME (fn))
9033 finish_thunk (fn);
9034 if (THUNK_ALIAS (fn))
9035 {
9036 fn = THUNK_ALIAS (fn);
9037 BV_FN (v) = fn;
9038 }
9039 fn_original = THUNK_TARGET (fn);
9040 }
9041
9042 /* If the only definition of this function signature along our
9043 primary base chain is from a lost primary, this vtable slot will
9044 never be used, so just zero it out. This is important to avoid
9045 requiring extra thunks which cannot be generated with the function.
9046
9047 We first check this in update_vtable_entry_for_fn, so we handle
9048 restored primary bases properly; we also need to do it here so we
9049 zero out unused slots in ctor vtables, rather than filling them
9050 with erroneous values (though harmless, apart from relocation
9051 costs). */
9052 if (BV_LOST_PRIMARY (v))
9053 init = size_zero_node;
9054
9055 if (! init)
9056 {
9057 /* Pull the offset for `this', and the function to call, out of
9058 the list. */
9059 delta = BV_DELTA (v);
9060 vcall_index = BV_VCALL_INDEX (v);
9061
9062 gcc_assert (TREE_CODE (delta) == INTEGER_CST);
9063 gcc_assert (TREE_CODE (fn) == FUNCTION_DECL);
9064
9065 /* You can't call an abstract virtual function; it's abstract.
9066 So, we replace these functions with __pure_virtual. */
9067 if (DECL_PURE_VIRTUAL_P (fn_original))
9068 {
9069 fn = abort_fndecl;
9070 if (!TARGET_VTABLE_USES_DESCRIPTORS)
9071 {
9072 if (abort_fndecl_addr == NULL)
9073 abort_fndecl_addr
9074 = fold_convert (vfunc_ptr_type_node,
9075 build_fold_addr_expr (fn));
9076 init = abort_fndecl_addr;
9077 }
9078 }
9079 /* Likewise for deleted virtuals. */
9080 else if (DECL_DELETED_FN (fn_original))
9081 {
9082 fn = get_identifier ("__cxa_deleted_virtual");
9083 if (!get_global_value_if_present (fn, &fn))
9084 fn = push_library_fn (fn, (build_function_type_list
9085 (void_type_node, NULL_TREE)),
9086 NULL_TREE, ECF_NORETURN);
9087 if (!TARGET_VTABLE_USES_DESCRIPTORS)
9088 init = fold_convert (vfunc_ptr_type_node,
9089 build_fold_addr_expr (fn));
9090 }
9091 else
9092 {
9093 if (!integer_zerop (delta) || vcall_index)
9094 {
9095 fn = make_thunk (fn, /*this_adjusting=*/1, delta, vcall_index);
9096 if (!DECL_NAME (fn))
9097 finish_thunk (fn);
9098 }
9099 /* Take the address of the function, considering it to be of an
9100 appropriate generic type. */
9101 if (!TARGET_VTABLE_USES_DESCRIPTORS)
9102 init = fold_convert (vfunc_ptr_type_node,
9103 build_fold_addr_expr (fn));
9104 /* Don't refer to a virtual destructor from a constructor
9105 vtable or a vtable for an abstract class, since destroying
9106 an object under construction is undefined behavior and we
9107 don't want it to be considered a candidate for speculative
9108 devirtualization. But do create the thunk for ABI
9109 compliance. */
9110 if (DECL_DESTRUCTOR_P (fn_original)
9111 && (CLASSTYPE_PURE_VIRTUALS (DECL_CONTEXT (fn_original))
9112 || orig_binfo != binfo))
9113 init = size_zero_node;
9114 }
9115 }
9116
9117 /* And add it to the chain of initializers. */
9118 if (TARGET_VTABLE_USES_DESCRIPTORS)
9119 {
9120 int i;
9121 if (init == size_zero_node)
9122 for (i = 0; i < TARGET_VTABLE_USES_DESCRIPTORS; ++i)
9123 CONSTRUCTOR_APPEND_ELT (*inits, NULL_TREE, init);
9124 else
9125 for (i = 0; i < TARGET_VTABLE_USES_DESCRIPTORS; ++i)
9126 {
9127 tree fdesc = build2 (FDESC_EXPR, vfunc_ptr_type_node,
9128 fn, build_int_cst (NULL_TREE, i));
9129 TREE_CONSTANT (fdesc) = 1;
9130
9131 CONSTRUCTOR_APPEND_ELT (*inits, NULL_TREE, fdesc);
9132 }
9133 }
9134 else
9135 CONSTRUCTOR_APPEND_ELT (*inits, NULL_TREE, init);
9136 }
9137 }
9138
9139 /* Adds to vid->inits the initializers for the vbase and vcall
9140 offsets in BINFO, which is in the hierarchy dominated by T. */
9141
9142 static void
9143 build_vcall_and_vbase_vtbl_entries (tree binfo, vtbl_init_data* vid)
9144 {
9145 tree b;
9146
9147 /* If this is a derived class, we must first create entries
9148 corresponding to the primary base class. */
9149 b = get_primary_binfo (binfo);
9150 if (b)
9151 build_vcall_and_vbase_vtbl_entries (b, vid);
9152
9153 /* Add the vbase entries for this base. */
9154 build_vbase_offset_vtbl_entries (binfo, vid);
9155 /* Add the vcall entries for this base. */
9156 build_vcall_offset_vtbl_entries (binfo, vid);
9157 }
9158
9159 /* Returns the initializers for the vbase offset entries in the vtable
9160 for BINFO (which is part of the class hierarchy dominated by T), in
9161 reverse order. VBASE_OFFSET_INDEX gives the vtable index
9162 where the next vbase offset will go. */
9163
9164 static void
9165 build_vbase_offset_vtbl_entries (tree binfo, vtbl_init_data* vid)
9166 {
9167 tree vbase;
9168 tree t;
9169 tree non_primary_binfo;
9170
9171 /* If there are no virtual baseclasses, then there is nothing to
9172 do. */
9173 if (!CLASSTYPE_VBASECLASSES (BINFO_TYPE (binfo)))
9174 return;
9175
9176 t = vid->derived;
9177
9178 /* We might be a primary base class. Go up the inheritance hierarchy
9179 until we find the most derived class of which we are a primary base:
9180 it is the offset of that which we need to use. */
9181 non_primary_binfo = binfo;
9182 while (BINFO_INHERITANCE_CHAIN (non_primary_binfo))
9183 {
9184 tree b;
9185
9186 /* If we have reached a virtual base, then it must be a primary
9187 base (possibly multi-level) of vid->binfo, or we wouldn't
9188 have called build_vcall_and_vbase_vtbl_entries for it. But it
9189 might be a lost primary, so just skip down to vid->binfo. */
9190 if (BINFO_VIRTUAL_P (non_primary_binfo))
9191 {
9192 non_primary_binfo = vid->binfo;
9193 break;
9194 }
9195
9196 b = BINFO_INHERITANCE_CHAIN (non_primary_binfo);
9197 if (get_primary_binfo (b) != non_primary_binfo)
9198 break;
9199 non_primary_binfo = b;
9200 }
9201
9202 /* Go through the virtual bases, adding the offsets. */
9203 for (vbase = TYPE_BINFO (BINFO_TYPE (binfo));
9204 vbase;
9205 vbase = TREE_CHAIN (vbase))
9206 {
9207 tree b;
9208 tree delta;
9209
9210 if (!BINFO_VIRTUAL_P (vbase))
9211 continue;
9212
9213 /* Find the instance of this virtual base in the complete
9214 object. */
9215 b = copied_binfo (vbase, binfo);
9216
9217 /* If we've already got an offset for this virtual base, we
9218 don't need another one. */
9219 if (BINFO_VTABLE_PATH_MARKED (b))
9220 continue;
9221 BINFO_VTABLE_PATH_MARKED (b) = 1;
9222
9223 /* Figure out where we can find this vbase offset. */
9224 delta = size_binop (MULT_EXPR,
9225 vid->index,
9226 convert (ssizetype,
9227 TYPE_SIZE_UNIT (vtable_entry_type)));
9228 if (vid->primary_vtbl_p)
9229 BINFO_VPTR_FIELD (b) = delta;
9230
9231 if (binfo != TYPE_BINFO (t))
9232 /* The vbase offset had better be the same. */
9233 gcc_assert (tree_int_cst_equal (delta, BINFO_VPTR_FIELD (vbase)));
9234
9235 /* The next vbase will come at a more negative offset. */
9236 vid->index = size_binop (MINUS_EXPR, vid->index,
9237 ssize_int (TARGET_VTABLE_DATA_ENTRY_DISTANCE));
9238
9239 /* The initializer is the delta from BINFO to this virtual base.
9240 The vbase offsets go in reverse inheritance-graph order, and
9241 we are walking in inheritance graph order so these end up in
9242 the right order. */
9243 delta = size_diffop_loc (input_location,
9244 BINFO_OFFSET (b), BINFO_OFFSET (non_primary_binfo));
9245
9246 CONSTRUCTOR_APPEND_ELT (vid->inits, NULL_TREE,
9247 fold_build1_loc (input_location, NOP_EXPR,
9248 vtable_entry_type, delta));
9249 }
9250 }
9251
9252 /* Adds the initializers for the vcall offset entries in the vtable
9253 for BINFO (which is part of the class hierarchy dominated by VID->DERIVED)
9254 to VID->INITS. */
9255
9256 static void
9257 build_vcall_offset_vtbl_entries (tree binfo, vtbl_init_data* vid)
9258 {
9259 /* We only need these entries if this base is a virtual base. We
9260 compute the indices -- but do not add to the vtable -- when
9261 building the main vtable for a class. */
9262 if (binfo == TYPE_BINFO (vid->derived)
9263 || (BINFO_VIRTUAL_P (binfo)
9264 /* If BINFO is RTTI_BINFO, then (since BINFO does not
9265 correspond to VID->DERIVED), we are building a primary
9266 construction virtual table. Since this is a primary
9267 virtual table, we do not need the vcall offsets for
9268 BINFO. */
9269 && binfo != vid->rtti_binfo))
9270 {
9271 /* We need a vcall offset for each of the virtual functions in this
9272 vtable. For example:
9273
9274 class A { virtual void f (); };
9275 class B1 : virtual public A { virtual void f (); };
9276 class B2 : virtual public A { virtual void f (); };
9277 class C: public B1, public B2 { virtual void f (); };
9278
9279 A C object has a primary base of B1, which has a primary base of A. A
9280 C also has a secondary base of B2, which no longer has a primary base
9281 of A. So the B2-in-C construction vtable needs a secondary vtable for
9282 A, which will adjust the A* to a B2* to call f. We have no way of
9283 knowing what (or even whether) this offset will be when we define B2,
9284 so we store this "vcall offset" in the A sub-vtable and look it up in
9285 a "virtual thunk" for B2::f.
9286
9287 We need entries for all the functions in our primary vtable and
9288 in our non-virtual bases' secondary vtables. */
9289 vid->vbase = binfo;
9290 /* If we are just computing the vcall indices -- but do not need
9291 the actual entries -- not that. */
9292 if (!BINFO_VIRTUAL_P (binfo))
9293 vid->generate_vcall_entries = false;
9294 /* Now, walk through the non-virtual bases, adding vcall offsets. */
9295 add_vcall_offset_vtbl_entries_r (binfo, vid);
9296 }
9297 }
9298
9299 /* Build vcall offsets, starting with those for BINFO. */
9300
9301 static void
9302 add_vcall_offset_vtbl_entries_r (tree binfo, vtbl_init_data* vid)
9303 {
9304 int i;
9305 tree primary_binfo;
9306 tree base_binfo;
9307
9308 /* Don't walk into virtual bases -- except, of course, for the
9309 virtual base for which we are building vcall offsets. Any
9310 primary virtual base will have already had its offsets generated
9311 through the recursion in build_vcall_and_vbase_vtbl_entries. */
9312 if (BINFO_VIRTUAL_P (binfo) && vid->vbase != binfo)
9313 return;
9314
9315 /* If BINFO has a primary base, process it first. */
9316 primary_binfo = get_primary_binfo (binfo);
9317 if (primary_binfo)
9318 add_vcall_offset_vtbl_entries_r (primary_binfo, vid);
9319
9320 /* Add BINFO itself to the list. */
9321 add_vcall_offset_vtbl_entries_1 (binfo, vid);
9322
9323 /* Scan the non-primary bases of BINFO. */
9324 for (i = 0; BINFO_BASE_ITERATE (binfo, i, base_binfo); ++i)
9325 if (base_binfo != primary_binfo)
9326 add_vcall_offset_vtbl_entries_r (base_binfo, vid);
9327 }
9328
9329 /* Called from build_vcall_offset_vtbl_entries_r. */
9330
9331 static void
9332 add_vcall_offset_vtbl_entries_1 (tree binfo, vtbl_init_data* vid)
9333 {
9334 /* Make entries for the rest of the virtuals. */
9335 tree orig_fn;
9336
9337 /* The ABI requires that the methods be processed in declaration
9338 order. */
9339 for (orig_fn = TYPE_METHODS (BINFO_TYPE (binfo));
9340 orig_fn;
9341 orig_fn = DECL_CHAIN (orig_fn))
9342 if (TREE_CODE (orig_fn) == FUNCTION_DECL && DECL_VINDEX (orig_fn))
9343 add_vcall_offset (orig_fn, binfo, vid);
9344 }
9345
9346 /* Add a vcall offset entry for ORIG_FN to the vtable. */
9347
9348 static void
9349 add_vcall_offset (tree orig_fn, tree binfo, vtbl_init_data *vid)
9350 {
9351 size_t i;
9352 tree vcall_offset;
9353 tree derived_entry;
9354
9355 /* If there is already an entry for a function with the same
9356 signature as FN, then we do not need a second vcall offset.
9357 Check the list of functions already present in the derived
9358 class vtable. */
9359 FOR_EACH_VEC_SAFE_ELT (vid->fns, i, derived_entry)
9360 {
9361 if (same_signature_p (derived_entry, orig_fn)
9362 /* We only use one vcall offset for virtual destructors,
9363 even though there are two virtual table entries. */
9364 || (DECL_DESTRUCTOR_P (derived_entry)
9365 && DECL_DESTRUCTOR_P (orig_fn)))
9366 return;
9367 }
9368
9369 /* If we are building these vcall offsets as part of building
9370 the vtable for the most derived class, remember the vcall
9371 offset. */
9372 if (vid->binfo == TYPE_BINFO (vid->derived))
9373 {
9374 tree_pair_s elt = {orig_fn, vid->index};
9375 vec_safe_push (CLASSTYPE_VCALL_INDICES (vid->derived), elt);
9376 }
9377
9378 /* The next vcall offset will be found at a more negative
9379 offset. */
9380 vid->index = size_binop (MINUS_EXPR, vid->index,
9381 ssize_int (TARGET_VTABLE_DATA_ENTRY_DISTANCE));
9382
9383 /* Keep track of this function. */
9384 vec_safe_push (vid->fns, orig_fn);
9385
9386 if (vid->generate_vcall_entries)
9387 {
9388 tree base;
9389 tree fn;
9390
9391 /* Find the overriding function. */
9392 fn = find_final_overrider (vid->rtti_binfo, binfo, orig_fn);
9393 if (fn == error_mark_node)
9394 vcall_offset = build_zero_cst (vtable_entry_type);
9395 else
9396 {
9397 base = TREE_VALUE (fn);
9398
9399 /* The vbase we're working on is a primary base of
9400 vid->binfo. But it might be a lost primary, so its
9401 BINFO_OFFSET might be wrong, so we just use the
9402 BINFO_OFFSET from vid->binfo. */
9403 vcall_offset = size_diffop_loc (input_location,
9404 BINFO_OFFSET (base),
9405 BINFO_OFFSET (vid->binfo));
9406 vcall_offset = fold_build1_loc (input_location,
9407 NOP_EXPR, vtable_entry_type,
9408 vcall_offset);
9409 }
9410 /* Add the initializer to the vtable. */
9411 CONSTRUCTOR_APPEND_ELT (vid->inits, NULL_TREE, vcall_offset);
9412 }
9413 }
9414
9415 /* Return vtbl initializers for the RTTI entries corresponding to the
9416 BINFO's vtable. The RTTI entries should indicate the object given
9417 by VID->rtti_binfo. */
9418
9419 static void
9420 build_rtti_vtbl_entries (tree binfo, vtbl_init_data* vid)
9421 {
9422 tree b;
9423 tree t;
9424 tree offset;
9425 tree decl;
9426 tree init;
9427
9428 t = BINFO_TYPE (vid->rtti_binfo);
9429
9430 /* To find the complete object, we will first convert to our most
9431 primary base, and then add the offset in the vtbl to that value. */
9432 b = binfo;
9433 while (CLASSTYPE_HAS_PRIMARY_BASE_P (BINFO_TYPE (b))
9434 && !BINFO_LOST_PRIMARY_P (b))
9435 {
9436 tree primary_base;
9437
9438 primary_base = get_primary_binfo (b);
9439 gcc_assert (BINFO_PRIMARY_P (primary_base)
9440 && BINFO_INHERITANCE_CHAIN (primary_base) == b);
9441 b = primary_base;
9442 }
9443 offset = size_diffop_loc (input_location,
9444 BINFO_OFFSET (vid->rtti_binfo), BINFO_OFFSET (b));
9445
9446 /* The second entry is the address of the typeinfo object. */
9447 if (flag_rtti)
9448 decl = build_address (get_tinfo_decl (t));
9449 else
9450 decl = integer_zero_node;
9451
9452 /* Convert the declaration to a type that can be stored in the
9453 vtable. */
9454 init = build_nop (vfunc_ptr_type_node, decl);
9455 CONSTRUCTOR_APPEND_ELT (vid->inits, NULL_TREE, init);
9456
9457 /* Add the offset-to-top entry. It comes earlier in the vtable than
9458 the typeinfo entry. Convert the offset to look like a
9459 function pointer, so that we can put it in the vtable. */
9460 init = build_nop (vfunc_ptr_type_node, offset);
9461 CONSTRUCTOR_APPEND_ELT (vid->inits, NULL_TREE, init);
9462 }
9463
9464 /* TRUE iff TYPE is uniquely derived from PARENT. Ignores
9465 accessibility. */
9466
9467 bool
9468 uniquely_derived_from_p (tree parent, tree type)
9469 {
9470 tree base = lookup_base (type, parent, ba_unique, NULL, tf_none);
9471 return base && base != error_mark_node;
9472 }
9473
9474 /* TRUE iff TYPE is publicly & uniquely derived from PARENT. */
9475
9476 bool
9477 publicly_uniquely_derived_p (tree parent, tree type)
9478 {
9479 tree base = lookup_base (type, parent, ba_ignore_scope | ba_check,
9480 NULL, tf_none);
9481 return base && base != error_mark_node;
9482 }
9483
9484 /* CTX1 and CTX2 are declaration contexts. Return the innermost common
9485 class between them, if any. */
9486
9487 tree
9488 common_enclosing_class (tree ctx1, tree ctx2)
9489 {
9490 if (!TYPE_P (ctx1) || !TYPE_P (ctx2))
9491 return NULL_TREE;
9492 gcc_assert (ctx1 == TYPE_MAIN_VARIANT (ctx1)
9493 && ctx2 == TYPE_MAIN_VARIANT (ctx2));
9494 if (ctx1 == ctx2)
9495 return ctx1;
9496 for (tree t = ctx1; TYPE_P (t); t = TYPE_CONTEXT (t))
9497 TYPE_MARKED_P (t) = true;
9498 tree found = NULL_TREE;
9499 for (tree t = ctx2; TYPE_P (t); t = TYPE_CONTEXT (t))
9500 if (TYPE_MARKED_P (t))
9501 {
9502 found = t;
9503 break;
9504 }
9505 for (tree t = ctx1; TYPE_P (t); t = TYPE_CONTEXT (t))
9506 TYPE_MARKED_P (t) = false;
9507 return found;
9508 }
9509
9510 #include "gt-cp-class.h"