2024-08-07 16:05:14 +03:00
|
|
|
#ifndef CIADPI_ERROR_H
|
|
|
|
#define CIADPI_ERROR_H
|
2024-08-07 14:25:26 +03:00
|
|
|
|
2024-02-19 12:51:34 +03:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <errno.h>
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
2024-02-24 20:44:54 +03:00
|
|
|
#include <winsock2.h>
|
|
|
|
#endif
|
|
|
|
#ifdef ANDROID_APP
|
|
|
|
#include <android/log.h>
|
2024-02-19 12:51:34 +03:00
|
|
|
#endif
|
|
|
|
|
2024-09-13 22:23:04 +03:00
|
|
|
#include "params.h"
|
|
|
|
|
2024-02-19 12:51:34 +03:00
|
|
|
#ifdef _WIN32
|
|
|
|
#define get_e() \
|
|
|
|
unie(WSAGetLastError())
|
|
|
|
#else
|
|
|
|
#define get_e() \
|
|
|
|
errno
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
2024-02-24 20:44:54 +03:00
|
|
|
#define uniperror(str) \
|
2024-08-07 14:25:26 +03:00
|
|
|
fprintf(stderr, "%s: %ld\n", str, GetLastError())
|
2024-02-19 12:51:34 +03:00
|
|
|
#else
|
2024-02-24 20:44:54 +03:00
|
|
|
#ifdef ANDROID_APP
|
|
|
|
#define uniperror(str) \
|
2024-02-24 23:13:25 +03:00
|
|
|
__android_log_print(ANDROID_LOG_ERROR, "proxy", \
|
2024-02-24 20:44:54 +03:00
|
|
|
"%s: %s\n", str, strerror(errno))
|
|
|
|
#else
|
|
|
|
#define uniperror(str) \
|
|
|
|
perror(str)
|
|
|
|
#endif
|
2024-02-19 12:51:34 +03:00
|
|
|
#endif
|
|
|
|
|
2024-05-02 19:36:29 +03:00
|
|
|
static inline const int unie(int e)
|
2024-02-19 12:51:34 +03:00
|
|
|
{
|
|
|
|
#ifdef _WIN32
|
|
|
|
switch (e) {
|
|
|
|
case WSAEWOULDBLOCK:
|
|
|
|
return EAGAIN;
|
|
|
|
case WSAETIMEDOUT:
|
|
|
|
return ETIMEDOUT;
|
|
|
|
case WSAENETUNREACH:
|
|
|
|
return ENETUNREACH;
|
|
|
|
case WSAEHOSTUNREACH:
|
|
|
|
return EHOSTUNREACH;
|
|
|
|
case WSAECONNREFUSED:
|
|
|
|
return ECONNREFUSED;
|
2024-03-08 04:48:35 +03:00
|
|
|
case WSAECONNRESET:
|
|
|
|
return ECONNRESET;
|
2024-02-19 12:51:34 +03:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
return e;
|
|
|
|
}
|
2024-02-24 20:44:54 +03:00
|
|
|
|
|
|
|
#ifdef ANDROID_APP
|
|
|
|
#define LOG_E ANDROID_LOG_ERROR
|
|
|
|
#define LOG_S ANDROID_LOG_DEBUG
|
|
|
|
#define LOG_L ANDROID_LOG_VERBOSE
|
|
|
|
#define LOG(s, str, ...) \
|
|
|
|
__android_log_print(s, "proxy", str, ##__VA_ARGS__)
|
|
|
|
#else
|
|
|
|
#define LOG_E -1
|
|
|
|
#define LOG_S 1
|
|
|
|
#define LOG_L 2
|
|
|
|
#define LOG(s, str, ...) \
|
|
|
|
if (params.debug >= s) \
|
|
|
|
fprintf(stderr, str, ##__VA_ARGS__)
|
2024-07-18 23:59:44 +03:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#define INIT_ADDR_STR(dst) \
|
2024-08-20 18:22:59 +03:00
|
|
|
char ADDR_STR[INET6_ADDRSTRLEN]; \
|
|
|
|
const char *p = 0; \
|
2024-07-18 23:59:44 +03:00
|
|
|
if (dst.sa.sa_family == AF_INET) \
|
2024-08-20 18:22:59 +03:00
|
|
|
p = inet_ntop(AF_INET, &dst.in.sin_addr, ADDR_STR, sizeof(ADDR_STR)); \
|
2024-07-18 23:59:44 +03:00
|
|
|
else \
|
2024-08-20 18:22:59 +03:00
|
|
|
p = inet_ntop(AF_INET6, &dst.in6.sin6_addr, ADDR_STR, sizeof(ADDR_STR)); \
|
|
|
|
if (!p) uniperror("inet_ntop");
|
2024-08-07 14:25:26 +03:00
|
|
|
|
|
|
|
#endif
|
2024-11-14 20:44:38 +03:00
|
|
|
|
|
|
|
#define INIT_HEX_STR(b, s) \
|
|
|
|
char HEX_STR[s * 2 + 1]; \
|
|
|
|
HEX_STR[sizeof(HEX_STR) - 1] = 0; \
|
|
|
|
do { \
|
|
|
|
size_t i; \
|
|
|
|
for (i = 0; i + 4 <= s; i += 4) \
|
|
|
|
snprintf(HEX_STR + i * 2, sizeof(HEX_STR) - i * 2, \
|
|
|
|
"%02x%02x%02x%02x", b[i],b[i+1],b[i+2],b[i+3]); \
|
|
|
|
for (; i < s; i++) \
|
|
|
|
snprintf(HEX_STR + i * 2, sizeof(HEX_STR) - i * 2, "%02x", b[i]); \
|
|
|
|
} while (0);
|