diff --git a/NEWS b/NEWS index 335d1fe66..87354dac8 100644 --- a/NEWS +++ b/NEWS @@ -20,6 +20,10 @@ ver 0.19 (not yet released) * the update thread runs at "idle" priority * the output thread runs at "real-time" priority +ver 0.18.8 (not yet released) +* decoder + - ffmpeg: support libav v10_alpha1 + ver 0.18.7 (2013/01/13) * playlist - pls: fix crash after parser error diff --git a/src/decoder/FfmpegDecoderPlugin.cxx b/src/decoder/FfmpegDecoderPlugin.cxx index 7b827da27..0d4256bd9 100644 --- a/src/decoder/FfmpegDecoderPlugin.cxx +++ b/src/decoder/FfmpegDecoderPlugin.cxx @@ -38,6 +38,10 @@ extern "C" { #include #include #include + +#if LIBAVUTIL_VERSION_MAJOR >= 53 +#include +#endif } #include @@ -453,7 +457,11 @@ ffmpeg_decode(Decoder &decoder, InputStream &input) decoder_initialized(decoder, audio_format, input.seekable, total_time); +#if LIBAVUTIL_VERSION_MAJOR >= 53 + AVFrame *frame = av_frame_alloc(); +#else AVFrame *frame = avcodec_alloc_frame(); +#endif if (!frame) { LogError(ffmpeg_domain, "Could not allocate frame"); avformat_close_input(&format_context); @@ -497,7 +505,9 @@ ffmpeg_decode(Decoder &decoder, InputStream &input) } } while (cmd != DecoderCommand::STOP); -#if LIBAVCODEC_VERSION_INT >= AV_VERSION_INT(54, 28, 0) +#if LIBAVUTIL_VERSION_MAJOR >= 53 + av_frame_free(&frame); +#elif LIBAVCODEC_VERSION_INT >= AV_VERSION_INT(54, 28, 0) avcodec_free_frame(&frame); #else av_freep(&frame);