[llvm-branch-commits] [clang] release/20.x: [C++20] [Modules] Don't diagnose duplicated friend declarations between modules incorrectly (PR #125809)
via llvm-branch-commits
llvm-branch-commits at lists.llvm.org
Tue Feb 4 22:21:55 PST 2025
https://github.com/llvmbot created https://github.com/llvm/llvm-project/pull/125809
Backport c5a9a72b3cd118a23193d01bf9393fbf1d4b90ae
Requested by: @ChuanqiXu9
>From d8a541445ede9e8bcbe4762c2b3139a64fb1cfd2 Mon Sep 17 00:00:00 2001
From: Chuanqi Xu <yedeng.yd at linux.alibaba.com>
Date: Wed, 5 Feb 2025 13:41:48 +0800
Subject: [PATCH] [C++20] [Modules] Don't diagnose duplicated friend
declarations between modules incorrectly
Close https://github.com/llvm/llvm-project/issues/125521
We shouldn't use the ownership information for friend declarations to do
anything.
(cherry picked from commit c5a9a72b3cd118a23193d01bf9393fbf1d4b90ae)
---
clang/lib/AST/ASTContext.cpp | 3 +-
clang/lib/Serialization/ASTReaderDecl.cpp | 5 ++
clang/test/Modules/pr125521.cppm | 57 +++++++++++++++++++++++
3 files changed, 64 insertions(+), 1 deletion(-)
create mode 100644 clang/test/Modules/pr125521.cppm
diff --git a/clang/lib/AST/ASTContext.cpp b/clang/lib/AST/ASTContext.cpp
index e58091ce95f625..dbeb3d105ad17c 100644
--- a/clang/lib/AST/ASTContext.cpp
+++ b/clang/lib/AST/ASTContext.cpp
@@ -1055,7 +1055,8 @@ void ASTContext::PrintStats() const {
void ASTContext::mergeDefinitionIntoModule(NamedDecl *ND, Module *M,
bool NotifyListeners) {
if (NotifyListeners)
- if (auto *Listener = getASTMutationListener())
+ if (auto *Listener = getASTMutationListener();
+ Listener && !ND->isUnconditionallyVisible())
Listener->RedefinedHiddenDefinition(ND, M);
MergedDefModules[cast<NamedDecl>(ND->getCanonicalDecl())].push_back(M);
diff --git a/clang/lib/Serialization/ASTReaderDecl.cpp b/clang/lib/Serialization/ASTReaderDecl.cpp
index 8210eb2143acf5..1aa94d5a22abe2 100644
--- a/clang/lib/Serialization/ASTReaderDecl.cpp
+++ b/clang/lib/Serialization/ASTReaderDecl.cpp
@@ -3746,6 +3746,11 @@ void ASTDeclReader::checkMultipleDefinitionInNamedModules(ASTReader &Reader,
Func && Func->getTemplateSpecializationInfo())
return;
+ // The module ownership of in-class friend declaration is not straightforward.
+ // Avoid diagnosing such cases.
+ if (D->getFriendObjectKind() || Previous->getFriendObjectKind())
+ return;
+
Module *M = Previous->getOwningModule();
if (!M)
return;
diff --git a/clang/test/Modules/pr125521.cppm b/clang/test/Modules/pr125521.cppm
new file mode 100644
index 00000000000000..d064cdfe3eb73b
--- /dev/null
+++ b/clang/test/Modules/pr125521.cppm
@@ -0,0 +1,57 @@
+// RUN: rm -rf %t
+// RUN: mkdir -p %t
+// RUN: split-file %s %t
+//
+// RUN: %clang_cc1 -std=c++20 %t/mod2.cppm -emit-module-interface -o %t/mod2.pcm
+// RUN: %clang_cc1 -std=c++20 %t/mod1.cppm -emit-module-interface -o %t/mod1.pcm \
+// RUN: -fmodule-file=Mod2=%t/mod2.pcm
+// RUN: %clang_cc1 -std=c++20 %t/test.cc -fmodule-file=Mod2=%t/mod2.pcm -fmodule-file=Mod=%t/mod1.pcm \
+// RUN: -fsyntax-only -verify
+
+// RUN: %clang_cc1 -std=c++20 %t/mod2.cppm -emit-module-interface -o %t/mod2.pcm
+// RUN: %clang_cc1 -std=c++20 %t/mod1.cppm -emit-module-interface -o %t/mod1.pcm \
+// RUN: -fmodule-file=Mod2=%t/mod2.pcm
+// RUN: %clang_cc1 -std=c++20 %t/mod1.pcm -fmodule-file=Mod2=%t/mod2.pcm -emit-llvm -o - \
+// RUN: | FileCheck %t/mod1.cppm
+
+//--- hello.h
+template <typename V> int get() noexcept {return 0;};
+
+template <typename T>
+class List
+{
+ template <typename V> friend int get() noexcept;
+};
+
+//--- mod2.cppm
+module;
+#include "hello.h"
+export module Mod2;
+export const char *modFn2() {
+ List<int> a;
+ return "hello";
+}
+
+//--- mod1.cppm
+module;
+#include "hello.h"
+export module Mod;
+import Mod2;
+export extern "C" const char *modFn() {
+ List<int> a;
+ List<double> b;
+ return modFn2();
+}
+
+// Fine enough to check it won't crash.
+// CHECK: define {{.*}}@modFn
+
+//--- test.cc
+// expected-no-diagnostics
+import Mod;
+import Mod2;
+
+void test() {
+ modFn();
+ modFn2();
+}
More information about the llvm-branch-commits
mailing list