On Apr 22, 2025, at 12:34, Matthias Andree <mand...@freebsd.org> wrote:

> Am 22.04.25 um 20:40 schrieb John Baldwin:
>> On 4/11/25 13:14, Mark Millard wrote:
>>> John Baldwin <jhb_at_FreeBSD.org> wrote on
>>> Date: Fri, 11 Apr 2025 13:54:30 UTC :
>>> 
>>>> The branch main has been updated by jhb:
>>>> 
>>>> URL: https://cgit.FreeBSD.org/src/commit/? 
>>>> id=6527682ab7058e5023a2a6dea01d51c15dca701f
>>>> 
>>>> commit 6527682ab7058e5023a2a6dea01d51c15dca701f
>>>> Author: John Baldwin <j...@freebsd.org>
>>>> AuthorDate: 2025-04-11 13:53:50 +0000
>>>> Commit: John Baldwin <j...@freebsd.org>
>>>> CommitDate: 2025-04-11 13:53:50 +0000
>>>> 
>>>> src: Use gnu++17 as the default C++ standard
>>>> 
>>>> Previously the compiler's default C++ standard was used unlike C where
>>>> bsd.sys.mk explicitly sets a default language version. Setting an
>>>> explicit default version will give a more uniform experience across
>>>> different compilers and compiler versions.
>>>> 
>>>> gnu++17 was chosen to match the default C standard. It is well
>>>> supported by a wide range of clang (5+) and GCC (9+) versions.
>>>> 
>>>> gnu++17 is also the default C++ standard in recent versions of clang
>>>> (16+) and GCC (11+). As a result, many of the explicit CXXSTD
>>>> settings in Makefiles had the effect of lowering the C++ standard
>>>> instead of raising it as was originally intended and are removed.
>>>> 
>>>> Note that the remaining explicit CXXSTD settings for atf and liblutok
>>>> explicitly lower the standard to C++11 due to use of the deprecated
>>>> auto_ptr<> template which is removed in later versions.
>>>> 
>>>> Reviewed by: imp, asomers, dim, emaste
>>>> Differential Revision: https://reviews.freebsd.org/D49223
>>> 
>>> [The note below is just a thought prompted by this. It applies
>>> to the prior context as well.]
>>> 
>>> As I understand many C++ ports use the system c++ toolchain
>>> and libc++ to build and operate --and there is only one libc++
>>> available in some respects. If that is the case
>>> . . .
>>> 
>>> This ends ends up controlling the C++ library's features for
>>> any libc++ library material used via any of:
>> No, it does not.  libc++ is mostly templates and uses many #ifdef's
>> to provide support for multiple language standards.  For the actual
>> symbols required at runtime, we build libc++ such that it includes
>> all of them (in particular, we use a higher CXXSTD to build libc++
>> itself and have for a long time).  So, no, this doesn't change
>> anything in libc++ itself.  It merely changes the default C++
>> environment when using bsd.*.mk.
>> The same is true of libstdc++ use by GCC.  It also supports the
>> full range of C++ versions in the dynamic library and does not
>> require separate builds for different C++ versions.
> 
> Last time I looked, we couldn't mix things though. Case in point, 
> graphics/rawtherapee.  Once you tell it to use GCC *and* libstdc++, due to 
> its use of other C++ libraries, we break linking because the std::string 
> implementations between libstdc++ and libc++ are not interchangeable.  For an 
> isolated application that just uses standard library features, we're good, 
> but once other C++ binary libraries (.so files) come into play, we're stuck.
> 
> And once a compiler uses builtins that the oldest supported libc++ - that of 
> FreeBSD 13.4 - doesn't support, we limit what the application can do.  This 
> prevented specifically updating the default ports GCC and it's stuck until 
> 13.4 will have gone out of support.

One thing that modern enough lang/gcc* do allow is use of
-stdlib=libc++ instead of -stdlib=libstdc++ .

However, that does not mean that various ports are set up
to allow a required set of them (that are g++ based) for a
specific purpose all to build with libc++ instead of
libstdc++ .

I'm not aware of any infrastructure set up for a global
"use libc++ when using lang/gcc*" when building packages
(or ports).

===
Mark Millard
marklmi at yahoo.com


Reply via email to