]> granicus.if.org Git - clang/commitdiff
PR43242: Fix crash when typo-correcting to an operator() that should not
authorRichard Smith <richard-llvm@metafoo.co.uk>
Mon, 9 Sep 2019 23:07:22 +0000 (23:07 +0000)
committerRichard Smith <richard-llvm@metafoo.co.uk>
Mon, 9 Sep 2019 23:07:22 +0000 (23:07 +0000)
have been visible.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@371468 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaExpr.cpp
test/SemaCXX/lambda-expressions.cpp

index 816d37e0b5e9ba986e5e7b541f94bcd8f031d8da..98f98be16970e7aa989264df0931278fc4daac85 100644 (file)
@@ -1990,16 +1990,7 @@ bool Sema::DiagnoseEmptyLookup(Scope *S, CXXScopeSpec &SS, LookupResult &R,
       R.clear();
     }
 
-    // In Microsoft mode, if we are performing lookup from within a friend
-    // function definition declared at class scope then we must set
-    // DC to the lexical parent to be able to search into the parent
-    // class.
-    if (getLangOpts().MSVCCompat && isa<FunctionDecl>(DC) &&
-        cast<FunctionDecl>(DC)->getFriendObjectKind() &&
-        DC->getLexicalParent()->isRecord())
-      DC = DC->getLexicalParent();
-    else
-      DC = DC->getParent();
+    DC = DC->getLookupParent();
   }
 
   // We didn't find anything, so try to correct for a typo.
index 311def9147f36f3c58231b073b68df025af65ab9..5fff855102fb1bf6f25fcae94732d2849753c674 100644 (file)
@@ -630,3 +630,7 @@ void Run(const int& points) {
   };
 }
 }
+
+void operator_parens() {
+  [&](int x){ operator()(); }(0); // expected-error {{undeclared 'operator()'}}
+}