392 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C++
		
	
	
	
		
		
			
		
	
	
			392 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C++
		
	
	
	
|  | //
 | ||
|  | // error.hpp
 | ||
|  | // ~~~~~~~~~
 | ||
|  | //
 | ||
|  | // Copyright (c) 2003-2023 Christopher M. Kohlhoff (chris at kohlhoff dot com)
 | ||
|  | //
 | ||
|  | // Distributed under the Boost Software License, Version 1.0. (See accompanying
 | ||
|  | // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
 | ||
|  | //
 | ||
|  | 
 | ||
|  | #ifndef ASIO_ERROR_HPP
 | ||
|  | #define ASIO_ERROR_HPP
 | ||
|  | 
 | ||
|  | #if defined(_MSC_VER) && (_MSC_VER >= 1200)
 | ||
|  | # pragma once
 | ||
|  | #endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
 | ||
|  | 
 | ||
|  | #include "asio/detail/config.hpp"
 | ||
|  | #include "asio/error_code.hpp"
 | ||
|  | #include "asio/system_error.hpp"
 | ||
|  | #if defined(ASIO_WINDOWS) \
 | ||
|  |   || defined(__CYGWIN__) \ | ||
|  |   || defined(ASIO_WINDOWS_RUNTIME) | ||
|  | # include <winerror.h>
 | ||
|  | #else
 | ||
|  | # include <cerrno>
 | ||
|  | # include <netdb.h>
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #if defined(GENERATING_DOCUMENTATION)
 | ||
|  | /// INTERNAL ONLY.
 | ||
|  | # define ASIO_NATIVE_ERROR(e) implementation_defined
 | ||
|  | /// INTERNAL ONLY.
 | ||
|  | # define ASIO_SOCKET_ERROR(e) implementation_defined
 | ||
|  | /// INTERNAL ONLY.
 | ||
|  | # define ASIO_NETDB_ERROR(e) implementation_defined
 | ||
|  | /// INTERNAL ONLY.
 | ||
|  | # define ASIO_GETADDRINFO_ERROR(e) implementation_defined
 | ||
|  | /// INTERNAL ONLY.
 | ||
|  | # define ASIO_WIN_OR_POSIX(e_win, e_posix) implementation_defined
 | ||
|  | #elif defined(ASIO_WINDOWS_RUNTIME)
 | ||
|  | # define ASIO_NATIVE_ERROR(e) __HRESULT_FROM_WIN32(e)
 | ||
|  | # define ASIO_SOCKET_ERROR(e) __HRESULT_FROM_WIN32(WSA ## e)
 | ||
|  | # define ASIO_NETDB_ERROR(e) __HRESULT_FROM_WIN32(WSA ## e)
 | ||
|  | # define ASIO_GETADDRINFO_ERROR(e) __HRESULT_FROM_WIN32(WSA ## e)
 | ||
|  | # define ASIO_WIN_OR_POSIX(e_win, e_posix) e_win
 | ||
|  | #elif defined(ASIO_WINDOWS) || defined(__CYGWIN__)
 | ||
|  | # define ASIO_NATIVE_ERROR(e) e
 | ||
|  | # define ASIO_SOCKET_ERROR(e) WSA ## e
 | ||
|  | # define ASIO_NETDB_ERROR(e) WSA ## e
 | ||
|  | # define ASIO_GETADDRINFO_ERROR(e) WSA ## e
 | ||
|  | # define ASIO_WIN_OR_POSIX(e_win, e_posix) e_win
 | ||
|  | #else
 | ||
|  | # define ASIO_NATIVE_ERROR(e) e
 | ||
|  | # define ASIO_SOCKET_ERROR(e) e
 | ||
|  | # define ASIO_NETDB_ERROR(e) e
 | ||
|  | # define ASIO_GETADDRINFO_ERROR(e) e
 | ||
|  | # define ASIO_WIN_OR_POSIX(e_win, e_posix) e_posix
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #include "asio/detail/push_options.hpp"
 | ||
|  | 
 | ||
