blob: 4fcac21d51e7bde949f1325f2c004fbb8150bc84 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
#include "mp_msg.h"
static int mp_msg_levels[MSGT_MAX]; // verbose level of this module
#if 1
void mp_msg_init(int verbose){
int i;
for(i=0;i<MSGT_MAX;i++){
mp_msg_levels[i]=verbose;
}
}
void mp_msg_c( int x, const char *format, ... ){
va_list va;
if((x&255)>mp_msg_levels[x>>8]) return; // do not display
va_start(va, format);
if((x&255)<=MSGL_ERR){
// fprintf(stderr,"%%%%%% ");
vfprintf(stderr,format, va);
} else {
// printf("%%%%%% ");
vprintf(format, va);
}
va_end(va);
}
#else
FILE *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
|