summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaExprObjC.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2011-12-01 01:37:36 +0000
committerDouglas Gregor <dgregor@apple.com>2011-12-01 01:37:36 +0000
commitd8fb1e30ebc39aeeca0a99ac20e02e08444b56f6 (patch)
tree4210d5ca1c9d259a5112aa7fc47d4d92b9ee2aec /clang/lib/Sema/SemaExprObjC.cpp
parent79d0428046705ac9c0e4db9aa3cf6bc669e9d57f (diff)
downloadbcm5719-llvm-d8fb1e30ebc39aeeca0a99ac20e02e08444b56f6.tar.gz
bcm5719-llvm-d8fb1e30ebc39aeeca0a99ac20e02e08444b56f6.zip
When sending a message to a receiver that has "unknown any" type,
force the unknown any type to "id" so that the message send can be completed without requiring a case. Fixes <rdar://problem/10506646>. llvm-svn: 145552
Diffstat (limited to 'clang/lib/Sema/SemaExprObjC.cpp')
-rw-r--r--clang/lib/Sema/SemaExprObjC.cpp10
1 files changed, 7 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaExprObjC.cpp b/clang/lib/Sema/SemaExprObjC.cpp
index c4f01c093a7..cc17e6b890d 100644
--- a/clang/lib/Sema/SemaExprObjC.cpp
+++ b/clang/lib/Sema/SemaExprObjC.cpp
@@ -1211,9 +1211,13 @@ ExprResult Sema::BuildInstanceMessage(Expr *Receiver,
// and determine receiver type.
if (Receiver) {
if (Receiver->hasPlaceholderType()) {
- ExprResult result = CheckPlaceholderExpr(Receiver);
- if (result.isInvalid()) return ExprError();
- Receiver = result.take();
+ ExprResult Result;
+ if (Receiver->getType() == Context.UnknownAnyTy)
+ Result = forceUnknownAnyToType(Receiver, Context.getObjCIdType());
+ else
+ Result = CheckPlaceholderExpr(Receiver);
+ if (Result.isInvalid()) return ExprError();
+ Receiver = Result.take();
}
if (Receiver->isTypeDependent()) {
OpenPOWER on IntegriCloud