|  | namespace asio { | ||
|  | namespace error { | ||
|  | 
 | ||
|  | enum basic_errors | ||
|  | { | ||
|  |   /// Permission denied.
 | ||
|  |   access_denied = ASIO_SOCKET_ERROR(EACCES), | ||
|  | 
 | ||
|  |   /// Address family not supported by protocol.
 | ||
|  |   address_family_not_supported = ASIO_SOCKET_ERROR(EAFNOSUPPORT), | ||
|  | 
 | ||
|  |   /// Address already in use.
 | ||
|  |   address_in_use = ASIO_SOCKET_ERROR(EADDRINUSE), | ||
|  | 
 | ||
|  |   /// Transport endpoint is already connected.
 | ||
|  |   already_connected = ASIO_SOCKET_ERROR(EISCONN), | ||
|  | 
 | ||
|  |   /// Operation already in progress.
 | ||
|  |   already_started = ASIO_SOCKET_ERROR(EALREADY), | ||
|  | 
 | ||
|  |   /// Broken pipe.
 | ||
|  |   broken_pipe = ASIO_WIN_OR_POSIX( | ||
|  |       ASIO_NATIVE_ERROR(ERROR_BROKEN_PIPE), | ||
|  |       ASIO_NATIVE_ERROR(EPIPE)), | ||
|  | 
 | ||
|  |   /// A connection has been aborted.
 | ||
|  |   connection_aborted = ASIO_SOCKET_ERROR(ECONNABORTED), | ||
|  | 
 | ||
|  |   /// Connection refused.
 | ||
|  |   connection_refused = ASIO_SOCKET_ERROR(ECONNREFUSED), | ||
|  | 
 | ||
|  |   /// Connection reset by peer.
 | ||
|  |   connection_reset = ASIO_SOCKET_ERROR(ECONNRESET), | ||
|  | 
 | ||
|  |   /// Bad file descriptor.
 | ||
|  |   bad_descriptor = ASIO_SOCKET_ERROR(EBADF), | ||
|  | 
 | ||
|  |   /// Bad address.
 | ||
|  |   fault = ASIO_SOCKET_ERROR(EFAULT), | ||
|  | 
 | ||
|  |   /// No route to host.
 | ||
|  |   host_unreachable = ASIO_SOCKET_ERROR(EHOSTUNREACH), | ||
|  | 
 | ||
|  |   /// Operation now in progress.
 | ||
|  |   in_progress = ASIO_SOCKET_ERROR(EINPROGRESS), | ||
|  | 
 | ||
|  |   /// Interrupted system call.
 | ||
|  |   interrupted = ASIO_SOCKET_ERROR(EINTR), | ||
|  | 
 | ||
|  |   /// Invalid argument.
 | ||
|  |   invalid_argument = ASIO_SOCKET_ERROR(EINVAL), | ||
|  | 
 | ||
|  |   /// Message too long.
 | ||
|  |   message_size = ASIO_SOCKET_ERROR(EMSGSIZE), | ||
|  | 
 | ||
|  |   /// The name was too long.
 | ||
|  |   name_too_long = ASIO_SOCKET_ERROR(ENAMETOOLONG), | ||
|  | 
 | ||
|  |   /// Network is down.
 | ||
|  |   network_down = ASIO_SOCKET_ERROR(ENETDOWN), | ||
|  | 
 | ||
|  |   /// Network dropped connection on reset.
 | ||
|  |   network_reset = ASIO_SOCKET_ERROR(ENETRESET), | ||
|  | 
 | ||
|  |   /// Network is unreachable.
 | ||
|  |   network_unreachable = ASIO_SOCKET_ERROR(ENETUNREACH), | ||
|  | 
 | ||
|  |   /// Too many open files.
 | ||
|  |   no_descriptors = ASIO_SOCKET_ERROR(EMFILE), | ||
|  | 
 | ||
|  |   /// No buffer space available.
 | ||
|  |   no_buffer_space = ASIO_SOCKET_ERROR(ENOBUFS), | ||
|  | 
 | ||
|  |   /// Cannot allocate memory.
 | ||
|  |   no_memory = ASIO_WIN_OR_POSIX( | ||
|  |       ASIO_NATIVE_ERROR(ERROR_OUTOFMEMORY), | ||
|  |       ASIO_NATIVE_ERROR(ENOMEM)), | ||
|  | 
 | ||
|  |   /// Operation not permitted.
 | ||
|  |   no_permission = ASIO_WIN_OR_POSIX( | ||
|  |       ASIO_NATIVE_ERROR(ERROR_ACCESS_DENIED), | ||
|  |       ASIO_NATIVE_ERROR(EPERM)), | ||
|  | 
 | ||
|  |   /// Protocol not available.
 | ||
|  |   no_protocol_option = ASIO_SOCKET_ERROR(ENOPROTOOPT), | ||
|  | 
 | ||
|  |   /// No such device.
 | ||
|  |   no_such_device = ASIO_WIN_OR_POSIX( | ||
|  |       ASIO_NATIVE_ERROR(ERROR_BAD_UNIT), | ||
|  |       ASIO_NATIVE_ERROR(ENODEV)), | ||
|  | 
 | ||
|  |   /// Transport endpoint is not connected.
 | ||
|  |   not_connected = ASIO_SOCKET_ERROR(ENOTCONN), | ||
|  | 
 | ||
|  |   /// Socket operation on non-socket.
 | ||
|  |   not_socket = ASIO_SOCKET_ERROR(ENOTSOCK), | ||
|  | 
 | ||
|  |   /// Operation cancelled.
 | ||
|  |   operation_aborted = ASIO_WIN_OR_POSIX( | ||
|  |       ASIO_NATIVE_ERROR(ERROR_OPERATION_ABORTED), | ||
|  |       ASIO_NATIVE_ERROR(ECANCELED)), | ||
|  | 
 | ||
|  |   /// Operation not supported.
 | ||
|  |   operation_not_supported = ASIO_SOCKET_ERROR(EOPNOTSUPP), | ||
|  | 
 | ||
|  |   /// Cannot send after transport endpoint shutdown.
 | ||
|  |   shut_down = ASIO_SOCKET_ERROR(ESHUTDOWN), | ||
|  | 
 | ||
|  |   /// Connection timed out.
 | ||
|  |   timed_out = ASIO_SOCKET_ERROR(ETIMEDOUT), | ||
|  | 
 | ||
|  |   /// Resource temporarily unavailable.
 | ||
|  |   try_again = ASIO_WIN_OR_POSIX( | ||
|  |       ASIO_NATIVE_ERROR(ERROR_RETRY), | ||
|  |       ASIO_NATIVE_ERROR(EAGAIN)), | ||
|  | 
 | ||
|  |   /// The socket is marked non-blocking and the requested operation would block.
 | ||
|  |   would_block = ASIO_SOCKET_ERROR(EWOULDBLOCK) | ||
|  | }; | ||
|  | 
 | ||
|  | enum netdb_errors | ||
|  | { | ||
|  |   /// Host not found (authoritative).
 | ||
|  |   host_not_found = ASIO_NETDB_ERROR(HOST_NOT_FOUND), | ||
|  | 
 | ||
|  |   /// Host not found (non-authoritative).
 | ||
|  |   host_not_found_try_again = ASIO_NETDB_ERROR(TRY_AGAIN), | ||
|  | 
 | ||
|  |   /// The query is valid but does not have associated address data.
 | ||
|  |   no_data = ASIO_NETDB_ERROR(NO_DATA), | ||
|  | 
 | ||
|  |   /// A non-recoverable error occurred.
 | ||
|  |   no_recovery = ASIO_NETDB_ERROR(NO_RECOVERY) | ||
|  | }; | ||
|  | 
 | ||
|  | enum addrinfo_errors | ||
|  | { | ||
|  |   /// The service is not supported for the given socket type.
 | ||
|  |   service_not_found = ASIO_WIN_OR_POSIX( | ||
|  |       ASIO_NATIVE_ERROR(WSATYPE_NOT_FOUND), | ||
|  |       ASIO_GETADDRINFO_ERROR(EAI_SERVICE)), | ||
|  | 
 | ||
|  |   /// The socket type is not supported.
 | ||
|  |   socket_type_not_supported = ASIO_WIN_OR_POSIX( | ||
|  |       ASIO_NATIVE_ERROR(WSAESOCKTNOSUPPORT), | ||
|  |       ASIO_GETADDRINFO_ERROR(EAI_SOCKTYPE)) | ||
|  | }; | ||
|  | 
 | ||
|  | enum misc_errors | ||
|  | { | ||
|  |   /// Already open.
 | ||
|  |   already_open = 1, | ||
|  | 
 | ||
|  |   /// End of file or stream.
 | ||
|  |   eof, | ||
|  | 
 | ||
|  |   /// Element not found.
 | ||
|  |   not_found, | ||
|  | 
 | ||
|  |   /// The descriptor cannot fit into the select system call's fd_set.
 | ||
|  |   fd_set_failure | ||
|  | }; | ||
|  | 
 | ||
|  | // boostify: non-boost code starts here
 | ||
|  | #if !defined(ASIO_ERROR_LOCATION)
 | ||
|  | # define ASIO_ERROR_LOCATION(e) (void)0
 | ||
|  | #endif // !defined(ASIO_ERROR_LOCATION)
 | ||
|  | 
 | ||
|  | // boostify: non-boost code ends here
 | ||
|  | #if !defined(ASIO_ERROR_LOCATION) \
 | ||
|  |   && !defined(ASIO_DISABLE_ERROR_LOCATION) \ | ||
|  |   && defined(ASIO_HAS_BOOST_CONFIG) \ | ||
|  |   && (BOOST_VERSION >= 107900) | ||
|  | 
 | ||
|  | # define ASIO_ERROR_LOCATION(e) \
 | ||
|  |   do { \ | ||
|  |     BOOST_STATIC_CONSTEXPR boost::source_location loc \ | ||
|  |       = BOOST_CURRENT_LOCATION; \ | ||
|  |     (e).assign((e), &loc); \ | ||
|  |   } while (false) | ||
|  | 
 | ||
|  | #else // !defined(ASIO_ERROR_LOCATION)
 | ||
|  |       //   && !defined(ASIO_DISABLE_ERROR_LOCATION)
 | ||
|  |       //   && defined(ASIO_HAS_BOOST_CONFIG)
 | ||
|  |       //   && (BOOST_VERSION >= 107900)
 | ||
|  | 
 | ||
|  | # define ASIO_ERROR_LOCATION(e) (void)0
 | ||
|  | 
 | ||
|  | #endif // !defined(ASIO_ERROR_LOCATION)
 | ||
|  |        //   && !defined(ASIO_DISABLE_ERROR_LOCATION)
 | ||
|  |        //   && defined(ASIO_HAS_BOOST_CONFIG)
 | ||
|  |        //   && (BOOST_VERSION >= 107900)
 | ||
|  | 
 | ||
|  | inline void clear(asio::error_code& ec) | ||
|  | { | ||
|  |   ec.assign(0, ec.category()); | ||
|  | } | ||
|  | 
 | ||
|  | inline const asio::error_category& get_system_category() | ||
|  | { | ||
|  |   return asio::system_category(); | ||
|  | } | ||
|  | 
 | ||
|  | #if !defined(ASIO_WINDOWS) && !defined(__CYGWIN__)
 | ||
|  | 
 | ||
|  | extern ASIO_DECL | ||
|  | const asio::error_category& get_netdb_category(); | ||
|  | 
 | ||
|  | extern ASIO_DECL | ||
|  | const asio::error_category& get_addrinfo_category(); | ||
|  | 
 | ||
|  | #else // !defined(ASIO_WINDOWS) && !defined(__CYGWIN__)
 | ||
|  | 
 | ||
|  | inline const asio::error_category& get_netdb_category() | ||
|  | { | ||
|  |   return get_system_category(); | ||
|  | } | ||
|  | 
 | ||
|  | inline const asio::error_category& get_addrinfo_category() | ||
|  | { | ||
|  |   return get_system_category(); | ||
|  | } | ||
|  | 
 | ||
|  | #endif // !defined(ASIO_WINDOWS) && !defined(__CYGWIN__)
 | ||
|  | 
 | ||
|  | extern ASIO_DECL | ||
|  | const asio::error_category& get_misc_category(); | ||
|  | 
 | ||
|  | static const asio::error_category& | ||
|  |   system_category ASIO_UNUSED_VARIABLE | ||
|  |   = asio::error::get_system_category(); | ||
|  | static const asio::error_category& | ||
|  |   netdb_category ASIO_UNUSED_VARIABLE | ||
|  |   = asio::error::get_netdb_category(); | ||
|  | static const asio::error_category& | ||
|  |   addrinfo_category ASIO_UNUSED_VARIABLE | ||
|  |   = asio::error::get_addrinfo_category(); | ||
|  | static const asio::error_category& | ||
|  |   misc_category ASIO_UNUSED_VARIABLE | ||
|  |   = asio::error::get_misc_category(); | ||
|  | 
 | ||
|  | } // namespace error
 | ||
|  | } // namespace asio
 | ||
