📄 mp_msg.c
字号:
//#define MSG_USE_COLORS#include <stdio.h>#include <stdlib.h>#include <stdarg.h>#include "config.h"#if defined(FOR_MENCODER) || defined(CODECS2HTML)#undef ENABLE_GUI_CODE#elif defined(HAVE_NEW_GUI)#define ENABLE_GUI_CODE HAVE_NEW_GUI#else#undef ENABLE_GUI_CODE#endif#if ENABLE_GUI_CODE#include "Gui/mplayer/widgets.h"extern void gtkMessageBox( int type,char * str );extern int use_gui;#endif#include "mp_msg.h"/* maximum message length of mp_msg */#define MSGSIZE_MAX 3072static int mp_msg_levels[MSGT_MAX]; // verbose level of this module#if 1void mp_msg_init(){#ifdef USE_I18N#ifdef MP_DEBUG fprintf(stdout, "Using GNU internationalization\n"); fprintf(stdout, "Original domain: %s\n", textdomain(NULL)); fprintf(stdout, "Original dirname: %s\n", bindtextdomain(textdomain(NULL),NULL));#endif bindtextdomain("mplayer", PREFIX"/share/locale"); textdomain("mplayer");#ifdef MP_DEBUG fprintf(stdout, "Current domain: %s\n", textdomain(NULL)); fprintf(stdout, "Current dirname: %s\n\n", bindtextdomain(textdomain(NULL),NULL));#endif#endif mp_msg_set_level(MSGL_STATUS);}void mp_msg_set_level(int verbose){ int i; for(i=0;i<MSGT_MAX;i++){ mp_msg_levels[i]=verbose; }}int mp_msg_test(int mod, int lev){ return lev <= mp_msg_levels[mod];}void mp_msg_c( int x, const char *format, ... ){#if 1 va_list va; char tmp[MSGSIZE_MAX]; if((x&255)>mp_msg_levels[x>>8]) return; // do not display va_start(va, format); vsnprintf(tmp, MSGSIZE_MAX, mp_gettext(format), va); va_end(va); tmp[MSGSIZE_MAX-2] = '\n'; tmp[MSGSIZE_MAX-1] = 0;#if ENABLE_GUI_CODE if(use_gui) { switch(x & 255) { case MSGL_FATAL: gtkMessageBox(GTK_MB_FATAL|GTK_MB_SIMPLE, tmp); break; case MSGL_ERR: gtkMessageBox(GTK_MB_ERROR|GTK_MB_SIMPLE, tmp); break;#if 0// WARNING! Do NOT enable this! There are too many non-critical messages with// MSGL_WARN, for example: broken SPU packets, codec's bit error messages,// etc etc, they should not raise up a new window every time. case MSGL_WARN: gtkMessageBox(GTK_MB_WARNING|GTK_MB_SIMPLE, tmp); break;#endif } }#endif#ifdef MSG_USE_COLORS/* that's only a silly color test */#ifdef MP_DEBUG { int c; static int flag=1; if(flag) for(c=0;c<16;c++) printf("\033[%d;3%dm*** COLOR TEST %d ***\n",(c>7),c&7,c); flag=0; }#endif { unsigned char v_colors[10]={9,9,11,14,15,7,6,5,5,5}; int c=v_colors[(x & 255)]; fprintf(((x & 255) <= MSGL_WARN)?stderr:stdout, "\033[%d;3%dm",(c>7),c&7); }#endif if ((x & 255) <= MSGL_WARN){ fprintf(stderr, "%s", tmp);fflush(stderr); } else { printf("%s", tmp);fflush(stdout); }#else va_list va; if((x&255)>mp_msg_levels[x>>8]) return; // do not display va_start(va, format);#if ENABLE_GUI_CODE if(use_gui){ char tmp[16*80]; vsnprintf( tmp,8*80,format,va ); tmp[8*80-1]=0; switch( x&255 ) { case MSGL_FATAL: fprintf( stderr,"%s",tmp ); fflush(stderr); gtkMessageBox( GTK_MB_FATAL|GTK_MB_SIMPLE,tmp ); break; case MSGL_ERR: fprintf( stderr,"%s",tmp ); fflush(stderr); gtkMessageBox( GTK_MB_ERROR|GTK_MB_SIMPLE,tmp ); break; case MSGL_WARN: fprintf( stderr, "%s",tmp ); fflush(stdout); gtkMessageBox( GTK_MB_WARNING|GTK_MB_SIMPLE,tmp ); break; default: fprintf(stderr, "%s",tmp ); fflush(stdout); } } else#endif if((x&255)<=MSGL_ERR){// fprintf(stderr,"%%%%%% "); vfprintf(stderr,format, va); fflush(stderr); } else {// printf("%%%%%% "); vfprintf(stderr,format, va); fflush(stdout); } va_end(va);#endif}#elseFILE *mp_msg_file[MSGT_MAX]; // print message to this file (can be stdout/err)static FILE* mp_msg_last_file=NULL;// how to handle errors->stderr messages->stdout ?void mp_msg( int x, const char *format, ... ){ if((x&255)>mp_msg_levels[x>>8] || !mp_msg_file[x>>8]) return; // do not display va_list va; va_start(va, format); vfprintf(mp_msg_file[x>>8],format, va); if(mp_msg_last_file!=mp_msg_file[x>>8]){ fflush(mp_msg_file[x>>8]); mp_msg_last_file=mp_msg_file[x>>8]; } va_end(va);}#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -