diff options
author | Steve Naroff <snaroff@apple.com> | 2008-11-17 16:28:52 +0000 |
---|---|---|
committer | Steve Naroff <snaroff@apple.com> | 2008-11-17 16:28:52 +0000 |
commit | ecf2bb8724d41a72292b80c88bf35b46ec51a39f (patch) | |
tree | 66514f043eb80c3af1cacfaa795325f6f155e9ee /clang | |
parent | d69246bd5badd17babae14aa202caaf2152dd3d5 (diff) | |
download | bcm5719-llvm-ecf2bb8724d41a72292b80c88bf35b46ec51a39f.tar.gz bcm5719-llvm-ecf2bb8724d41a72292b80c88bf35b46ec51a39f.zip |
Fix <rdar://problem/6320086> parser rejects block capturing ivar.
llvm-svn: 59444
Diffstat (limited to 'clang')
-rw-r--r-- | clang/lib/Sema/Sema.cpp | 5 | ||||
-rw-r--r-- | clang/test/SemaObjC/block-ivar.m | 19 |
2 files changed, 23 insertions, 1 deletions
diff --git a/clang/lib/Sema/Sema.cpp b/clang/lib/Sema/Sema.cpp index b78336b6cd2..64959495269 100644 --- a/clang/lib/Sema/Sema.cpp +++ b/clang/lib/Sema/Sema.cpp @@ -241,5 +241,8 @@ const LangOptions &Sema::getLangOptions() const { } ObjCMethodDecl *Sema::getCurMethodDecl() { - return dyn_cast<ObjCMethodDecl>(CurContext); + DeclContext *DC = CurContext; + while (isa<BlockDecl>(DC)) + DC = DC->getParent(); + return dyn_cast<ObjCMethodDecl>(DC); } diff --git a/clang/test/SemaObjC/block-ivar.m b/clang/test/SemaObjC/block-ivar.m new file mode 100644 index 00000000000..d1f56b651d3 --- /dev/null +++ b/clang/test/SemaObjC/block-ivar.m @@ -0,0 +1,19 @@ +// RUN: clang -fsyntax-only -verify %s + +@interface NSObject { + struct objc_object *isa; +} +@end +@interface Foo : NSObject { + int _prop; +} +@end + +@implementation Foo +- (int)doSomething { + int (^blk)(void) = ^{ return _prop; }; + return blk(); +} + +@end + |