ChuanqiXu added a comment.

FYI

When I implements/tests the modularized STL for libstdc++ 
(https://github.com/ChuanqiXu9/stdmodules), I find the patch blocks it. Due to 
the time is limited (I really wish we could have something workable in 
clang15), I made a pre-review commit in: 
https://github.com/llvm/llvm-project/commit/15ddc09ef9b05ffd5398165049b5202264fa203a

The problem shows in the tests:

  struct A {};
  
   template<typename Func>
   constexpr bool __call_is_nt(A)
   {
       return true;
   }
   ns::A make();
  
   template <typename T>
   bool foo(T t) {
       auto func = [](){};
       return __call_is_nt<decltype(func)>(t);
   }

The linkage of `__call_is_nt<decltype(func)>` in clang is internal linkage. So 
it is refused by this patch. This is not the fault of the patch. According to 
[basic.link], only names have linkage. So __call_is_nt<decltype(func)> should 
have same linkage with  its template, which should be external.

The root cause for the problem is that the semantics of internal linkage in 
clang is a mixed form of internal linkage and TU-Local in C++ Specifications. 
So here is the slight difference. It is hard to fix the root problem so I 
choose to give a workaround here.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D129174/new/

https://reviews.llvm.org/D129174

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to