aboutsummaryrefslogtreecommitdiffstats
path: root/libavutil/log.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2014-04-03 20:40:33 +0200
committerMichael Niedermayer <michaelni@gmx.at>2014-04-03 20:44:14 +0200
commitc16e00618122a7f1217f5174a6c4013eb57421b0 (patch)
treea89cf01819d097408ed3ce96d3d7cc28e399149e /libavutil/log.c
parent061e340c05bde91ac988677e47bc562b04be5c20 (diff)
parent7763118cae4eb468b032dbd29af15a011c2c233b (diff)
downloadffmpeg-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.c22
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