/* * utils.h - Misc utilities * * Copyright (C) 2013 - 2015, Max Lv * * This file is part of the shadowsocks-libev. * * shadowsocks-libev is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * shadowsocks-libev is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with shadowsocks-libev; see the file COPYING. If not, see * . */ #ifndef _UTILS_H #define _UTILS_H #include #include #define PORTSTRLEN 16 #define SS_ADDRSTRLEN (INET6_ADDRSTRLEN + PORTSTRLEN + 1) #ifdef ANDROID #include #define USE_TTY() #define USE_SYSLOG(ident) #define LOGI(...) \ ((void)__android_log_print(ANDROID_LOG_DEBUG, "shadowsocks", \ __VA_ARGS__)) #define LOGE(...) \ ((void)__android_log_print(ANDROID_LOG_ERROR, "shadowsocks", \ __VA_ARGS__)) #else #define STR(x) #x #define TOSTR(x) STR(x) #ifdef LIB_ONLY extern FILE * logfile; #define TIME_FORMAT "%Y-%m-%d %H:%M:%S" #define USE_TTY() #define USE_SYSLOG(ident) #define USE_LOGFILE(ident) \ do { \ if (ident != NULL) { logfile = fopen(ident, "w+"); } } \ while (0) #define CLOSE_LOGFILE \ do { \ if (logfile != NULL) { fclose(logfile); } } \ while (0) #define LOGI(format, ...) \ do { \ if (logfile != NULL) { \ time_t now = time(NULL); \ char timestr[20]; \ strftime(timestr, 20, TIME_FORMAT, localtime(&now)); \ fprintf(logfile, " %s INFO: " format "\n", timestr, ## __VA_ARGS__); \ fflush(logfile); } \ } \ while (0) #define LOGE(format, ...) \ do { \ if (logfile != NULL) { \ time_t now = time(NULL); \ char timestr[20]; \ strftime(timestr, 20, TIME_FORMAT, localtime(&now)); \ fprintf(logfile, " %s ERROR: " format "\n", timestr, \ ## __VA_ARGS__); \ fflush(logfile); } \ } \ while (0) #elif defined(_WIN32) #define TIME_FORMAT "%Y-%m-%d %H:%M:%S" #define USE_TTY() #define USE_SYSLOG(ident) #define LOGI(format, ...) \ do { \ time_t now = time(NULL); \ char timestr[20]; \ strftime(timestr, 20, TIME_FORMAT, localtime(&now)); \ fprintf(stderr, " %s INFO: " format "\n", timestr, ## __VA_ARGS__); \ fflush(stderr); } \ while (0) #define LOGE(format, ...) \ do { \ time_t now = time(NULL); \ char timestr[20]; \ strftime(timestr, 20, TIME_FORMAT, localtime(&now)); \ fprintf(stderr, " %s ERROR: " format "\n", timestr, ## __VA_ARGS__); \ fflush(stderr); } \ while (0) #else #include extern int use_tty; #define USE_TTY() \ do { \ use_tty = isatty(STDERR_FILENO); \ } while (0) \ #define HAS_SYSLOG extern int use_syslog; #define TIME_FORMAT "%F %T" #define USE_SYSLOG(ident) \ do { \ use_syslog = 1; \ openlog((ident), LOG_CONS | LOG_PID, 0); } \ while (0) #define LOGI(format, ...) \ do { \ if (use_syslog) { \ syslog(LOG_INFO, format, ## __VA_ARGS__); \ } else { \ time_t now = time(NULL); \ char timestr[20]; \ strftime(timestr, 20, TIME_FORMAT, localtime(&now)); \ if (use_tty) { \ fprintf(stderr, "\e[01;32m %s INFO: \e[0m" format "\n", timestr, \ ## __VA_ARGS__); \ } else { \ fprintf(stderr, "%s INFO: " format "\n", timestr, \ ## __VA_ARGS__); \ } \ } \ } \ while (0) #define LOGE(format, ...) \ do { \ if (use_syslog) { \ syslog(LOG_ERR, format, ## __VA_ARGS__); \ } else { \ time_t now = time(NULL); \ char timestr[20]; \ strftime(timestr, 20, TIME_FORMAT, localtime(&now)); \ if (use_tty) { \ fprintf(stderr, "\e[01;35m %s ERROR: \e[0m" format "\n", timestr, \ ## __VA_ARGS__); \ } else { \ fprintf(stderr, " %s ERROR: " format "\n", timestr, \ ## __VA_ARGS__); \ } \ } } \ while (0) #endif /* _WIN32 */ #endif #ifdef __MINGW32__ #ifdef ERROR #undef ERROR #endif #define ERROR(s) ss_error(s) #else void ERROR(const char *s); #endif char *ss_itoa(int i); int run_as(const char *user); void FATAL(const char *msg); void usage(void); void daemonize(const char * path); char *ss_strndup(const char *s, size_t n); #ifdef HAVE_SETRLIMIT int set_nofile(int nofile); #endif #endif // _UTILS_H