On Mon, Mar 4, 2024, at 12:17 AM, Peter Johansson wrote:
> This is with autoconf 2.72 and GCC 9.4.0.
> I try to configure a project with
>
> ./configure 'CXX=c++ -std=c++2a'
>
> but the configure seems to dislike that because it outputs
>
> checking whether the compiler supports GNU C++... yes
> checking whether c++ -std=c++2a accepts -g... yes
> checking for c++ -std=c++2a option to enable C++11 features... -std=gnu++11
> checking dependency style of c++ -std=c++2a -std=gnu++11... gcc3
>
> So it decides to add -std=gnu++11.

Yeah, the logic for selecting a version of the C++ standard is inflexible
at the moment.  It always tries to force the highest standard that it
already knows about -- and right now that's C++ 2011, no higher.
(At the time 2.72 was released, the 202x C and C++ standards were still
in flux so we elected not to add support for them.)  Making it more
flexible -- specifically, allowing the project to declare which version
of the standard they want to use -- is tracked as
<https://savannah.gnu.org/support/index.php?110286>.

Also, what we currently have assumes that code that's valid in C++ XXXX
will _remain_ valid in C++ YYYY, where YYYY > XXXX.  That used to be
reliably true but the 202x standard drafts broke it.  That's why the
test program threw the error you quoted...

> conftest.cpp: In function 'int main(int, char**)':
> conftest.cpp:199:22: error: invalid conversion from 'const char8_t*' to
> 'const char*' [-fpermissive]
>   199 |   char const *utf8 = u8"UTF-8 string \u2500";

Fixing these things is a high priority for Autoconf 2.73 but nobody
currently has time to work on it.  If you have time, we would
appreciate your working on it -- even just a rough draft of revised
test programs would be helpful.

zw

Reply via email to