forked from pool/audacity
Dirk Mueller
e560b30a80
- Update Source tag for the new _service file-less Factory policy - Add audacity-1.3.13-ffmpeg.patch to compile with latest ffmpeg OBS-URL: https://build.opensuse.org/request/show/79371 OBS-URL: https://build.opensuse.org/package/show/multimedia:apps/audacity?expand=0&rev=52
165 lines
7.0 KiB
Diff
165 lines
7.0 KiB
Diff
--- audacity-src-1.3.13-beta.orig/src/export/ExportFFmpeg.cpp
|
|
+++ audacity-src-1.3.13-beta/src/export/ExportFFmpeg.cpp
|
|
@@ -352,7 +352,7 @@
|
|
avcodec_get_context_defaults(mEncAudioCodecCtx);
|
|
|
|
mEncAudioCodecCtx->codec_id = ExportFFmpegOptions::fmts[mSubFormat].codecid;
|
|
- mEncAudioCodecCtx->codec_type = CODEC_TYPE_AUDIO;
|
|
+ mEncAudioCodecCtx->codec_type = AVMEDIA_TYPE_AUDIO;
|
|
mEncAudioCodecCtx->codec_tag = av_codec_get_tag((const AVCodecTag **)mEncFormatCtx->oformat->codec_tag,mEncAudioCodecCtx->codec_id);
|
|
mSampleRate = (int)project->GetRate();
|
|
mEncAudioCodecCtx->global_quality = -99999; //quality mode is off by default;
|
|
@@ -403,7 +403,6 @@
|
|
mEncAudioCodecCtx->flags2 = 0;
|
|
if (gPrefs->Read(wxT("/FileFormats/FFmpegBitReservoir"),true)) mEncAudioCodecCtx->flags2 |= CODEC_FLAG2_BIT_RESERVOIR;
|
|
if (gPrefs->Read(wxT("/FileFormats/FFmpegVariableBlockLen"),true)) mEncAudioCodecCtx->flags2 |= 0x0004; //WMA only?
|
|
- mEncAudioCodecCtx->use_lpc = gPrefs->Read(wxT("/FileFormats/FFmpegUseLPC"),true);
|
|
mEncAudioCodecCtx->compression_level = gPrefs->Read(wxT("/FileFormats/FFmpegCompLevel"),-1);
|
|
mEncAudioCodecCtx->frame_size = gPrefs->Read(wxT("/FileFormats/FFmpegFrameSize"),(long)0);
|
|
mEncAudioCodecCtx->lpc_coeff_precision = gPrefs->Read(wxT("/FileFormats/FFmpegLPCCoefPrec"),(long)0);
|
|
@@ -569,7 +569,7 @@
|
|
pkt.stream_index = mEncAudioStream->index;
|
|
pkt.data = mEncAudioEncodedBuf;
|
|
pkt.size = nEncodedBytes;
|
|
- pkt.flags |= PKT_FLAG_KEY;
|
|
+ pkt.flags |= AV_PKT_FLAG_KEY;
|
|
|
|
// Set presentation time of frame (currently in the codec's timebase) in the stream timebase.
|
|
if(mEncAudioCodecCtx->coded_frame && mEncAudioCodecCtx->coded_frame->pts != int64_t(AV_NOPTS_VALUE))
|
|
@@ -656,7 +656,7 @@
|
|
|
|
pkt.stream_index = mEncAudioStream->index;
|
|
pkt.data = mEncAudioEncodedBuf;
|
|
- pkt.flags |= PKT_FLAG_KEY;
|
|
+ pkt.flags |= AV_PKT_FLAG_KEY;
|
|
|
|
// Write the encoded audio frame to the output file.
|
|
if ((ret = av_interleaved_write_frame(mEncFormatCtx, &pkt)) != 0)
|
|
--- audacity-src-1.3.13-beta.orig/src/export/ExportFFmpegDialogs.cpp
|
|
+++ audacity-src-1.3.13-beta/src/export/ExportFFmpegDialogs.cpp
|
|
@@ -1288,7 +1288,7 @@
|
|
while ((codec = av_codec_next(codec)))
|
|
{
|
|
// We're only interested in audio and only in encoders
|
|
- if (codec->type == CODEC_TYPE_AUDIO && codec->encode)
|
|
+ if (codec->type == AVMEDIA_TYPE_AUDIO && codec->encode)
|
|
{
|
|
mCodecNames.Add(wxString::FromUTF8(codec->name));
|
|
mCodecLongNames.Add(wxString::Format(wxT("%s - %s"),mCodecNames.Last().c_str(),wxString::FromUTF8(codec->long_name).c_str()));
|
|
@@ -1528,7 +1528,7 @@
|
|
// Find the codec, that is claimed to be compatible
|
|
AVCodec *codec = avcodec_find_encoder(CompatibilityList[i].codec);
|
|
// If it exists, is audio and has encoder
|
|
- if (codec != NULL && (codec->type == CODEC_TYPE_AUDIO) && codec->encode)
|
|
+ if (codec != NULL && (codec->type == AVMEDIA_TYPE_AUDIO) && codec->encode)
|
|
{
|
|
// If it was selected - remember it's new index
|
|
if ((id >= 0) && codec->id == id) index = mShownCodecNames.GetCount();
|
|
@@ -1543,7 +1543,7 @@
|
|
AVCodec *codec = NULL;
|
|
while ((codec = av_codec_next(codec)))
|
|
{
|
|
- if (codec->type == CODEC_TYPE_AUDIO && codec->encode)
|
|
+ if (codec->type == AVMEDIA_TYPE_AUDIO && codec->encode)
|
|
{
|
|
if (mShownCodecNames.Index(wxString::FromUTF8(codec->name)) < 0)
|
|
{
|
|
@@ -1563,7 +1563,7 @@
|
|
if (format != NULL)
|
|
{
|
|
AVCodec *codec = avcodec_find_encoder(format->audio_codec);
|
|
- if (codec != NULL && (codec->type == CODEC_TYPE_AUDIO) && codec->encode)
|
|
+ if (codec != NULL && (codec->type == AVMEDIA_TYPE_AUDIO) && codec->encode)
|
|
{
|
|
if ((id >= 0) && codec->id == id) index = mShownCodecNames.GetCount();
|
|
mShownCodecNames.Add(wxString::FromUTF8(codec->name));
|
|
--- audacity-src-1.3.13-beta.orig/src/FFmpeg.cpp
|
|
+++ audacity-src-1.3.13-beta/src/FFmpeg.cpp
|
|
@@ -316,7 +316,7 @@
|
|
pd.buf_size = 0;
|
|
pd.buf = (unsigned char *) av_malloc(PROBE_BUF_MAX + AVPROBE_PADDING_SIZE);
|
|
if (pd.buf == NULL) {
|
|
- err = AVERROR_NOMEM;
|
|
+ err = AVERROR(ENOMEM);
|
|
goto fail;
|
|
}
|
|
|
|
@@ -381,7 +381,7 @@
|
|
|
|
// Didn't find a suitable format, so bail
|
|
if (!fmt) {
|
|
- err = AVERROR_NOFMT;
|
|
+ err = AVERROR(EILSEQ);
|
|
goto fail;
|
|
}
|
|
|
|
@@ -855,7 +855,6 @@
|
|
FFMPEG_INITDYN(codec, avcodec_find_decoder);
|
|
FFMPEG_INITDYN(codec, avcodec_get_context_defaults);
|
|
FFMPEG_INITDYN(codec, avcodec_open);
|
|
- FFMPEG_INITDYN(codec, avcodec_decode_audio2);
|
|
FFMPEG_INITDYN(codec, avcodec_decode_audio3);
|
|
FFMPEG_INITDYN(codec, avcodec_encode_audio);
|
|
FFMPEG_INITDYN(codec, avcodec_close);
|
|
--- audacity-src-1.3.13-beta.orig/src/FFmpeg.h
|
|
+++ audacity-src-1.3.13-beta/src/FFmpeg.h
|
|
@@ -559,7 +559,11 @@
|
|
FFMPEG_FUNCTION_WITH_RETURN(
|
|
void*,
|
|
av_fast_realloc,
|
|
+#if LIBAVUTIL_VERSION_MAJOR < 51
|
|
(void *ptr, unsigned int *size, unsigned int min_size),
|
|
+#else
|
|
+ (void *ptr, unsigned int *size, size_t min_size),
|
|
+#endif
|
|
(ptr, size, min_size)
|
|
);
|
|
FFMPEG_FUNCTION_WITH_RETURN(
|
|
@@ -747,7 +751,11 @@
|
|
FFMPEG_FUNCTION_WITH_RETURN(
|
|
void*,
|
|
av_malloc,
|
|
+#if LIBAVUTIL_VERSION_MAJOR < 51
|
|
(unsigned int size),
|
|
+#else
|
|
+ (size_t size),
|
|
+#endif
|
|
(size)
|
|
);
|
|
FFMPEG_FUNCTION_NO_RETURN(
|
|
--- audacity-src-1.3.13-beta.orig/src/import/ImportFFmpeg.cpp
|
|
+++ audacity-src-1.3.13-beta/src/import/ImportFFmpeg.cpp
|
|
@@ -416,7 +416,7 @@
|
|
// Fill the stream contexts
|
|
for (unsigned int i = 0; i < mFormatContext->nb_streams; i++)
|
|
{
|
|
- if (mFormatContext->streams[i]->codec->codec_type == CODEC_TYPE_AUDIO)
|
|
+ if (mFormatContext->streams[i]->codec->codec_type == AVMEDIA_TYPE_AUDIO)
|
|
{
|
|
//Create a context
|
|
streamContext *sc = new streamContext;
|
|
--- audacity-src-1.3.13-beta.orig/src/ondemand/ODDecodeFFmpegTask.cpp
|
|
+++ audacity-src-1.3.13-beta/src/ondemand/ODDecodeFFmpegTask.cpp
|
|
@@ -156,7 +156,7 @@
|
|
//test the audio stream(s)
|
|
for (unsigned int i = 0; i < ic->nb_streams; i++)
|
|
{
|
|
- if (ic->streams[i]->codec->codec_type == CODEC_TYPE_AUDIO)
|
|
+ if (ic->streams[i]->codec->codec_type == AVMEDIA_TYPE_AUDIO)
|
|
{
|
|
audioStreamExists = true;
|
|
st = ic->streams[i];
|
|
@@ -573,10 +573,10 @@
|
|
}
|
|
}
|
|
|
|
- // avcodec_decode_audio2() expects the size of the output buffer as the 3rd parameter but
|
|
+ // avcodec_decode_audio3() expects the size of the output buffer as the 3rd parameter but
|
|
// also returns the number of bytes it decoded in the same parameter.
|
|
sc->m_decodedAudioSamplesValidSiz = sc->m_decodedAudioSamplesSiz;
|
|
- nBytesDecoded = avcodec_decode_audio2(sc->m_codecCtx,
|
|
+ nBytesDecoded = avcodec_decode_audio3(sc->m_codecCtx,
|
|
sc->m_decodedAudioSamples, // out
|
|
&sc->m_decodedAudioSamplesValidSiz, // in/out
|
|
pDecode, nDecodeSiz); // in
|