]> granicus.if.org Git - clang/commitdiff
objc: 'id' and block pointer compare in mergeTypes is
authorFariborz Jahanian <fjahanian@apple.com>
Thu, 26 Jan 2012 17:08:50 +0000 (17:08 +0000)
committerFariborz Jahanian <fjahanian@apple.com>
Thu, 26 Jan 2012 17:08:50 +0000 (17:08 +0000)
made symmetrical. // rdar://10734265

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@149065 91177308-0d34-0410-b5e6-96231b3b80d8

lib/AST/ASTContext.cpp
test/SemaObjC/block-id-as-block-argtype.m

index 5a7a73d3e8f8979ca92ff18b24411769582dd633..295489f48984a62800370e3c55dd2d45c00c6c88 100644 (file)
@@ -5934,9 +5934,12 @@ QualType ASTContext::mergeTypes(QualType LHS, QualType RHS,
         return LHS;
     }
     // allow block pointer type to match an 'id' type.
-    if (OfBlockPointer && !BlockReturnType &&
-        LHS->isObjCIdType() && RHS->isBlockPointerType())
-      return LHS;
+    if (OfBlockPointer && !BlockReturnType) {
+       if (LHS->isObjCIdType() && RHS->isBlockPointerType())
+         return LHS;
+      if (RHS->isObjCIdType() && LHS->isBlockPointerType())
+        return RHS;
+    }
     
     return QualType();
   }
index 1b71a5c87b577943a961245b42765fdd63c74130..20bb6adec3275d841a9648d2fcf88d48cd0cafad 100644 (file)
@@ -9,13 +9,19 @@ typedef void (^block4_t)(id arg);
 
 void fn(block4_t arg); // expected-note {{passing argument to parameter 'arg' here}}
 
+void another_fn(block2_t arg);
+
 int main() {
     block1_t b1;
     block2_t b2;
     block3_t b3;
     block3_t b4;
+    block4_t b5;
+
     fn(b1);  // expected-error {{incompatible block pointer types passing 'block1_t' (aka 'void (^)(int)') to parameter of type 'block4_t' (aka 'void (^)(id)')}}
     fn(b2);  // must succeed: block1_t *is* compatible with id
     fn(b3);  // succeeds: NSObject* compatible with id
     fn(b4);  // succeeds: id compatible with id
+
+    another_fn(b5);
 }