summaryrefslogtreecommitdiffstats
path: root/clang/test/Modules/Inputs
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2012-01-15 18:08:05 +0000
committerDouglas Gregor <dgregor@apple.com>2012-01-15 18:08:05 +0000
commitc03c52ea017aa470a05e12fe2a7fda91a2e22e3a (patch)
treef27389db9db8c1bbe157803b28163484ff50563e /clang/test/Modules/Inputs
parent358cd441701259c25f1a91890b24aff432082a4c (diff)
downloadbcm5719-llvm-c03c52ea017aa470a05e12fe2a7fda91a2e22e3a.tar.gz
bcm5719-llvm-c03c52ea017aa470a05e12fe2a7fda91a2e22e3a.zip
When deserializing the definition of a C++ class/ObjC class/ObjC
protocol, record the definition pointer in the canonical declaration for that entity, and then propagate that definition pointer from the canonical declaration to all other deserialized declarations. This approach works well even when deserializing declarations that didn't know about the original definition, which can occur with modules. A nice bonus from this definition-deserialization approach is that we no longer need update records when a definition is added, because the redeclaration chains ensure that the if any declaration is loaded, the definition will also get loaded. llvm-svn: 148223
Diffstat (limited to 'clang/test/Modules/Inputs')
-rw-r--r--clang/test/Modules/Inputs/redecl-merge-left-left.h2
-rw-r--r--clang/test/Modules/Inputs/redecl-merge-right.h4
2 files changed, 6 insertions, 0 deletions
diff --git a/clang/test/Modules/Inputs/redecl-merge-left-left.h b/clang/test/Modules/Inputs/redecl-merge-left-left.h
index 612608159b2..79c4d620bee 100644
--- a/clang/test/Modules/Inputs/redecl-merge-left-left.h
+++ b/clang/test/Modules/Inputs/redecl-merge-left-left.h
@@ -3,3 +3,5 @@
@class C4;
void accept_a_C4(C4*);
+@class ClassWithDef;
+
diff --git a/clang/test/Modules/Inputs/redecl-merge-right.h b/clang/test/Modules/Inputs/redecl-merge-right.h
index 86a3993bc47..113ff221741 100644
--- a/clang/test/Modules/Inputs/redecl-merge-right.h
+++ b/clang/test/Modules/Inputs/redecl-merge-right.h
@@ -88,3 +88,7 @@ public:
int ONE;
@import redecl_merge_top.Explicit;
const int one = ONE;
+
+@interface ClassWithDef
+- (void)method;
+@end
OpenPOWER on IntegriCloud