From: Fariborz Jahanian Date: Thu, 7 Jan 2010 18:18:32 +0000 (+0000) Subject: Fix rewriting of ivars. Fixes radar 7490331. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=84ed600154d48d75f204795410aae808d7e4b7bd;p=clang Fix rewriting of ivars. Fixes radar 7490331. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@92924 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Frontend/RewriteObjC.cpp b/lib/Frontend/RewriteObjC.cpp index 7e35475007..44fa263cff 100644 --- a/lib/Frontend/RewriteObjC.cpp +++ b/lib/Frontend/RewriteObjC.cpp @@ -1183,10 +1183,11 @@ Stmt *RewriteObjC::RewritePropertyGetter(ObjCPropertyRefExpr *PropRefExpr) { Stmt *RewriteObjC::RewriteObjCIvarRefExpr(ObjCIvarRefExpr *IV, SourceLocation OrigStart) { ObjCIvarDecl *D = IV->getDecl(); + const Expr *BaseExpr = IV->getBase(); if (CurMethodDef) { - if (const PointerType *pType = IV->getBase()->getType()->getAs()) { + if (IV->isArrow()) { ObjCInterfaceType *iFaceDecl = - dyn_cast(pType->getPointeeType()); + dyn_cast(BaseExpr->getType()->getPointeeType()); // lookup which class implements the instance variable. ObjCInterfaceDecl *clsDeclared = 0; iFaceDecl->getDecl()->lookupInstanceVariable(D->getIdentifier(), diff --git a/test/Rewriter/rewrite-ivar-use.m b/test/Rewriter/rewrite-ivar-use.m new file mode 100644 index 0000000000..9d6a0fa6bb --- /dev/null +++ b/test/Rewriter/rewrite-ivar-use.m @@ -0,0 +1,20 @@ +// RUN: %clang_cc1 -rewrite-objc %s -o - +// radar 7490331 + +@interface Foo { + int a; + id b; +} +- (void)bar; +- (void)baz:(id)q; +@end + +@implementation Foo +- (void)bar { + a = 42; + [self baz:b]; +} +- (void)baz:(id)q { +} +@end +