Index: third_party/libcxx/include/system_error |
=================================================================== |
--- third_party/libcxx/include/system_error (revision 0) |
+++ third_party/libcxx/include/system_error (revision 0) |
@@ -0,0 +1,642 @@ |
+// -*- C++ -*- |
+//===---------------------------- system_error ----------------------------===// |
+// |
+// The LLVM Compiler Infrastructure |
+// |
+// This file is dual licensed under the MIT and the University of Illinois Open |
+// Source Licenses. See LICENSE.TXT for details. |
+// |
+//===----------------------------------------------------------------------===// |
+ |
+#ifndef _LIBCPP_SYSTEM_ERROR |
+#define _LIBCPP_SYSTEM_ERROR |
+ |
+/* |
+ system_error synopsis |
+ |
+namespace std |
+{ |
+ |
+class error_category |
+{ |
+public: |
+ virtual ~error_category() noexcept; |
+ |
+ constexpr error_category(); |
+ error_category(const error_category&) = delete; |
+ error_category& operator=(const error_category&) = delete; |
+ |
+ virtual const char* name() const noexcept = 0; |
+ virtual error_condition default_error_condition(int ev) const noexcept; |
+ virtual bool equivalent(int code, const error_condition& condition) const noexcept; |
+ virtual bool equivalent(const error_code& code, int condition) const noexcept; |
+ virtual string message(int ev) const = 0; |
+ |
+ bool operator==(const error_category& rhs) const noexcept; |
+ bool operator!=(const error_category& rhs) const noexcept; |
+ bool operator<(const error_category& rhs) const noexcept; |
+}; |
+ |
+const error_category& generic_category() noexcept; |
+const error_category& system_category() noexcept; |
+ |
+template <class T> struct is_error_code_enum |
+ : public false_type {}; |
+ |
+template <class T> struct is_error_condition_enum |
+ : public false_type {}; |
+ |
+class error_code |
+{ |
+public: |
+ // constructors: |
+ error_code() noexcept; |
+ error_code(int val, const error_category& cat) noexcept; |
+ template <class ErrorCodeEnum> |
+ error_code(ErrorCodeEnum e) noexcept; |
+ |
+ // modifiers: |
+ void assign(int val, const error_category& cat) noexcept; |
+ template <class ErrorCodeEnum> |
+ error_code& operator=(ErrorCodeEnum e) noexcept; |
+ void clear() noexcept; |
+ |
+ // observers: |
+ int value() const noexcept; |
+ const error_category& category() const noexcept; |
+ error_condition default_error_condition() const noexcept; |
+ string message() const; |
+ explicit operator bool() const noexcept; |
+}; |
+ |
+// non-member functions: |
+bool operator<(const error_code& lhs, const error_code& rhs) noexcept; |
+template <class charT, class traits> |
+ basic_ostream<charT,traits>& |
+ operator<<(basic_ostream<charT,traits>& os, const error_code& ec); |
+ |
+class error_condition |
+{ |
+public: |
+ // constructors: |
+ error_condition() noexcept; |
+ error_condition(int val, const error_category& cat) noexcept; |
+ template <class ErrorConditionEnum> |
+ error_condition(ErrorConditionEnum e) noexcept; |
+ |
+ // modifiers: |
+ void assign(int val, const error_category& cat) noexcept; |
+ template <class ErrorConditionEnum> |
+ error_condition& operator=(ErrorConditionEnum e) noexcept; |
+ void clear() noexcept; |
+ |
+ // observers: |
+ int value() const noexcept; |
+ const error_category& category() const noexcept; |
+ string message() const noexcept; |
+ explicit operator bool() const noexcept; |
+}; |
+ |
+bool operator<(const error_condition& lhs, const error_condition& rhs) noexcept; |
+ |
+class system_error |
+ : public runtime_error |
+{ |
+public: |
+ system_error(error_code ec, const string& what_arg); |
+ system_error(error_code ec, const char* what_arg); |
+ system_error(error_code ec); |
+ system_error(int ev, const error_category& ecat, const string& what_arg); |
+ system_error(int ev, const error_category& ecat, const char* what_arg); |
+ system_error(int ev, const error_category& ecat); |
+ |
+ const error_code& code() const noexcept; |
+ const char* what() const noexcept; |
+}; |
+ |
+enum class errc |
+{ |
+ address_family_not_supported, // EAFNOSUPPORT |
+ address_in_use, // EADDRINUSE |
+ address_not_available, // EADDRNOTAVAIL |
+ already_connected, // EISCONN |
+ argument_list_too_long, // E2BIG |
+ argument_out_of_domain, // EDOM |
+ bad_address, // EFAULT |
+ bad_file_descriptor, // EBADF |
+ bad_message, // EBADMSG |
+ broken_pipe, // EPIPE |
+ connection_aborted, // ECONNABORTED |
+ connection_already_in_progress, // EALREADY |
+ connection_refused, // ECONNREFUSED |
+ connection_reset, // ECONNRESET |
+ cross_device_link, // EXDEV |
+ destination_address_required, // EDESTADDRREQ |
+ device_or_resource_busy, // EBUSY |
+ directory_not_empty, // ENOTEMPTY |
+ executable_format_error, // ENOEXEC |
+ file_exists, // EEXIST |
+ file_too_large, // EFBIG |
+ filename_too_long, // ENAMETOOLONG |
+ function_not_supported, // ENOSYS |
+ host_unreachable, // EHOSTUNREACH |
+ identifier_removed, // EIDRM |
+ illegal_byte_sequence, // EILSEQ |
+ inappropriate_io_control_operation, // ENOTTY |
+ interrupted, // EINTR |
+ invalid_argument, // EINVAL |
+ invalid_seek, // ESPIPE |
+ io_error, // EIO |
+ is_a_directory, // EISDIR |
+ message_size, // EMSGSIZE |
+ network_down, // ENETDOWN |
+ network_reset, // ENETRESET |
+ network_unreachable, // ENETUNREACH |
+ no_buffer_space, // ENOBUFS |
+ no_child_process, // ECHILD |
+ no_link, // ENOLINK |
+ no_lock_available, // ENOLCK |
+ no_message_available, // ENODATA |
+ no_message, // ENOMSG |
+ no_protocol_option, // ENOPROTOOPT |
+ no_space_on_device, // ENOSPC |
+ no_stream_resources, // ENOSR |
+ no_such_device_or_address, // ENXIO |
+ no_such_device, // ENODEV |
+ no_such_file_or_directory, // ENOENT |
+ no_such_process, // ESRCH |
+ not_a_directory, // ENOTDIR |
+ not_a_socket, // ENOTSOCK |
+ not_a_stream, // ENOSTR |
+ not_connected, // ENOTCONN |
+ not_enough_memory, // ENOMEM |
+ not_supported, // ENOTSUP |
+ operation_canceled, // ECANCELED |
+ operation_in_progress, // EINPROGRESS |
+ operation_not_permitted, // EPERM |
+ operation_not_supported, // EOPNOTSUPP |
+ operation_would_block, // EWOULDBLOCK |
+ owner_dead, // EOWNERDEAD |
+ permission_denied, // EACCES |
+ protocol_error, // EPROTO |
+ protocol_not_supported, // EPROTONOSUPPORT |
+ read_only_file_system, // EROFS |
+ resource_deadlock_would_occur, // EDEADLK |
+ resource_unavailable_try_again, // EAGAIN |
+ result_out_of_range, // ERANGE |
+ state_not_recoverable, // ENOTRECOVERABLE |
+ stream_timeout, // ETIME |
+ text_file_busy, // ETXTBSY |
+ timed_out, // ETIMEDOUT |
+ too_many_files_open_in_system, // ENFILE |
+ too_many_files_open, // EMFILE |
+ too_many_links, // EMLINK |
+ too_many_symbolic_link_levels, // ELOOP |
+ value_too_large, // EOVERFLOW |
+ wrong_protocol_type // EPROTOTYPE |
+}; |
+ |
+template <> struct is_error_condition_enum<errc> |
+ : true_type { } |
+ |
+error_code make_error_code(errc e) noexcept; |
+error_condition make_error_condition(errc e) noexcept; |
+ |
+// Comparison operators: |
+bool operator==(const error_code& lhs, const error_code& rhs) noexcept; |
+bool operator==(const error_code& lhs, const error_condition& rhs) noexcept; |
+bool operator==(const error_condition& lhs, const error_code& rhs) noexcept; |
+bool operator==(const error_condition& lhs, const error_condition& rhs) noexcept; |
+bool operator!=(const error_code& lhs, const error_code& rhs) noexcept; |
+bool operator!=(const error_code& lhs, const error_condition& rhs) noexcept; |
+bool operator!=(const error_condition& lhs, const error_code& rhs) noexcept; |
+bool operator!=(const error_condition& lhs, const error_condition& rhs) noexcept; |
+ |
+template <> struct hash<std::error_code>; |
+ |
+} // std |
+ |
+*/ |
+ |
+#include <__config> |
+#include <cerrno> |
+#include <type_traits> |
+#include <stdexcept> |
+#include <__functional_base> |
+ |
+#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) |
+#pragma GCC system_header |
+#endif |
+ |
+_LIBCPP_BEGIN_NAMESPACE_STD |
+ |
+// is_error_code_enum |
+ |
+template <class _Tp> |
+struct _LIBCPP_TYPE_VIS_ONLY is_error_code_enum |
+ : public false_type {}; |
+ |
+// is_error_condition_enum |
+ |
+template <class _Tp> |
+struct _LIBCPP_TYPE_VIS_ONLY is_error_condition_enum |
+ : public false_type {}; |
+ |
+// Some error codes are not present on all platforms, so we provide equivalents |
+// for them: |
+ |
+//enum class errc |
+_LIBCPP_DECLARE_STRONG_ENUM(errc) |
+{ |
+ address_family_not_supported = EAFNOSUPPORT, |
+ address_in_use = EADDRINUSE, |
+ address_not_available = EADDRNOTAVAIL, |
+ already_connected = EISCONN, |
+ argument_list_too_long = E2BIG, |
+ argument_out_of_domain = EDOM, |
+ bad_address = EFAULT, |
+ bad_file_descriptor = EBADF, |
+ bad_message = EBADMSG, |
+ broken_pipe = EPIPE, |
+ connection_aborted = ECONNABORTED, |
+ connection_already_in_progress = EALREADY, |
+ connection_refused = ECONNREFUSED, |
+ connection_reset = ECONNRESET, |
+ cross_device_link = EXDEV, |
+ destination_address_required = EDESTADDRREQ, |
+ device_or_resource_busy = EBUSY, |
+ directory_not_empty = ENOTEMPTY, |
+ executable_format_error = ENOEXEC, |
+ file_exists = EEXIST, |
+ file_too_large = EFBIG, |
+ filename_too_long = ENAMETOOLONG, |
+ function_not_supported = ENOSYS, |
+ host_unreachable = EHOSTUNREACH, |
+ identifier_removed = EIDRM, |
+ illegal_byte_sequence = EILSEQ, |
+ inappropriate_io_control_operation = ENOTTY, |
+ interrupted = EINTR, |
+ invalid_argument = EINVAL, |
+ invalid_seek = ESPIPE, |
+ io_error = EIO, |
+ is_a_directory = EISDIR, |
+ message_size = EMSGSIZE, |
+ network_down = ENETDOWN, |
+ network_reset = ENETRESET, |
+ network_unreachable = ENETUNREACH, |
+ no_buffer_space = ENOBUFS, |
+ no_child_process = ECHILD, |
+ no_link = ENOLINK, |
+ no_lock_available = ENOLCK, |
+#ifdef ENODATA |
+ no_message_available = ENODATA, |
+#else |
+ no_message_available = ENOMSG, |
+#endif |
+ no_message = ENOMSG, |
+ no_protocol_option = ENOPROTOOPT, |
+ no_space_on_device = ENOSPC, |
+#ifdef ENOSR |
+ no_stream_resources = ENOSR, |
+#else |
+ no_stream_resources = ENOMEM, |
+#endif |
+ no_such_device_or_address = ENXIO, |
+ no_such_device = ENODEV, |
+ no_such_file_or_directory = ENOENT, |
+ no_such_process = ESRCH, |
+ not_a_directory = ENOTDIR, |
+ not_a_socket = ENOTSOCK, |
+#ifdef ENOSTR |
+ not_a_stream = ENOSTR, |
+#else |
+ not_a_stream = EINVAL, |
+#endif |
+ not_connected = ENOTCONN, |
+ not_enough_memory = ENOMEM, |
+ not_supported = ENOTSUP, |
+ operation_canceled = ECANCELED, |
+ operation_in_progress = EINPROGRESS, |
+ operation_not_permitted = EPERM, |
+ operation_not_supported = EOPNOTSUPP, |
+ operation_would_block = EWOULDBLOCK, |
+ owner_dead = EOWNERDEAD, |
+ permission_denied = EACCES, |
+ protocol_error = EPROTO, |
+ protocol_not_supported = EPROTONOSUPPORT, |
+ read_only_file_system = EROFS, |
+ resource_deadlock_would_occur = EDEADLK, |
+ resource_unavailable_try_again = EAGAIN, |
+ result_out_of_range = ERANGE, |
+ state_not_recoverable = ENOTRECOVERABLE, |
+#ifdef ETIME |
+ stream_timeout = ETIME, |
+#else |
+ stream_timeout = ETIMEDOUT, |
+#endif |
+ text_file_busy = ETXTBSY, |
+ timed_out = ETIMEDOUT, |
+ too_many_files_open_in_system = ENFILE, |
+ too_many_files_open = EMFILE, |
+ too_many_links = EMLINK, |
+ too_many_symbolic_link_levels = ELOOP, |
+ value_too_large = EOVERFLOW, |
+ wrong_protocol_type = EPROTOTYPE |
+}; |
+_LIBCPP_DECLARE_STRONG_ENUM_EPILOG(errc) |
+ |
+template <> |
+struct _LIBCPP_TYPE_VIS_ONLY is_error_condition_enum<errc> |
+ : true_type { }; |
+ |
+#ifdef _LIBCPP_HAS_NO_STRONG_ENUMS |
+template <> |
+struct _LIBCPP_TYPE_VIS_ONLY is_error_condition_enum<errc::__lx> |
+ : true_type { }; |
+#endif |
+ |
+class _LIBCPP_TYPE_VIS error_condition; |
+class _LIBCPP_TYPE_VIS error_code; |
+ |
+// class error_category |
+ |
+class _LIBCPP_HIDDEN __do_message; |
+ |
+class _LIBCPP_TYPE_VIS error_category |
+{ |
+public: |
+ virtual ~error_category() _NOEXCEPT; |
+ |
+#ifdef _LIBCPP_BUILDING_SYSTEM_ERROR |
+ error_category() _NOEXCEPT; |
+#else |
+ _LIBCPP_ALWAYS_INLINE |
+ _LIBCPP_CONSTEXPR_AFTER_CXX11 error_category() _NOEXCEPT _LIBCPP_DEFAULT; |
+#endif |
+private: |
+ error_category(const error_category&);// = delete; |
+ error_category& operator=(const error_category&);// = delete; |
+ |
+public: |
+ virtual const char* name() const _NOEXCEPT = 0; |
+ virtual error_condition default_error_condition(int __ev) const _NOEXCEPT; |
+ virtual bool equivalent(int __code, const error_condition& __condition) const _NOEXCEPT; |
+ virtual bool equivalent(const error_code& __code, int __condition) const _NOEXCEPT; |
+ virtual string message(int __ev) const = 0; |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ bool operator==(const error_category& __rhs) const _NOEXCEPT {return this == &__rhs;} |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ bool operator!=(const error_category& __rhs) const _NOEXCEPT {return !(*this == __rhs);} |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ bool operator< (const error_category& __rhs) const _NOEXCEPT {return this < &__rhs;} |
+ |
+ friend class _LIBCPP_HIDDEN __do_message; |
+}; |
+ |
+class _LIBCPP_HIDDEN __do_message |
+ : public error_category |
+{ |
+public: |
+ virtual string message(int ev) const; |
+}; |
+ |
+_LIBCPP_FUNC_VIS const error_category& generic_category() _NOEXCEPT; |
+_LIBCPP_FUNC_VIS const error_category& system_category() _NOEXCEPT; |
+ |
+class _LIBCPP_TYPE_VIS error_condition |
+{ |
+ int __val_; |
+ const error_category* __cat_; |
+public: |
+ _LIBCPP_ALWAYS_INLINE |
+ error_condition() _NOEXCEPT : __val_(0), __cat_(&generic_category()) {} |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ error_condition(int __val, const error_category& __cat) _NOEXCEPT |
+ : __val_(__val), __cat_(&__cat) {} |
+ |
+ template <class _Ep> |
+ _LIBCPP_ALWAYS_INLINE |
+ error_condition(_Ep __e, |
+ typename enable_if<is_error_condition_enum<_Ep>::value>::type* = 0 |
+ ) _NOEXCEPT |
+ {*this = make_error_condition(__e);} |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ void assign(int __val, const error_category& __cat) _NOEXCEPT |
+ { |
+ __val_ = __val; |
+ __cat_ = &__cat; |
+ } |
+ |
+ template <class _Ep> |
+ _LIBCPP_ALWAYS_INLINE |
+ typename enable_if |
+ < |
+ is_error_condition_enum<_Ep>::value, |
+ error_condition& |
+ >::type |
+ operator=(_Ep __e) _NOEXCEPT |
+ {*this = make_error_condition(__e); return *this;} |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ void clear() _NOEXCEPT |
+ { |
+ __val_ = 0; |
+ __cat_ = &generic_category(); |
+ } |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ int value() const _NOEXCEPT {return __val_;} |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ const error_category& category() const _NOEXCEPT {return *__cat_;} |
+ string message() const; |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ _LIBCPP_EXPLICIT |
+ operator bool() const _NOEXCEPT {return __val_ != 0;} |
+}; |
+ |
+inline _LIBCPP_INLINE_VISIBILITY |
+error_condition |
+make_error_condition(errc __e) _NOEXCEPT |
+{ |
+ return error_condition(static_cast<int>(__e), generic_category()); |
+} |
+ |
+inline _LIBCPP_INLINE_VISIBILITY |
+bool |
+operator<(const error_condition& __x, const error_condition& __y) _NOEXCEPT |
+{ |
+ return __x.category() < __y.category() |
+ || (__x.category() == __y.category() && __x.value() < __y.value()); |
+} |
+ |
+// error_code |
+ |
+class _LIBCPP_TYPE_VIS error_code |
+{ |
+ int __val_; |
+ const error_category* __cat_; |
+public: |
+ _LIBCPP_ALWAYS_INLINE |
+ error_code() _NOEXCEPT : __val_(0), __cat_(&system_category()) {} |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ error_code(int __val, const error_category& __cat) _NOEXCEPT |
+ : __val_(__val), __cat_(&__cat) {} |
+ |
+ template <class _Ep> |
+ _LIBCPP_ALWAYS_INLINE |
+ error_code(_Ep __e, |
+ typename enable_if<is_error_code_enum<_Ep>::value>::type* = 0 |
+ ) _NOEXCEPT |
+ {*this = make_error_code(__e);} |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ void assign(int __val, const error_category& __cat) _NOEXCEPT |
+ { |
+ __val_ = __val; |
+ __cat_ = &__cat; |
+ } |
+ |
+ template <class _Ep> |
+ _LIBCPP_ALWAYS_INLINE |
+ typename enable_if |
+ < |
+ is_error_code_enum<_Ep>::value, |
+ error_code& |
+ >::type |
+ operator=(_Ep __e) _NOEXCEPT |
+ {*this = make_error_code(__e); return *this;} |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ void clear() _NOEXCEPT |
+ { |
+ __val_ = 0; |
+ __cat_ = &system_category(); |
+ } |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ int value() const _NOEXCEPT {return __val_;} |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ const error_category& category() const _NOEXCEPT {return *__cat_;} |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ error_condition default_error_condition() const _NOEXCEPT |
+ {return __cat_->default_error_condition(__val_);} |
+ |
+ string message() const; |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ _LIBCPP_EXPLICIT |
+ operator bool() const _NOEXCEPT {return __val_ != 0;} |
+}; |
+ |
+inline _LIBCPP_INLINE_VISIBILITY |
+error_code |
+make_error_code(errc __e) _NOEXCEPT |
+{ |
+ return error_code(static_cast<int>(__e), generic_category()); |
+} |
+ |
+inline _LIBCPP_INLINE_VISIBILITY |
+bool |
+operator<(const error_code& __x, const error_code& __y) _NOEXCEPT |
+{ |
+ return __x.category() < __y.category() |
+ || (__x.category() == __y.category() && __x.value() < __y.value()); |
+} |
+ |
+inline _LIBCPP_INLINE_VISIBILITY |
+bool |
+operator==(const error_code& __x, const error_code& __y) _NOEXCEPT |
+{ |
+ return __x.category() == __y.category() && __x.value() == __y.value(); |
+} |
+ |
+inline _LIBCPP_INLINE_VISIBILITY |
+bool |
+operator==(const error_code& __x, const error_condition& __y) _NOEXCEPT |
+{ |
+ return __x.category().equivalent(__x.value(), __y) |
+ || __y.category().equivalent(__x, __y.value()); |
+} |
+ |
+inline _LIBCPP_INLINE_VISIBILITY |
+bool |
+operator==(const error_condition& __x, const error_code& __y) _NOEXCEPT |
+{ |
+ return __y == __x; |
+} |
+ |
+inline _LIBCPP_INLINE_VISIBILITY |
+bool |
+operator==(const error_condition& __x, const error_condition& __y) _NOEXCEPT |
+{ |
+ return __x.category() == __y.category() && __x.value() == __y.value(); |
+} |
+ |
+inline _LIBCPP_INLINE_VISIBILITY |
+bool |
+operator!=(const error_code& __x, const error_code& __y) _NOEXCEPT |
+{return !(__x == __y);} |
+ |
+inline _LIBCPP_INLINE_VISIBILITY |
+bool |
+operator!=(const error_code& __x, const error_condition& __y) _NOEXCEPT |
+{return !(__x == __y);} |
+ |
+inline _LIBCPP_INLINE_VISIBILITY |
+bool |
+operator!=(const error_condition& __x, const error_code& __y) _NOEXCEPT |
+{return !(__x == __y);} |
+ |
+inline _LIBCPP_INLINE_VISIBILITY |
+bool |
+operator!=(const error_condition& __x, const error_condition& __y) _NOEXCEPT |
+{return !(__x == __y);} |
+ |
+template <> |
+struct _LIBCPP_TYPE_VIS_ONLY hash<error_code> |
+ : public unary_function<error_code, size_t> |
+{ |
+ _LIBCPP_INLINE_VISIBILITY |
+ size_t operator()(const error_code& __ec) const _NOEXCEPT |
+ { |
+ return static_cast<size_t>(__ec.value()); |
+ } |
+}; |
+ |
+// system_error |
+ |
+class _LIBCPP_TYPE_VIS system_error |
+ : public runtime_error |
+{ |
+ error_code __ec_; |
+public: |
+ system_error(error_code __ec, const string& __what_arg); |
+ system_error(error_code __ec, const char* __what_arg); |
+ system_error(error_code __ec); |
+ system_error(int __ev, const error_category& __ecat, const string& __what_arg); |
+ system_error(int __ev, const error_category& __ecat, const char* __what_arg); |
+ system_error(int __ev, const error_category& __ecat); |
+ ~system_error() _NOEXCEPT; |
+ |
+ _LIBCPP_ALWAYS_INLINE |
+ const error_code& code() const _NOEXCEPT {return __ec_;} |
+ |
+private: |
+ static string __init(const error_code&, string); |
+}; |
+ |
+_LIBCPP_FUNC_VIS void __throw_system_error(int ev, const char* what_arg); |
+ |
+_LIBCPP_END_NAMESPACE_STD |
+ |
+#endif // _LIBCPP_SYSTEM_ERROR |