aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2008-07-21 04:42:08 +0000
committerChris Lattner <sabre@nondot.org>2008-07-21 04:42:08 +0000
commit1f719747b214866535e63b0fe2f5f21da67a5387 (patch)
treecdf7d14294e172c7ae4b294df646adaa2e7384bf
parent68a057b4292f5ff814ec8da53f6cda8cdcfbd2ae (diff)
improve the diagnostic for an erroneous objc ivar reference
from: t.m:8:7: error: member reference is not to a structure or union pool->farm = 0; ^ ~~~~ to: t.m:8:7: error: 'NSAutoreleasePool' has member named 'farm' pool->farm = 0; ~~~~^ ~~~~ git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@53824 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--include/clang/Basic/DiagnosticKinds.def2
-rw-r--r--lib/Sema/SemaExpr.cpp5
2 files changed, 5 insertions, 2 deletions
diff --git a/include/clang/Basic/DiagnosticKinds.def b/include/clang/Basic/DiagnosticKinds.def
index ee8e33439a..b17102dede 100644
--- a/include/clang/Basic/DiagnosticKinds.def
+++ b/include/clang/Basic/DiagnosticKinds.def
@@ -881,6 +881,8 @@ DIAG(err_typecheck_subscript_not_object, ERROR,
"illegal subscript of non-object type '%0'")
DIAG(err_typecheck_member_reference_structUnion, ERROR,
"member reference is not to a structure or union")
+DIAG(err_typecheck_member_reference_ivar, ERROR,
+ "'%0' has member named '%1'")
DIAG(err_typecheck_member_reference_arrow, ERROR,
"member reference is not a pointer")
DIAG(err_typecheck_incomplete_tag, ERROR,
diff --git a/lib/Sema/SemaExpr.cpp b/lib/Sema/SemaExpr.cpp
index 7babcf9d4f..b81e090f7f 100644
--- a/lib/Sema/SemaExpr.cpp
+++ b/lib/Sema/SemaExpr.cpp
@@ -622,8 +622,9 @@ ActOnMemberReferenceExpr(ExprTy *Base, SourceLocation OpLoc,
if (ObjCIvarDecl *IV = IFTy->getDecl()->lookupInstanceVariable(&Member))
return new ObjCIvarRefExpr(IV, IV->getType(), MemberLoc, BaseExpr,
OpKind == tok::arrow);
- return Diag(OpLoc, diag::err_typecheck_member_reference_structUnion,
- SourceRange(MemberLoc));
+ return Diag(OpLoc, diag::err_typecheck_member_reference_ivar,
+ IFTy->getDecl()->getName(), Member.getName(),
+ BaseExpr->getSourceRange(), SourceRange(MemberLoc));
}
// Handle property access.