From: Fariborz Jahanian Date: Mon, 5 May 2008 18:51:55 +0000 (+0000) Subject: percolate @optional/@required protocols down to ASTs for X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=46b55e56d029aec699fc2701e43d70264da9ecd8;p=clang percolate @optional/@required protocols down to ASTs for properties declared in the protocol. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@50662 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/Driver/ASTConsumers.cpp b/Driver/ASTConsumers.cpp index 684b11eaed..20d4ce2a88 100644 --- a/Driver/ASTConsumers.cpp +++ b/Driver/ASTConsumers.cpp @@ -320,7 +320,11 @@ void DeclPrinter::PrintObjCCompatibleAliasDecl(ObjCCompatibleAliasDecl *AID) { /// PrintObjCPropertyDecl - print a property declaration. /// void DeclPrinter::PrintObjCPropertyDecl(ObjCPropertyDecl *PDecl) { - + if (PDecl->getPropertyImplementation() == ObjCPropertyDecl::Required) + Out << "@required\n"; + else if (PDecl->getPropertyImplementation() == ObjCPropertyDecl::Optional) + Out << "@optional\n"; + Out << "@property"; if (PDecl->getPropertyAttributes() != ObjCPropertyDecl::OBJC_PR_noattr) { bool first = true; diff --git a/include/clang/AST/DeclObjC.h b/include/clang/AST/DeclObjC.h index 5e92708962..7947b3dc38 100644 --- a/include/clang/AST/DeclObjC.h +++ b/include/clang/AST/DeclObjC.h @@ -1066,10 +1066,15 @@ public: OBJC_PR_nonatomic = 0x40, OBJC_PR_setter = 0x80 }; + + enum PropertyControl { None, Required, Optional }; private: QualType DeclType; unsigned PropertyAttributes : 8; + // @required/@optional + unsigned PropertyImplementation : 2; + IdentifierInfo *GetterName; // getter name of NULL if no getter IdentifierInfo *SetterName; // setter name of NULL if no setter @@ -1078,7 +1083,8 @@ private: PropertyAttributes(OBJC_PR_noattr), GetterName(0), SetterName(0) {} public: static ObjCPropertyDecl *Create(ASTContext &C, SourceLocation L, - IdentifierInfo *Id, QualType T); + IdentifierInfo *Id, QualType T, + PropertyControl propControl = None); QualType getType() const { return DeclType; } QualType getCanonicalType() const { return DeclType.getCanonicalType(); } @@ -1095,6 +1101,14 @@ public: IdentifierInfo *getSetterName() const { return SetterName; } void setSetterName(IdentifierInfo *Id) { SetterName = Id; } + // Related to @optional/@required declared in @protocol + void setPropertyImplementation(PropertyControl pc) { + PropertyImplementation = pc; + } + PropertyControl getPropertyImplementation() const { + return PropertyControl(PropertyImplementation); + } + static bool classof(const Decl *D) { return D->getKind() == ObjCProperty; } diff --git a/include/clang/Parse/Action.h b/include/clang/Parse/Action.h index f0d5158297..5d094ae892 100644 --- a/include/clang/Parse/Action.h +++ b/include/clang/Parse/Action.h @@ -685,7 +685,8 @@ public: } // ActOnProperty - called to build one property AST virtual DeclTy *ActOnProperty (Scope *S, SourceLocation AtLoc, - FieldDeclarator &FD, ObjCDeclSpec &ODS) { + FieldDeclarator &FD, ObjCDeclSpec &ODS, + tok::ObjCKeywordKind MethodImplKind) { return 0; } diff --git a/lib/AST/DeclObjC.cpp b/lib/AST/DeclObjC.cpp index 89f6d2c501..0cb777d8de 100644 --- a/lib/AST/DeclObjC.cpp +++ b/lib/AST/DeclObjC.cpp @@ -112,7 +112,8 @@ ObjCCompatibleAliasDecl::Create(ASTContext &C, ObjCPropertyDecl *ObjCPropertyDecl::Create(ASTContext &C, SourceLocation L, IdentifierInfo *Id, - QualType T) { + QualType T, + PropertyControl propControl) { void *Mem = C.getAllocator().Allocate(); return new (Mem) ObjCPropertyDecl(L, Id, T); } diff --git a/lib/Parse/ParseObjc.cpp b/lib/Parse/ParseObjc.cpp index d1b1c25c5a..8d404a9aaf 100644 --- a/lib/Parse/ParseObjc.cpp +++ b/lib/Parse/ParseObjc.cpp @@ -271,7 +271,8 @@ void Parser::ParseObjCInterfaceDeclList(DeclTy *interfaceDecl, FieldDeclarator &FD = FieldDeclarators[i]; // Install the property declarator into interfaceDecl. DeclTy *Property = Actions.ActOnProperty(CurScope, - DS.getSourceRange().getBegin(), FD, OCDS); + DS.getSourceRange().getBegin(), FD, OCDS, + MethodImplKind); allProperties.push_back(Property); } continue; diff --git a/lib/Sema/Sema.h b/lib/Sema/Sema.h index 68a834c6b4..6375fad086 100644 --- a/lib/Sema/Sema.h +++ b/lib/Sema/Sema.h @@ -676,7 +676,9 @@ public: DeclTy **allProperties = 0, unsigned pNum = 0); virtual DeclTy *ActOnProperty(Scope *S, SourceLocation AtLoc, - FieldDeclarator &FD, ObjCDeclSpec &ODS); + FieldDeclarator &FD, ObjCDeclSpec &ODS, + tok::ObjCKeywordKind MethodImplKind); + virtual DeclTy *ActOnPropertyImplDecl(SourceLocation AtLoc, SourceLocation PropertyLoc, bool ImplKind, DeclTy *ClassImplDecl, diff --git a/lib/Sema/SemaDeclObjC.cpp b/lib/Sema/SemaDeclObjC.cpp index afac82ca76..3b48810896 100644 --- a/lib/Sema/SemaDeclObjC.cpp +++ b/lib/Sema/SemaDeclObjC.cpp @@ -1022,7 +1022,8 @@ Sema::DeclTy *Sema::ActOnMethodDeclaration( Sema::DeclTy *Sema::ActOnProperty(Scope *S, SourceLocation AtLoc, FieldDeclarator &FD, - ObjCDeclSpec &ODS) { + ObjCDeclSpec &ODS, + tok::ObjCKeywordKind MethodImplKind) { QualType T = GetTypeForDeclarator(FD.D, S); ObjCPropertyDecl *PDecl = ObjCPropertyDecl::Create(Context, AtLoc, FD.D.getIdentifier(), T); @@ -1055,6 +1056,11 @@ Sema::DeclTy *Sema::ActOnProperty(Scope *S, SourceLocation AtLoc, if (ODS.getPropertyAttributes() & ObjCDeclSpec::DQ_PR_nonatomic) PDecl->setPropertyAttributes(ObjCPropertyDecl::OBJC_PR_nonatomic); + if (MethodImplKind == tok::objc_required) + PDecl->setPropertyImplementation(ObjCPropertyDecl::Required); + else if (MethodImplKind == tok::objc_optional) + PDecl->setPropertyImplementation(ObjCPropertyDecl::Optional); + return PDecl; }