diff options
author | Fariborz Jahanian <fjahanian@apple.com> | 2010-11-08 18:37:50 +0000 |
---|---|---|
committer | Fariborz Jahanian <fjahanian@apple.com> | 2010-11-08 18:37:50 +0000 |
commit | 086a24a2be5830a6bd43abdf7c74ffb3da676df1 (patch) | |
tree | d96605b3156bac329fe546f113e74cba4a172a27 | |
parent | c745320cf906fd9f79b783d3b71397f9d9677b0a (diff) | |
download | bcm5719-llvm-086a24a2be5830a6bd43abdf7c74ffb3da676df1.tar.gz bcm5719-llvm-086a24a2be5830a6bd43abdf7c74ffb3da676df1.zip |
Fixes a rewrite bug, rewriting nested property usage
inside blocks. Fixes //rdar: //8608293.
llvm-svn: 118425
-rw-r--r-- | clang/clang.xcodeproj/project.pbxproj | 1 | ||||
-rw-r--r-- | clang/lib/Rewrite/RewriteObjC.cpp | 5 | ||||
-rwxr-xr-x | clang/test/Rewriter/rewrite-nested-property-in-blocks.mm | 52 |
3 files changed, 57 insertions, 1 deletions
diff --git a/clang/clang.xcodeproj/project.pbxproj b/clang/clang.xcodeproj/project.pbxproj index 56ff905ad79..6013c3be978 100644 --- a/clang/clang.xcodeproj/project.pbxproj +++ b/clang/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/clang/lib/Rewrite/RewriteObjC.cpp b/clang/lib/Rewrite/RewriteObjC.cpp index 5fff38859cb..4e40b4effa9 100644 --- a/clang/lib/Rewrite/RewriteObjC.cpp +++ b/clang/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/clang/test/Rewriter/rewrite-nested-property-in-blocks.mm b/clang/test/Rewriter/rewrite-nested-property-in-blocks.mm new file mode 100755 index 00000000000..2dffe66ab32 --- /dev/null +++ b/clang/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 |