/* This work is licensed under a Creative Commons CCZero 1.0 Universal License. * See http://creativecommons.org/publicdomain/zero/1.0/ for more information. */ #include #include #include "ua_log_stdout.h" #include "ua_types_generated.h" #include "ua_types_generated_handling.h" /* ANSI escape sequences for color output taken from here: * https://stackoverflow.com/questions/3219393/stdlib-and-colored-output-in-c*/ #ifdef _WIN32 # define ANSI_COLOR_RED "" # define ANSI_COLOR_GREEN "" # define ANSI_COLOR_YELLOW "" # define ANSI_COLOR_BLUE "" # define ANSI_COLOR_MAGENTA "" # define ANSI_COLOR_CYAN "" # define ANSI_COLOR_RESET "" #else # define ANSI_COLOR_RED "\x1b[31m" # define ANSI_COLOR_GREEN "\x1b[32m" # define ANSI_COLOR_YELLOW "\x1b[33m" # define ANSI_COLOR_BLUE "\x1b[34m" # define ANSI_COLOR_MAGENTA "\x1b[35m" # define ANSI_COLOR_CYAN "\x1b[36m" # define ANSI_COLOR_RESET "\x1b[0m" #endif #ifdef UA_ENABLE_MULTITHREADING #include static pthread_mutex_t printf_mutex = PTHREAD_MUTEX_INITIALIZER; #endif const char *logLevelNames[6] = {"trace", "debug", ANSI_COLOR_GREEN "info", ANSI_COLOR_YELLOW "warn", ANSI_COLOR_RED "error", ANSI_COLOR_MAGENTA "fatal"}; const char *logCategoryNames[7] = {"network", "channel", "session", "server", "client", "userland", "securitypolicy"}; #ifdef __clang__ __attribute__((__format__(__printf__, 3 , 0))) #endif void UA_Log_Stdout(UA_LogLevel level, UA_LogCategory category, const char *msg, va_list args) { UA_String t = UA_DateTime_toString(UA_DateTime_now()); #ifdef UA_ENABLE_MULTITHREADING pthread_mutex_lock(&printf_mutex); #endif printf("[%.23s] %s/%s" ANSI_COLOR_RESET "\t", t.data, logLevelNames[level], logCategoryNames[category]); vprintf(msg, args); printf("\n"); fflush(stdout); #ifdef UA_ENABLE_MULTITHREADING pthread_mutex_unlock(&printf_mutex); #endif UA_ByteString_deleteMembers(&t); }