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