-
Notifications
You must be signed in to change notification settings - Fork 0
/
av_helpers.c
115 lines (104 loc) · 3.84 KB
/
av_helpers.c
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/*
* Generic libav* helpers
*
* This file is part of MPlayer.
*
* MPlayer is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* MPlayer is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with MPlayer; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#include "libavcodec/avcodec.h"
#include "libavformat/avformat.h"
#include "mp_msg.h"
#include "av_helpers.h"
int avcodec_initialized;
int avformat_initialized;
static void mp_msp_av_log_callback(void *ptr, int level, const char *fmt,
va_list vl)
{
static int print_prefix=1;
AVClass *avc= ptr ? *(AVClass **)ptr : NULL;
int type= MSGT_FIXME;
int mp_level;
switch(level){
case AV_LOG_VERBOSE: mp_level = MSGL_V ; break;
case AV_LOG_DEBUG: mp_level= MSGL_V ; break;
case AV_LOG_INFO : mp_level= MSGL_INFO; break;
case AV_LOG_ERROR: mp_level= MSGL_ERR ; break;
default : mp_level= level > AV_LOG_DEBUG ? MSGL_DBG2 : MSGL_ERR; break;
}
if (ptr && !avc)
mp_msg(MSGT_DECVIDEO, MSGL_ERR, "libav* called av_log with context containing a broken AVClass!\n");
if (avc) {
if(!strcmp(avc->class_name, "AVCodecContext")){
AVCodecContext *s= ptr;
if(s->codec){
if(s->codec->type == AVMEDIA_TYPE_AUDIO){
if(s->codec->decode)
type= MSGT_DECAUDIO;
}else if(s->codec->type == AVMEDIA_TYPE_VIDEO){
if(s->codec->decode)
type= MSGT_DECVIDEO;
}
//FIXME subtitles, encoders (what msgt for them? there is no appropriate ...)
}
}else if(!strcmp(avc->class_name, "AVFormatContext")){
AVFormatContext *s= ptr;
if(s->iformat)
type= MSGT_DEMUXER;
else if(s->oformat)
type= MSGT_MUXER;
}
}
if (!mp_msg_test(type, mp_level)) return;
if(print_prefix && avc) {
mp_msg(type, mp_level, "[%s @ %p]", avc->item_name(ptr), avc);
}
print_prefix= strchr(fmt, '\n') != NULL;
mp_msg_va(type, mp_level, fmt, vl);
}
static void show_av_version(int type, const char *name,
int header_ver, int ver, const char *conf)
{
#ifdef CONFIG_FFMPEG_SO
#define FFMPEG_TYPE "external"
#else
#define FFMPEG_TYPE "internal"
#endif
mp_msg(type, MSGL_INFO, "%s version %d.%d.%d (" FFMPEG_TYPE ")\n",
name, ver >> 16, (ver >> 8) & 0xFF, ver & 0xFF);
if (header_ver != ver)
mp_msg(type, MSGL_INFO, "Mismatching header version %d.%d.%d\n",
header_ver >> 16, (header_ver >> 8) & 0xFF, header_ver & 0xFF);
mp_msg(type, MSGL_V, "Configuration: %s\n", conf);
}
void init_avcodec(void)
{
if (!avcodec_initialized) {
show_av_version(MSGT_DECVIDEO, "libavcodec", LIBAVCODEC_VERSION_INT,
avcodec_version(), avcodec_configuration());
avcodec_register_all();
avcodec_initialized = 1;
av_log_set_callback(mp_msp_av_log_callback);
}
}
void init_avformat(void)
{
if (!avformat_initialized) {
show_av_version(MSGT_DEMUX, "libavformat", LIBAVFORMAT_VERSION_INT,
avformat_version(), avformat_configuration());
av_register_all();
avformat_initialized = 1;
av_log_set_callback(mp_msp_av_log_callback);
}
}