mirror of
https://github.com/intel/llvm.git
synced 2026-01-27 06:06:34 +08:00
PCH support for Objective-C property declarations (UNTESTED!)
llvm-svn: 69843
This commit is contained in:
@@ -1071,7 +1071,8 @@ public:
|
||||
IdentifierInfo *Id, QualType T,
|
||||
PropertyControl propControl = None);
|
||||
QualType getType() const { return DeclType; }
|
||||
|
||||
void setType(QualType T) { DeclType = T; }
|
||||
|
||||
PropertyAttributeKind getPropertyAttributes() const {
|
||||
return PropertyAttributeKind(PropertyAttributes);
|
||||
}
|
||||
|
||||
@@ -303,7 +303,21 @@ void PCHDeclReader::VisitObjCCompatibleAliasDecl(ObjCCompatibleAliasDecl *CAD) {
|
||||
|
||||
void PCHDeclReader::VisitObjCPropertyDecl(ObjCPropertyDecl *D) {
|
||||
VisitNamedDecl(D);
|
||||
// FIXME: Implement.
|
||||
D->setType(Reader.GetType(Record[Idx++]));
|
||||
// FIXME: stable encoding
|
||||
D->setPropertyAttributes(
|
||||
(ObjCPropertyDecl::PropertyAttributeKind)Record[Idx++]);
|
||||
// FIXME: stable encoding
|
||||
D->setPropertyImplementation(
|
||||
(ObjCPropertyDecl::PropertyControl)Record[Idx++]);
|
||||
D->setGetterName(Reader.ReadDeclarationName(Record, Idx).getObjCSelector());
|
||||
D->setSetterName(Reader.ReadDeclarationName(Record, Idx).getObjCSelector());
|
||||
D->setGetterMethodDecl(
|
||||
cast_or_null<ObjCMethodDecl>(Reader.GetDecl(Record[Idx++])));
|
||||
D->setSetterMethodDecl(
|
||||
cast_or_null<ObjCMethodDecl>(Reader.GetDecl(Record[Idx++])));
|
||||
D->setPropertyIvarDecl(
|
||||
cast_or_null<ObjCIvarDecl>(Reader.GetDecl(Record[Idx++])));
|
||||
}
|
||||
|
||||
void PCHDeclReader::VisitObjCImplDecl(ObjCImplDecl *D) {
|
||||
@@ -2264,7 +2278,7 @@ Decl *PCHReader::ReadDeclRecord(uint64_t Offset, unsigned Index) {
|
||||
}
|
||||
|
||||
case pch::DECL_OBJC_PROPERTY: {
|
||||
// FIXME: Implement.
|
||||
D = ObjCPropertyDecl::Create(Context, 0, SourceLocation(), 0, QualType());
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
@@ -478,7 +478,16 @@ void PCHDeclWriter::VisitObjCCompatibleAliasDecl(ObjCCompatibleAliasDecl *D) {
|
||||
|
||||
void PCHDeclWriter::VisitObjCPropertyDecl(ObjCPropertyDecl *D) {
|
||||
VisitNamedDecl(D);
|
||||
// FIXME: Implement.
|
||||
Writer.AddTypeRef(D->getType(), Record);
|
||||
// FIXME: stable encoding
|
||||
Record.push_back((unsigned)D->getPropertyAttributes());
|
||||
// FIXME: stable encoding
|
||||
Record.push_back((unsigned)D->getPropertyImplementation());
|
||||
Writer.AddDeclarationName(D->getGetterName(), Record);
|
||||
Writer.AddDeclarationName(D->getSetterName(), Record);
|
||||
Writer.AddDeclRef(D->getGetterMethodDecl(), Record);
|
||||
Writer.AddDeclRef(D->getSetterMethodDecl(), Record);
|
||||
Writer.AddDeclRef(D->getPropertyIvarDecl(), Record);
|
||||
Code = pch::DECL_OBJC_PROPERTY;
|
||||
}
|
||||
|
||||
@@ -1715,7 +1724,13 @@ void PCHWriter::WriteDeclsBlock(ASTContext &Context) {
|
||||
W.Code = (pch::DeclCode)0;
|
||||
W.Visit(D);
|
||||
if (DC) W.VisitDeclContext(DC, LexicalOffset, VisibleOffset);
|
||||
assert(W.Code && "Unhandled declaration kind while generating PCH");
|
||||
|
||||
if (!W.Code) {
|
||||
fprintf(stderr, "Cannot serialize declaration of kind %s\n",
|
||||
D->getDeclKindName());
|
||||
assert(false && "Unhandled declaration kind while generating PCH");
|
||||
exit(-1);
|
||||
}
|
||||
Stream.EmitRecord(W.Code, Record);
|
||||
|
||||
// If the declaration had any attributes, write them now.
|
||||
|
||||
12
clang/test/PCH/objc_property.h
Normal file
12
clang/test/PCH/objc_property.h
Normal file
@@ -0,0 +1,12 @@
|
||||
/* For use with the objc_property.m PCH test */
|
||||
@interface TestProperties
|
||||
{
|
||||
int value;
|
||||
float percentage;
|
||||
}
|
||||
|
||||
+ alloc;
|
||||
|
||||
@property int value;
|
||||
@property float percentage;
|
||||
@end
|
||||
11
clang/test/PCH/objc_property.m
Normal file
11
clang/test/PCH/objc_property.m
Normal file
@@ -0,0 +1,11 @@
|
||||
// Test this without pch.
|
||||
// FIXME: clang-cc -include %S/objc_property.h -fsyntax-only -verify %s &&
|
||||
|
||||
// Test with pch.
|
||||
// FIXME: clang-cc -x=objective-c -emit-pch -o %t %S/objc_property.h &&
|
||||
// FIXME: clang-cc -include-pch %t -fsyntax-only -verify %s
|
||||
|
||||
void func() {
|
||||
TestProperties *xx = [TestProperties alloc];
|
||||
xx.value = 5;
|
||||
}
|
||||
Reference in New Issue
Block a user