jeanPerier wrote:

HI @mizvekov, after your patch, some llvm build broke because a piece of code 
in flang does not compile anymore with tip of the tree clang:

See: https://lab.llvm.org/buildbot/#/builders/4/builds/1670

Here is a reproducer:

```
#include<complex>
std::complex<float> test(std::complex<float> z1) {
  using F0 = std::complex<float> (*)(const std::complex<float> &, const 
std::complex<float> &);
  F0  ptr{std::pow};
  return ptr(z1, z1);
}
```

The new error is:
```
repro.cpp:5:11: error: address of overloaded function 'pow' is ambiguous
    5 |   F0  ptr{std::pow};
      |           ^
/usr/lib/gcc/x86_64-linux-gnu/11/../../../../include/c++/11/complex:1062:5: 
note: candidate function [with _Tp = float]
 1062 |     pow(const complex<_Tp>& __x, const complex<_Tp>& __y)
      |     ^
/usr/lib/gcc/x86_64-linux-gnu/11/../../../../include/c++/11/complex:1899:5: 
note: candidate function [with _Tp = float, _Up = float]
 1899 |     pow(const std::complex<_Tp>& __x, const std::complex<_Up>& __y)
```

Other g++ (and previously clang) compile without warning here. Is this new 
error justified?

The piece of code with this pattern in flang is here, and is building a table 
of host math functions to use when folding: 
https://github.com/llvm/llvm-project/blob/a919588df4f108cef5829363a9ec6a1968dbb03a/flang/lib/Evaluate/intrinsics-library.cpp#L278

I have a workaround for it (#106718) but I do not understand if raising such 
C++ error is intentional with your patch.

https://github.com/llvm/llvm-project/pull/100692
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to