summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaExpr.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2009-12-31 07:42:17 +0000
committerDouglas Gregor <dgregor@apple.com>2009-12-31 07:42:17 +0000
commitaf2bd473d2fe7d757be539f89163bbb1c83c5501 (patch)
tree70a49aa1239330833b08745edcdc44c65f731256 /clang/lib/Sema/SemaExpr.cpp
parent9039ff89122007e4523c23ce2f7f50fb82580c21 (diff)
downloadbcm5719-llvm-af2bd473d2fe7d757be539f89163bbb1c83c5501.tar.gz
bcm5719-llvm-af2bd473d2fe7d757be539f89163bbb1c83c5501.zip
Typo correction for member access into classes/structs/unions, e.g.,
s.fnd("hello") llvm-svn: 92345
Diffstat (limited to 'clang/lib/Sema/SemaExpr.cpp')
-rw-r--r--clang/lib/Sema/SemaExpr.cpp19
1 files changed, 18 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp
index c87a274122b..6bb6ea3e512 100644
--- a/clang/lib/Sema/SemaExpr.cpp
+++ b/clang/lib/Sema/SemaExpr.cpp
@@ -932,7 +932,7 @@ bool Sema::DiagnoseEmptyLookup(Scope *S, const CXXScopeSpec &SS,
// We didn't find anything, so try to correct for a typo.
if (S && CorrectTypo(R, S, &SS) &&
- (isa<ValueDecl>(*R.begin()) || isa<TemplateDecl>(*R.begin()))) {
+ (isa<ValueDecl>(*R.begin()) || isa<FunctionTemplateDecl>(*R.begin()))) {
if (SS.isEmpty())
Diag(R.getNameLoc(), diagnostic_suggest) << Name << R.getLookupName()
<< CodeModificationHint::CreateReplacement(R.getNameLoc(),
@@ -2346,6 +2346,23 @@ LookupMemberExprInRecord(Sema &SemaRef, LookupResult &R,
// The record definition is complete, now look up the member.
SemaRef.LookupQualifiedName(R, DC);
+ if (!R.empty())
+ return false;
+
+ // We didn't find anything with the given name, so try to correct
+ // for typos.
+ DeclarationName Name = R.getLookupName();
+ if (SemaRef.CorrectTypo(R, 0, &SS, DC) &&
+ (isa<ValueDecl>(*R.begin()) || isa<FunctionTemplateDecl>(*R.begin()))) {
+ SemaRef.Diag(R.getNameLoc(), diag::err_no_member_suggest)
+ << Name << DC << R.getLookupName() << SS.getRange()
+ << CodeModificationHint::CreateReplacement(R.getNameLoc(),
+ R.getLookupName().getAsString());
+ return false;
+ } else {
+ R.clear();
+ }
+
return false;
}
OpenPOWER on IntegriCloud