summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>2010-08-09 10:54:37 +0000
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>2010-08-09 10:54:37 +0000
commita8607779a41a1054123123dbb5fd40ccdbafab03 (patch)
treef9d37a870c6a720a3fe97b4136c4a83c52388555 /clang
parentc049f7547bd57065349148affdff70dcf82e134a (diff)
downloadbcm5719-llvm-a8607779a41a1054123123dbb5fd40ccdbafab03.tar.gz
bcm5719-llvm-a8607779a41a1054123123dbb5fd40ccdbafab03.zip
Complete PCH support for ObjCPropertyImplDecl.
llvm-svn: 110570
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Frontend/PCHReaderDecl.cpp3
-rw-r--r--clang/lib/Frontend/PCHWriterDecl.cpp9
-rw-r--r--clang/test/PCH/objcxx-ivar-class.h6
-rw-r--r--clang/test/PCH/objcxx-ivar-class.mm6
4 files changed, 19 insertions, 5 deletions
diff --git a/clang/lib/Frontend/PCHReaderDecl.cpp b/clang/lib/Frontend/PCHReaderDecl.cpp
index 6c0bdf6068f..7aab7b7557c 100644
--- a/clang/lib/Frontend/PCHReaderDecl.cpp
+++ b/clang/lib/Frontend/PCHReaderDecl.cpp
@@ -526,7 +526,8 @@ void PCHDeclReader::VisitObjCPropertyImplDecl(ObjCPropertyImplDecl *D) {
cast_or_null<ObjCPropertyDecl>(Reader.GetDecl(Record[Idx++])));
D->setPropertyIvarDecl(
cast_or_null<ObjCIvarDecl>(Reader.GetDecl(Record[Idx++])));
- // FIXME. read GetterCXXConstructor and SetterCXXAssignment
+ D->setGetterCXXConstructor(Reader.ReadExpr(Cursor));
+ D->setSetterCXXAssignment(Reader.ReadExpr(Cursor));
}
void PCHDeclReader::VisitFieldDecl(FieldDecl *FD) {
diff --git a/clang/lib/Frontend/PCHWriterDecl.cpp b/clang/lib/Frontend/PCHWriterDecl.cpp
index 6a78140b3ad..a509ed1dce9 100644
--- a/clang/lib/Frontend/PCHWriterDecl.cpp
+++ b/clang/lib/Frontend/PCHWriterDecl.cpp
@@ -305,8 +305,10 @@ void PCHDeclWriter::VisitObjCMethodDecl(ObjCMethodDecl *D) {
VisitNamedDecl(D);
// FIXME: convert to LazyStmtPtr?
// Unlike C/C++, method bodies will never be in header files.
- Record.push_back(D->getBody() != 0);
- if (D->getBody() != 0) {
+ bool HasBodyStuff = D->getBody() != 0 ||
+ D->getSelfDecl() != 0 || D->getCmdDecl() != 0;
+ Record.push_back(HasBodyStuff);
+ if (HasBodyStuff) {
Writer.AddStmt(D->getBody());
Writer.AddDeclRef(D->getSelfDecl(), Record);
Writer.AddDeclRef(D->getCmdDecl(), Record);
@@ -478,7 +480,8 @@ void PCHDeclWriter::VisitObjCPropertyImplDecl(ObjCPropertyImplDecl *D) {
Writer.AddSourceLocation(D->getLocStart(), Record);
Writer.AddDeclRef(D->getPropertyDecl(), Record);
Writer.AddDeclRef(D->getPropertyIvarDecl(), Record);
- // FIXME. write GetterCXXConstructor and SetterCXXAssignment.
+ Writer.AddStmt(D->getGetterCXXConstructor());
+ Writer.AddStmt(D->getSetterCXXAssignment());
Code = pch::DECL_OBJC_PROPERTY_IMPL;
}
diff --git a/clang/test/PCH/objcxx-ivar-class.h b/clang/test/PCH/objcxx-ivar-class.h
index aa114e5577b..50ebda709db 100644
--- a/clang/test/PCH/objcxx-ivar-class.h
+++ b/clang/test/PCH/objcxx-ivar-class.h
@@ -1,11 +1,15 @@
struct S {
S();
+ S(const S&);
+ S& operator= (const S&);
};
@interface C {
- S s;
+ S position;
}
+@property(assign, nonatomic) S position;
@end
@implementation C
+ @synthesize position;
@end
diff --git a/clang/test/PCH/objcxx-ivar-class.mm b/clang/test/PCH/objcxx-ivar-class.mm
index 48d359c11b9..89d3e087f90 100644
--- a/clang/test/PCH/objcxx-ivar-class.mm
+++ b/clang/test/PCH/objcxx-ivar-class.mm
@@ -5,5 +5,11 @@
// RUN: %clang_cc1 -x objective-c++-header -emit-pch -o %t %S/objcxx-ivar-class.h
// RUN: %clang_cc1 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s
+// CHECK: [C position]
+// CHECK: call void @_ZN1SC1ERKS_
+
+// CHECK: [C setPosition:]
+// CHECK: call %struct.S* @_ZN1SaSERKS_
+
// CHECK: [C .cxx_destruct]
// CHECK: [C .cxx_construct]
OpenPOWER on IntegriCloud