|  | 
 | ||
|  | #if defined(ASIO_HAS_STD_SYSTEM_ERROR)
 | ||
|  | namespace std { | ||
|  | 
 | ||
|  | template<> struct is_error_code_enum<asio::error::basic_errors> | ||
|  | { | ||
|  |   static const bool value = true; | ||
|  | }; | ||
|  | 
 | ||
|  | template<> struct is_error_code_enum<asio::error::netdb_errors> | ||
|  | { | ||
|  |   static const bool value = true; | ||
|  | }; | ||
|  | 
 | ||
|  | template<> struct is_error_code_enum<asio::error::addrinfo_errors> | ||
|  | { | ||
|  |   static const bool value = true; | ||
|  | }; | ||
|  | 
 | ||
|  | template<> struct is_error_code_enum<asio::error::misc_errors> | ||
|  | { | ||
|  |   static const bool value = true; | ||
|  | }; | ||
|  | 
 | ||
|  | } // namespace std
 | ||
|  | #endif // defined(ASIO_HAS_STD_SYSTEM_ERROR)
 | ||
|  | 
 | ||
|  | namespace asio { | ||
|  | namespace error { | ||
|  | 
 | ||
|  | inline asio::error_code make_error_code(basic_errors e) | ||
|  | { | ||
|  |   return asio::error_code( | ||
|  |       static_cast<int>(e), get_system_category()); | ||
|  | } | ||
|  | 
 | ||
|  | inline asio::error_code make_error_code(netdb_errors e) | ||
|  | { | ||
|  |   return asio::error_code( | ||
|  |       static_cast<int>(e), get_netdb_category()); | ||
|  | } | ||
|  | 
 | ||
|  | inline asio::error_code make_error_code(addrinfo_errors e) | ||
|  | { | ||
|  |   return asio::error_code( | ||
|  |       static_cast<int>(e), get_addrinfo_category()); | ||
|  | } | ||
|  | 
 | ||
|  | inline asio::error_code make_error_code(misc_errors e) | ||
|  | { | ||
|  |   return asio::error_code( | ||
|  |       static_cast<int>(e), get_misc_category()); | ||
|  | } | ||
|  | 
 | ||
|  | } // namespace error
 | ||
|  | namespace stream_errc { | ||
|  |   // Simulates the proposed stream_errc scoped enum.
 | ||
|  |   using error::eof; | ||
|  |   using error::not_found; | ||
|  | } // namespace stream_errc
 | ||
|  | namespace socket_errc { | ||
|  |   // Simulates the proposed socket_errc scoped enum.
 | ||
|  |   using error::already_open; | ||
|  |   using error::not_found; | ||
|  | } // namespace socket_errc
 | ||
|  | namespace resolver_errc { | ||
|  |   // Simulates the proposed resolver_errc scoped enum.
 | ||
|  |   using error::host_not_found; | ||
|  |   const error::netdb_errors try_again = error::host_not_found_try_again; | ||
|  |   using error::service_not_found; | ||
|  | } // namespace resolver_errc
 | ||
|  | } // namespace asio
 | ||
|  | 
 | ||
|  | #include "asio/detail/pop_options.hpp"
 | ||
|  | 
 | ||
|  | #undef ASIO_NATIVE_ERROR
 | ||
|  | #undef ASIO_SOCKET_ERROR
 | ||
|  | #undef ASIO_NETDB_ERROR
 | ||
|  | #undef ASIO_GETADDRINFO_ERROR
 | ||
|  | #undef ASIO_WIN_OR_POSIX
 | ||
|  | 
 | ||
|  | #if defined(ASIO_HEADER_ONLY)
 | ||
|  | # include "asio/impl/error.ipp"
 | ||
|  | #endif // defined(ASIO_HEADER_ONLY)
 | ||
|  | 
 | ||
|  | #endif // ASIO_ERROR_HPP
 |