[clang] [C++20][Modules] Fix crash/compiler error due broken AST links (PR #123648)

Dmitry Polukhin via cfe-commits cfe-commits at lists.llvm.org
Wed Jan 22 05:00:17 PST 2025


================
@@ -799,14 +813,14 @@ void ASTDeclWriter::VisitFunctionDecl(FunctionDecl *D) {
   }
 
   if (D->getFriendObjectKind()) {
-    // For a function defined inline within a class template, we have to force
-    // the canonical definition to be the one inside the canonical definition of
-    // the template. Remember this relation to deserialize them together.
-    if (auto *RD = dyn_cast<CXXRecordDecl>(D->getLexicalParent()))
-      if (RD->isDependentContext() && RD->isThisDeclarationADefinition()) {
-        Writer.RelatedDeclsMap[Writer.GetDeclRef(RD)].push_back(
-            Writer.GetDeclRef(D));
-      }
+    // For a friend function defined inline within a class template, we have to
+    // force the definition to be the one inside the definition of the template
+    // class. Remember this relation to deserialize them together.
+    if (auto *RD = dyn_cast<CXXRecordDecl>(D->getLexicalParent());
+        isDefinitionInDependentContext(RD)) {
----------------
dmpolukhin wrote:

Added but I think it cannot happen after `getFriendObjectKind` check.

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


More information about the cfe-commits mailing list