2001-08-16 22:13:20 +00:00
|
|
|
|
2005-12-06 08:47:32 +00:00
|
|
|
//#define MSG_USE_COLORS
|
2002-08-31 14:54:00 +00:00
|
|
|
|
2001-08-16 22:13:20 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdarg.h>
|
2006-03-27 08:38:32 +00:00
|
|
|
#include <string.h>
|
2001-08-16 22:13:20 +00:00
|
|
|
|
2001-09-20 10:27:24 +00:00
|
|
|
#include "config.h"
|
|
|
|
|
2006-03-08 12:45:48 +00:00
|
|
|
#ifdef USE_ICONV
|
|
|
|
#include <iconv.h>
|
2007-01-26 09:57:09 +00:00
|
|
|
#include <errno.h>
|
2007-04-01 21:59:54 +00:00
|
|
|
extern char* get_term_charset(void);
|
2006-03-08 12:45:48 +00:00
|
|
|
#endif
|
|
|
|
|
2007-03-12 18:35:52 +00:00
|
|
|
#if defined(FOR_MENCODER)
|
2005-09-29 05:21:12 +00:00
|
|
|
#undef HAVE_NEW_GUI
|
2007-10-07 08:41:31 +00:00
|
|
|
int use_gui;
|
2002-12-27 16:17:57 +00:00
|
|
|
#endif
|
|
|
|
|
2005-09-29 05:21:12 +00:00
|
|
|
#ifdef HAVE_NEW_GUI
|
2007-04-23 07:42:42 +00:00
|
|
|
#include "gui/interface.h"
|
2001-09-20 10:27:24 +00:00
|
|
|
#endif
|
2001-08-16 22:13:20 +00:00
|
|
|
#include "mp_msg.h"
|
|
|
|
|
2002-06-05 02:24:35 +00:00
|
|
|
/* maximum message length of mp_msg */
|
|
|
|
#define MSGSIZE_MAX 3072
|
|
|
|
|
2006-03-05 18:28:20 +00:00
|
|
|
int mp_msg_levels[MSGT_MAX]; // verbose level of this module. inited to -2
|
2005-12-07 05:12:07 +00:00
|
|
|
int mp_msg_level_all = MSGL_STATUS;
|
|
|
|
int verbose = 0;
|
2006-03-08 12:45:48 +00:00
|
|
|
#ifdef USE_ICONV
|
|
|
|
char *mp_msg_charset = NULL;
|
|
|
|
static char *old_charset = NULL;
|
|
|
|
static iconv_t msgiconv;
|
|
|
|
#endif
|
2001-08-16 22:13:20 +00:00
|
|
|
|
2007-01-26 09:57:09 +00:00
|
|
|
const char* filename_recode(const char* filename)
|
|
|
|
{
|
|
|
|
#if !defined(USE_ICONV) || !defined(MSG_CHARSET)
|
|
|
|
return filename;
|
|
|
|
#else
|
|
|
|
static iconv_t inv_msgiconv = (iconv_t)(-1);
|
|
|
|
static char recoded_filename[MSGSIZE_MAX];
|
|
|
|
size_t filename_len, max_path;
|
|
|
|
char* precoded;
|
2007-01-27 10:11:40 +00:00
|
|
|
if (!mp_msg_charset ||
|
|
|
|
!strcasecmp(mp_msg_charset, MSG_CHARSET) ||
|
2007-01-27 10:10:05 +00:00
|
|
|
!strcasecmp(mp_msg_charset, "noconv"))
|
|
|
|
return filename;
|
2007-01-26 09:57:09 +00:00
|
|
|
if (inv_msgiconv == (iconv_t)(-1)) {
|
2007-01-27 10:10:05 +00:00
|
|
|
inv_msgiconv = iconv_open(MSG_CHARSET, mp_msg_charset);
|
|
|
|
if (inv_msgiconv == (iconv_t)(-1))
|
|
|
|
return filename;
|
2007-01-26 09:57:09 +00:00
|
|
|
}
|
|
|
|
filename_len = strlen(filename);
|
|
|
|
max_path = MSGSIZE_MAX - 4;
|
|
|
|
precoded = recoded_filename;
|
|
|
|
if (iconv(inv_msgiconv, &filename, &filename_len,
|
2007-01-27 10:10:05 +00:00
|
|
|
&precoded, &max_path) == (size_t)(-1) && errno == E2BIG) {
|
|
|
|
precoded[0] = precoded[1] = precoded[2] = '.';
|
|
|
|
precoded += 3;
|
2007-01-26 09:57:09 +00:00
|
|
|
}
|
|
|
|
*precoded = '\0';
|
|
|
|
return recoded_filename;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2006-02-09 14:08:03 +00:00
|
|
|
void mp_msg_init(void){
|
2005-12-06 08:42:48 +00:00
|
|
|
int i;
|
2006-01-20 20:38:46 +00:00
|
|
|
char *env = getenv("MPLAYER_VERBOSE");
|
|
|
|
if (env)
|
|
|
|
verbose = atoi(env);
|
2005-12-06 08:42:48 +00:00
|
|
|
for(i=0;i<MSGT_MAX;i++) mp_msg_levels[i] = -2;
|
2006-04-24 07:20:34 +00:00
|
|
|
mp_msg_levels[MSGT_IDENTIFY] = -1; // no -identify output by default
|
2006-03-08 12:45:48 +00:00
|
|
|
#ifdef USE_ICONV
|
|
|
|
mp_msg_charset = getenv("MPLAYER_CHARSET");
|
2007-03-04 19:04:08 +00:00
|
|
|
if (!mp_msg_charset)
|
|
|
|
mp_msg_charset = get_term_charset();
|
2006-03-08 12:45:48 +00:00
|
|
|
#endif
|
2001-08-16 22:13:20 +00:00
|
|
|
}
|
|
|
|
|
2002-08-21 21:31:20 +00:00
|
|
|
int mp_msg_test(int mod, int lev)
|
|
|
|
{
|
2005-12-06 08:42:48 +00:00
|
|
|
return lev <= (mp_msg_levels[mod] == -2 ? mp_msg_level_all + verbose : mp_msg_levels[mod]);
|
2002-08-21 21:31:20 +00:00
|
|
|
}
|
|
|
|
|
2005-09-29 05:21:12 +00:00
|
|
|
void mp_msg(int mod, int lev, const char *format, ... ){
|
2002-03-15 21:08:14 +00:00
|
|
|
va_list va;
|
2002-06-05 02:24:35 +00:00
|
|
|
char tmp[MSGSIZE_MAX];
|
2007-12-17 09:02:21 +00:00
|
|
|
|
2005-12-06 08:42:48 +00:00
|
|
|
if (!mp_msg_test(mod, lev)) return; // do not display
|
2002-03-23 19:29:48 +00:00
|
|
|
va_start(va, format);
|
2006-03-30 22:28:32 +00:00
|
|
|
vsnprintf(tmp, MSGSIZE_MAX, format, va);
|
2002-08-31 13:44:03 +00:00
|
|
|
va_end(va);
|
2003-09-12 15:46:16 +00:00
|
|
|
tmp[MSGSIZE_MAX-2] = '\n';
|
2002-06-05 02:24:35 +00:00
|
|
|
tmp[MSGSIZE_MAX-1] = 0;
|
2002-03-15 21:08:14 +00:00
|
|
|
|
2005-09-29 05:21:12 +00:00
|
|
|
#ifdef HAVE_NEW_GUI
|
2002-03-15 21:08:14 +00:00
|
|
|
if(use_gui)
|
2005-09-29 05:21:12 +00:00
|
|
|
guiMessageBox(lev, tmp);
|
2002-03-15 21:08:14 +00:00
|
|
|
#endif
|
|
|
|
|
2006-03-08 12:45:48 +00:00
|
|
|
#if defined(USE_ICONV) && defined(MSG_CHARSET)
|
|
|
|
if (mp_msg_charset && strcasecmp(mp_msg_charset, "noconv")) {
|
|
|
|
char tmp2[MSGSIZE_MAX];
|
|
|
|
size_t inlen = strlen(tmp), outlen = MSGSIZE_MAX;
|
|
|
|
char *in = tmp, *out = tmp2;
|
|
|
|
if (!old_charset || strcmp(old_charset, mp_msg_charset)) {
|
|
|
|
if (old_charset) {
|
|
|
|
free(old_charset);
|
|
|
|
iconv_close(msgiconv);
|
|
|
|
}
|
|
|
|
msgiconv = iconv_open(mp_msg_charset, MSG_CHARSET);
|
|
|
|
old_charset = strdup(mp_msg_charset);
|
|
|
|
}
|
2006-03-24 02:31:29 +00:00
|
|
|
if (msgiconv == (iconv_t)(-1)) {
|
|
|
|
fprintf(stderr,"iconv: conversion from %s to %s unsupported\n"
|
2006-08-27 08:10:07 +00:00
|
|
|
,MSG_CHARSET,mp_msg_charset);
|
2006-03-24 02:31:29 +00:00
|
|
|
}else{
|
2006-03-08 12:45:48 +00:00
|
|
|
memset(tmp2, 0, MSGSIZE_MAX);
|
|
|
|
while (iconv(msgiconv, &in, &inlen, &out, &outlen) == -1) {
|
|
|
|
if (!inlen || !outlen)
|
|
|
|
break;
|
|
|
|
*out++ = *in++;
|
|
|
|
outlen--; inlen--;
|
|
|
|
}
|
|
|
|
strncpy(tmp, tmp2, MSGSIZE_MAX);
|
|
|
|
tmp[MSGSIZE_MAX-1] = 0;
|
|
|
|
tmp[MSGSIZE_MAX-2] = '\n';
|
2006-03-24 02:31:29 +00:00
|
|
|
}
|
2006-03-08 12:45:48 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2002-08-31 14:54:00 +00:00
|
|
|
#ifdef MSG_USE_COLORS
|
2003-07-13 14:43:28 +00:00
|
|
|
/* that's only a silly color test */
|
2005-09-03 19:27:48 +00:00
|
|
|
#ifdef MP_ANNOY_ME
|
2002-08-31 14:54:00 +00:00
|
|
|
{ int c;
|
|
|
|
static int flag=1;
|
|
|
|
if(flag)
|
2005-09-03 19:27:48 +00:00
|
|
|
for(c=0;c<24;c++)
|
2002-08-31 14:54:00 +00:00
|
|
|
printf("\033[%d;3%dm*** COLOR TEST %d ***\n",(c>7),c&7,c);
|
|
|
|
flag=0;
|
|
|
|
}
|
2007-12-17 09:02:21 +00:00
|
|
|
#endif
|
2007-01-27 10:10:05 +00:00
|
|
|
{ unsigned char v_colors[10]={9,1,3,15,7,2,2,8,8,8};
|
2006-12-18 18:50:46 +00:00
|
|
|
static const char *mod_text[MSGT_MAX]= {
|
2005-09-03 19:27:48 +00:00
|
|
|
"GLOBAL",
|
|
|
|
"CPLAYER",
|
|
|
|
"GPLAYER",
|
|
|
|
"VIDEOOUT",
|
|
|
|
"AUDIOOUT",
|
|
|
|
"DEMUXER",
|
|
|
|
"DS",
|
|
|
|
"DEMUX",
|
|
|
|
"HEADER",
|
|
|
|
"AVSYNC",
|
|
|
|
"AUTOQ",
|
|
|
|
"CFGPARSER",
|
|
|
|
"DECAUDIO",
|
|
|
|
"DECVIDEO",
|
|
|
|
"SEEK",
|
|
|
|
"WIN32",
|
|
|
|
"OPEN",
|
|
|
|
"DVD",
|
|
|
|
"PARSEES",
|
|
|
|
"LIRC",
|
|
|
|
"STREAM",
|
|
|
|
"CACHE",
|
|
|
|
"MENCODER",
|
|
|
|
"XACODEC",
|
|
|
|
"TV",
|
|
|
|
"OSDEP",
|
|
|
|
"SPUDEC",
|
|
|
|
"PLAYTREE",
|
|
|
|
"INPUT",
|
|
|
|
"VFILTER",
|
|
|
|
"OSD",
|
|
|
|
"NETWORK",
|
|
|
|
"CPUDETECT",
|
|
|
|
"CODECCFG",
|
|
|
|
"SWS",
|
|
|
|
"VOBSUB",
|
|
|
|
"SUBREADER",
|
|
|
|
"AFILTER",
|
|
|
|
"NETST",
|
2006-12-18 18:50:46 +00:00
|
|
|
"MUXER",
|
|
|
|
"OSDMENU",
|
|
|
|
"IDENTIFY",
|
|
|
|
"RADIO",
|
|
|
|
"ASS",
|
|
|
|
"LOADER",
|
2007-06-05 16:13:00 +00:00
|
|
|
"STATUSLINE",
|
2006-12-18 18:50:46 +00:00
|
|
|
};
|
2005-09-03 19:27:48 +00:00
|
|
|
|
2005-09-29 05:21:12 +00:00
|
|
|
int c=v_colors[lev];
|
|
|
|
int c2=(mod+1)%15+1;
|
2005-09-03 19:27:48 +00:00
|
|
|
static int header=1;
|
2005-09-29 05:21:12 +00:00
|
|
|
FILE *stream= (lev) <= MSGL_WARN ? stderr : stdout;
|
2005-09-03 19:27:48 +00:00
|
|
|
if(header){
|
2005-09-29 05:21:12 +00:00
|
|
|
fprintf(stream, "\033[%d;3%dm%9s\033[0;37m: ",c2>>3,c2&7, mod_text[mod]);
|
2005-09-03 19:27:48 +00:00
|
|
|
}
|
|
|
|
fprintf(stream, "\033[%d;3%dm",c>>3,c&7);
|
|
|
|
header= tmp[strlen(tmp)-1] == '\n'
|
2006-02-24 14:56:28 +00:00
|
|
|
||tmp[strlen(tmp)-1] == '\r';
|
2002-08-31 14:54:00 +00:00
|
|
|
}
|
|
|
|
#endif
|
2005-09-29 05:21:12 +00:00
|
|
|
if (lev <= MSGL_WARN){
|
2007-01-27 10:10:05 +00:00
|
|
|
fprintf(stderr, "%s", tmp);fflush(stderr);
|
2002-08-31 13:44:03 +00:00
|
|
|
} else {
|
2007-01-27 10:10:05 +00:00
|
|
|
printf("%s", tmp);fflush(stdout);
|
2002-08-31 13:44:03 +00:00
|
|
|
}
|
2001-08-16 22:13:20 +00:00
|
|
|
}
|