]> granicus.if.org Git - clang/commitdiff
improve diagnostics about problems with receivers to highlight the receiver.
authorChris Lattner <sabre@nondot.org>
Mon, 21 Jul 2008 06:16:07 +0000 (06:16 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 21 Jul 2008 06:16:07 +0000 (06:16 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@53842 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaExprObjC.cpp

index 0e5de3ab1470abd503e26f6521876f1f67dc0fdc..bed9d5d306aeafbf064eadf7d75f87c17a2274ad 100644 (file)
@@ -266,7 +266,7 @@ Sema::ExprResult Sema::ActOnInstanceMessage(
       Method = InstanceMethodPool[Sel].Method;
     if (!Method) {
       Diag(lbrac, diag::warn_method_not_found, std::string("-"), Sel.getName(),
-           SourceRange(lbrac, rbrac));
+           RExpr->getSourceRange());
       returnType = Context.getObjCIdType();
     } else {
       returnType = Method->getResultType();
@@ -295,7 +295,7 @@ Sema::ExprResult Sema::ActOnInstanceMessage(
     if (!Method)
       Diag(lbrac, diag::warn_method_not_found_in_protocol, 
            std::string("-"), Sel.getName(),
-           SourceRange(lbrac, rbrac));
+           RExpr->getSourceRange());
   } else if (const ObjCInterfaceType *OCIReceiver = 
                 receiverType->getAsPointerToObjCInterfaceType()) {
     // We allow sending a message to a pointer to an interface (an object).
@@ -321,7 +321,7 @@ Sema::ExprResult Sema::ActOnInstanceMessage(
            SourceRange(lbrac, rbrac));
   } else {
     Diag(lbrac, diag::error_bad_receiver_type,
-         RExpr->getType().getAsString());
+         RExpr->getType().getAsString(), RExpr->getSourceRange());
     return true;
   }