diff options
Diffstat (limited to 'lib/CodeGen')
-rw-r--r-- | lib/CodeGen/CGObjC.cpp | 14 | ||||
-rw-r--r-- | lib/CodeGen/CodeGenFunction.h | 7 | ||||
-rw-r--r-- | lib/CodeGen/CodeGenModule.cpp | 6 |
3 files changed, 17 insertions, 10 deletions
diff --git a/lib/CodeGen/CGObjC.cpp b/lib/CodeGen/CGObjC.cpp index 845d5ff00c..e605065848 100644 --- a/lib/CodeGen/CGObjC.cpp +++ b/lib/CodeGen/CGObjC.cpp @@ -137,14 +137,15 @@ void CodeGenFunction::GenerateObjCMethod(const ObjCMethodDecl *OMD) { /// GenerateObjCGetter - Generate an Objective-C property getter /// function. The given Decl must be either an ObjCCategoryImplDecl /// or an ObjCImplementationDecl. -void CodeGenFunction::GenerateObjCGetter(const ObjCPropertyImplDecl *PID) { +void CodeGenFunction::GenerateObjCGetter(ObjCImplementationDecl *IMP, + const ObjCPropertyImplDecl *PID) { ObjCIvarDecl *Ivar = PID->getPropertyIvarDecl(); const ObjCPropertyDecl *PD = PID->getPropertyDecl(); ObjCMethodDecl *OMD = PD->getGetterMethodDecl(); assert(OMD && "Invalid call to generate getter (empty method)"); // FIXME: This is rather murky, we create this here since they will // not have been created by Sema for us. - OMD->createImplicitParams(getContext()); + OMD->createImplicitParams(getContext(), IMP->getClassInterface()); StartObjCMethod(OMD); // Determine if we should use an objc_getProperty call for @@ -173,7 +174,7 @@ void CodeGenFunction::GenerateObjCGetter(const ObjCPropertyImplDecl *PID) { QualType IdTy = getContext().getObjCIdType(); llvm::Value *SelfAsId = Builder.CreateBitCast(LoadObjCSelf(), Types.ConvertType(IdTy)); - llvm::Value *Offset = EmitIvarOffset(OMD->getClassInterface(), Ivar); + llvm::Value *Offset = EmitIvarOffset(IMP->getClassInterface(), Ivar); llvm::Value *True = llvm::ConstantInt::get(Types.ConvertTypeForMem(getContext().BoolTy), 1); CallArgList Args; @@ -204,14 +205,15 @@ void CodeGenFunction::GenerateObjCGetter(const ObjCPropertyImplDecl *PID) { /// GenerateObjCSetter - Generate an Objective-C property setter /// function. The given Decl must be either an ObjCCategoryImplDecl /// or an ObjCImplementationDecl. -void CodeGenFunction::GenerateObjCSetter(const ObjCPropertyImplDecl *PID) { +void CodeGenFunction::GenerateObjCSetter(ObjCImplementationDecl *IMP, + const ObjCPropertyImplDecl *PID) { ObjCIvarDecl *Ivar = PID->getPropertyIvarDecl(); const ObjCPropertyDecl *PD = PID->getPropertyDecl(); ObjCMethodDecl *OMD = PD->getSetterMethodDecl(); assert(OMD && "Invalid call to generate setter (empty method)"); // FIXME: This is rather murky, we create this here since they will // not have been created by Sema for us. - OMD->createImplicitParams(getContext()); + OMD->createImplicitParams(getContext(), IMP->getClassInterface()); StartObjCMethod(OMD); bool IsCopy = PD->getSetterKind() == ObjCPropertyDecl::Copy; @@ -244,7 +246,7 @@ void CodeGenFunction::GenerateObjCSetter(const ObjCPropertyImplDecl *PID) { QualType IdTy = getContext().getObjCIdType(); llvm::Value *SelfAsId = Builder.CreateBitCast(LoadObjCSelf(), Types.ConvertType(IdTy)); - llvm::Value *Offset = EmitIvarOffset(OMD->getClassInterface(), Ivar); + llvm::Value *Offset = EmitIvarOffset(IMP->getClassInterface(), Ivar); llvm::Value *Arg = LocalDeclMap[OMD->getParamDecl(0)]; llvm::Value *ArgAsId = Builder.CreateBitCast(Builder.CreateLoad(Arg, "arg"), diff --git a/lib/CodeGen/CodeGenFunction.h b/lib/CodeGen/CodeGenFunction.h index 63af44f9cb..600582c96e 100644 --- a/lib/CodeGen/CodeGenFunction.h +++ b/lib/CodeGen/CodeGenFunction.h @@ -45,6 +45,7 @@ namespace clang { class ObjCInterfaceDecl; class ObjCIvarDecl; class ObjCMethodDecl; + class ObjCImplementationDecl; class ObjCPropertyImplDecl; class TargetInfo; class VarDecl; @@ -176,11 +177,13 @@ public: /// GenerateObjCGetter - Synthesize an Objective-C property getter /// function. - void GenerateObjCGetter(const ObjCPropertyImplDecl *PID); + void GenerateObjCGetter(ObjCImplementationDecl *IMP, + const ObjCPropertyImplDecl *PID); /// GenerateObjCSetter - Synthesize an Objective-C property setter /// function for the given property. - void GenerateObjCSetter(const ObjCPropertyImplDecl *PID); + void GenerateObjCSetter(ObjCImplementationDecl *IMP, + const ObjCPropertyImplDecl *PID); void GenerateCode(const FunctionDecl *FD, llvm::Function *Fn); diff --git a/lib/CodeGen/CodeGenModule.cpp b/lib/CodeGen/CodeGenModule.cpp index c8fa994916..82e732163b 100644 --- a/lib/CodeGen/CodeGenModule.cpp +++ b/lib/CodeGen/CodeGenModule.cpp @@ -980,10 +980,12 @@ void CodeGenModule::EmitObjCPropertyImplementations(const // property. What we want to know is if the method is defined in // this implementation. if (!D->getInstanceMethod(PD->getGetterName())) - CodeGenFunction(*this).GenerateObjCGetter(PID); + CodeGenFunction(*this).GenerateObjCGetter( + const_cast<ObjCImplementationDecl *>(D), PID); if (!PD->isReadOnly() && !D->getInstanceMethod(PD->getSetterName())) - CodeGenFunction(*this).GenerateObjCSetter(PID); + CodeGenFunction(*this).GenerateObjCSetter( + const_cast<ObjCImplementationDecl *>(D), PID); } } } |