// This should compile to empty function; check that no size of
// vector is determined and there is no allocation
// { dg-final { scan-tree-dump-not "_M_start" "optimized" } }
-// { dg-final { scan-tree-dump-not "delete" "optimized" } }
+// For C++26 delete appears in ~bad_array() and ~bad_array_new_length() dtors.
+// { dg-final { scan-tree-dump-not "delete" "optimized" { target c++23_down } } }
for (std::vector<int>::size_type i = 0; i < s; i++)
f(v[i]);
}
-// { dg-final { scan-tree-dump-not "delete" "optimized" } }
+// For C++26 delete appears in ~bad_array() and ~bad_array_new_length() dtors.
+// { dg-final { scan-tree-dump-not "delete" "optimized" { target c++23_down } } }
}
return sum;
}
-// { dg-final { scan-tree-dump-not "delete" "optimized" } }
+// For C++26 delete appears in ~bad_array() and ~bad_array_new_length() dtors.
+// { dg-final { scan-tree-dump-not "delete" "optimized" { target c++23_down } } }
for (std::vector<int>::size_type i = 0; i < s; i++)
f(v[i]);
}
-// { dg-final { scan-tree-dump-not "delete" "optimized" } }
+// For C++26 delete appears in ~bad_array() and ~bad_array_new_length() dtors.
+// { dg-final { scan-tree-dump-not "delete" "optimized" { target c++23_down } } }
void foo7(){
std::vector<c7> vi = {c7(),c7(),c7()};
}
-// { dg-final { scan-tree-dump-not "delete" "optimized" } }
+// For C++26 delete appears in ~bad_array() and ~bad_array_new_length() dtors.
+// { dg-final { scan-tree-dump-not "delete" "optimized" { target c++23_down } } }
#if __cplusplus >= 201103L
/* std::__throw_bad_alloc and std::__throw_bad_array_new_length. */
-#include <bits/functexcept.h>
+#include <bits/new_throw.h>
namespace omp
{
_ZN11__gnu_debug25_Safe_local_iterator_base16_M_attach_singleEPKNS_30_Safe_unordered_container_baseEb;
_ZNK11__gnu_debug30_Safe_unordered_container_base13_M_detach_allEv;
_ZNK11__gnu_debug30_Safe_unordered_container_base7_M_swapERKS0_;
+
+ # std::__cow_string
+ _ZNSt12__cow_stringC2EPKc;
+ _ZNSt12__cow_stringC2EPKc[jmy];
+ _ZNSt12__cow_stringC2ERKS_;
+ _ZNSt12__cow_stringC2EOS_;
+ _ZNSt12__cow_stringD2Ev;
+ _ZNSt12__cow_stringaSERKS_;
+ _ZNSt12__cow_stringaSEOS_;
+ _ZNKSt12__cow_string5c_strEv;
} GLIBCXX_3.4.34;
# Symbols in the support library (libsupc++) have their own tag.
${bits_srcdir}/intcmp.h \
${bits_srcdir}/invoke.h \
${bits_srcdir}/iterator_concepts.h \
+ ${bits_srcdir}/new_except.h \
+ ${bits_srcdir}/new_throw.h \
${bits_srcdir}/max_size_type.h \
${bits_srcdir}/memoryfwd.h \
${bits_srcdir}/monostate.h \
${bits_srcdir}/ranges_util.h \
${bits_srcdir}/refwrap.h \
${bits_srcdir}/sat_arith.h \
+ ${bits_srcdir}/stdexcept_except.h \
+ ${bits_srcdir}/stdexcept_throw.h \
+ ${bits_srcdir}/stdexcept_throwdef.h \
+ ${bits_srcdir}/stdexcept_throwfwd.h \
${bits_srcdir}/stl_algo.h \
${bits_srcdir}/stl_algobase.h \
${bits_srcdir}/stl_construct.h \
${bits_srcdir}/intcmp.h \
${bits_srcdir}/invoke.h \
${bits_srcdir}/iterator_concepts.h \
+ ${bits_srcdir}/new_except.h \
+ ${bits_srcdir}/new_throw.h \
${bits_srcdir}/max_size_type.h \
${bits_srcdir}/memoryfwd.h \
${bits_srcdir}/monostate.h \
${bits_srcdir}/ranges_util.h \
${bits_srcdir}/refwrap.h \
${bits_srcdir}/sat_arith.h \
+ ${bits_srcdir}/stdexcept_except.h \
+ ${bits_srcdir}/stdexcept_throw.h \
+ ${bits_srcdir}/stdexcept_throwdef.h \
+ ${bits_srcdir}/stdexcept_throwfwd.h \
${bits_srcdir}/stl_algo.h \
${bits_srcdir}/stl_algobase.h \
${bits_srcdir}/stl_construct.h \
#pragma GCC system_header
#endif
+#include <bits/functexcept.h>
#include <bits/localefwd.h>
#include <bits/locale_classes.h>
#include <bits/locale_facets.h>
// [format.formatter], formatter
template<typename _Tp, typename _CharT = char> struct formatter;
-/// @cond undocumented
- [[noreturn]]
- inline void
- __throw_format_error(const char* __what);
-
namespace __format
{
#ifdef _GLIBCXX_USE_WCHAR_T
#include <bits/c++config.h>
#include <bits/exception_defines.h>
+#if _GLIBCXX_HOSTED
namespace std _GLIBCXX_VISIBILITY(default)
{
_GLIBCXX_BEGIN_NAMESPACE_VERSION
-
-#if _GLIBCXX_HOSTED
// Helper for exception objects in <except>
void
__throw_bad_exception(void) __attribute__((__noreturn__));
- // Helper for exception objects in <new>
- void
- __throw_bad_alloc(void) __attribute__((__noreturn__));
-
- void
- __throw_bad_array_new_length(void) __attribute__((__noreturn__));
-
// Helper for exception objects in <typeinfo>
void
__throw_bad_cast(void) __attribute__((__noreturn__,__cold__));
__throw_bad_typeid(void) __attribute__((__noreturn__,__cold__));
// Helpers for exception objects in <stdexcept>
- void
- __throw_logic_error(const char*) __attribute__((__noreturn__,__cold__));
-
- void
- __throw_domain_error(const char*) __attribute__((__noreturn__,__cold__));
-
- void
- __throw_invalid_argument(const char*) __attribute__((__noreturn__,__cold__));
-
- void
- __throw_length_error(const char*) __attribute__((__noreturn__,__cold__));
-
- void
- __throw_out_of_range(const char*) __attribute__((__noreturn__,__cold__));
-
- void
- __throw_out_of_range_fmt(const char*, ...) __attribute__((__noreturn__,__cold__))
- __attribute__((__format__(__gnu_printf__, 1, 2)));
-
- void
- __throw_runtime_error(const char*) __attribute__((__noreturn__,__cold__));
-
void
__throw_range_error(const char*) __attribute__((__noreturn__,__cold__));
- void
- __throw_overflow_error(const char*) __attribute__((__noreturn__,__cold__));
-
- void
- __throw_underflow_error(const char*) __attribute__((__noreturn__,__cold__));
-
// Helpers for exception objects in <ios>
void
__throw_ios_failure(const char*) __attribute__((__noreturn__,__cold__));
void
__throw_bad_function_call() __attribute__((__noreturn__,__cold__));
-#else // ! HOSTED
-
- __attribute__((__noreturn__)) inline void
- __throw_invalid_argument(const char*)
- { std::__terminate(); }
-
- __attribute__((__noreturn__)) inline void
- __throw_out_of_range(const char*)
- { std::__terminate(); }
-
- __attribute__((__noreturn__)) inline void
- __throw_out_of_range_fmt(const char*, ...)
- { std::__terminate(); }
-
- __attribute__((__noreturn__)) inline void
- __throw_runtime_error(const char*)
- { std::__terminate(); }
-
- __attribute__((__noreturn__)) inline void
- __throw_overflow_error(const char*)
- { std::__terminate(); }
-
-#endif // HOSTED
-
_GLIBCXX_END_NAMESPACE_VERSION
} // namespace
+#endif // HOSTED
#endif
#define _HASHTABLE_POLICY_H 1
#include <tuple> // for std::tuple, std::forward_as_tuple
+#include <bits/stdexcept_throw.h>
#include <bits/functional_hash.h> // for __is_fast_hash
#include <bits/stl_algobase.h> // for std::min
#include <bits/stl_pair.h> // for std::pair
#pragma GCC system_header
#endif
+#include <bits/functexcept.h>
#include <bits/localefwd.h>
#include <string>
#include <ext/atomicity.h>
#include <new> // operator new(size_t, void*)
#include <cstddef> // size_t, max_align_t, byte
-#include <bits/functexcept.h> // __throw_bad_array_new_length
+#include <bits/new_throw.h> // __throw_bad_array_new_length
#include <bits/uses_allocator.h> // allocator_arg_t, __use_alloc
#include <bits/uses_allocator_args.h> // uninitialized_construct_using_alloc
#include <ext/numeric_traits.h> // __int_traits
#include <bits/c++config.h>
#include <new>
-#include <bits/functexcept.h>
+#include <bits/new_throw.h>
#include <bits/move.h>
#if __cplusplus >= 201103L
#include <type_traits>
--- /dev/null
+// Exception classes for <new> -*- C++ -*-
+
+// Copyright (C) 2001-2025 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+
+// Under Section 7 of GPL version 3, you are granted additional
+// permissions described in the GCC Runtime Library Exception, version
+// 3.1, as published by the Free Software Foundation.
+
+// You should have received a copy of the GNU General Public License and
+// a copy of the GCC Runtime Library Exception along with this program;
+// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
+// <http://www.gnu.org/licenses/>.
+
+/** @file bits/new_except.h
+ * This is an internal header file, included by other library headers.
+ * Do not attempt to use it directly. @headername{new}
+ */
+
+//
+// ISO C++ 14882: 19.1 Exception classes
+//
+
+#ifndef _NEW_EXCEPT_H
+#define _NEW_EXCEPT_H 1
+
+#include <bits/c++config.h>
+#include <bits/exception_defines.h>
+#include <bits/exception.h>
+
+extern "C++"
+{
+
+namespace std _GLIBCXX_VISIBILITY(default)
+{
+_GLIBCXX_BEGIN_NAMESPACE_VERSION
+
+ /**
+ * @brief Exception possibly thrown by @c new.
+ * @ingroup exceptions
+ *
+ * @c bad_alloc (or classes derived from it) is used to report allocation
+ * errors from the throwing forms of @c new. */
+ class bad_alloc : public exception
+ {
+ public:
+ _GLIBCXX26_CONSTEXPR bad_alloc() throw() { }
+
+#if __cplusplus >= 201103L
+ _GLIBCXX26_CONSTEXPR bad_alloc(const bad_alloc&) = default;
+ _GLIBCXX26_CONSTEXPR bad_alloc& operator=(const bad_alloc&) = default;
+#endif
+
+#if __cplusplus >= 202400L
+ constexpr virtual ~bad_alloc() noexcept {}
+
+ constexpr virtual const char* what() const noexcept
+ {
+ return "std::bad_alloc";
+ }
+#else
+ // This declaration is not useless:
+ // http://gcc.gnu.org/onlinedocs/gcc-3.0.2/gcc_6.html#SEC118
+ virtual ~bad_alloc() throw();
+
+ // See comment in eh_exception.cc.
+ virtual const char* what() const throw();
+#endif
+ };
+
+#if __cplusplus >= 201103L
+ class bad_array_new_length : public bad_alloc
+ {
+ public:
+ _GLIBCXX26_CONSTEXPR bad_array_new_length() throw() { }
+
+#if __cplusplus >= 202400L
+ constexpr virtual ~bad_array_new_length() noexcept {}
+
+ constexpr virtual const char* what() const noexcept
+ {
+ return "std::bad_array_new_length";
+ }
+#else
+ // This declaration is not useless:
+ // http://gcc.gnu.org/onlinedocs/gcc-3.0.2/gcc_6.html#SEC118
+ virtual ~bad_array_new_length() throw();
+
+ // See comment in eh_exception.cc.
+ virtual const char* what() const throw();
+#endif
+ };
+#endif
+
+_GLIBCXX_END_NAMESPACE_VERSION
+} // namespace
+
+}
+
+#endif
--- /dev/null
+// Function-Based Exception Support -*- C++ -*-
+
+// Copyright (C) 2001-2025 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+
+// Under Section 7 of GPL version 3, you are granted additional
+// permissions described in the GCC Runtime Library Exception, version
+// 3.1, as published by the Free Software Foundation.
+
+// You should have received a copy of the GNU General Public License and
+// a copy of the GCC Runtime Library Exception along with this program;
+// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
+// <http://www.gnu.org/licenses/>.
+
+/** @file bits/new_throw.h
+ * This is an internal header file, included by other library headers.
+ * Do not attempt to use it directly. @headername{new}
+ */
+
+//
+// ISO C++ 14882: 19.1 Exception classes
+//
+
+#ifndef _NEW_THROW_H
+#define _NEW_THROW_H 1
+
+#include <bits/c++config.h>
+#include <bits/exception_defines.h>
+#if (_GLIBCXX_HOSTED && __cpp_exceptions && __cplusplus > 202302L \
+ && __cpp_constexpr_exceptions >= 202411L)
+#include <bits/new_except.h>
+#endif
+
+namespace std _GLIBCXX_VISIBILITY(default)
+{
+_GLIBCXX_BEGIN_NAMESPACE_VERSION
+
+#if _GLIBCXX_HOSTED
+#if (__cpp_exceptions && __cplusplus > 202302L \
+ && __cpp_constexpr_exceptions >= 202411L)
+ // Helper for exception objects in <new>
+ [[noreturn, __gnu__::__always_inline__]] constexpr void
+ __throw_bad_alloc(void)
+ {
+ throw bad_alloc();
+ }
+
+ [[noreturn, __gnu__::__always_inline__]] constexpr void
+ __throw_bad_array_new_length(void)
+ {
+ throw bad_array_new_length();
+ }
+#else
+ // Helper for exception objects in <new>
+ void
+ __throw_bad_alloc(void) __attribute__((__noreturn__));
+
+ void
+ __throw_bad_array_new_length(void) __attribute__((__noreturn__));
+#endif
+#endif // HOSTED
+
+_GLIBCXX_END_NAMESPACE_VERSION
+} // namespace
+
+#endif
# error include <cmath> and define __STDCPP_WANT_MATH_SPEC_FUNCS__
#endif
+#include <bits/stdexcept_throw.h>
#include <bits/stl_algobase.h>
#include <limits>
#include <type_traits>
--- /dev/null
+// Exception classes for <stdexcept> -*- C++ -*-
+
+// Copyright (C) 2001-2025 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+
+// Under Section 7 of GPL version 3, you are granted additional
+// permissions described in the GCC Runtime Library Exception, version
+// 3.1, as published by the Free Software Foundation.
+
+// You should have received a copy of the GNU General Public License and
+// a copy of the GCC Runtime Library Exception along with this program;
+// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
+// <http://www.gnu.org/licenses/>.
+
+/** @file bits/stdexcept_except.h
+ * This is an internal header file, included by other library headers.
+ * Do not attempt to use it directly. @headername{stdexcept} */
+
+#ifndef _STDEXCEPT_EXCEPT_H
+#define _STDEXCEPT_EXCEPT_H 1
+
+#include <exception>
+#include <string>
+
+namespace std _GLIBCXX_VISIBILITY(default)
+{
+_GLIBCXX_BEGIN_NAMESPACE_VERSION
+
+#if _GLIBCXX_USE_DUAL_ABI
+#if _GLIBCXX_USE_CXX11_ABI
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ struct __cow_constexpr_string;
+ namespace __detail
+ {
+ extern "C"
+ {
+ void _ZNSt12__cow_stringC2EPKcm(__cow_constexpr_string*, const char*,
+ unsigned long);
+ void _ZNSt12__cow_stringC2EPKcj(__cow_constexpr_string*, const char*,
+ unsigned int);
+ void _ZNSt12__cow_stringC2EPKcy(__cow_constexpr_string*, const char*,
+ unsigned long long);
+ void _ZNSt12__cow_stringC2EPKc(__cow_constexpr_string*, const char*);
+ void _ZNSt12__cow_stringC2ERKS_(__cow_constexpr_string*,
+ const __cow_constexpr_string&) noexcept;
+ void _ZNSt12__cow_stringC2EOS_(__cow_constexpr_string*,
+ __cow_constexpr_string&&) noexcept;
+ void _ZNSt12__cow_stringD2Ev(__cow_constexpr_string*);
+ __cow_constexpr_string&
+ _ZNSt12__cow_stringaSERKS_(__cow_constexpr_string*,
+ const __cow_constexpr_string&) noexcept;
+ __cow_constexpr_string&
+ _ZNSt12__cow_stringaSEOS_(__cow_constexpr_string*,
+ __cow_constexpr_string&&) noexcept;
+ const char*
+ _ZNKSt12__cow_string5c_strEv(const __cow_constexpr_string*) noexcept;
+ }
+ } // namespace __detail
+
+ // Emulates an old COW string when the new std::string is in use,
+ // but in addition is constexpr and uses the __cow_string out of
+ // line cdtors/methods unless manifestly constant evaluated.
+ struct __cow_constexpr_string
+ {
+ union {
+ const char* _M_p;
+ char _M_bytes[sizeof(const char*)];
+ string* _M_str;
+ };
+
+ [[__gnu__::__always_inline__]] constexpr
+ __cow_constexpr_string(const string& __o)
+ {
+ if consteval {
+ _M_str = new string(__o);
+ } else {
+ __cow_constexpr_string_ctor(__o.c_str(), __o.length());
+ }
+ }
+
+ [[__gnu__::__always_inline__]] inline void
+ __cow_constexpr_string_ctor(const char *__s, unsigned long __l)
+ {
+ __detail::_ZNSt12__cow_stringC2EPKcm(this, __s, __l);
+ }
+
+ [[__gnu__::__always_inline__]] inline void
+ __cow_constexpr_string_ctor(const char *__s, unsigned int __l)
+ {
+ __detail::_ZNSt12__cow_stringC2EPKcj(this, __s, __l);
+ }
+
+ [[__gnu__::__always_inline__]] inline void
+ __cow_constexpr_string_ctor(const char *__s, unsigned long long __l)
+ {
+ __detail::_ZNSt12__cow_stringC2EPKcy(this, __s, __l);
+ }
+
+ [[__gnu__::__always_inline__]] constexpr
+ __cow_constexpr_string(const char* __o)
+ {
+ if consteval {
+ _M_str = new string(__o);
+ } else {
+ __detail::_ZNSt12__cow_stringC2EPKc(this, __o);
+ }
+ }
+
+ [[__gnu__::__always_inline__]] constexpr
+ __cow_constexpr_string(const __cow_constexpr_string& __o) noexcept
+ {
+ if consteval {
+ _M_str = new string(*__o._M_str);
+ } else {
+ __detail::_ZNSt12__cow_stringC2ERKS_(this, __o);
+ }
+ }
+
+ [[__gnu__::__always_inline__]] constexpr __cow_constexpr_string&
+ operator=(const __cow_constexpr_string& __o) noexcept
+ {
+ if consteval {
+ string* __p = _M_str;
+ _M_str = new string(*__o._M_str);
+ delete __p;
+ return *this;
+ } else {
+ return __detail::_ZNSt12__cow_stringaSERKS_(this, __o);
+ }
+ }
+
+ [[__gnu__::__always_inline__]] constexpr
+ ~__cow_constexpr_string()
+ {
+ if consteval {
+ delete _M_str;
+ } else {
+ __detail::_ZNSt12__cow_stringD2Ev(this);
+ }
+ }
+
+ [[__gnu__::__always_inline__]] constexpr
+ __cow_constexpr_string(__cow_constexpr_string&& __o) noexcept
+ {
+ if consteval {
+ _M_str = new string(std::move(*__o._M_str));
+ } else {
+ __detail::_ZNSt12__cow_stringC2EOS_(this, std::move(__o));
+ }
+ }
+
+ [[__gnu__::__always_inline__]] constexpr __cow_constexpr_string&
+ operator=(__cow_constexpr_string&& __o) noexcept
+ {
+ if consteval {
+ string* __p = _M_str;
+ _M_str = new string(std::move(*__o._M_str));
+ delete __p;
+ return *this;
+ } else {
+ return __detail::_ZNSt12__cow_stringaSEOS_(this, std::move(__o));
+ }
+ }
+
+ [[__gnu__::__always_inline__]] constexpr const char*
+ c_str() const noexcept
+ {
+ if consteval {
+ return _M_str->c_str();
+ } else {
+ return __detail::_ZNKSt12__cow_string5c_strEv(this);
+ }
+ }
+ };
+
+ typedef __cow_constexpr_string __cow_string;
+#else
+ // Emulates an old COW string when the new std::string is in use.
+ struct __cow_string
+ {
+ union {
+ const char* _M_p;
+ char _M_bytes[sizeof(const char*)];
+ };
+
+ __cow_string();
+ __cow_string(const std::string&);
+ __cow_string(const char*, size_t);
+ __cow_string(const __cow_string&) _GLIBCXX_NOTHROW;
+ __cow_string& operator=(const __cow_string&) _GLIBCXX_NOTHROW;
+ ~__cow_string();
+#if __cplusplus >= 201103L
+ __cow_string(__cow_string&&) noexcept;
+ __cow_string& operator=(__cow_string&&) noexcept;
+#endif
+ };
+#endif
+
+ typedef basic_string<char> __sso_string;
+#else // _GLIBCXX_USE_CXX11_ABI
+ typedef basic_string<char> __cow_string;
+
+ // Emulates a new SSO string when the old std::string is in use.
+ struct __sso_string
+ {
+ struct __str
+ {
+ const char* _M_p;
+ size_t _M_string_length;
+ char _M_local_buf[16];
+ };
+
+ union {
+ __str _M_s;
+ char _M_bytes[sizeof(__str)];
+ };
+
+ __sso_string() _GLIBCXX_NOTHROW;
+ __sso_string(const std::string&);
+ __sso_string(const char*, size_t);
+ __sso_string(const __sso_string&);
+ __sso_string& operator=(const __sso_string&);
+ ~__sso_string();
+#if __cplusplus >= 201103L
+ __sso_string(__sso_string&&) noexcept;
+ __sso_string& operator=(__sso_string&&) noexcept;
+#endif
+ };
+#endif // _GLIBCXX_USE_CXX11_ABI
+#else // _GLIBCXX_USE_DUAL_ABI
+ typedef basic_string<char> __sso_string;
+ typedef basic_string<char> __cow_string;
+#endif
+
+ /**
+ * @addtogroup exceptions
+ * @{
+ */
+
+ /** Logic errors represent problems in the internal logic of a program;
+ * in theory, these are preventable, and even detectable before the
+ * program runs (e.g., violations of class invariants).
+ * @brief One of two subclasses of exception.
+ */
+ class logic_error : public exception
+ {
+ __cow_string _M_msg;
+
+ public:
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ constexpr explicit
+ logic_error(const string& __arg) _GLIBCXX_TXN_SAFE
+ : _M_msg(__arg) {}
+
+ constexpr explicit
+ logic_error(const char* __arg) _GLIBCXX_TXN_SAFE
+ : _M_msg(__arg) {}
+
+ constexpr logic_error(logic_error&& __arg) noexcept = default;
+ constexpr logic_error& operator=(logic_error&& __arg) noexcept = default;
+ constexpr logic_error(const logic_error&) noexcept = default;
+ constexpr logic_error& operator=(const logic_error&) noexcept = default;
+
+ constexpr virtual ~logic_error() _GLIBCXX_TXN_SAFE_DYN noexcept { }
+
+ constexpr virtual const char*
+ what() const _GLIBCXX_TXN_SAFE_DYN noexcept
+ {
+ return _M_msg.c_str();
+ }
+#else
+ /** Takes a character string describing the error. */
+ explicit
+ logic_error(const string& __arg) _GLIBCXX_TXN_SAFE;
+
+#if __cplusplus >= 201103L
+ explicit
+ logic_error(const char*) _GLIBCXX_TXN_SAFE;
+
+ logic_error(logic_error&&) noexcept;
+ logic_error& operator=(logic_error&&) noexcept;
+#endif
+
+#if _GLIBCXX_USE_CXX11_ABI || _GLIBCXX_DEFINE_STDEXCEPT_COPY_OPS
+ logic_error(const logic_error&) _GLIBCXX_NOTHROW;
+ logic_error& operator=(const logic_error&) _GLIBCXX_NOTHROW;
+#elif __cplusplus >= 201103L
+ logic_error(const logic_error&) = default;
+ logic_error& operator=(const logic_error&) = default;
+#endif
+
+ virtual ~logic_error() _GLIBCXX_TXN_SAFE_DYN _GLIBCXX_NOTHROW;
+
+ /** Returns a C-style character string describing the general cause of
+ * the current error (the same string passed to the ctor). */
+ virtual const char*
+ what() const _GLIBCXX_TXN_SAFE_DYN _GLIBCXX_NOTHROW;
+#endif
+
+# ifdef _GLIBCXX_TM_TS_INTERNAL
+ friend void*
+ ::_txnal_logic_error_get_msg(void* e);
+# endif
+ };
+
+ /** Thrown by the library, or by you, to report domain errors (domain in
+ * the mathematical sense). */
+ class domain_error : public logic_error
+ {
+ public:
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ constexpr explicit domain_error(const string& __arg) _GLIBCXX_TXN_SAFE
+ : logic_error(__arg) { }
+ constexpr explicit domain_error(const char* __arg) _GLIBCXX_TXN_SAFE
+ : logic_error(__arg) { }
+ constexpr domain_error(const domain_error&) = default;
+ constexpr domain_error& operator=(const domain_error&) = default;
+ constexpr domain_error(domain_error&&) = default;
+ constexpr domain_error& operator=(domain_error&&) = default;
+ constexpr virtual ~domain_error() _GLIBCXX_NOTHROW { }
+#else
+ explicit domain_error(const string& __arg) _GLIBCXX_TXN_SAFE;
+#if __cplusplus >= 201103L
+ explicit domain_error(const char*) _GLIBCXX_TXN_SAFE;
+ domain_error(const domain_error&) = default;
+ domain_error& operator=(const domain_error&) = default;
+ domain_error(domain_error&&) = default;
+ domain_error& operator=(domain_error&&) = default;
+#endif
+ virtual ~domain_error() _GLIBCXX_NOTHROW;
+#endif
+ };
+
+ /** Thrown to report invalid arguments to functions. */
+ class invalid_argument : public logic_error
+ {
+ public:
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ constexpr explicit invalid_argument(const string& __arg) _GLIBCXX_TXN_SAFE
+ : logic_error(__arg) { }
+ constexpr explicit invalid_argument(const char* __arg) _GLIBCXX_TXN_SAFE
+ : logic_error(__arg) { }
+ constexpr invalid_argument(const invalid_argument&) = default;
+ constexpr invalid_argument& operator=(const invalid_argument&) = default;
+ constexpr invalid_argument(invalid_argument&&) = default;
+ constexpr invalid_argument& operator=(invalid_argument&&) = default;
+ constexpr virtual ~invalid_argument() _GLIBCXX_NOTHROW { }
+#else
+ explicit invalid_argument(const string& __arg) _GLIBCXX_TXN_SAFE;
+#if __cplusplus >= 201103L
+ explicit invalid_argument(const char*) _GLIBCXX_TXN_SAFE;
+ invalid_argument(const invalid_argument&) = default;
+ invalid_argument& operator=(const invalid_argument&) = default;
+ invalid_argument(invalid_argument&&) = default;
+ invalid_argument& operator=(invalid_argument&&) = default;
+#endif
+ virtual ~invalid_argument() _GLIBCXX_NOTHROW;
+#endif
+ };
+
+ /** Thrown when an object is constructed that would exceed its maximum
+ * permitted size (e.g., a basic_string instance). */
+ class length_error : public logic_error
+ {
+ public:
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ constexpr explicit length_error(const string& __arg) _GLIBCXX_TXN_SAFE
+ : logic_error(__arg) { }
+ constexpr explicit length_error(const char* __arg) _GLIBCXX_TXN_SAFE
+ : logic_error(__arg) { }
+ constexpr length_error(const length_error&) = default;
+ constexpr length_error& operator=(const length_error&) = default;
+ constexpr length_error(length_error&&) = default;
+ constexpr length_error& operator=(length_error&&) = default;
+ constexpr virtual ~length_error() _GLIBCXX_NOTHROW { }
+#else
+ explicit length_error(const string& __arg) _GLIBCXX_TXN_SAFE;
+#if __cplusplus >= 201103L
+ explicit length_error(const char*) _GLIBCXX_TXN_SAFE;
+ length_error(const length_error&) = default;
+ length_error& operator=(const length_error&) = default;
+ length_error(length_error&&) = default;
+ length_error& operator=(length_error&&) = default;
+#endif
+ virtual ~length_error() _GLIBCXX_NOTHROW;
+#endif
+ };
+
+ /** This represents an argument whose value is not within the expected
+ * range (e.g., boundary checks in basic_string). */
+ class out_of_range : public logic_error
+ {
+ public:
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ constexpr explicit out_of_range(const string& __arg) _GLIBCXX_TXN_SAFE
+ : logic_error(__arg) { }
+ constexpr explicit out_of_range(const char* __arg) _GLIBCXX_TXN_SAFE
+ : logic_error(__arg) { }
+ constexpr out_of_range(const out_of_range&) = default;
+ constexpr out_of_range& operator=(const out_of_range&) = default;
+ constexpr out_of_range(out_of_range&&) = default;
+ constexpr out_of_range& operator=(out_of_range&&) = default;
+ constexpr virtual ~out_of_range() _GLIBCXX_NOTHROW { }
+#else
+ explicit out_of_range(const string& __arg) _GLIBCXX_TXN_SAFE;
+#if __cplusplus >= 201103L
+ explicit out_of_range(const char*) _GLIBCXX_TXN_SAFE;
+ out_of_range(const out_of_range&) = default;
+ out_of_range& operator=(const out_of_range&) = default;
+ out_of_range(out_of_range&&) = default;
+ out_of_range& operator=(out_of_range&&) = default;
+#endif
+ virtual ~out_of_range() _GLIBCXX_NOTHROW;
+#endif
+ };
+
+ /** Runtime errors represent problems outside the scope of a program;
+ * they cannot be easily predicted and can generally only be caught as
+ * the program executes.
+ * @brief One of two subclasses of exception.
+ */
+ class runtime_error : public exception
+ {
+ __cow_string _M_msg;
+
+ public:
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ constexpr explicit
+ runtime_error(const string& __arg) _GLIBCXX_TXN_SAFE
+ : _M_msg(__arg) {}
+
+ constexpr explicit
+ runtime_error(const char* __arg) _GLIBCXX_TXN_SAFE
+ : _M_msg(__arg) {}
+
+ constexpr runtime_error(runtime_error&&) noexcept = default;
+ constexpr runtime_error& operator=(runtime_error&&) noexcept = default;
+ constexpr runtime_error(const runtime_error&) noexcept = default;
+ runtime_error& operator=(const runtime_error&) noexcept = default;
+
+ constexpr virtual ~runtime_error() _GLIBCXX_TXN_SAFE_DYN noexcept { }
+
+ constexpr virtual const char*
+ what() const _GLIBCXX_TXN_SAFE_DYN noexcept
+ {
+ return _M_msg.c_str();
+ }
+#else
+ /** Takes a character string describing the error. */
+ explicit
+ runtime_error(const string& __arg) _GLIBCXX_TXN_SAFE;
+
+#if __cplusplus >= 201103L
+ explicit
+ runtime_error(const char*) _GLIBCXX_TXN_SAFE;
+
+ runtime_error(runtime_error&&) noexcept;
+ runtime_error& operator=(runtime_error&&) noexcept;
+#endif
+
+#if _GLIBCXX_USE_CXX11_ABI || _GLIBCXX_DEFINE_STDEXCEPT_COPY_OPS
+ runtime_error(const runtime_error&) _GLIBCXX_NOTHROW;
+ runtime_error& operator=(const runtime_error&) _GLIBCXX_NOTHROW;
+#elif __cplusplus >= 201103L
+ runtime_error(const runtime_error&) = default;
+ runtime_error& operator=(const runtime_error&) = default;
+#endif
+
+ virtual ~runtime_error() _GLIBCXX_TXN_SAFE_DYN _GLIBCXX_NOTHROW;
+
+ /** Returns a C-style character string describing the general cause of
+ * the current error (the same string passed to the ctor). */
+ virtual const char*
+ what() const _GLIBCXX_TXN_SAFE_DYN _GLIBCXX_NOTHROW;
+#endif
+
+# ifdef _GLIBCXX_TM_TS_INTERNAL
+ friend void*
+ ::_txnal_runtime_error_get_msg(void* e);
+# endif
+ };
+
+ /** Thrown to indicate arithmetic overflow. */
+ class overflow_error : public runtime_error
+ {
+ public:
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ constexpr explicit overflow_error(const string& __arg) _GLIBCXX_TXN_SAFE
+ : runtime_error(__arg) { }
+ constexpr explicit overflow_error(const char* __arg) _GLIBCXX_TXN_SAFE
+ : runtime_error(__arg) { }
+ constexpr overflow_error(const overflow_error&) = default;
+ constexpr overflow_error& operator=(const overflow_error&) = default;
+ constexpr overflow_error(overflow_error&&) = default;
+ constexpr overflow_error& operator=(overflow_error&&) = default;
+ constexpr virtual ~overflow_error() noexcept { }
+#else
+ explicit overflow_error(const string& __arg) _GLIBCXX_TXN_SAFE;
+#if __cplusplus >= 201103L
+ explicit overflow_error(const char*) _GLIBCXX_TXN_SAFE;
+ overflow_error(const overflow_error&) = default;
+ overflow_error& operator=(const overflow_error&) = default;
+ overflow_error(overflow_error&&) = default;
+ overflow_error& operator=(overflow_error&&) = default;
+#endif
+ virtual ~overflow_error() _GLIBCXX_NOTHROW;
+#endif
+ };
+
+ /** Thrown to indicate arithmetic underflow. */
+ class underflow_error : public runtime_error
+ {
+ public:
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ constexpr explicit underflow_error(const string& __arg) _GLIBCXX_TXN_SAFE
+ : runtime_error(__arg) { }
+ constexpr explicit underflow_error(const char* __arg) _GLIBCXX_TXN_SAFE
+ : runtime_error(__arg) { }
+ constexpr underflow_error(const underflow_error&) = default;
+ constexpr underflow_error& operator=(const underflow_error&) = default;
+ constexpr underflow_error(underflow_error&&) = default;
+ constexpr underflow_error& operator=(underflow_error&&) = default;
+ constexpr virtual ~underflow_error() noexcept { }
+#else
+ explicit underflow_error(const string& __arg) _GLIBCXX_TXN_SAFE;
+#if __cplusplus >= 201103L
+ explicit underflow_error(const char*) _GLIBCXX_TXN_SAFE;
+ underflow_error(const underflow_error&) = default;
+ underflow_error& operator=(const underflow_error&) = default;
+ underflow_error(underflow_error&&) = default;
+ underflow_error& operator=(underflow_error&&) = default;
+#endif
+ virtual ~underflow_error() _GLIBCXX_NOTHROW;
+#endif
+ };
+
+ /// @} group exceptions
+
+_GLIBCXX_END_NAMESPACE_VERSION
+} // namespace
+
+#endif /* _STDEXCEPT_EXCEPT_H */
--- /dev/null
+// Function-Based Exception Support -*- C++ -*-
+
+// Copyright (C) 2001-2025 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+
+// Under Section 7 of GPL version 3, you are granted additional
+// permissions described in the GCC Runtime Library Exception, version
+// 3.1, as published by the Free Software Foundation.
+
+// You should have received a copy of the GNU General Public License and
+// a copy of the GCC Runtime Library Exception along with this program;
+// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
+// <http://www.gnu.org/licenses/>.
+
+/** @file bits/stdexcept_throw.h
+ * This is an internal header file, included by other library headers.
+ * Do not attempt to use it directly. @headername{stdexcept}
+ */
+
+//
+// ISO C++ 14882: 19.1 Exception classes
+//
+
+#include <bits/c++config.h>
+#include <bits/exception_defines.h>
+
+#if (_GLIBCXX_HOSTED && __cpp_exceptions && __cplusplus > 202302L \
+ && __cpp_constexpr_exceptions >= 202411L)
+// This is a complicated case. Classes like std::logic_error
+// are defined in <stdexcept> but need std::string and <string>
+// needs __throw_logic_error and a few others. So, for C++26
+// constant expression we need to forward declare the constexpr
+// __throw_logic_error etc. functions when included recursively
+// from <string> and then at the end of that header make sure
+// <stdexcept> is included and define those.
+// If <string> hasn't been included yet, include it at the end
+// of this header and that will arrange for all these to be
+// defined.
+#if defined(_GLIBCXX_STRING) || __glibcxx_exc_in_string == 2
+#ifdef __glibcxx_exc_in_string
+#include <bits/stdexcept_throwfwd.h>
+#else
+#include <bits/stdexcept_throwdef.h>
+#endif
+#endif
+#if !defined(_GLIBCXX_STRING) && __glibcxx_exc_in_string != 2
+#include <string>
+#endif
+#else
+#include <bits/stdexcept_throwfwd.h>
+#endif
--- /dev/null
+// Function-Based Exception Support -*- C++ -*-
+
+// Copyright (C) 2001-2025 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+
+// Under Section 7 of GPL version 3, you are granted additional
+// permissions described in the GCC Runtime Library Exception, version
+// 3.1, as published by the Free Software Foundation.
+
+// You should have received a copy of the GNU General Public License and
+// a copy of the GCC Runtime Library Exception along with this program;
+// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
+// <http://www.gnu.org/licenses/>.
+
+/** @file bits/stdexcept_throwdef.h
+ * This is an internal header file, included by other library headers.
+ * Do not attempt to use it directly. @headername{stdexcept}
+ */
+
+//
+// ISO C++ 14882: 19.1 Exception classes
+//
+
+#ifndef _STDEXCEPT_THROWDEF_H
+#define _STDEXCEPT_THROWDEF_H 1
+
+#include <bits/c++config.h>
+#include <bits/exception_defines.h>
+#if (_GLIBCXX_HOSTED && __cpp_exceptions && __cplusplus > 202302L \
+ && __cpp_constexpr_exceptions >= 202411L)
+
+namespace std _GLIBCXX_VISIBILITY(default)
+{
+_GLIBCXX_BEGIN_NAMESPACE_VERSION
+
+ // Helpers for exception objects in <stdexcept>
+ namespace __detail
+ {
+ extern "C"
+ {
+ [[noreturn, __gnu__::__cold__]] void
+ _ZSt19__throw_logic_errorPKc(const char*);
+
+ [[noreturn, __gnu__::__cold__]] void
+ _ZSt20__throw_domain_errorPKc(const char*);
+
+ [[noreturn, __gnu__::__cold__]] void
+ _ZSt24__throw_invalid_argumentPKc(const char*);
+
+ [[noreturn, __gnu__::__cold__]] void
+ _ZSt20__throw_length_errorPKc(const char*);
+
+ [[noreturn, __gnu__::__cold__]] void
+ _ZSt20__throw_out_of_rangePKc(const char*);
+
+ [[noreturn, __gnu__::__cold__]]
+ [[__gnu__::__format__(__gnu_printf__, 1, 2)]] void
+ _ZSt24__throw_out_of_range_fmtPKcz(const char*, ...);
+
+ [[noreturn, __gnu__::__cold__]] void
+ _ZSt21__throw_runtime_errorPKc(const char*);
+
+ [[noreturn, __gnu__::__cold__]] void
+ _ZSt22__throw_overflow_errorPKc(const char*);
+
+ [[noreturn, __gnu__::__cold__]] void
+ _ZSt23__throw_underflow_errorPKc(const char*);
+ }
+ } // namespace __detail
+
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_logic_error(const char* __s)
+ {
+ if consteval {
+ throw logic_error(__s);
+ } else {
+ __detail::_ZSt19__throw_logic_errorPKc(__s);
+ }
+ }
+
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_domain_error(const char* __s)
+ {
+ if consteval {
+ throw domain_error(__s);
+ } else {
+ __detail::_ZSt20__throw_domain_errorPKc(__s);
+ }
+ }
+
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_invalid_argument(const char* __s)
+ {
+ if consteval {
+ throw invalid_argument(__s);
+ } else {
+ __detail::_ZSt24__throw_invalid_argumentPKc(__s);
+ }
+ }
+
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_length_error(const char* __s)
+ {
+ if consteval {
+ throw length_error(__s);
+ } else {
+ __detail::_ZSt20__throw_length_errorPKc(__s);
+ }
+ }
+
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_out_of_range(const char* __s)
+ {
+ if consteval {
+ throw out_of_range(__s);
+ } else {
+ __detail::_ZSt20__throw_out_of_rangePKc(__s);
+ }
+ }
+
+ template <typename... _Args>
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_out_of_range_fmt(const char* __s, _Args... __args)
+ {
+ if consteval {
+ throw out_of_range(__s);
+ } else {
+ __detail::_ZSt24__throw_out_of_range_fmtPKcz(__s, __args...);
+ }
+ }
+
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_runtime_error(const char* __s)
+ {
+ if consteval {
+ throw runtime_error(__s);
+ } else {
+ __detail::_ZSt21__throw_runtime_errorPKc(__s);
+ }
+ }
+
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_overflow_error(const char* __s)
+ {
+ if consteval {
+ throw overflow_error(__s);
+ } else {
+ __detail::_ZSt22__throw_overflow_errorPKc(__s);
+ }
+ }
+
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_underflow_error(const char* __s)
+ {
+ if consteval {
+ throw underflow_error(__s);
+ } else {
+ __detail::_ZSt23__throw_underflow_errorPKc(__s);
+ }
+ }
+
+_GLIBCXX_END_NAMESPACE_VERSION
+} // namespace
+
+#endif
+
+#endif
--- /dev/null
+// Function-Based Exception Support -*- C++ -*-
+
+// Copyright (C) 2001-2025 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 3, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+
+// Under Section 7 of GPL version 3, you are granted additional
+// permissions described in the GCC Runtime Library Exception, version
+// 3.1, as published by the Free Software Foundation.
+
+// You should have received a copy of the GNU General Public License and
+// a copy of the GCC Runtime Library Exception along with this program;
+// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
+// <http://www.gnu.org/licenses/>.
+
+/** @file bits/stdexcept_throwfwd.h
+ * This is an internal header file, included by other library headers.
+ * Do not attempt to use it directly. @headername{stdexcept}
+ */
+
+//
+// ISO C++ 14882: 19.1 Exception classes
+//
+
+#ifndef _STDEXCEPT_THROWFWD_H
+#define _STDEXCEPT_THROWFWD_H 1
+
+#include <bits/c++config.h>
+#include <bits/exception_defines.h>
+
+namespace std _GLIBCXX_VISIBILITY(default)
+{
+_GLIBCXX_BEGIN_NAMESPACE_VERSION
+
+#if _GLIBCXX_HOSTED
+#if (__cpp_exceptions && __cplusplus > 202302L \
+ && __cpp_constexpr_exceptions >= 202411L)
+ // Helper for exception objects in <stdexcept>
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_logic_error(const char*);
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_domain_error(const char*);
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_invalid_argument(const char*);
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_length_error(const char*);
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_out_of_range(const char*);
+ template <typename... _Args>
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_out_of_range_fmt(const char* __s, _Args... __args);
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_runtime_error(const char*);
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_overflow_error(const char*);
+ [[noreturn, __gnu__::__always_inline__, __gnu__::__cold__]] constexpr void
+ __throw_underflow_error(const char*);
+#else
+ // Helpers for exception objects in <stdexcept>
+ void
+ __throw_logic_error(const char*) __attribute__((__noreturn__,__cold__));
+
+ void
+ __throw_domain_error(const char*) __attribute__((__noreturn__,__cold__));
+
+ void
+ __throw_invalid_argument(const char*) __attribute__((__noreturn__,__cold__));
+
+ void
+ __throw_length_error(const char*) __attribute__((__noreturn__,__cold__));
+
+ void
+ __throw_out_of_range(const char*) __attribute__((__noreturn__,__cold__));
+
+ void
+ __throw_out_of_range_fmt(const char*, ...)
+ __attribute__((__noreturn__,__cold__,__format__(__gnu_printf__, 1, 2)));
+
+ void
+ __throw_runtime_error(const char*) __attribute__((__noreturn__,__cold__));
+
+ void
+ __throw_overflow_error(const char*) __attribute__((__noreturn__,__cold__));
+
+ void
+ __throw_underflow_error(const char*) __attribute__((__noreturn__,__cold__));
+#endif
+
+#else // ! HOSTED
+
+ __attribute__((__noreturn__)) inline void
+ __throw_invalid_argument(const char*)
+ { std::__terminate(); }
+
+ __attribute__((__noreturn__)) inline void
+ __throw_out_of_range(const char*)
+ { std::__terminate(); }
+
+ __attribute__((__noreturn__)) inline void
+ __throw_out_of_range_fmt(const char*, ...)
+ { std::__terminate(); }
+
+ __attribute__((__noreturn__)) inline void
+ __throw_runtime_error(const char*)
+ { std::__terminate(); }
+
+ __attribute__((__noreturn__)) inline void
+ __throw_overflow_error(const char*)
+ { std::__terminate(); }
+
+#endif // HOSTED
+
+_GLIBCXX_END_NAMESPACE_VERSION
+} // namespace
+
+#endif
#define _STL_ALGOBASE_H 1
#include <bits/c++config.h>
-#include <bits/functexcept.h>
#include <bits/cpp_type_traits.h>
#include <ext/type_traits.h>
#include <ext/numeric_traits.h>
#ifndef _STL_MAP_H
#define _STL_MAP_H 1
-#include <bits/functexcept.h>
+#include <bits/stdexcept_throw.h>
#include <bits/concept_check.h>
#if __cplusplus >= 201103L
#include <initializer_list>
#define _STL_VECTOR_H 1
#include <bits/stl_iterator_base_funcs.h>
-#include <bits/functexcept.h>
+#include <bits/stdexcept_throw.h>
#include <bits/concept_check.h>
#if __cplusplus >= 201103L
#include <initializer_list>
ftms = {
name = constexpr_exceptions;
- // TODO Remove when PR121114 is resolved
- no_stdname = true;
values = {
- v = 1; // TODO 202411;
+ v = 202502;
cxxmin = 26;
extra_cond = "__cpp_constexpr_exceptions >= 202411L";
};
#if !defined(__cpp_lib_constexpr_exceptions)
# if (__cplusplus > 202302L) && (__cpp_constexpr_exceptions >= 202411L)
-# define __glibcxx_constexpr_exceptions 1L
+# define __glibcxx_constexpr_exceptions 202502L
# if defined(__glibcxx_want_all) || defined(__glibcxx_want_constexpr_exceptions)
+# define __cpp_lib_constexpr_exceptions 202502L
# endif
# endif
#endif /* !defined(__cpp_lib_constexpr_exceptions) */
#include <stdexcept>
#include <new>
#include <initializer_list>
-#include <bits/functexcept.h>
+#include <bits/exception_defines.h>
#include <bits/functional_hash.h>
#include <bits/enable_special_members.h>
#include <bits/move.h>
#include <bits/requires_hosted.h> // GNU extensions are currently omitted
#include <utility> // For std::pair.
-#include <bits/functexcept.h> // For __throw_bad_alloc().
+#include <bits/new_throw.h> // For __throw_bad_alloc().
#include <bits/stl_function.h> // For greater_equal, and less_equal.
#include <new> // For operator new.
#include <debug/debug.h> // _GLIBCXX_DEBUG_ASSERT
#include <exception>
#include <bits/gthr.h>
-#include <bits/functexcept.h>
+#include <bits/exception_defines.h>
#include <bits/cpp_type_traits.h>
#include <ext/type_traits.h>
#include <bits/requires_hosted.h> // GNU extensions are currently omitted
#include <stdexcept>
-#include <bits/functexcept.h>
+#include <bits/stdexcept_throw.h>
#include <ext/alloc_traits.h>
namespace __gnu_cxx _GLIBCXX_VISIBILITY(default)
#include <cstdlib>
#include <cstddef>
#include <new>
-#include <bits/functexcept.h>
+#include <bits/new_throw.h>
#include <bits/move.h>
#if __cplusplus >= 201103L
#include <type_traits>
#include <new>
#include <cstdlib>
-#include <bits/functexcept.h>
+#include <bits/new_throw.h>
#include <ext/atomicity.h>
#include <bits/move.h>
#if __cplusplus >= 201103L
#include <bits/c++config.h>
#include <cstdlib>
#include <new>
-#include <bits/functexcept.h>
+#include <bits/new_throw.h>
#include <ext/atomicity.h>
#include <ext/concurrence.h>
#include <bits/move.h>
#include <cstdio>
#include <ostream>
-#include <bits/functexcept.h>
+#include <bits/stdexcept_throw.h>
#include <ext/algorithm> // For copy_n and lexicographical_compare_3way
#include <ext/memory> // For uninitialized_copy_n
#include <bits/c++config.h>
#include <ext/numeric_traits.h>
-#include <bits/functexcept.h>
+#include <bits/stdexcept_throw.h>
#include <cstdlib>
#include <cwchar>
#include <cstdio>
#include <ostream>
#include <stdexcept>
#include <utility>
-#include <bits/functexcept.h>
+#include <bits/new_throw.h>
+#include <bits/stdexcept_throw.h>
#include <bits/move.h>
#if __cplusplus >= 201103L
# include <functional>
#include <ext/vstring_fwd.h>
#include <debug/debug.h>
#include <bits/stl_function.h> // For less
-#include <bits/functexcept.h>
+#include <bits/stdexcept_throw.h>
#include <bits/localefwd.h>
#include <bits/ostream_insert.h>
#include <bits/stl_iterator.h>
#include <initializer_list>
#include <type_traits>
-#include <bits/functexcept.h>
+#include <bits/stdexcept_throw.h>
#include <bits/stl_algobase.h>
#include <bits/range_access.h> // std::begin, std::end etc.
#include <bits/utility.h> // std::index_sequence, std::tuple_size
#pragma GCC system_header
#endif
-#include <bits/functexcept.h> // For invalid_argument, out_of_range,
- // overflow_error
+#include <bits/stdexcept_throw.h> // For invalid_argument, out_of_range,
+ // overflow_error
#include <bits/stl_algobase.h> // For std::fill
#if _GLIBCXX_HOSTED
#include <bits/requires_hosted.h> // containers are hosted only
+#include <bits/stdexcept_throw.h>
#include <bits/stl_algobase.h>
#include <bits/allocator.h>
#include <bits/stl_construct.h>
#define __glibcxx_want_expected
#define __glibcxx_want_freestanding_expected
#define __glibcxx_want_constrained_equality
+#define __glibcxx_want_constexpr_exceptions
#include <bits/version.h>
#ifdef __cpp_lib_expected // C++ >= 23 && __cpp_concepts >= 202002L
template<typename _Er>
class bad_expected_access;
+#if __cpp_lib_constexpr_exceptions >= 202502L
+#define _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS constexpr
+#else
+#define _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS
+#endif
+
template<>
class bad_expected_access<void> : public exception
{
protected:
- bad_expected_access() noexcept { }
+ _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS bad_expected_access() noexcept { }
+ _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS
bad_expected_access(const bad_expected_access&) noexcept = default;
+ _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS
bad_expected_access(bad_expected_access&&) noexcept = default;
+ _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS
bad_expected_access& operator=(const bad_expected_access&) noexcept = default;
+ _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS
bad_expected_access& operator=(bad_expected_access&&) noexcept = default;
+ _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS
~bad_expected_access() = default;
public:
[[nodiscard]]
- const char*
+ _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS const char*
what() const noexcept override
{ return "bad access to std::expected without expected value"; }
};
template<typename _Er>
class bad_expected_access : public bad_expected_access<void> {
public:
- explicit
+ _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS explicit
bad_expected_access(_Er __e) : _M_unex(std::move(__e)) { }
// XXX const char* what() const noexcept override;
[[nodiscard]]
- _Er&
+ _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS _Er&
error() & noexcept
{ return _M_unex; }
[[nodiscard]]
- const _Er&
+ _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS const _Er&
error() const & noexcept
{ return _M_unex; }
[[nodiscard]]
- _Er&&
+ _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS _Er&&
error() && noexcept
{ return std::move(_M_unex); }
[[nodiscard]]
- const _Er&&
+ _GLIBCXX_CONSTEXPR_BAD_EXPECTED_ACCESS const _Er&&
error() const && noexcept
{ return std::move(_M_unex); }
#include <ranges> // views::zip
#include <type_traits>
#include <vector>
-#include <bits/functexcept.h>
+#include <bits/stdexcept_throw.h>
#include <bits/stl_algo.h>
#include <bits/stl_function.h> // less
#include <bits/stl_pair.h>
#include <optional>
#include <type_traits>
#include <vector>
-#include <bits/functexcept.h>
#include <bits/stl_algo.h>
#include <bits/stl_function.h> // less
#include <bits/stl_pair.h>
#define __glibcxx_want_format
#define __glibcxx_want_format_ranges
#define __glibcxx_want_format_uchar
+#define __glibcxx_want_constexpr_exceptions
#include <bits/version.h>
#ifdef __cpp_lib_format // C++ >= 20 && HOSTED
formatter& operator=(const formatter&) = delete;
};
+#if __cpp_lib_constexpr_exceptions >= 202502L
+#define _GLIBCXX_CONSTEXPR_FORMAT_ERROR constexpr
+#else
+#define _GLIBCXX_CONSTEXPR_FORMAT_ERROR
+#endif
+
// [format.error], class format_error
class format_error : public runtime_error
{
public:
- explicit format_error(const string& __what) : runtime_error(__what) { }
- explicit format_error(const char* __what) : runtime_error(__what) { }
+ _GLIBCXX_CONSTEXPR_FORMAT_ERROR explicit format_error(const string& __what)
+ : runtime_error(__what) { }
+ _GLIBCXX_CONSTEXPR_FORMAT_ERROR explicit format_error(const char* __what)
+ : runtime_error(__what) { }
};
/// @cond undocumented
__throw_format_error(const char* __what)
{ _GLIBCXX_THROW_OR_ABORT(format_error(__what)); }
+#undef _GLIBCXX_CONSTEXPR_FORMAT_ERROR
+
namespace __format
{
// XXX use named functions for each constexpr error?
#endif
#include <bits/requires_hosted.h> // concurrency
+#include <bits/functexcept.h>
#if __cplusplus < 201103L
# include <bits/c++0x_warning.h>
#ifdef __glibcxx_inplace_vector // C++ >= 26
#include <compare>
#include <initializer_list>
+#include <bits/stdexcept_throw.h>
#include <bits/range_access.h>
#include <bits/ranges_base.h> // borrowed_iterator_t, __detail::__container_compatible_range
#include <bits/ranges_util.h> // subrange
#define __glibcxx_want_optional
#define __glibcxx_want_optional_range_support
#define __glibcxx_want_constrained_equality
+#define __glibcxx_want_constexpr_exceptions
#include <bits/version.h>
#ifdef __cpp_lib_optional // C++ >= 17
bad_optional_access() = default;
virtual ~bad_optional_access() = default;
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ constexpr
+#endif
const char* what() const noexcept override
{ return "bad optional access"; }
};
// XXX Does not belong here.
- [[__noreturn__]] inline void
+ [[__noreturn__]]
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ constexpr
+#else
+ inline
+#endif
+ void
__throw_bad_optional_access()
{ _GLIBCXX_THROW_OR_ABORT(bad_optional_access()); }
#include <bits/chrono.h>
#include <bits/error_constants.h>
+#include <bits/new_throw.h>
#include <bits/functexcept.h>
#include <bits/move.h> // move, __exchange
#include <bits/std_mutex.h> // defer_lock_t
#include <exception>
#include <string>
+#include <bits/stdexcept_except.h>
namespace std _GLIBCXX_VISIBILITY(default)
{
_GLIBCXX_BEGIN_NAMESPACE_VERSION
-#if _GLIBCXX_USE_DUAL_ABI
-#if _GLIBCXX_USE_CXX11_ABI
- // Emulates an old COW string when the new std::string is in use.
- struct __cow_string
- {
- union {
- const char* _M_p;
- char _M_bytes[sizeof(const char*)];
- };
-
- __cow_string();
- __cow_string(const std::string&);
- __cow_string(const char*, size_t);
- __cow_string(const __cow_string&) _GLIBCXX_NOTHROW;
- __cow_string& operator=(const __cow_string&) _GLIBCXX_NOTHROW;
- ~__cow_string();
-#if __cplusplus >= 201103L
- __cow_string(__cow_string&&) noexcept;
- __cow_string& operator=(__cow_string&&) noexcept;
-#endif
- };
-
- typedef basic_string<char> __sso_string;
-#else // _GLIBCXX_USE_CXX11_ABI
- typedef basic_string<char> __cow_string;
-
- // Emulates a new SSO string when the old std::string is in use.
- struct __sso_string
- {
- struct __str
- {
- const char* _M_p;
- size_t _M_string_length;
- char _M_local_buf[16];
- };
-
- union {
- __str _M_s;
- char _M_bytes[sizeof(__str)];
- };
-
- __sso_string() _GLIBCXX_NOTHROW;
- __sso_string(const std::string&);
- __sso_string(const char*, size_t);
- __sso_string(const __sso_string&);
- __sso_string& operator=(const __sso_string&);
- ~__sso_string();
-#if __cplusplus >= 201103L
- __sso_string(__sso_string&&) noexcept;
- __sso_string& operator=(__sso_string&&) noexcept;
-#endif
- };
-#endif // _GLIBCXX_USE_CXX11_ABI
-#else // _GLIBCXX_USE_DUAL_ABI
- typedef basic_string<char> __sso_string;
- typedef basic_string<char> __cow_string;
-#endif
-
/**
* @addtogroup exceptions
* @{
*/
- /** Logic errors represent problems in the internal logic of a program;
- * in theory, these are preventable, and even detectable before the
- * program runs (e.g., violations of class invariants).
- * @brief One of two subclasses of exception.
- */
- class logic_error : public exception
- {
- __cow_string _M_msg;
-
- public:
- /** Takes a character string describing the error. */
- explicit
- logic_error(const string& __arg) _GLIBCXX_TXN_SAFE;
-
-#if __cplusplus >= 201103L
- explicit
- logic_error(const char*) _GLIBCXX_TXN_SAFE;
-
- logic_error(logic_error&&) noexcept;
- logic_error& operator=(logic_error&&) noexcept;
-#endif
-
-#if _GLIBCXX_USE_CXX11_ABI || _GLIBCXX_DEFINE_STDEXCEPT_COPY_OPS
- logic_error(const logic_error&) _GLIBCXX_NOTHROW;
- logic_error& operator=(const logic_error&) _GLIBCXX_NOTHROW;
-#elif __cplusplus >= 201103L
- logic_error(const logic_error&) = default;
- logic_error& operator=(const logic_error&) = default;
-#endif
-
- virtual ~logic_error() _GLIBCXX_TXN_SAFE_DYN _GLIBCXX_NOTHROW;
-
- /** Returns a C-style character string describing the general cause of
- * the current error (the same string passed to the ctor). */
- virtual const char*
- what() const _GLIBCXX_TXN_SAFE_DYN _GLIBCXX_NOTHROW;
-
-# ifdef _GLIBCXX_TM_TS_INTERNAL
- friend void*
- ::_txnal_logic_error_get_msg(void* e);
-# endif
- };
-
- /** Thrown by the library, or by you, to report domain errors (domain in
- * the mathematical sense). */
- class domain_error : public logic_error
- {
- public:
- explicit domain_error(const string& __arg) _GLIBCXX_TXN_SAFE;
-#if __cplusplus >= 201103L
- explicit domain_error(const char*) _GLIBCXX_TXN_SAFE;
- domain_error(const domain_error&) = default;
- domain_error& operator=(const domain_error&) = default;
- domain_error(domain_error&&) = default;
- domain_error& operator=(domain_error&&) = default;
-#endif
- virtual ~domain_error() _GLIBCXX_NOTHROW;
- };
-
- /** Thrown to report invalid arguments to functions. */
- class invalid_argument : public logic_error
- {
- public:
- explicit invalid_argument(const string& __arg) _GLIBCXX_TXN_SAFE;
-#if __cplusplus >= 201103L
- explicit invalid_argument(const char*) _GLIBCXX_TXN_SAFE;
- invalid_argument(const invalid_argument&) = default;
- invalid_argument& operator=(const invalid_argument&) = default;
- invalid_argument(invalid_argument&&) = default;
- invalid_argument& operator=(invalid_argument&&) = default;
-#endif
- virtual ~invalid_argument() _GLIBCXX_NOTHROW;
- };
-
- /** Thrown when an object is constructed that would exceed its maximum
- * permitted size (e.g., a basic_string instance). */
- class length_error : public logic_error
- {
- public:
- explicit length_error(const string& __arg) _GLIBCXX_TXN_SAFE;
-#if __cplusplus >= 201103L
- explicit length_error(const char*) _GLIBCXX_TXN_SAFE;
- length_error(const length_error&) = default;
- length_error& operator=(const length_error&) = default;
- length_error(length_error&&) = default;
- length_error& operator=(length_error&&) = default;
-#endif
- virtual ~length_error() _GLIBCXX_NOTHROW;
- };
-
- /** This represents an argument whose value is not within the expected
- * range (e.g., boundary checks in basic_string). */
- class out_of_range : public logic_error
- {
- public:
- explicit out_of_range(const string& __arg) _GLIBCXX_TXN_SAFE;
-#if __cplusplus >= 201103L
- explicit out_of_range(const char*) _GLIBCXX_TXN_SAFE;
- out_of_range(const out_of_range&) = default;
- out_of_range& operator=(const out_of_range&) = default;
- out_of_range(out_of_range&&) = default;
- out_of_range& operator=(out_of_range&&) = default;
-#endif
- virtual ~out_of_range() _GLIBCXX_NOTHROW;
- };
-
- /** Runtime errors represent problems outside the scope of a program;
- * they cannot be easily predicted and can generally only be caught as
- * the program executes.
- * @brief One of two subclasses of exception.
- */
- class runtime_error : public exception
- {
- __cow_string _M_msg;
-
- public:
- /** Takes a character string describing the error. */
- explicit
- runtime_error(const string& __arg) _GLIBCXX_TXN_SAFE;
-
-#if __cplusplus >= 201103L
- explicit
- runtime_error(const char*) _GLIBCXX_TXN_SAFE;
-
- runtime_error(runtime_error&&) noexcept;
- runtime_error& operator=(runtime_error&&) noexcept;
-#endif
-
-#if _GLIBCXX_USE_CXX11_ABI || _GLIBCXX_DEFINE_STDEXCEPT_COPY_OPS
- runtime_error(const runtime_error&) _GLIBCXX_NOTHROW;
- runtime_error& operator=(const runtime_error&) _GLIBCXX_NOTHROW;
-#elif __cplusplus >= 201103L
- runtime_error(const runtime_error&) = default;
- runtime_error& operator=(const runtime_error&) = default;
-#endif
-
- virtual ~runtime_error() _GLIBCXX_TXN_SAFE_DYN _GLIBCXX_NOTHROW;
-
- /** Returns a C-style character string describing the general cause of
- * the current error (the same string passed to the ctor). */
- virtual const char*
- what() const _GLIBCXX_TXN_SAFE_DYN _GLIBCXX_NOTHROW;
-
-# ifdef _GLIBCXX_TM_TS_INTERNAL
- friend void*
- ::_txnal_runtime_error_get_msg(void* e);
-# endif
- };
-
/** Thrown to indicate range errors in internal computations. */
class range_error : public runtime_error
{
public:
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ constexpr explicit range_error(const string& __arg) _GLIBCXX_TXN_SAFE
+ : runtime_error(__arg) { }
+ constexpr explicit range_error(const char* __arg) _GLIBCXX_TXN_SAFE
+ : runtime_error(__arg) { }
+ constexpr range_error(const range_error&) = default;
+ constexpr range_error& operator=(const range_error&) = default;
+ constexpr range_error(range_error&&) = default;
+ constexpr range_error& operator=(range_error&&) = default;
+ constexpr virtual ~range_error() noexcept { }
+#else
explicit range_error(const string& __arg) _GLIBCXX_TXN_SAFE;
#if __cplusplus >= 201103L
explicit range_error(const char*) _GLIBCXX_TXN_SAFE;
range_error& operator=(range_error&&) = default;
#endif
virtual ~range_error() _GLIBCXX_NOTHROW;
- };
-
- /** Thrown to indicate arithmetic overflow. */
- class overflow_error : public runtime_error
- {
- public:
- explicit overflow_error(const string& __arg) _GLIBCXX_TXN_SAFE;
-#if __cplusplus >= 201103L
- explicit overflow_error(const char*) _GLIBCXX_TXN_SAFE;
- overflow_error(const overflow_error&) = default;
- overflow_error& operator=(const overflow_error&) = default;
- overflow_error(overflow_error&&) = default;
- overflow_error& operator=(overflow_error&&) = default;
-#endif
- virtual ~overflow_error() _GLIBCXX_NOTHROW;
- };
-
- /** Thrown to indicate arithmetic underflow. */
- class underflow_error : public runtime_error
- {
- public:
- explicit underflow_error(const string& __arg) _GLIBCXX_TXN_SAFE;
-#if __cplusplus >= 201103L
- explicit underflow_error(const char*) _GLIBCXX_TXN_SAFE;
- underflow_error(const underflow_error&) = default;
- underflow_error& operator=(const underflow_error&) = default;
- underflow_error(underflow_error&&) = default;
- underflow_error& operator=(underflow_error&&) = default;
#endif
- virtual ~underflow_error() _GLIBCXX_NOTHROW;
};
/// @} group exceptions
#include <bits/requires_hosted.h> // containers
#include <bits/c++config.h>
+#define __glibcxx_exc_in_string 1
#include <bits/stringfwd.h>
#include <bits/char_traits.h>
#include <bits/allocator.h>
#include <bits/stl_iterator.h>
#include <bits/stl_function.h> // For less
#include <ext/numeric_traits.h>
+#include <bits/stdexcept_throw.h>
#include <bits/stl_algobase.h>
#include <bits/range_access.h>
#include <bits/basic_string.h>
#include <bits/basic_string.tcc>
+#if (_GLIBCXX_HOSTED && __cpp_exceptions && __cplusplus > 202302L \
+ && __cpp_constexpr_exceptions >= 202411L)
+#include <bits/stdexcept_except.h>
+#undef __glibcxx_exc_in_string
+#include <bits/stdexcept_throw.h>
+#else
+#undef __glibcxx_exc_in_string
+#endif
#define __glibcxx_want_algorithm_default_value_type
#define __glibcxx_want_allocator_traits_is_always_equal
#if __cplusplus >= 201703L
#include <bits/char_traits.h>
-#include <bits/functexcept.h>
+#ifndef __glibcxx_exc_in_string
+#define __glibcxx_exc_in_string 2
+#include <bits/stdexcept_throw.h>
+#endif
#include <bits/functional_hash.h>
#include <bits/range_access.h>
#include <bits/stl_algobase.h>
#include <bits/string_view.tcc>
+#if __glibcxx_exc_in_string == 2
+#undef __glibcxx_exc_in_string
+#if (_GLIBCXX_HOSTED && __cpp_exceptions && __cplusplus > 202302L \
+ && __cpp_constexpr_exceptions >= 202411L)
+#include <bits/stdexcept_throw.h>
+#endif
+#endif
+
#endif // __cplusplus <= 201402L
-#endif // _GLIBCXX_EXPERIMENTAL_STRING_VIEW
+#endif // _GLIBCXX_STRING_VIEW
#include <bits/alloc_traits.h>
#include <bits/allocator.h>
-#include <bits/functexcept.h>
#include <bits/std_mutex.h>
namespace std _GLIBCXX_VISIBILITY(default)
#define __glibcxx_want_freestanding_variant
#define __glibcxx_want_variant
#define __glibcxx_want_constrained_equality
+#define __glibcxx_want_constexpr_exceptions
#include <bits/version.h>
#ifdef __cpp_lib_variant // C++ >= 17
&& (is_swappable_v<_Types> && ...))>
swap(variant<_Types...>&, variant<_Types...>&) = delete;
- [[noreturn]] void __throw_bad_variant_access(unsigned);
+#if __cpp_lib_constexpr_exceptions >= 202502L
+#define _GLIBCXX_CONSTEXPR_BAD_VARIANT_ACCESS constexpr
+#else
+#define _GLIBCXX_CONSTEXPR_BAD_VARIANT_ACCESS
+#endif
+ [[noreturn]] _GLIBCXX_CONSTEXPR_BAD_VARIANT_ACCESS void
+ __throw_bad_variant_access(unsigned);
class bad_variant_access : public exception
{
public:
- bad_variant_access() noexcept { }
+ _GLIBCXX_CONSTEXPR_BAD_VARIANT_ACCESS bad_variant_access() noexcept { }
- const char* what() const noexcept override
+ _GLIBCXX_CONSTEXPR_BAD_VARIANT_ACCESS const char* what()
+ const noexcept override
{ return _M_reason; }
private:
// Must only be called with a string literal
+ _GLIBCXX_CONSTEXPR_BAD_VARIANT_ACCESS
bad_variant_access(const char* __reason) noexcept : _M_reason(__reason) { }
// Must point to a string with static storage duration:
const char* _M_reason = "bad variant access";
- friend void __throw_bad_variant_access([[maybe_unused]] unsigned __n)
+ friend _GLIBCXX_CONSTEXPR_BAD_VARIANT_ACCESS void
+ __throw_bad_variant_access([[maybe_unused]] unsigned __n)
{
[[maybe_unused]] static constexpr const char* __reasons[] = {
"std::get: wrong index for variant",
};
_GLIBCXX_THROW_OR_ABORT(bad_variant_access(__reasons[__n % 4u]));
}
+#undef _GLIBCXX_CONSTEXPR_BAD_VARIANT_ACCESS
};
template<typename... _Types>
#endif
#include <bits/requires_hosted.h> // TR1
+#include <bits/stdexcept_throw.h>
#include <bits/stl_algobase.h>
#endif
#include <bits/requires_hosted.h> // TR1
+#include <bits/stdexcept_throw.h>
#include <cmath>
#include <iosfwd> // std::basic_ostream
#include <ext/atomicity.h>
#include <ext/concurrence.h>
-#include <bits/functexcept.h>
#include <bits/stl_function.h> // std::less
#include <debug/debug.h>
#include <tr1/type_traits>
#include <vector>
#include <string>
#include <istream>
-#include <bits/functexcept.h>
+#include <bits/stdexcept_throw.h>
#include <bits/stl_algo.h> // For fill
#include <bits/cxxabi_forced.h>
#define __glibcxx_want_destroying_delete
#define __glibcxx_want_constexpr_new
#include <bits/version.h>
+#include <bits/new_except.h> // std::bad_alloc, std::bad_array_new_length
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wc++11-extensions" // scoped enum
namespace std
{
- /**
- * @brief Exception possibly thrown by @c new.
- * @ingroup exceptions
- *
- * @c bad_alloc (or classes derived from it) is used to report allocation
- * errors from the throwing forms of @c new. */
- class bad_alloc : public exception
- {
- public:
- _GLIBCXX26_CONSTEXPR bad_alloc() throw() { }
-
-#if __cplusplus >= 201103L
- _GLIBCXX26_CONSTEXPR bad_alloc(const bad_alloc&) = default;
- _GLIBCXX26_CONSTEXPR bad_alloc& operator=(const bad_alloc&) = default;
-#endif
-
-#if __cplusplus >= 202400L
- constexpr virtual ~bad_alloc() noexcept {}
-
- constexpr virtual const char* what() const noexcept
- {
- return "std::bad_alloc";
- }
-#else
- // This declaration is not useless:
- // http://gcc.gnu.org/onlinedocs/gcc-3.0.2/gcc_6.html#SEC118
- virtual ~bad_alloc() throw();
-
- // See comment in eh_exception.cc.
- virtual const char* what() const throw();
-#endif
- };
-
-#if __cplusplus >= 201103L
- class bad_array_new_length : public bad_alloc
- {
- public:
- _GLIBCXX26_CONSTEXPR bad_array_new_length() throw() { }
-
-#if __cplusplus >= 202400L
- constexpr virtual ~bad_array_new_length() noexcept {}
-
- constexpr virtual const char* what() const noexcept
- {
- return "std::bad_array_new_length";
- }
-#else
- // This declaration is not useless:
- // http://gcc.gnu.org/onlinedocs/gcc-3.0.2/gcc_6.html#SEC118
- virtual ~bad_array_new_length() throw();
-
- // See comment in eh_exception.cc.
- virtual const char* what() const throw();
-#endif
- };
-#endif
-
#if __cpp_aligned_new
enum class align_val_t: size_t {};
#endif
__cow_string();
__cow_string(const std::string& s);
+ __cow_string(const char*);
__cow_string(const char*, size_t n);
__cow_string(const __cow_string&) noexcept;
__cow_string& operator=(const __cow_string&) noexcept;
~__cow_string();
__cow_string(__cow_string&&) noexcept;
__cow_string& operator=(__cow_string&&) noexcept;
+ const char* c_str() const noexcept;
};
__cow_string::__cow_string() : _M_str() { }
__cow_string::__cow_string(const std::string& s) : _M_str(s) { }
+ __cow_string::__cow_string(const char* s) : _M_str(s) { }
+
__cow_string::__cow_string(const char* s, size_t n) : _M_str(s, n) { }
__cow_string::__cow_string(const __cow_string& s) noexcept
return *this;
}
+ const char*
+ __cow_string::c_str() const noexcept
+ {
+ return _M_str.c_str();
+ }
+
static_assert(sizeof(__cow_string) == sizeof(std::string),
"sizeof(std::string) has changed");
static_assert(alignof(__cow_string) == alignof(std::string),
// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
// <http://www.gnu.org/licenses/>.
-#include <bits/functexcept.h>
#include <cstdlib>
#include <exception>
#include <stdexcept>
#include <stdexcept>
#include <bits/regex_error.h>
-#include <bits/functexcept.h>
namespace std _GLIBCXX_VISIBILITY(default)
{
#include <stdarg.h>
#include <stddef.h>
-#include <bits/functexcept.h>
+#include <bits/stdexcept_throw.h>
namespace __gnu_cxx {
#include <system_error>
#include <cerrno>
#include <cxxabi_forced.h>
+#include <bits/functexcept.h>
#ifndef _GLIBCXX_USE_NANOSLEEP
# ifdef _GLIBCXX_HAVE_SLEEP
#include <cstdlib>
#include <cstring>
#include <locale.h>
-#include <bits/functexcept.h>
#if _GLIBCXX_HAVE_XLOCALE_H
# include <xlocale.h>
#endif
#include <exception>
-#ifdef __cpp_lib_constexpr_exceptions
-# error "Feature test macro for constexpr_exceptions should not be provided by <exception>"
+#ifndef __cpp_lib_constexpr_exceptions
+# error "Feature test macro for constexpr_exceptions is missing in <exception>"
+#elif __cpp_lib_constexpr_exceptions < 202502L
+# error "Feature test macro for constexpr_exceptions has wrong value in <exception>"
#endif
-
--- /dev/null
+// { dg-do preprocess { target c++26 } }
+// { dg-add-options no_pch }
+
+#include <stdexcept>
+
+#ifndef __cpp_lib_constexpr_exceptions
+# error "Feature test macro for constexpr_exceptions is missing in <stdexcept>"
+#elif __cpp_lib_constexpr_exceptions < 202502L
+# error "Feature test macro for constexpr_exceptions has wrong value in <stdexcept>"
+#endif
--- /dev/null
+// { dg-do compile { target c++26 } }
+
+#include <string>
+#include <stdexcept>
+#include <testsuite_hooks.h>
+
+template <typename T>
+constexpr bool test01()
+{
+ try
+ {
+ std::string s = "This is the first logic error";
+ throw T(s);
+ }
+ catch (const T &x)
+ {
+ VERIFY( std::string(x.what()) == "This is the first logic error" );
+ }
+ try
+ {
+ throw T("This is the second logic error");
+ }
+ catch (const std::logic_error &x)
+ {
+ VERIFY( std::string(x.what()) == "This is the second logic error" );
+ }
+ std::string s = "This is the third logic error";
+ T l(s);
+ try
+ {
+ throw T(l);
+ }
+ catch (const std::logic_error &x)
+ {
+ VERIFY( std::string(x.what()) == "This is the third logic error" );
+ }
+ VERIFY( std::string(l.what()) == "This is the third logic error" );
+ s = "This is the fourth logic error";
+ l = T(s);
+ try
+ {
+ throw T(std::move(l));
+ }
+ catch (const T &x)
+ {
+ VERIFY( std::string(x.what()) == "This is the fourth logic error" );
+ }
+ T l2(s);
+ l2 = T("This is the fifth logic error");
+ VERIFY( std::string(l2.what()) == "This is the fifth logic error" );
+ T l3("This is the sixth logic error");
+ VERIFY( std::string(l3.what()) == "This is the sixth logic error" );
+ l3 = l2;
+ VERIFY( std::string(l2.what()) == "This is the fifth logic error" );
+ VERIFY( std::string(l3.what()) == "This is the fifth logic error" );
+ l3 = T("This is the seventh logic error");
+ l2 = std::move(l3);
+ VERIFY( std::string(l2.what()) == "This is the seventh logic error" );
+ return true;
+}
+
+static_assert(test01<std::logic_error>());
+static_assert(test01<std::domain_error>());
+static_assert(test01<std::invalid_argument>());
+static_assert(test01<std::length_error>());
+static_assert(test01<std::out_of_range>());
+
+int main(void)
+{
+ test01<std::logic_error>();
+ test01<std::domain_error>();
+ test01<std::invalid_argument>();
+ test01<std::length_error>();
+ test01<std::out_of_range>();
+}
--- /dev/null
+// { dg-do compile { target c++26 } }
+
+#include <string>
+#include <stdexcept>
+#include <testsuite_hooks.h>
+
+template <typename T>
+constexpr bool test01()
+{
+ try
+ {
+ std::string s = "This is the first runtime error";
+ throw T(s);
+ }
+ catch (const T &x)
+ {
+ VERIFY( std::string(x.what()) == "This is the first runtime error" );
+ }
+ try
+ {
+ throw T("This is the second runtime error");
+ }
+ catch (const std::runtime_error &x)
+ {
+ VERIFY( std::string(x.what()) == "This is the second runtime error" );
+ }
+ std::string s = "This is the third runtime error";
+ T l(s);
+ try
+ {
+ throw T(l);
+ }
+ catch (const std::runtime_error &x)
+ {
+ VERIFY( std::string(x.what()) == "This is the third runtime error" );
+ }
+ VERIFY( std::string(l.what()) == "This is the third runtime error" );
+ s = "This is the fourth runtime error";
+ l = T(s);
+ try
+ {
+ throw T(std::move(l));
+ }
+ catch (const T &x)
+ {
+ VERIFY( std::string(x.what()) == "This is the fourth runtime error" );
+ }
+ T l2(s);
+ l2 = T("This is the fifth runtime error");
+ VERIFY( std::string(l2.what()) == "This is the fifth runtime error" );
+ T l3("This is the sixth runtime error");
+ VERIFY( std::string(l3.what()) == "This is the sixth runtime error" );
+ l3 = l2;
+ VERIFY( std::string(l2.what()) == "This is the fifth runtime error" );
+ VERIFY( std::string(l3.what()) == "This is the fifth runtime error" );
+ l3 = T("This is the seventh runtime error");
+ l2 = std::move(l3);
+ VERIFY( std::string(l2.what()) == "This is the seventh runtime error" );
+ return true;
+}
+
+static_assert(test01<std::runtime_error>());
+static_assert(test01<std::range_error>());
+static_assert(test01<std::overflow_error>());
+static_assert(test01<std::underflow_error>());
+
+int main(void)
+{
+ test01<std::runtime_error>();
+ test01<std::range_error>();
+ test01<std::overflow_error>();
+ test01<std::underflow_error>();
+}
{
std::allocator<long long> a;
auto n = std::size_t(-1) / (sizeof(long long) - 1);
- auto p = a.allocate(n); // { dg-error "constexpr" }
+ auto p = a.allocate(n); // { dg-error "constexpr" "" { target c++23_down } }
a.deallocate(p, n);
return true;
}
static_assert( test_pr105957() ); // { dg-error "non-constant" }
+// { dg-error "uncaught exception of type 'std::bad_array_new_length'" "" { target c++26 } 16 }
-// { dg-error "throw_bad_array_new_length" "" { target *-*-* } 0 }
+// { dg-error "throw_bad_array_new_length" "" { target c++23_down } 0 }
return true;
}
-void
+#if __cpp_lib_constexpr_exceptions >= 202502L
+constexpr
+#endif
+bool
test_value_throw()
{
std::expected<int, int> e1 = std::unexpected(9);
VERIFY( false );
} catch (const std::bad_expected_access<int>& e) {
VERIFY( e.error() == 9 );
+ long c = e.what()[0];
+ VERIFY( c == e.what()[0] );
}
try {
std::move(e1).value();
} catch (const std::bad_expected_access<int>& e) {
VERIFY( e.error() == 8 );
}
+ return true;
}
constexpr bool
test_has_value();
static_assert( test_value() );
test_value();
+#if __cpp_lib_constexpr_exceptions >= 202502L
+ static_assert( test_value_throw() );
+#endif
test_value_throw();
static_assert( test_error() );
test_error();
# error "Feature-test macro for freestanding expected has wrong value in <version>"
#endif
+#if __cplusplus > 202302L
+# ifndef __cpp_lib_constexpr_exceptions
+# error "Feature test macro for constexpr_exceptions is missing in <version>"
+# elif __cpp_lib_constexpr_exceptions < 202502L
+# error "Feature test macro for constexpr_exceptions has wrong value in <version>"
+# endif
+#endif
+
#undef __cpp_lib_expected
#undef __cpp_lib_freestanding_expected
+#undef __cpp_lib_constexpr_exceptions
#include <expected>
#ifndef __cpp_lib_expected
#elif __cpp_lib_freestanding_expected != 202311L
# error "Feature-test macro for freestanding expected has wrong value in <expected>"
#endif
+
+#if __cplusplus > 202302L
+# ifndef __cpp_lib_constexpr_exceptions
+# error "Feature test macro for constexpr_exceptions is missing in <expected>"
+# elif __cpp_lib_constexpr_exceptions < 202502L
+# error "Feature test macro for constexpr_exceptions has wrong value in <expected>"
+# endif
+#endif
// <http://www.gnu.org/licenses/>.
#include <optional>
+#include <testsuite_hooks.h>
struct value_type
{
int i;
};
+#if __cpp_lib_constexpr_exceptions >= 202502L
+void eat(int x)
+{
+}
+
+constexpr bool test01()
+{
+ enum outcome_type { nothrow, caught, bad_catch };
+
+ outcome_type outcome {};
+ std::optional<value_type> o = std::nullopt;
+
+ try
+ {
+ eat(o.value().i);
+ }
+ catch(std::bad_optional_access const& x)
+ {
+ outcome = caught;
+ long c = x.what()[0];
+ VERIFY( c == x.what()[0] );
+ }
+ catch(...)
+ { outcome = bad_catch; }
+
+ VERIFY( outcome == caught );
+ return true;
+}
+
+static_assert( test01() );
+#endif
+
int main()
{
constexpr std::optional<value_type> o { value_type { 51 } };
# elif __cpp_lib_optional_range_support != 202406L
# error "Feature test macro for optional range support has wrong value for C++26 in <version>"
# endif
+
+# ifndef __cpp_lib_constexpr_exceptions
+# error "Feature test macro for constexpr_exceptions is missing in <version>"
+# elif __cpp_lib_constexpr_exceptions < 202502L
+# error "Feature test macro for constexpr_exceptions has wrong value in <version>"
+# endif
#endif
#undef __cpp_lib_optional
#undef __cpp_lib_freestanding_optional
#undef __cpp_lib_optional_range_support
+#undef __cpp_lib_constexpr_exceptions
#include <optional>
#if __cplusplus >= 202302L
# if __cpp_lib_optional_range_support != 202406L
# error "Feature test macro for optional range support has wrong value for C++26 in <optional>"
# endif
+
+# ifndef __cpp_lib_constexpr_exceptions
+# error "Feature test macro for constexpr_exceptions is missing in <optional>"
+# elif __cpp_lib_constexpr_exceptions < 202502L
+# error "Feature test macro for constexpr_exceptions has wrong value in <optional>"
+# endif
#endif
# error "Feature test macro for variant has wrong value for C++20 in <variant>"
#endif
+#if __cpp_lib_constexpr_exceptions >= 202502L
+#include <string>
+#endif
#include <testsuite_hooks.h>
static_assert( test_assign() );
+#if __cpp_lib_constexpr_exceptions >= 202502L
+constexpr bool test_get()
+{
+ VERIFY(std::get<1>(std::variant<int, std::string>("a")) == "a");
+ VERIFY(std::get<std::string>(std::variant<int, std::string>("a")) == "a");
+ {
+ try
+ {
+ std::get<0>(std::variant<int, std::string>("a"));
+ }
+ catch (const std::bad_variant_access& x)
+ {
+ long c = x.what()[0];
+ VERIFY( c == x.what()[0] );
+ }
+ }
+ {
+ try
+ {
+ std::get<int>(std::variant<int, std::string>("a"));
+ }
+ catch (const std::bad_variant_access& x)
+ {
+ long c = x.what()[0];
+ VERIFY( c == x.what()[0] );
+ }
+ }
+ return true;
+}
+
+static_assert (test_get() );
+#endif
+
constexpr bool
test_emplace()
{
#endif
#endif
+#if __cplusplus > 202302L
+#ifndef __cpp_lib_constexpr_exceptions
+# error "Feature test macro for constexpr_exceptions is missing in <version>"
+#elif __cpp_lib_constexpr_exceptions < 202502L
+# error "Feature test macro for constexpr_exceptions has wrong value in <version>"
+#endif
+#endif
+
#undef __cpp_lib_variant
#undef __cpp_lib_freestanding_variant
+#undef __cpp_lib_constexpr_exceptions
#include <variant>
#if __cplusplus >= 202302L
# error "Feature test macro for freestanding std::variant has wrong value in <variant>"
#endif
#endif
+
+#if __cplusplus > 202302L
+#ifndef __cpp_lib_constexpr_exceptions
+# error "Feature test macro for constexpr_exceptions is missing in <variant>"
+#elif __cpp_lib_constexpr_exceptions < 202502L
+# error "Feature test macro for constexpr_exceptions has wrong value in <variant>"
+#endif
+#endif
v.reserve(N);
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
try
{
std::inplace_vector<T, N> v;
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
try
{
VERIFY( e4a == T(5) );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
try
{
VERIFY( z0.begin() == z0.end() );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if not consteval {
+#endif
try
{
std::inplace_vector<int, 2> ct(3);
{
}
+#ifndef __cpp_lib_constexpr_exceptions
}
#endif
+#endif
#ifdef __cpp_lib_constexpr_inplace_vector
#error remove the consteval check
VERIFY( z0.begin() == z0.end() );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if not consteval {
+#endif
try
{
std::inplace_vector<int, 2> ct(3, 11);
catch (std::bad_alloc const&)
{
}
+#ifndef __cpp_lib_constexpr_exceptions
}
#endif
+#endif
#ifdef __cpp_lib_constexpr_inplace_vector
#error remove the consteval check
VERIFY( z0.begin() == z0.end() );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if not consteval {
+#endif
try
{
std::inplace_vector<int, 2> ct{11, 22, 33};
catch (std::bad_alloc const&)
{
}
+#ifndef __cpp_lib_constexpr_exceptions
}
#endif
+#endif
#ifdef __cpp_lib_constexpr_inplace_vector
#error remove the consteval check
VERIFY( eq<T>(v4, {a, 4}) );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
bounds = typename It::ContainerType(a, a+9);
try
VERIFY( eq<T>(v4, {a, 4}) );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
try
{
VERIFY( v.empty() );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
static_assert(N < 9);
VERIFY( v.empty() );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
static_assert(N < 9);
VERIFY( rit4.base() == a+2 );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
try
{
VERIFY( it == v.begin() );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
v = std::inplace_vector<T, N>(std::from_range, std::span(a, a+N));
try
VERIFY( eq<T>(v, {a, 15}) );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
try
{
VERIFY( it == v.begin() + 5 );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
const bool seg = std::ranges::sized_range<Range> || std::ranges::forward_range<Range>;
auto vc = v;
VERIFY( it == v.begin() + 5 );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
const bool seg = std::forward_iterator<It>;
auto vc = v;
VERIFY( it == v.begin() + 5 );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
std::initializer_list<T> il
= {T(0), T(1), T(2), T(3), T(4), T(5), T(6), T(7), T(8), T(9)};
VERIFY( it == v.begin() + 5 );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
try
{
VERIFY( eq<T>(v, {a, N}) );
#ifdef __cpp_exceptions
-#ifdef __cpp_lib_constexpr_exceptions
-#error remove the consteval check
-#endif
+#ifndef __cpp_lib_constexpr_exceptions
if consteval {
return;
}
+#endif
try
{
#include <limits.h>
#include <utility>
#include <stdlib.h>
-#include <bits/functexcept.h>
+#include <bits/exception_defines.h>
namespace __gnu_pbds
{
#define _GLIBCXX_TESTSUITE_HOOKS_H
#include <bits/c++config.h>
-#include <bits/functexcept.h>
+#include <bits/stdexcept_throw.h>
#include <ctime>
#include <stdio.h>