From: Fariborz Jahanian Date: Mon, 8 Nov 2010 18:37:50 +0000 (+0000) Subject: Fixes a rewrite bug, rewriting nested property usage X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=da4ad9fa26b607adde033badcf67396ebc0cfe17;p=clang Fixes a rewrite bug, rewriting nested property usage inside blocks. Fixes //rdar: //8608293. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@118425 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/clang.xcodeproj/project.pbxproj b/clang.xcodeproj/project.pbxproj index 56ff905ad7..6013c3be97 100644 --- a/clang.xcodeproj/project.pbxproj +++ b/clang.xcodeproj/project.pbxproj @@ -1931,7 +1931,6 @@ isa = PBXProject; buildConfigurationList = 1DEB923508733DC60010E9CD /* Build configuration list for PBXProject "clang" */; compatibilityVersion = "Xcode 2.4"; - developmentRegion = English; hasScannedForEncodings = 1; knownRegions = ( English, diff --git a/lib/Rewrite/RewriteObjC.cpp b/lib/Rewrite/RewriteObjC.cpp index 5fff38859c..4e40b4effa 100644 --- a/lib/Rewrite/RewriteObjC.cpp +++ b/lib/Rewrite/RewriteObjC.cpp @@ -5524,7 +5524,12 @@ Stmt *RewriteObjC::RewriteFunctionBodyOrGlobalInitializer(Stmt *S) { GetInnerBlockDeclRefExprs(BE->getBody(), InnerBlockDeclRefs, InnerContexts); // Rewrite the block body in place. + Stmt *SaveCurrentBody = CurrentBody; + CurrentBody = BE->getBody(); + PropParentMap = 0; RewriteFunctionBodyOrGlobalInitializer(BE->getBody()); + CurrentBody = SaveCurrentBody; + PropParentMap = 0; ImportedLocalExternalDecls.clear(); // Now we snarf the rewritten text and stash it away for later use. std::string Str = Rewrite.getRewrittenText(BE->getSourceRange()); diff --git a/test/Rewriter/rewrite-nested-property-in-blocks.mm b/test/Rewriter/rewrite-nested-property-in-blocks.mm new file mode 100755 index 0000000000..2dffe66ab3 --- /dev/null +++ b/test/Rewriter/rewrite-nested-property-in-blocks.mm @@ -0,0 +1,52 @@ +// RUN: %clang_cc1 -x objective-c++ -Wno-return-type -fblocks -fms-extensions -rewrite-objc %s -o %t-rw.cpp +// RUN: %clang_cc1 -fsyntax-only -fms-extensions -Wno-address-of-temporary -Did="void *" -D"SEL=void*" -D"__declspec(X)=" %t-rw.cpp +// radar 8608293 + +void *sel_registerName(const char *); + +extern "C" void nowarn(id); + +extern "C" void noblockwarn(void (^)()); + +@interface INTFOFPROP +@property (readwrite, retain) INTFOFPROP *outer; +@property (readwrite, retain) id inner; +@end + +@interface NSSet +- (NSSet *)objectsPassingTest:(char (^)(id obj, char *stop))predicate ; +@end + +@interface INTF +- (NSSet *)Meth; +@end + +@implementation INTF + +- (NSSet *)Meth +{ + NSSet *aces; + + noblockwarn(^() { + INTFOFPROP *ace; + nowarn(ace.outer.inner); + noblockwarn(^() { + INTFOFPROP *ace; + nowarn(ace.outer.inner); + }); + }); + + noblockwarn(^() { + INTFOFPROP *ace; + nowarn(ace.outer.inner); + }); + +return [aces objectsPassingTest:^(id obj, char *stop) + { + INTFOFPROP *ace = (INTFOFPROP *)obj; + nowarn(ace.outer.inner); + return (char)0; + }]; + +} +@end