[PATCH] D86411: [libunwind] Remove static_assert / __has_feature macros
Ryan Prichard via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon Aug 24 04:55:38 PDT 2020
rprichard added a comment.
In D86411#2232638 <https://reviews.llvm.org/D86411#2232638>, @mstorsjo wrote:
> I guess this fix makes sense - I'd be surprised if we don't already require C++11 for building in general.
I see many uses of `auto` and `nullptr` in libunwind. In release/10.x, on targets using `dl_iterate_phdr`, AddressSpace.hpp used a lambda function.
The change that broke GCC builds (D86102 <https://reviews.llvm.org/D86102>) adds additional uses of `alignof`, which is also C++11 only. (The previous uses were in a test file.)
> However I do see that when building, the cmake project files don't seem to force building in C++11 mode (at least when building, I don't see any `-std=c++11` or similar), so this would break building with older versions of GCC that do support C++11 but still default to C++98, so I guess it'd be safest if we'd have something that enforces the version of C++ that actually is required.
When I built libunwind using GCC (for use with glibc), using libunwind/CMakeLists.txt, I saw ninja passing `-std=c++11` on the C++ compile command lines. I think it was caused by the `CXX_STANDARD 11` in libunwind/src/CMakeLists.txt (e.g. for unwind_shared <https://github.com/llvm/llvm-project/blob/6a44edb8da335bba355cd180a3f43564d14cd1be/libunwind/src/CMakeLists.txt#L135>). When I removed the `CXX_STANDARD 11` lines, I no longer saw `-std=c++11` on the command lines.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D86411/new/
https://reviews.llvm.org/D86411
More information about the llvm-commits
mailing list