]> granicus.if.org Git - clang/commitdiff
Fix <rdar://problem/6252226> parser thinks block argument is undefined identifier...
authorSteve Naroff <snaroff@apple.com>
Sun, 28 Sep 2008 00:13:36 +0000 (00:13 +0000)
committerSteve Naroff <snaroff@apple.com>
Sun, 28 Sep 2008 00:13:36 +0000 (00:13 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@56761 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaExpr.cpp
test/Sema/block-return.c

index e8b4d8cb4b3f0131fd4f98c4bfb70531541c2177..dfa53ac4398651113eb97c0eccc1ae1be8a147d4 100644 (file)
@@ -366,9 +366,14 @@ Sema::ExprResult Sema::ActOnIdentifierExpr(Scope *S, SourceLocation Loc,
   }
   // If we are parsing a block, check the block parameter list.
   if (CurBlock) {
-    for (unsigned i = 0, e = CurBlock->Params.size(); i != e; ++i)
-      if (CurBlock->Params[i]->getIdentifier() == &II)
-        D = CurBlock->Params[i];
+    BlockSemaInfo *BLK = CurBlock;
+    do {
+      for (unsigned i = 0, e = BLK->Params.size(); i != e && D == 0; ++i)
+        if (BLK->Params[i]->getIdentifier() == &II)
+          D = BLK->Params[i];
+      if (D) 
+        break; // Found!
+    } while ((BLK = BLK->PrevBlockInfo));  // Look through any enclosing blocks.
   }
   if (D == 0) {
     // Otherwise, this could be an implicitly declared function reference (legal
index 6d660d140221e1ed6a874ea3ea7bbc8ae1210c14..ba3a0d269faf49d07015a85c8f09b6ea1a627bbb 100644 (file)
@@ -77,4 +77,6 @@ static int funk(char *s) {
 void foo4() {
   int (^xx)(const char *s) = ^(char *s) { return 1; }; // expected-warning {{incompatible block pointer types initializing 'int (^)(char *)', expected 'int (^)(char const *)'}}
   int (*yy)(const char *s) = funk; // expected-warning {{incompatible pointer types initializing 'int (char *)', expected 'int (*)(char const *)'}}
+  
+  int (^nested)(char *s) = ^(char *str) { void (^nest)(void) = ^(void) { printf("%s\n", str); }; next(); return 1; };
 }