[clang] [ASTImporter] Fix infinite recurse on return type declared inside body (#68775) (PR #89096)

Matheus Izvekov via cfe-commits cfe-commits at lists.llvm.org
Wed Apr 17 19:16:47 PDT 2024


================
@@ -3647,15 +3647,19 @@ class IsTypeDeclaredInsideVisitor
 };
 } // namespace
 
-/// This function checks if the function has 'auto' return type that contains
+/// This function checks if the given function has a return type that contains
 /// a reference (in any way) to a declaration inside the same function.
-bool ASTNodeImporter::hasAutoReturnTypeDeclaredInside(FunctionDecl *D) {
+bool ASTNodeImporter::hasReturnTypeDeclaredInside(FunctionDecl *D) {
   QualType FromTy = D->getType();
   const auto *FromFPT = FromTy->getAs<FunctionProtoType>();
   assert(FromFPT && "Must be called on FunctionProtoType");
 
+  bool IsLambdaDefinition = false;
+  if (const auto *MD = dyn_cast<CXXMethodDecl>(D))
+    IsLambdaDefinition = cast<CXXRecordDecl>(MD->getDeclContext())->isLambda();
----------------
mizvekov wrote:

Thanks, this works, but if we are going this way, why not also check the lambda was defined without a return type?

https://github.com/llvm/llvm-project/pull/89096


More information about the cfe-commits mailing list