diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2014-04-03 20:40:33 +0200 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2014-04-03 20:44:14 +0200 |
commit | c16e00618122a7f1217f5174a6c4013eb57421b0 (patch) | |
tree | a89cf01819d097408ed3ce96d3d7cc28e399149e /libavutil/log.c | |
parent | 061e340c05bde91ac988677e47bc562b04be5c20 (diff) | |
parent | 7763118cae4eb468b032dbd29af15a011c2c233b (diff) | |
download | ffmpeg-c16e00618122a7f1217f5174a6c4013eb57421b0.tar.gz |
Merge commit '7763118cae4eb468b032dbd29af15a011c2c233b'
* commit '7763118cae4eb468b032dbd29af15a011c2c233b':
log: Support for 256color terminals
Conflicts:
doc/APIchanges
libavutil/log.c
libavutil/version.h
Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavutil/log.c')
-rw-r--r-- | libavutil/log.c | 22 |
1 files changed, 17 insertions, 5 deletions
diff --git a/libavutil/log.c b/libavutil/log.c index af293e724b..b39196d5ff 100644 --- a/libavutil/log.c +++ b/libavutil/log.c @@ -126,9 +126,11 @@ static void check_color_terminal(void) background = attr_orig & 0xF0; } #elif HAVE_ISATTY + char *term = getenv("TERM"); use_color = !getenv("NO_COLOR") && !getenv("AV_LOG_FORCE_NOCOLOR") && (getenv("TERM") && isatty(2) || getenv("AV_LOG_FORCE_COLOR")); - if (getenv("AV_LOG_FORCE_256COLOR")) + if ( getenv("AV_LOG_FORCE_256COLOR") + || strstr(term, "256color")); use_color *= 256; #else use_color = getenv("AV_LOG_FORCE_COLOR") && !getenv("NO_COLOR") && @@ -136,7 +138,7 @@ static void check_color_terminal(void) #endif } -static void colored_fputs(int level, const char *str) +static void colored_fputs(int level, int tint, const char *str) { if (!*str) return; @@ -157,6 +159,12 @@ static void colored_fputs(int level, const char *str) (color[level] >> 4) & 15, color[level] & 15, str); + } else if (tint && use_color == 256) { + fprintf(stderr, + "\033[48;5;%dm\033[38;5;%dm%s\033[0m", + (color[level] >> 16) & 0xff, + tint, + str); } else if (use_color == 256 && level != AV_LOG_INFO/8) { fprintf(stderr, "\033[48;5;%dm\033[38;5;%dm%s\033[0m", @@ -250,6 +258,10 @@ void av_log_default_callback(void* ptr, int level, const char* fmt, va_list vl) char line[LINE_SZ]; static int is_atty; int type[2]; + int tint = av_clip(level >> 8, 0, 256); + + level &= 0xff; + if (level > av_log_level) return; @@ -278,11 +290,11 @@ void av_log_default_callback(void* ptr, int level, const char* fmt, va_list vl) } strcpy(prev, line); sanitize(part[0].str); - colored_fputs(type[0], part[0].str); + colored_fputs(type[0], 0, part[0].str); sanitize(part[1].str); - colored_fputs(type[1], part[1].str); + colored_fputs(type[1], 0, part[1].str); sanitize(part[2].str); - colored_fputs(av_clip(level >> 3, 0, 6), part[2].str); + colored_fputs(av_clip(level >> 3, 0, 6), tint, part[2].str); end: av_bprint_finalize(part+2, NULL); #if HAVE_PTHREADS |