diff options
author | Douglas Gregor <dgregor@apple.com> | 2011-12-01 01:37:36 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2011-12-01 01:37:36 +0000 |
commit | d8fb1e30ebc39aeeca0a99ac20e02e08444b56f6 (patch) | |
tree | 4210d5ca1c9d259a5112aa7fc47d4d92b9ee2aec /clang/lib/Sema/SemaExprObjC.cpp | |
parent | 79d0428046705ac9c0e4db9aa3cf6bc669e9d57f (diff) | |
download | bcm5719-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.cpp | 10 |
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()) { |