[libcxx-commits] [libcxx] [libc++] Removes the _LIBCPP_VERBOSE_ABORT_NOT_NOEXCEPT macro. (PR #135494)
Mark de Wever via libcxx-commits
libcxx-commits at lists.llvm.org
Sat Apr 12 06:45:50 PDT 2025
https://github.com/mordante updated https://github.com/llvm/llvm-project/pull/135494
>From 131fc4b6eae3718818fc86bcc38e9cf7497c71aa Mon Sep 17 00:00:00 2001
From: Mark de Wever <koraq at xs4all.nl>
Date: Sat, 12 Apr 2025 15:31:26 +0200
Subject: [PATCH] [libc++] Removes the _LIBCPP_VERBOSE_ABORT_NOT_NOEXCEPT
macro.
This makes __libcpp_verbose_abort unconditionally noexcept. This was
planned for the upcomming release.
---
libcxx/docs/ReleaseNotes/21.rst | 6 +++---
libcxx/include/__verbose_abort | 8 +-------
libcxx/src/verbose_abort.cpp | 2 +-
3 files changed, 5 insertions(+), 11 deletions(-)
diff --git a/libcxx/docs/ReleaseNotes/21.rst b/libcxx/docs/ReleaseNotes/21.rst
index a8f20ed0abaf0..de92eeeaaa7dd 100644
--- a/libcxx/docs/ReleaseNotes/21.rst
+++ b/libcxx/docs/ReleaseNotes/21.rst
@@ -70,6 +70,9 @@ Deprecations and Removals
- ``std::is_trivial`` and ``std::is_trivial_v`` are deprecated in C++26 and later.
+- The ``_LIBCPP_VERBOSE_ABORT_NOT_NOEXCEPT`` has been removed, making ``std::__libcpp_verbose_abort``
+ unconditionally ``noexcept``.
+
Potentially breaking changes
----------------------------
@@ -91,9 +94,6 @@ LLVM 21
If you are using C++03 in your project, you should consider moving to a newer version of the Standard to get the most
out of libc++.
-- The ``_LIBCPP_VERBOSE_ABORT_NOT_NOEXCEPT`` macro will be removed in LLVM 21, making ``std::__libcpp_verbose_abort``
- unconditionally ``noexcept``.
-
- Non-conforming extension ``packaged_task::result_type`` will be removed in LLVM 21.
LLVM 22
diff --git a/libcxx/include/__verbose_abort b/libcxx/include/__verbose_abort
index 2d45cd0eb7f5d..f8b696733e2b3 100644
--- a/libcxx/include/__verbose_abort
+++ b/libcxx/include/__verbose_abort
@@ -18,16 +18,10 @@
_LIBCPP_BEGIN_NAMESPACE_STD
-#if defined(_LIBCPP_VERBOSE_ABORT_NOT_NOEXCEPT)
-# define _LIBCPP_VERBOSE_ABORT_NOEXCEPT
-#else
-# define _LIBCPP_VERBOSE_ABORT_NOEXCEPT _NOEXCEPT
-#endif
-
// This function should never be called directly from the code -- it should only be called through
// the _LIBCPP_VERBOSE_ABORT macro.
[[__noreturn__]] _LIBCPP_AVAILABILITY_VERBOSE_ABORT _LIBCPP_OVERRIDABLE_FUNC_VIS _LIBCPP_ATTRIBUTE_FORMAT(
- __printf__, 1, 2) void __libcpp_verbose_abort(const char* __format, ...) _LIBCPP_VERBOSE_ABORT_NOEXCEPT;
+ __printf__, 1, 2) void __libcpp_verbose_abort(const char* __format, ...) _NOEXCEPT;
// _LIBCPP_VERBOSE_ABORT(format, args...)
//
diff --git a/libcxx/src/verbose_abort.cpp b/libcxx/src/verbose_abort.cpp
index fd6bc4943d6ba..94bdb451dee7a 100644
--- a/libcxx/src/verbose_abort.cpp
+++ b/libcxx/src/verbose_abort.cpp
@@ -23,7 +23,7 @@ extern "C" void android_set_abort_message(const char* msg);
_LIBCPP_BEGIN_NAMESPACE_STD
-_LIBCPP_WEAK void __libcpp_verbose_abort(char const* format, ...) _LIBCPP_VERBOSE_ABORT_NOEXCEPT {
+_LIBCPP_WEAK void __libcpp_verbose_abort(char const* format, ...) noexcept {
// Write message to stderr. We do this before formatting into a
// buffer so that we still get some information out if that fails.
{
More information about the libcxx-commits
mailing list