[gcc r15-1716] libstdc++: Define __glibcxx_assert_fail for non-verbose build [PR115585]
Jonathan Wakely
redi@gcc.gnu.org
Fri Jun 28 19:23:31 GMT 2024
https://gcc.gnu.org/g:52370c839edd04df86d3ff2b71fcdca0c7376a7f
commit r15-1716-g52370c839edd04df86d3ff2b71fcdca0c7376a7f
Author: Jonathan Wakely <jwakely@redhat.com>
Date: Fri Jun 28 15:14:15 2024 +0100
libstdc++: Define __glibcxx_assert_fail for non-verbose build [PR115585]
When the library is configured with --disable-libstdcxx-verbose the
assertions just abort instead of calling __glibcxx_assert_fail, and so I
didn't export that function for the non-verbose build. However, that
option is documented to not change the library ABI, so we still need to
export the symbol from the library. It could be needed by programs
compiled against the headers from a verbose build.
The non-verbose definition can just call abort so that it doesn't pull
in I/O symbols, which are unwanted in a non-verbose build.
libstdc++-v3/ChangeLog:
PR libstdc++/115585
* src/c++11/assert_fail.cc (__glibcxx_assert_fail): Add
definition for non-verbose builds.
Diff:
---
libstdc++-v3/src/c++11/assert_fail.cc | 10 +++++++++-
1 file changed, 9 insertions(+), 1 deletion(-)
diff --git a/libstdc++-v3/src/c++11/assert_fail.cc b/libstdc++-v3/src/c++11/assert_fail.cc
index 6d99c7958f3..76c8a5a5c2f 100644
--- a/libstdc++-v3/src/c++11/assert_fail.cc
+++ b/libstdc++-v3/src/c++11/assert_fail.cc
@@ -22,10 +22,10 @@
// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
// <http://www.gnu.org/licenses/>.
-#include <cstdio> // for std::fprintf, stderr
#include <cstdlib> // for std::abort
#ifdef _GLIBCXX_VERBOSE_ASSERT
+#include <cstdio> // for std::fprintf, stderr
namespace std
{
[[__noreturn__]]
@@ -41,4 +41,12 @@ namespace std
abort();
}
}
+#else
+namespace std
+{
+ [[__noreturn__]]
+ void
+ __glibcxx_assert_fail(const char*, int, const char*, const char*) noexcept
+ { abort(); }
+}
#endif
More information about the Gcc-cvs
mailing list