| 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
|
|
|