2010-05-12 03:42:16 +08:00
|
|
|
// -*- C++ -*-
|
|
|
|
//===---------------------------- system_error ----------------------------===//
|
|
|
|
//
|
2010-05-12 05:36:01 +08:00
|
|
|
// The LLVM Compiler Infrastructure
|
2010-05-12 03:42:16 +08:00
|
|
|
//
|
2010-11-17 06:09:02 +08:00
|
|
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
|
|
|
// Source Licenses. See LICENSE.TXT for details.
|
2010-05-12 03:42:16 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef _LIBCPP_SYSTEM_ERROR
|
|
|
|
#define _LIBCPP_SYSTEM_ERROR
|
|
|
|
|
|
|
|
/*
|
|
|
|
system_error synopsis
|
|
|
|
|
|
|
|
namespace std
|
|
|
|
{
|
|
|
|
|
|
|
|
class error_category
|
|
|
|
{
|
|
|
|
public:
|
2011-05-27 03:48:01 +08:00
|
|
|
virtual ~error_category() noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
2013-08-21 10:57:19 +08:00
|
|
|
constexpr error_category();
|
2010-05-12 03:42:16 +08:00
|
|
|
error_category(const error_category&) = delete;
|
|
|
|
error_category& operator=(const error_category&) = delete;
|
|
|
|
|
2011-05-27 03:48:01 +08:00
|
|
|
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;
|
2010-05-12 03:42:16 +08:00
|
|
|
virtual string message(int ev) const = 0;
|
|
|
|
|
2011-05-27 03:48:01 +08:00
|
|
|
bool operator==(const error_category& rhs) const noexcept;
|
|
|
|
bool operator!=(const error_category& rhs) const noexcept;
|
|
|
|
bool operator<(const error_category& rhs) const noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
};
|
|
|
|
|
2011-05-27 03:48:01 +08:00
|
|
|
const error_category& generic_category() noexcept;
|
|
|
|
const error_category& system_category() noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
template <class T> struct is_error_code_enum
|
|
|
|
: public false_type {};
|
|
|
|
|
|
|
|
template <class T> struct is_error_condition_enum
|
|
|
|
: public false_type {};
|
|
|
|
|
2016-09-25 01:36:14 +08:00
|
|
|
template <class _Tp>
|
2018-01-03 01:17:01 +08:00
|
|
|
inline constexpr size_t is_error_condition_enum_v = is_error_condition_enum<_Tp>::value; // C++17
|
2016-09-25 01:36:14 +08:00
|
|
|
|
|
|
|
template <class _Tp>
|
2018-01-03 01:17:01 +08:00
|
|
|
inline constexpr size_t is_error_code_enum_v = is_error_code_enum<_Tp>::value; // C++17
|
2016-09-25 01:36:14 +08:00
|
|
|
|
2010-05-12 03:42:16 +08:00
|
|
|
class error_code
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// constructors:
|
2011-05-27 03:48:01 +08:00
|
|
|
error_code() noexcept;
|
|
|
|
error_code(int val, const error_category& cat) noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
template <class ErrorCodeEnum>
|
2011-05-27 03:48:01 +08:00
|
|
|
error_code(ErrorCodeEnum e) noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
// modifiers:
|
2011-05-27 03:48:01 +08:00
|
|
|
void assign(int val, const error_category& cat) noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
template <class ErrorCodeEnum>
|
2011-05-27 03:48:01 +08:00
|
|
|
error_code& operator=(ErrorCodeEnum e) noexcept;
|
|
|
|
void clear() noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
// observers:
|
2011-05-27 03:48:01 +08:00
|
|
|
int value() const noexcept;
|
|
|
|
const error_category& category() const noexcept;
|
|
|
|
error_condition default_error_condition() const noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
string message() const;
|
2011-05-27 03:48:01 +08:00
|
|
|
explicit operator bool() const noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
// non-member functions:
|
2011-05-27 03:48:01 +08:00
|
|
|
bool operator<(const error_code& lhs, const error_code& rhs) noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
template <class charT, class traits>
|
|
|
|
basic_ostream<charT,traits>&
|
|
|
|
operator<<(basic_ostream<charT,traits>& os, const error_code& ec);
|
|
|
|
|
|
|
|
class error_condition
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// constructors:
|
2011-05-27 03:48:01 +08:00
|
|
|
error_condition() noexcept;
|
|
|
|
error_condition(int val, const error_category& cat) noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
template <class ErrorConditionEnum>
|
2011-05-27 03:48:01 +08:00
|
|
|
error_condition(ErrorConditionEnum e) noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
// modifiers:
|
2011-05-27 03:48:01 +08:00
|
|
|
void assign(int val, const error_category& cat) noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
template <class ErrorConditionEnum>
|
2011-05-27 03:48:01 +08:00
|
|
|
error_condition& operator=(ErrorConditionEnum e) noexcept;
|
|
|
|
void clear() noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
// observers:
|
2011-05-27 03:48:01 +08:00
|
|
|
int value() const noexcept;
|
|
|
|
const error_category& category() const noexcept;
|
|
|
|
string message() const noexcept;
|
|
|
|
explicit operator bool() const noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
};
|
|
|
|
|
2011-05-27 03:48:01 +08:00
|
|
|
bool operator<(const error_condition& lhs, const error_condition& rhs) noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
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);
|
|
|
|
|
2011-05-27 03:48:01 +08:00
|
|
|
const error_code& code() const noexcept;
|
|
|
|
const char* what() const noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
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 { }
|
|
|
|
|
2011-05-27 03:48:01 +08:00
|
|
|
error_code make_error_code(errc e) noexcept;
|
|
|
|
error_condition make_error_condition(errc e) noexcept;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
// Comparison operators:
|
2011-05-27 03:48:01 +08:00
|
|
|
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;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
template <> struct hash<std::error_code>;
|
2016-11-15 02:22:19 +08:00
|
|
|
template <> struct hash<std::error_condition>;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
} // std
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <__config>
|
|
|
|
#include <cerrno>
|
|
|
|
#include <type_traits>
|
|
|
|
#include <stdexcept>
|
|
|
|
#include <__functional_base>
|
2017-09-12 00:05:42 +08:00
|
|
|
#include <string>
|
2010-05-12 03:42:16 +08:00
|
|
|
|
2011-10-18 04:05:10 +08:00
|
|
|
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
|
2010-05-12 03:42:16 +08:00
|
|
|
#pragma GCC system_header
|
2011-10-18 04:05:10 +08:00
|
|
|
#endif
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
_LIBCPP_BEGIN_NAMESPACE_STD
|
|
|
|
|
|
|
|
// is_error_code_enum
|
|
|
|
|
2010-09-24 01:31:07 +08:00
|
|
|
template <class _Tp>
|
2017-01-05 07:56:00 +08:00
|
|
|
struct _LIBCPP_TEMPLATE_VIS is_error_code_enum
|
2010-05-12 03:42:16 +08:00
|
|
|
: public false_type {};
|
|
|
|
|
2016-09-25 01:36:14 +08:00
|
|
|
#if _LIBCPP_STD_VER > 14
|
|
|
|
template <class _Tp>
|
2018-01-03 01:17:01 +08:00
|
|
|
_LIBCPP_INLINE_VAR constexpr size_t is_error_code_enum_v = is_error_code_enum<_Tp>::value;
|
2016-09-25 01:36:14 +08:00
|
|
|
#endif
|
|
|
|
|
2010-05-12 03:42:16 +08:00
|
|
|
// is_error_condition_enum
|
|
|
|
|
2010-09-24 01:31:07 +08:00
|
|
|
template <class _Tp>
|
2017-01-05 07:56:00 +08:00
|
|
|
struct _LIBCPP_TEMPLATE_VIS is_error_condition_enum
|
2010-05-12 03:42:16 +08:00
|
|
|
: public false_type {};
|
|
|
|
|
2016-09-25 01:36:14 +08:00
|
|
|
#if _LIBCPP_STD_VER > 14
|
|
|
|
template <class _Tp>
|
2018-01-03 01:17:01 +08:00
|
|
|
_LIBCPP_INLINE_VAR constexpr size_t is_error_condition_enum_v = is_error_condition_enum<_Tp>::value;
|
2016-09-25 01:36:14 +08:00
|
|
|
#endif
|
|
|
|
|
2010-08-12 00:52:41 +08:00
|
|
|
// Some error codes are not present on all platforms, so we provide equivalents
|
|
|
|
// for them:
|
|
|
|
|
2010-05-12 03:42:16 +08:00
|
|
|
//enum class errc
|
2011-12-03 03:36:40 +08:00
|
|
|
_LIBCPP_DECLARE_STRONG_ENUM(errc)
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
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,
|
2010-08-12 00:52:41 +08:00
|
|
|
#ifdef ENODATA
|
2010-05-12 03:42:16 +08:00
|
|
|
no_message_available = ENODATA,
|
2010-08-12 00:52:41 +08:00
|
|
|
#else
|
|
|
|
no_message_available = ENOMSG,
|
|
|
|
#endif
|
2010-05-12 03:42:16 +08:00
|
|
|
no_message = ENOMSG,
|
|
|
|
no_protocol_option = ENOPROTOOPT,
|
|
|
|
no_space_on_device = ENOSPC,
|
2010-08-12 00:52:41 +08:00
|
|
|
#ifdef ENOSR
|
2010-05-12 03:42:16 +08:00
|
|
|
no_stream_resources = ENOSR,
|
2010-08-12 00:52:41 +08:00
|
|
|
#else
|
|
|
|
no_stream_resources = ENOMEM,
|
|
|
|
#endif
|
2010-05-12 03:42:16 +08:00
|
|
|
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,
|
2010-08-12 00:52:41 +08:00
|
|
|
#ifdef ENOSTR
|
2010-05-12 03:42:16 +08:00
|
|
|
not_a_stream = ENOSTR,
|
2010-08-12 00:52:41 +08:00
|
|
|
#else
|
|
|
|
not_a_stream = EINVAL,
|
|
|
|
#endif
|
2010-05-12 03:42:16 +08:00
|
|
|
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,
|
2010-08-12 00:52:41 +08:00
|
|
|
#ifdef ETIME
|
2010-05-12 03:42:16 +08:00
|
|
|
stream_timeout = ETIME,
|
2010-08-12 00:52:41 +08:00
|
|
|
#else
|
|
|
|
stream_timeout = ETIMEDOUT,
|
|
|
|
#endif
|
2010-05-12 03:42:16 +08:00
|
|
|
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
|
|
|
|
};
|
2011-12-03 03:36:40 +08:00
|
|
|
_LIBCPP_DECLARE_STRONG_ENUM_EPILOG(errc)
|
2010-05-12 03:42:16 +08:00
|
|
|
|
2010-09-24 01:31:07 +08:00
|
|
|
template <>
|
2017-01-05 07:56:00 +08:00
|
|
|
struct _LIBCPP_TEMPLATE_VIS is_error_condition_enum<errc>
|
2010-05-12 03:42:16 +08:00
|
|
|
: true_type { };
|
|
|
|
|
2011-12-03 03:36:40 +08:00
|
|
|
#ifdef _LIBCPP_HAS_NO_STRONG_ENUMS
|
2010-09-24 01:31:07 +08:00
|
|
|
template <>
|
2017-01-05 07:56:00 +08:00
|
|
|
struct _LIBCPP_TEMPLATE_VIS is_error_condition_enum<errc::__lx>
|
2010-05-12 03:42:16 +08:00
|
|
|
: true_type { };
|
2011-12-03 03:36:40 +08:00
|
|
|
#endif
|
2010-05-12 03:42:16 +08:00
|
|
|
|
2013-03-07 07:30:19 +08:00
|
|
|
class _LIBCPP_TYPE_VIS error_condition;
|
|
|
|
class _LIBCPP_TYPE_VIS error_code;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
// class error_category
|
|
|
|
|
2012-09-14 08:39:16 +08:00
|
|
|
class _LIBCPP_HIDDEN __do_message;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
2013-03-07 07:30:19 +08:00
|
|
|
class _LIBCPP_TYPE_VIS error_category
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
public:
|
2011-05-27 03:48:01 +08:00
|
|
|
virtual ~error_category() _NOEXCEPT;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
2017-01-03 06:17:51 +08:00
|
|
|
#if defined(_LIBCPP_BUILDING_SYSTEM_ERROR) && \
|
2017-01-17 11:16:26 +08:00
|
|
|
defined(_LIBCPP_DEPRECATED_ABI_LEGACY_LIBRARY_DEFINITIONS_FOR_INLINE_FUNCTIONS)
|
2011-05-27 03:48:01 +08:00
|
|
|
error_category() _NOEXCEPT;
|
2013-08-21 10:57:19 +08:00
|
|
|
#else
|
2013-08-23 01:41:48 +08:00
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2015-08-28 15:02:42 +08:00
|
|
|
_LIBCPP_CONSTEXPR_AFTER_CXX11 error_category() _NOEXCEPT _LIBCPP_DEFAULT
|
2013-08-21 10:57:19 +08:00
|
|
|
#endif
|
2012-03-22 00:18:57 +08:00
|
|
|
private:
|
2010-05-12 03:42:16 +08:00
|
|
|
error_category(const error_category&);// = delete;
|
|
|
|
error_category& operator=(const error_category&);// = delete;
|
|
|
|
|
|
|
|
public:
|
2011-05-27 03:48:01 +08:00
|
|
|
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;
|
2010-05-12 03:42:16 +08:00
|
|
|
virtual string message(int __ev) const = 0;
|
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
bool operator==(const error_category& __rhs) const _NOEXCEPT {return this == &__rhs;}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
bool operator!=(const error_category& __rhs) const _NOEXCEPT {return !(*this == __rhs);}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
bool operator< (const error_category& __rhs) const _NOEXCEPT {return this < &__rhs;}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
2012-09-14 08:39:16 +08:00
|
|
|
friend class _LIBCPP_HIDDEN __do_message;
|
2010-05-12 03:42:16 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
class _LIBCPP_HIDDEN __do_message
|
|
|
|
: public error_category
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual string message(int ev) const;
|
|
|
|
};
|
|
|
|
|
2013-08-13 02:38:34 +08:00
|
|
|
_LIBCPP_FUNC_VIS const error_category& generic_category() _NOEXCEPT;
|
|
|
|
_LIBCPP_FUNC_VIS const error_category& system_category() _NOEXCEPT;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
2013-03-07 07:30:19 +08:00
|
|
|
class _LIBCPP_TYPE_VIS error_condition
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
int __val_;
|
|
|
|
const error_category* __cat_;
|
|
|
|
public:
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
error_condition() _NOEXCEPT : __val_(0), __cat_(&generic_category()) {}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
error_condition(int __val, const error_category& __cat) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
: __val_(__val), __cat_(&__cat) {}
|
|
|
|
|
2011-11-30 02:15:50 +08:00
|
|
|
template <class _Ep>
|
2010-05-12 03:42:16 +08:00
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-11-30 02:15:50 +08:00
|
|
|
error_condition(_Ep __e,
|
|
|
|
typename enable_if<is_error_condition_enum<_Ep>::value>::type* = 0
|
2011-05-27 03:48:01 +08:00
|
|
|
) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{*this = make_error_condition(__e);}
|
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
void assign(int __val, const error_category& __cat) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
__val_ = __val;
|
|
|
|
__cat_ = &__cat;
|
|
|
|
}
|
|
|
|
|
2011-11-30 02:15:50 +08:00
|
|
|
template <class _Ep>
|
2010-05-12 03:42:16 +08:00
|
|
|
_LIBCPP_ALWAYS_INLINE
|
|
|
|
typename enable_if
|
|
|
|
<
|
2011-11-30 02:15:50 +08:00
|
|
|
is_error_condition_enum<_Ep>::value,
|
2010-05-12 03:42:16 +08:00
|
|
|
error_condition&
|
|
|
|
>::type
|
2011-11-30 02:15:50 +08:00
|
|
|
operator=(_Ep __e) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{*this = make_error_condition(__e); return *this;}
|
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
void clear() _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
__val_ = 0;
|
|
|
|
__cat_ = &generic_category();
|
|
|
|
}
|
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
int value() const _NOEXCEPT {return __val_;}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
const error_category& category() const _NOEXCEPT {return *__cat_;}
|
2010-05-12 03:42:16 +08:00
|
|
|
string message() const;
|
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2012-02-22 05:46:43 +08:00
|
|
|
_LIBCPP_EXPLICIT
|
2011-05-27 03:48:01 +08:00
|
|
|
operator bool() const _NOEXCEPT {return __val_ != 0;}
|
2010-05-12 03:42:16 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY
|
|
|
|
error_condition
|
2011-05-27 03:48:01 +08:00
|
|
|
make_error_condition(errc __e) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
return error_condition(static_cast<int>(__e), generic_category());
|
|
|
|
}
|
|
|
|
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY
|
|
|
|
bool
|
2011-05-27 03:48:01 +08:00
|
|
|
operator<(const error_condition& __x, const error_condition& __y) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
return __x.category() < __y.category()
|
2011-12-02 04:21:04 +08:00
|
|
|
|| (__x.category() == __y.category() && __x.value() < __y.value());
|
2010-05-12 03:42:16 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// error_code
|
|
|
|
|
2013-03-07 07:30:19 +08:00
|
|
|
class _LIBCPP_TYPE_VIS error_code
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
int __val_;
|
|
|
|
const error_category* __cat_;
|
|
|
|
public:
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
error_code() _NOEXCEPT : __val_(0), __cat_(&system_category()) {}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
error_code(int __val, const error_category& __cat) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
: __val_(__val), __cat_(&__cat) {}
|
|
|
|
|
2011-11-30 02:15:50 +08:00
|
|
|
template <class _Ep>
|
2010-05-12 03:42:16 +08:00
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-11-30 02:15:50 +08:00
|
|
|
error_code(_Ep __e,
|
|
|
|
typename enable_if<is_error_code_enum<_Ep>::value>::type* = 0
|
2011-05-27 03:48:01 +08:00
|
|
|
) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{*this = make_error_code(__e);}
|
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
void assign(int __val, const error_category& __cat) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
__val_ = __val;
|
|
|
|
__cat_ = &__cat;
|
|
|
|
}
|
|
|
|
|
2011-11-30 02:15:50 +08:00
|
|
|
template <class _Ep>
|
2010-05-12 03:42:16 +08:00
|
|
|
_LIBCPP_ALWAYS_INLINE
|
|
|
|
typename enable_if
|
|
|
|
<
|
2011-11-30 02:15:50 +08:00
|
|
|
is_error_code_enum<_Ep>::value,
|
2010-05-12 03:42:16 +08:00
|
|
|
error_code&
|
|
|
|
>::type
|
2011-11-30 02:15:50 +08:00
|
|
|
operator=(_Ep __e) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{*this = make_error_code(__e); return *this;}
|
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
void clear() _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
__val_ = 0;
|
|
|
|
__cat_ = &system_category();
|
|
|
|
}
|
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
int value() const _NOEXCEPT {return __val_;}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
const error_category& category() const _NOEXCEPT {return *__cat_;}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
error_condition default_error_condition() const _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{return __cat_->default_error_condition(__val_);}
|
|
|
|
|
|
|
|
string message() const;
|
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2012-02-22 05:46:43 +08:00
|
|
|
_LIBCPP_EXPLICIT
|
2011-05-27 03:48:01 +08:00
|
|
|
operator bool() const _NOEXCEPT {return __val_ != 0;}
|
2010-05-12 03:42:16 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY
|
|
|
|
error_code
|
2011-05-27 03:48:01 +08:00
|
|
|
make_error_code(errc __e) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
return error_code(static_cast<int>(__e), generic_category());
|
|
|
|
}
|
|
|
|
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY
|
|
|
|
bool
|
2011-05-27 03:48:01 +08:00
|
|
|
operator<(const error_code& __x, const error_code& __y) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
return __x.category() < __y.category()
|
2011-12-02 04:21:04 +08:00
|
|
|
|| (__x.category() == __y.category() && __x.value() < __y.value());
|
2010-05-12 03:42:16 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY
|
|
|
|
bool
|
2011-05-27 03:48:01 +08:00
|
|
|
operator==(const error_code& __x, const error_code& __y) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
return __x.category() == __y.category() && __x.value() == __y.value();
|
|
|
|
}
|
|
|
|
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY
|
|
|
|
bool
|
2011-05-27 03:48:01 +08:00
|
|
|
operator==(const error_code& __x, const error_condition& __y) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
return __x.category().equivalent(__x.value(), __y)
|
|
|
|
|| __y.category().equivalent(__x, __y.value());
|
|
|
|
}
|
|
|
|
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY
|
|
|
|
bool
|
2011-05-27 03:48:01 +08:00
|
|
|
operator==(const error_condition& __x, const error_code& __y) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
return __y == __x;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY
|
|
|
|
bool
|
2011-05-27 03:48:01 +08:00
|
|
|
operator==(const error_condition& __x, const error_condition& __y) _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
return __x.category() == __y.category() && __x.value() == __y.value();
|
|
|
|
}
|
|
|
|
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY
|
|
|
|
bool
|
2011-05-27 03:48:01 +08:00
|
|
|
operator!=(const error_code& __x, const error_code& __y) _NOEXCEPT
|
|
|
|
{return !(__x == __y);}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY
|
|
|
|
bool
|
2011-05-27 03:48:01 +08:00
|
|
|
operator!=(const error_code& __x, const error_condition& __y) _NOEXCEPT
|
|
|
|
{return !(__x == __y);}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY
|
|
|
|
bool
|
2011-05-27 03:48:01 +08:00
|
|
|
operator!=(const error_condition& __x, const error_code& __y) _NOEXCEPT
|
|
|
|
{return !(__x == __y);}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
inline _LIBCPP_INLINE_VISIBILITY
|
|
|
|
bool
|
2011-05-27 03:48:01 +08:00
|
|
|
operator!=(const error_condition& __x, const error_condition& __y) _NOEXCEPT
|
|
|
|
{return !(__x == __y);}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
template <>
|
2017-01-05 07:56:00 +08:00
|
|
|
struct _LIBCPP_TEMPLATE_VIS hash<error_code>
|
2010-05-12 03:42:16 +08:00
|
|
|
: public unary_function<error_code, size_t>
|
|
|
|
{
|
2010-09-24 01:31:07 +08:00
|
|
|
_LIBCPP_INLINE_VISIBILITY
|
2011-05-27 03:48:01 +08:00
|
|
|
size_t operator()(const error_code& __ec) const _NOEXCEPT
|
2010-05-12 03:42:16 +08:00
|
|
|
{
|
|
|
|
return static_cast<size_t>(__ec.value());
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2016-11-15 02:22:19 +08:00
|
|
|
template <>
|
2017-01-05 07:56:00 +08:00
|
|
|
struct _LIBCPP_TEMPLATE_VIS hash<error_condition>
|
2016-11-15 02:22:19 +08:00
|
|
|
: public unary_function<error_condition, size_t>
|
|
|
|
{
|
|
|
|
_LIBCPP_INLINE_VISIBILITY
|
|
|
|
size_t operator()(const error_condition& __ec) const _NOEXCEPT
|
|
|
|
{
|
|
|
|
return static_cast<size_t>(__ec.value());
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2010-05-12 03:42:16 +08:00
|
|
|
// system_error
|
|
|
|
|
2013-03-07 07:30:19 +08:00
|
|
|
class _LIBCPP_TYPE_VIS system_error
|
2010-05-12 03:42:16 +08:00
|
|
|
: 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);
|
2011-05-27 03:48:01 +08:00
|
|
|
~system_error() _NOEXCEPT;
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
_LIBCPP_ALWAYS_INLINE
|
2011-05-27 03:48:01 +08:00
|
|
|
const error_code& code() const _NOEXCEPT {return __ec_;}
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
private:
|
|
|
|
static string __init(const error_code&, string);
|
|
|
|
};
|
|
|
|
|
2016-08-27 10:26:42 +08:00
|
|
|
_LIBCPP_NORETURN _LIBCPP_FUNC_VIS
|
|
|
|
void __throw_system_error(int ev, const char* what_arg);
|
2010-05-12 03:42:16 +08:00
|
|
|
|
|
|
|
_LIBCPP_END_NAMESPACE_STD
|
|
|
|
|
|
|
|
#endif // _LIBCPP_SYSTEM_ERROR
|