2020-11-16 14:47:43 +08:00
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
2021-05-18 00:25:11 +08:00
|
|
|
// A multi-platform support c++11 library with focus on asynchronous socket I/O for any
|
2021-01-14 15:30:18 +08:00
|
|
|
// client application.
|
2020-11-16 14:47:43 +08:00
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
/*
|
|
|
|
The MIT License (MIT)
|
|
|
|
|
2023-01-01 17:36:38 +08:00
|
|
|
Copyright (c) 2012-2023 HALX99
|
2020-11-16 14:47:43 +08:00
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in all
|
|
|
|
copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
SOFTWARE.
|
|
|
|
*/
|
|
|
|
#ifndef YASIO__CONFIG_HPP
|
|
|
|
#define YASIO__CONFIG_HPP
|
|
|
|
#include "yasio/compiler/feature_test.hpp"
|
|
|
|
|
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_HEADER_ONLY to enable yasio core implementation header
|
|
|
|
** only
|
|
|
|
*/
|
2023-05-14 23:08:02 +08:00
|
|
|
#define YASIO_HEADER_ONLY 1
|
2020-11-16 14:47:43 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_VERBOSE_LOG to enable verbose log
|
|
|
|
*/
|
|
|
|
// #define YASIO_VERBOSE_LOG 1
|
|
|
|
|
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_USE_SPSC_QUEUE to use SPSC queue in io_service
|
|
|
|
** Remark: By default, yasio use std's queue + mutex to ensure thread safe, If you want
|
|
|
|
** more fast messege queue and only have one thread to call io_service write APIs,
|
|
|
|
** you may need uncomment it.
|
|
|
|
*/
|
|
|
|
// #define YASIO_USE_SPSC_QUEUE 1
|
|
|
|
|
2021-05-18 00:25:11 +08:00
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_USE_SHARED_PACKET to use std::shared_ptr wrap network packet.
|
|
|
|
*/
|
|
|
|
// #define YASIO_USE_SHARED_PACKET 1
|
|
|
|
|
2020-11-16 14:47:43 +08:00
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_DISABLE_OBJECT_POOL to disable object_pool for allocating
|
|
|
|
** protocol data unit
|
|
|
|
*/
|
|
|
|
// #define YASIO_DISABLE_OBJECT_POOL 1
|
|
|
|
|
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_ENABLE_ARES_PROFILER to test async resolve performance
|
|
|
|
*/
|
|
|
|
// #define YASIO_ENABLE_ARES_PROFILER 1
|
|
|
|
|
|
|
|
/*
|
2023-04-17 00:28:05 +08:00
|
|
|
** Uncomment or add compiler flag -DYASIO_USE_CARES to use c-ares to perform async resolve
|
2020-11-16 14:47:43 +08:00
|
|
|
*/
|
2023-04-05 13:32:13 +08:00
|
|
|
// #define YASIO_USE_CARES 1
|
2020-11-16 14:47:43 +08:00
|
|
|
|
|
|
|
/*
|
2021-01-14 15:30:18 +08:00
|
|
|
** Uncomment or add compiler flag -DYASIO_SSL_BACKEND=1 for SSL support with OpenSSL
|
|
|
|
** 1. -DYASIO_SSL_BACKEND=1: OpenSSL
|
|
|
|
** 2. -DYASIO_SSL_BACKEND=2: mbedtls
|
2020-11-16 14:47:43 +08:00
|
|
|
*/
|
2023-05-14 23:08:02 +08:00
|
|
|
#define YASIO_SSL_BACKEND 1
|
2020-11-16 14:47:43 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_DISABLE_CONCURRENT_SINGLETON to disable concurrent
|
|
|
|
*singleton
|
|
|
|
*/
|
|
|
|
// #define YASIO_DISABLE_CONCURRENT_SINGLETON 1
|
|
|
|
|
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_ENABLE_UDS to enable unix domain socket via SOCK_STREAM
|
|
|
|
*/
|
|
|
|
// #define YASIO_ENABLE_UDS 1
|
|
|
|
|
|
|
|
/*
|
2023-01-01 17:36:38 +08:00
|
|
|
** Uncomment or add compiler flag -DYASIO_NT_COMPAT_GAI for compatible with Windows XP
|
2020-11-16 14:47:43 +08:00
|
|
|
** see: https://docs.microsoft.com/en-us/windows/win32/api/ws2tcpip/nf-ws2tcpip-getaddrinfo
|
|
|
|
*/
|
|
|
|
// #define YASIO_NT_COMPAT_GAI 1
|
|
|
|
|
|
|
|
/*
|
2020-12-15 18:58:04 +08:00
|
|
|
** Uncomment or add compiler flag -DYASIO_MINIFY_EVENT to minfy size of io_event
|
2020-11-16 14:47:43 +08:00
|
|
|
*/
|
|
|
|
// #define YASIO_MINIFY_EVENT 1
|
|
|
|
|
2020-12-15 18:58:04 +08:00
|
|
|
/*
|
2023-04-17 00:28:05 +08:00
|
|
|
** Uncomment or add compiler flag -DYASIO_ENABLE_HALF_FLOAT to enable half-precision floating-point support
|
2020-12-15 18:58:04 +08:00
|
|
|
*/
|
2023-04-17 00:28:05 +08:00
|
|
|
// #define YASIO_ENABLE_HALF_FLOAT 1
|
2020-11-16 14:47:43 +08:00
|
|
|
|
2021-05-18 00:25:11 +08:00
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_ENABLE_PASSIVE_EVENT to enable server channel open/close event
|
|
|
|
*/
|
|
|
|
// #define YASIO_ENABLE_PASSIVE_EVENT 1
|
|
|
|
|
2021-06-24 12:33:07 +08:00
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_NO_USER_TIMER to disable io_channel user_timer
|
|
|
|
*/
|
|
|
|
// #define YASIO_NO_USER_TIMER 1
|
|
|
|
|
2021-11-23 12:53:13 +08:00
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_OBS_BUILTIN_STACK to enable obstream builtin stack
|
|
|
|
** for push/pop operations, by default disabled for performance purpose
|
|
|
|
*/
|
|
|
|
// #define YASIO_OBS_BUILTIN_STACK 1
|
|
|
|
|
2023-01-01 17:36:38 +08:00
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_DISABLE_POLL to use socket.select for all platforms
|
|
|
|
** If you need support Windows XP, you need disable poll
|
|
|
|
*/
|
|
|
|
// #define YASIO_DISABLE_POLL 1
|
|
|
|
|
2023-04-17 00:28:05 +08:00
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_DISABLE_EPOLL to disable epoll
|
|
|
|
*/
|
|
|
|
// #define YASIO_DISABLE_EPOLL 1
|
|
|
|
|
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_DISABLE_KQUEUE to disable kqueue for bsd-like OS
|
|
|
|
*/
|
|
|
|
// #define YASIO_DISABLE_KQUEUE 1
|
|
|
|
|
2023-04-22 20:27:21 +08:00
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_DISABLE_EVPORT for SunOS 5.10+
|
|
|
|
*/
|
|
|
|
// #define YASIO_DISABLE_EVPORT 1
|
|
|
|
|
2023-04-17 00:28:05 +08:00
|
|
|
/*
|
|
|
|
** Uncomment or add compiler flag -DYASIO_ENABLE_WEPOLL for windows
|
|
|
|
*/
|
|
|
|
// #define YASIO_ENABLE_WEPOLL 1
|
|
|
|
|
|
|
|
#if YASIO__HAS_EPOLL
|
|
|
|
# define epoll_close close
|
|
|
|
typedef int epoll_handle_t;
|
|
|
|
#elif defined(_WIN32) && defined(YASIO_ENABLE_WEPOLL)
|
|
|
|
# include "wepoll/wepoll.h"
|
|
|
|
# undef YASIO__HAS_EPOLL
|
|
|
|
# define YASIO__HAS_EPOLL 1
|
|
|
|
typedef HANDLE epoll_handle_t;
|
|
|
|
#endif
|
|
|
|
|
2020-12-15 18:58:04 +08:00
|
|
|
#if defined(YASIO_HEADER_ONLY)
|
|
|
|
# define YASIO__DECL inline
|
2020-11-16 14:47:43 +08:00
|
|
|
#else
|
2020-12-15 18:58:04 +08:00
|
|
|
# define YASIO__DECL
|
2020-11-16 14:47:43 +08:00
|
|
|
#endif
|
|
|
|
|
2021-05-18 00:25:11 +08:00
|
|
|
/*
|
|
|
|
** The interop decl, it's useful for store managed c# function as c++ function pointer properly.
|
|
|
|
*/
|
|
|
|
#if !defined(_WIN32) || YASIO__64BITS
|
|
|
|
# define YASIO_INTEROP_DECL
|
|
|
|
#else
|
|
|
|
# define YASIO_INTEROP_DECL __stdcall
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined(YASIO_API)
|
2021-10-09 13:48:56 +08:00
|
|
|
# if defined(YASIO_BUILD_SHARED_LIBS) && !defined(YASIO_HEADER_ONLY)
|
|
|
|
# if defined(_WIN32) && defined(YASIO_EXPORT_DLL)
|
2021-05-18 00:25:11 +08:00
|
|
|
# if defined(YASIO_LIB)
|
|
|
|
# define YASIO_API __declspec(dllexport)
|
|
|
|
# else
|
|
|
|
# define YASIO_API __declspec(dllimport)
|
|
|
|
# endif
|
|
|
|
# else
|
|
|
|
# define YASIO_API
|
|
|
|
# endif
|
|
|
|
# else
|
|
|
|
# define YASIO_API
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
2020-11-16 14:47:43 +08:00
|
|
|
#define YASIO_ARRAYSIZE(A) (sizeof(A) / sizeof((A)[0]))
|
|
|
|
|
2021-01-18 15:39:38 +08:00
|
|
|
#define YASIO_SSIZEOF(T) static_cast<int>(sizeof(T))
|
|
|
|
|
2021-05-18 00:25:11 +08:00
|
|
|
// clang-format off
|
2020-11-16 14:47:43 +08:00
|
|
|
/*
|
|
|
|
** YASIO_OBSOLETE_DEPRECATE
|
|
|
|
*/
|
|
|
|
#if defined(__GNUC__) && ((__GNUC__ >= 4) || ((__GNUC__ == 3) && (__GNUC_MINOR__ >= 1)))
|
|
|
|
# define YASIO_OBSOLETE_DEPRECATE(_Replacement) __attribute__((deprecated))
|
|
|
|
#elif _MSC_VER >= 1400 // vs 2005 or higher
|
2021-05-18 00:25:11 +08:00
|
|
|
# define YASIO_OBSOLETE_DEPRECATE(_Replacement) \
|
2020-12-15 18:58:04 +08:00
|
|
|
__declspec(deprecated("This function will be removed in the future. Consider using " #_Replacement " instead."))
|
2020-11-16 14:47:43 +08:00
|
|
|
#else
|
|
|
|
# define YASIO_OBSOLETE_DEPRECATE(_Replacement)
|
|
|
|
#endif
|
2021-05-18 00:25:11 +08:00
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
#if defined(UE_BUILD_DEBUG) || defined(UE_BUILD_DEVELOPMENT) || defined(UE_BUILD_TEST) || defined(UE_BUILD_SHIPPING) || defined(UE_SERVER)
|
|
|
|
# define YASIO_INSIDE_UNREAL 1
|
|
|
|
#endif // Unreal Engine 4 bullshit
|
2020-11-16 14:47:43 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
** The yasio version macros
|
|
|
|
*/
|
2023-04-05 13:32:13 +08:00
|
|
|
#define YASIO_VERSION_NUM 0x040000
|
2020-11-16 14:47:43 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
** The macros used by io_service.
|
|
|
|
*/
|
|
|
|
// The default max listen count of tcp server.
|
|
|
|
#define YASIO_SOMAXCONN 19
|
|
|
|
|
|
|
|
// The default ttl of multicast
|
|
|
|
#define YASIO_DEFAULT_MULTICAST_TTL (int)128
|
|
|
|
|
2021-01-19 15:00:08 +08:00
|
|
|
// The max internet buffer size
|
2020-11-16 14:47:43 +08:00
|
|
|
#define YASIO_INET_BUFFER_SIZE 65536
|
|
|
|
|
2021-01-19 15:00:08 +08:00
|
|
|
// The max pdu buffer length, avoid large memory allocation when application decode a huge length.
|
2020-11-16 14:47:43 +08:00
|
|
|
#define YASIO_MAX_PDU_BUFFER_SIZE static_cast<int>(1 * 1024 * 1024)
|
|
|
|
|
2021-01-19 15:00:08 +08:00
|
|
|
// The max Initial Bytes To Strip for unpack.
|
|
|
|
#define YASIO_UNPACK_MAX_STRIP 32
|
2020-11-16 14:47:43 +08:00
|
|
|
|
|
|
|
// The fallback name servers when c-ares can't get name servers from system config,
|
|
|
|
// For Android 8 or later, yasio will try to retrive through jni automitically,
|
2021-01-19 15:00:08 +08:00
|
|
|
// For iOS, since c-ares-1.16.1, it will use libresolv for retrieving DNS servers.
|
2020-11-16 14:47:43 +08:00
|
|
|
// please see:
|
2021-01-19 15:00:08 +08:00
|
|
|
// https://c-ares.haxx.se/changelog.html
|
2020-11-16 14:47:43 +08:00
|
|
|
// https://github.com/c-ares/c-ares/issues/276
|
|
|
|
// https://github.com/c-ares/c-ares/pull/148
|
2021-10-23 21:51:50 +08:00
|
|
|
#define YASIO_FALLBACK_NAME_SERVERS "8.8.8.8,223.5.5.5,114.114.114.114"
|
2020-11-16 14:47:43 +08:00
|
|
|
|
2023-01-10 22:19:30 +08:00
|
|
|
// Since ubuntu 16.04, the /etc/resolv.conf control by systemd-resolved service,
|
|
|
|
// and the preferred non loopback name server was store to /run/systemd/resolve/resolv.conf
|
|
|
|
// refer to: https://unix.stackexchange.com/questions/612416/why-does-etc-resolv-conf-point-at-127-0-0-53
|
|
|
|
#define YASIO_SYSTEMD_RESOLV_PATH "/run/systemd/resolve/resolv.conf"
|
|
|
|
#define YASIO_SYSTEMD_RESOLV_PATH_LEN (sizeof(YASIO_SYSTEMD_RESOLV_PATH) - 1)
|
|
|
|
|
2022-07-11 09:12:40 +08:00
|
|
|
// The yasio ssl client PIN for server to recognize
|
|
|
|
#define YASIO_SSL_PIN "yasio_ssl_client"
|
|
|
|
#define YASIO_SSL_PIN_LEN (sizeof(YASIO_SSL_PIN) - 1)
|
|
|
|
|
2023-01-04 23:20:07 +08:00
|
|
|
#define YASIO_SSL_PON "yasio_ssl_server"
|
|
|
|
#define YASIO_SSL_PON_LEN (sizeof(YASIO_SSL_PON) - 1)
|
|
|
|
|
2023-04-17 00:28:05 +08:00
|
|
|
// The msg flag for socket.send
|
|
|
|
// Linux: MSG_NOSIGNAL as to socket.send flag to ignore SIGPIPE
|
|
|
|
// BSDs: use setsockopt SO_NOSIGPIPE to ignore SIGPIPE
|
|
|
|
// Refer to: https://linux.die.net/man/2/send
|
|
|
|
#if defined(__linux__)
|
|
|
|
# define YASIO_MSG_FLAG MSG_NOSIGNAL
|
|
|
|
#else
|
|
|
|
# define YASIO_MSG_FLAG 0
|
|
|
|
#endif
|
|
|
|
|
2020-11-16 14:47:43 +08:00
|
|
|
#endif
|