diff options
| author | Sebastian Redl <sebastian.redl@getdesigned.at> | 2011-04-24 16:28:06 +0000 |
|---|---|---|
| committer | Sebastian Redl <sebastian.redl@getdesigned.at> | 2011-04-24 16:28:06 +0000 |
| commit | ab238a7d1895201ad3d10fc961ca68105b3844fb (patch) | |
| tree | 35f13e5311908fff8776d51f1aef650b2d7c87e9 /clang/test/PCH/chain-implicit-definition.cpp | |
| parent | f830df4e9d1aa0c6971de46d0b8c899788443cb9 (diff) | |
| download | bcm5719-llvm-ab238a7d1895201ad3d10fc961ca68105b3844fb.tar.gz bcm5719-llvm-ab238a7d1895201ad3d10fc961ca68105b3844fb.zip | |
Synthesizing the definition of an implicit member is an AST modification, so notify any mutation listeners of it. This fixes a crasher in chained PCH, where an implicit destructor in a PCH gets a definition in a chained PCH, which is then lost. However, any further use of the destructor would cause its definition to be regenerated in the final file, hiding the bug.
llvm-svn: 130103
Diffstat (limited to 'clang/test/PCH/chain-implicit-definition.cpp')
| -rw-r--r-- | clang/test/PCH/chain-implicit-definition.cpp | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/clang/test/PCH/chain-implicit-definition.cpp b/clang/test/PCH/chain-implicit-definition.cpp new file mode 100644 index 00000000000..3ec4f62bcbd --- /dev/null +++ b/clang/test/PCH/chain-implicit-definition.cpp @@ -0,0 +1,39 @@ +// no PCH +// RUN: %clang_cc1 -emit-llvm -o /dev/null -include %s -include %s %s +// with PCH +// RUN: %clang_cc1 -emit-llvm -o /dev/null -chain-include %s -chain-include %s %s +#if !defined(PASS1) +#define PASS1 + +// A base with a virtual dtor. +struct A { + virtual ~A(); +}; + +// A derived class with an implicit virtual dtor. +struct B : A { + // Key function to suppress vtable definition. + virtual void virt(); +}; + +#elif !defined(PASS2) +#define PASS2 + +// Further derived class that requires ~B(). +// Causes definition of ~B(), but it was lost when saving PCH. +struct C : B { + C(); + ~C() {} +}; + +#else + +void foo() { + // Variable that requires ~C(). + C c; +} + +// VTable placement would again cause definition of ~B(), hiding the bug, +// if not for B::virt(), which suppresses the placement. + +#endif |

