/* $Id$ */ #include #include #include #define CLR_FATAL (PJ_TERM_COLOR_BRIGHT | PJ_TERM_COLOR_R) #define CLR_WARNING (PJ_TERM_COLOR_BRIGHT | PJ_TERM_COLOR_R | PJ_TERM_COLOR_G) #define CLR_INFO (PJ_TERM_COLOR_BRIGHT | PJ_TERM_COLOR_R | PJ_TERM_COLOR_G | \ PJ_TERM_COLOR_B) #define CLR_DEFAULT (PJ_TERM_COLOR_R | PJ_TERM_COLOR_G | PJ_TERM_COLOR_B) static void term_set_color(int level) { #if defined(PJ_TERM_HAS_COLOR) && PJ_TERM_HAS_COLOR != 0 unsigned attr = 0; switch (level) { case 0: case 1: attr = CLR_FATAL; break; case 2: attr = CLR_WARNING; break; case 3: attr = CLR_INFO; break; default: attr = CLR_DEFAULT; break; } pj_term_set_color(attr); #endif } static void term_restore_color(void) { #if defined(PJ_TERM_HAS_COLOR) && PJ_TERM_HAS_COLOR != 0 pj_term_set_color(CLR_DEFAULT); #endif } PJ_DEF(void) pj_log_write(int level, const char *buffer, int len) { PJ_CHECK_STACK(); PJ_UNUSED_ARG(len); /* Copy to terminal/file. */ term_set_color(level); fputs(buffer, stdout); term_restore_color(); fflush(stdout); }