mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-28 06:56:01 -05:00
[xcode] Modifications for ffmpeg 5 (fixes #1396)
This commit is contained in:
parent
119eb46daa
commit
b5087e110f
@ -452,7 +452,12 @@ static int
|
|||||||
stream_add(struct encode_ctx *ctx, struct stream_ctx *s, enum AVCodecID codec_id)
|
stream_add(struct encode_ctx *ctx, struct stream_ctx *s, enum AVCodecID codec_id)
|
||||||
{
|
{
|
||||||
const AVCodecDescriptor *codec_desc;
|
const AVCodecDescriptor *codec_desc;
|
||||||
|
#if (LIBAVFORMAT_VERSION_MAJOR > 59) || ((LIBAVFORMAT_VERSION_MAJOR == 59) && (LIBAVFORMAT_VERSION_MINOR > 15))
|
||||||
|
const AVCodec *encoder;
|
||||||
|
#else
|
||||||
|
// Not const before ffmpeg 5.0
|
||||||
AVCodec *encoder;
|
AVCodec *encoder;
|
||||||
|
#endif
|
||||||
AVDictionary *options = NULL;
|
AVDictionary *options = NULL;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
@ -916,7 +921,12 @@ avio_evbuffer_close(AVIOContext *s)
|
|||||||
static int
|
static int
|
||||||
open_decoder(AVCodecContext **dec_ctx, unsigned int *stream_index, struct decode_ctx *ctx, enum AVMediaType type)
|
open_decoder(AVCodecContext **dec_ctx, unsigned int *stream_index, struct decode_ctx *ctx, enum AVMediaType type)
|
||||||
{
|
{
|
||||||
|
#if (LIBAVFORMAT_VERSION_MAJOR > 59) || ((LIBAVFORMAT_VERSION_MAJOR == 59) && (LIBAVFORMAT_VERSION_MINOR > 15))
|
||||||
|
const AVCodec *decoder;
|
||||||
|
#else
|
||||||
|
// Not const before ffmpeg 5.0
|
||||||
AVCodec *decoder;
|
AVCodec *decoder;
|
||||||
|
#endif
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
ret = av_find_best_stream(ctx->ifmt_ctx, type, -1, -1, &decoder, 0);
|
ret = av_find_best_stream(ctx->ifmt_ctx, type, -1, -1, &decoder, 0);
|
||||||
@ -964,7 +974,12 @@ open_input(struct decode_ctx *ctx, const char *path, struct transcode_evbuf_io *
|
|||||||
{
|
{
|
||||||
AVDictionary *options = NULL;
|
AVDictionary *options = NULL;
|
||||||
AVCodecContext *dec_ctx;
|
AVCodecContext *dec_ctx;
|
||||||
|
#if (LIBAVFORMAT_VERSION_MAJOR > 59) || ((LIBAVFORMAT_VERSION_MAJOR == 59) && (LIBAVFORMAT_VERSION_MINOR > 15))
|
||||||
|
const AVInputFormat *ifmt;
|
||||||
|
#else
|
||||||
|
// Not const before ffmpeg 5.0
|
||||||
AVInputFormat *ifmt;
|
AVInputFormat *ifmt;
|
||||||
|
#endif
|
||||||
unsigned int stream_index;
|
unsigned int stream_index;
|
||||||
const char *user_agent;
|
const char *user_agent;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
@ -1084,7 +1099,12 @@ close_input(struct decode_ctx *ctx)
|
|||||||
static int
|
static int
|
||||||
open_output(struct encode_ctx *ctx, struct decode_ctx *src_ctx)
|
open_output(struct encode_ctx *ctx, struct decode_ctx *src_ctx)
|
||||||
{
|
{
|
||||||
|
#if (LIBAVFORMAT_VERSION_MAJOR > 59) || ((LIBAVFORMAT_VERSION_MAJOR == 59) && (LIBAVFORMAT_VERSION_MINOR > 15))
|
||||||
|
const AVOutputFormat *oformat;
|
||||||
|
#else
|
||||||
|
// Not const before ffmpeg 5.0
|
||||||
AVOutputFormat *oformat;
|
AVOutputFormat *oformat;
|
||||||
|
#endif
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
oformat = av_guess_format(ctx->settings.format, NULL, NULL);
|
oformat = av_guess_format(ctx->settings.format, NULL, NULL);
|
||||||
@ -1094,12 +1114,17 @@ open_output(struct encode_ctx *ctx, struct decode_ctx *src_ctx)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clear AVFMT_NOFILE bit, it is not allowed as we will set our own AVIOContext
|
#if (LIBAVFORMAT_VERSION_MAJOR > 59) || ((LIBAVFORMAT_VERSION_MAJOR == 59) && (LIBAVFORMAT_VERSION_MINOR > 15))
|
||||||
|
CHECK_ERRNO(L_XCODE, avformat_alloc_output_context2(&ctx->ofmt_ctx, oformat, NULL, NULL));
|
||||||
|
#else
|
||||||
|
// Clear AVFMT_NOFILE bit, it is not allowed as we will set our own AVIOContext.
|
||||||
|
// If this is not done with e.g. ffmpeg 3.4 then artwork rescaling will fail.
|
||||||
oformat->flags &= ~AVFMT_NOFILE;
|
oformat->flags &= ~AVFMT_NOFILE;
|
||||||
|
|
||||||
CHECK_NULL(L_XCODE, ctx->ofmt_ctx = avformat_alloc_context());
|
CHECK_NULL(L_XCODE, ctx->ofmt_ctx = avformat_alloc_context());
|
||||||
|
|
||||||
ctx->ofmt_ctx->oformat = oformat;
|
ctx->ofmt_ctx->oformat = oformat;
|
||||||
|
#endif
|
||||||
|
|
||||||
ctx->obuf = evbuffer_new();
|
ctx->obuf = evbuffer_new();
|
||||||
if (!ctx->obuf)
|
if (!ctx->obuf)
|
||||||
@ -1513,7 +1538,12 @@ transcode_decode_setup_raw(enum transcode_profile profile, struct media_quality
|
|||||||
{
|
{
|
||||||
const AVCodecDescriptor *codec_desc;
|
const AVCodecDescriptor *codec_desc;
|
||||||
struct decode_ctx *ctx;
|
struct decode_ctx *ctx;
|
||||||
|
#if (LIBAVFORMAT_VERSION_MAJOR > 59) || ((LIBAVFORMAT_VERSION_MAJOR == 59) && (LIBAVFORMAT_VERSION_MINOR > 15))
|
||||||
|
const AVCodec *decoder;
|
||||||
|
#else
|
||||||
|
// Not const before ffmpeg 5.0
|
||||||
AVCodec *decoder;
|
AVCodec *decoder;
|
||||||
|
#endif
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
CHECK_NULL(L_XCODE, ctx = calloc(1, sizeof(struct decode_ctx)));
|
CHECK_NULL(L_XCODE, ctx = calloc(1, sizeof(struct decode_ctx)));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user