summaryrefslogtreecommitdiffstats
path: root/clang/test/PCH
diff options
context:
space:
mode:
authorSebastian Redl <sebastian.redl@getdesigned.at>2011-04-24 16:28:06 +0000
committerSebastian Redl <sebastian.redl@getdesigned.at>2011-04-24 16:28:06 +0000
commitab238a7d1895201ad3d10fc961ca68105b3844fb (patch)
tree35f13e5311908fff8776d51f1aef650b2d7c87e9 /clang/test/PCH
parentf830df4e9d1aa0c6971de46d0b8c899788443cb9 (diff)
downloadbcm5719-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')
-rw-r--r--clang/test/PCH/chain-implicit-definition.cpp39
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
OpenPOWER on IntegriCloud