~medibuntu-maintainers/mplayer/medibuntu.precise

« back to all changes in this revision

Viewing changes to av_helpers.c

  • Committer: Gauvain Pocentek
  • Date: 2012-03-06 11:59:12 UTC
  • mfrom: (66.1.15 precise)
  • Revision ID: gauvain@pocentek.net-20120306115912-h9d6kt9j0l532oo5
* Merge from Ubuntu:
  - put back faac support
  - recommends apport-hooks-medibuntu
  - change Maintainer, Uploaders & Vcs-* fields.
* New upstream snapshot
* upload to unstable
* Build against external libmpeg2
* drop 51_FTBFS_arm.patch again
* no longer build depend on libcdparanoia-dev on the Hurd
* Fix FTBFS on the hurd.
  Thanks to Samuel Thibault <sthibault@debian.org> (Closes: #654974)
* Fix FTBFS on arm
* New upstream snapshot, Closes: #650339, #643621, #481807
* Imported Upstream version 1.0~rc4+svn34492
* Bump standards version
* Bump dependency on libav >= 4:0.8~, Closes: #653887
* Fix build-indep
* Build mplayer-gui again, Closes: #568514
* Drop debian/all-lang-config-mak.sh, no longer needed
* include .dfsg1 in version number
* remove get-orig-source target
* no longer prune compiler flags from the environment
* No longer advertise nor build 3fdx, mga and dxr3 backends,
  Closes: #496106, #442181, #533546
* beautify mplayer version identification string
* Brown paperbag upload.
* Next try to fix build failure on sparce after recent binutils change.
* Brown paperbag upload.
* Really fix build failure on sparc after recent binutils change.
* Properly set Replaces/Conflicts on mplayer2{,-dbg} to avoid
  file overwrite errors.
* Adjust versioning of mplayer listed in the mplayer-dbg's Depends field.
* Fix build failure on sparc after recent binutils change.
* Urgency medium bumped because of RC-level bugfix
  and speeding up x264 transition.
* Update to my @debian.org email.
* Upload to unstable
* Enable joystick support on Linux only, Closes: #638408
* Rebuild fixes toolchain issue on arm, Closes: #637077
* New upstream snapshot
* following the discussion started by Diego Biurrun <diego@biurrun.de>
  in debian-devel, I have prepared a new packaging of 'mplayer'
  (with code that comes from CVS)
* the upstream tar.bz cannot be distributed by Debian, since it contains
   CSS code; so I am repackaging it 
* I have tried my best to address all known issues:
  - the package contains the detailed Copyright made by Diego Biurrun 
  - the package does not contain CSS code, or  AFAIK other code on which 
     there is active patent enforcement
  - there is a script  debian/cvs-changelog.sh  that shows all changes
     done to files included in this source.
    This should comply with GPLv2 sec 2.a  (in spirit if not in letter)
    For this reason, the source code contains CVS directories.
* needs   make (>= 3.80) for 'html-chunked-$(1)' in DOCS/xml/Makefile

* some corrections, as suggested Diego Biurrun
  - binary codecs should go into /usr/lib/codecs (upstream default)
  - better template 'mplayer/install_codecs'
  - an empty 'font=' in mplayer.conf breaks mplayer: postinst corrected
* correction in 'mplayer/cfgnote'
* better mplayer.postinst and mplayer.config

* New upstream release
* better debian/copyright file
* do not ship a skin
* New upstream release
* changed DEB_BUILD_OPTIONS to DEB_BUILD_CONFIGURE ,
  DEB_BUILD_OPTIONS is used as in debian policy
* use gcc-3.4
* changed xlibs-dev to a long list of dependencies, for Debian/etch
* try to adhere to  http://www.mplayerhq.hu/DOCS/tech/binary-packaging.txt
  (see README.Debian for details)
* removed dependency on xlibmesa-dev, disabled opengl
* New upstream release
* Simon McVittie <hacks@pseudorandom.co.uk> wonderful work:
- Work around Debian bug #267442 (glibc's sys/uio.h and gcc's altivec.h have
  conflicting uses for __vector) by re-ordering #includes
- Fix potential symlink attack in ./configure
- Disable support for binary codecs on platforms for which those codecs
  aren't available; also disable the corresponding Debconf note when it's
  inappropriate
- Changed Build-Depends: so it works in pbuilder
- Explicitly build-depend on libjpeg62-dev, libfontconfig1-dev,
  libungif4-dev 
- Tweak debian/rules to avoid certain errors being ignored
- Use --language=all
* provide a target  'debian/rules get-orig-source' 
  that recreates the orig.tar.gz ; then use the above orig.tar.gz
* rewrote some parts of debian/rules
* don't clean and recompile docs if upstream ships them
* mplayer-doc was shipping too much stuff
* translated man pages where not installed properly
* compile with libdv4-dev
* correct README.Debian
* Forgot build-dep on libtheora
* Must not depend on libxvidcore
* New upstream release
* new release.
* rc1 to become 0.90
* new pre-release
* new pre-release
* gtk bug fixed.
* new release.
* version bumped
* 0.60 pre2 release
* 0.60 pre-release.

Show diffs side-by-side

added added

removed removed

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