llvm-project/clang/test/CodeGenCXX/Inputs
Aleksandr Urakov 5c3d8fe853 [AST] Do not align virtual bases in `MicrosoftRecordLayoutBuilder` when
an external layout is used

Summary:
The patch removes alignment of virtual bases when an external layout is used.
We have two cases:
- the external layout source has an information about virtual bases offsets,
  so we just use them;
- the external source has no information about virtual bases offsets. In this
  case we can't predict where the base will be located. If we will align it but
  there will be something like `#pragma pack(push, 1)` really, then likely our
  layout will not fit into the real structure size, and then some asserts will
  hit. The asserts look reasonable, so I don't think that we need to remove
  them. May be it would be better instead don't align fields / bases etc.
  (so treat it always as `#pragma pack(push, 1)`) when an external layout source
  is used but no info about a field location is presented.

This one is related to D49871

Reviewers: rnk, rsmith, zturner, mstorsjo, majnemer

Reviewed By: rnk

Subscribers: cfe-commits

Tags: #clang

Differential Revision: https://reviews.llvm.org/D53497

llvm-svn: 345012
2018-10-23 08:23:22 +00:00
..
debug-info-class-limited.cpp
override-bit-field-layout.layout Use external layout information to layout bit-fields for MS ABI. 2018-07-13 21:07:42 +00:00
override-layout-nameless-struct-union.layout Improve support of PDB as an external layout source 2018-07-31 08:27:06 +00:00
override-layout-packed-base.layout [AST] Do not align virtual bases in `MicrosoftRecordLayoutBuilder` when 2018-10-23 08:23:22 +00:00
profile-remap.map Add a flag to remap manglings when reading profile data information. 2018-10-10 23:13:35 +00:00
profile-remap.proftext Add a flag to remap manglings when reading profile data information. 2018-10-10 23:13:35 +00:00
profile-remap.samples Add a flag to remap manglings when reading profile data information. 2018-10-10 23:13:35 +00:00
std-compare.h