[PATCH] D147655: Implement mangling rules for C++20 concepts and requires-expressions.

John McCall via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Tue Sep 26 10:38:00 PDT 2023


rjmccall added a comment.

In D147655#4650964 <https://reviews.llvm.org/D147655#4650964>, @probinson wrote:

> Hi @rsmith,
>
>> these two different templates would have the same mangling:
>
>   template <typename T, T I> T returnit() {return I;};
>   template <typename T, int I> T returnit() { return I; }
>
> I tried compiling `long foo() { return returnit<long, 4>(); }` with these two templates, and got different manglings. 
> `_Z8returnitIlLl4EET_v` and
> `_Z8returnitIlLi4EET_v`
>
> Am I misunderstanding something about the problem with the old mangling rules?

You need to do `returnit<int, 4>`.


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D147655



More information about the llvm-commits mailing list