lib/ffmpeg/Filter: eliminate class FilterContext
Since AVFilterContext are freed automatically, this wrapper class serves no purpose. Let's remove it.
This commit is contained in:
@@ -32,12 +32,12 @@ extern "C" {
|
||||
FfmpegFilter::FfmpegFilter(const AudioFormat &in_audio_format,
|
||||
const AudioFormat &_out_audio_format,
|
||||
Ffmpeg::FilterGraph &&_graph,
|
||||
Ffmpeg::FilterContext &&_buffer_src,
|
||||
Ffmpeg::FilterContext &&_buffer_sink) noexcept
|
||||
AVFilterContext &_buffer_src,
|
||||
AVFilterContext &_buffer_sink) noexcept
|
||||
:Filter(_out_audio_format),
|
||||
graph(std::move(_graph)),
|
||||
buffer_src(std::move(_buffer_src)),
|
||||
buffer_sink(std::move(_buffer_sink)),
|
||||
buffer_src(_buffer_src),
|
||||
buffer_sink(_buffer_sink),
|
||||
in_format(Ffmpeg::ToFfmpegSampleFormat(in_audio_format.format)),
|
||||
in_sample_rate(in_audio_format.sample_rate),
|
||||
in_channels(in_audio_format.channels),
|
||||
@@ -61,7 +61,7 @@ FfmpegFilter::FilterPCM(ConstBuffer<void> src)
|
||||
|
||||
memcpy(frame.GetData(0), src.data, src.size);
|
||||
|
||||
int err = av_buffersrc_add_frame(buffer_src.get(), frame.get());
|
||||
int err = av_buffersrc_add_frame(&buffer_src, frame.get());
|
||||
if (err < 0)
|
||||
throw MakeFfmpegError(err, "av_buffersrc_write_frame() failed");
|
||||
|
||||
@@ -69,7 +69,7 @@ FfmpegFilter::FilterPCM(ConstBuffer<void> src)
|
||||
|
||||
frame.Unref();
|
||||
|
||||
err = av_buffersink_get_frame(buffer_sink.get(), frame.get());
|
||||
err = av_buffersink_get_frame(&buffer_sink, frame.get());
|
||||
if (err < 0) {
|
||||
if (err == AVERROR(EAGAIN) || err == AVERROR_EOF)
|
||||
return nullptr;
|
||||
|
@@ -30,7 +30,7 @@
|
||||
*/
|
||||
class FfmpegFilter final : public Filter {
|
||||
Ffmpeg::FilterGraph graph;
|
||||
Ffmpeg::FilterContext buffer_src, buffer_sink;
|
||||
AVFilterContext &buffer_src, &buffer_sink;
|
||||
Ffmpeg::Frame frame;
|
||||
|
||||
FfmpegBuffer interleave_buffer;
|
||||
@@ -51,8 +51,8 @@ public:
|
||||
FfmpegFilter(const AudioFormat &in_audio_format,
|
||||
const AudioFormat &_out_audio_format,
|
||||
Ffmpeg::FilterGraph &&_graph,
|
||||
Ffmpeg::FilterContext &&_buffer_src,
|
||||
Ffmpeg::FilterContext &&_buffer_sink) noexcept;
|
||||
AVFilterContext &_buffer_src,
|
||||
AVFilterContext &_buffer_sink) noexcept;
|
||||
|
||||
/* virtual methods from class Filter */
|
||||
ConstBuffer<void> FilterPCM(ConstBuffer<void> src) override;
|
||||
|
@@ -42,14 +42,13 @@ PreparedFfmpegFilter::Open(AudioFormat &in_audio_format)
|
||||
{
|
||||
Ffmpeg::FilterGraph graph;
|
||||
|
||||
auto buffer_src =
|
||||
Ffmpeg::FilterContext::MakeAudioBufferSource(in_audio_format,
|
||||
*graph);
|
||||
auto &buffer_src =
|
||||
Ffmpeg::MakeAudioBufferSource(in_audio_format, *graph);
|
||||
|
||||
auto buffer_sink = Ffmpeg::FilterContext::MakeAudioBufferSink(*graph);
|
||||
auto &buffer_sink = Ffmpeg::MakeAudioBufferSink(*graph);
|
||||
|
||||
Ffmpeg::FilterInOut io_sink("out", *buffer_sink);
|
||||
Ffmpeg::FilterInOut io_src("in", *buffer_src);
|
||||
Ffmpeg::FilterInOut io_sink("out", buffer_sink);
|
||||
Ffmpeg::FilterInOut io_src("in", buffer_src);
|
||||
auto io = graph.Parse(graph_string, std::move(io_sink),
|
||||
std::move(io_src));
|
||||
|
||||
@@ -62,14 +61,14 @@ PreparedFfmpegFilter::Open(AudioFormat &in_audio_format)
|
||||
graph.CheckAndConfigure();
|
||||
|
||||
const auto out_audio_format =
|
||||
Ffmpeg::DetectFilterOutputFormat(in_audio_format, *buffer_src,
|
||||
*buffer_sink);
|
||||
Ffmpeg::DetectFilterOutputFormat(in_audio_format, buffer_src,
|
||||
buffer_sink);
|
||||
|
||||
return std::make_unique<FfmpegFilter>(in_audio_format,
|
||||
out_audio_format,
|
||||
std::move(graph),
|
||||
std::move(buffer_src),
|
||||
std::move(buffer_sink));
|
||||
buffer_src,
|
||||
buffer_sink);
|
||||
}
|
||||
|
||||
static std::unique_ptr<PreparedFilter>
|
||||
|
@@ -42,14 +42,14 @@ OpenHdcdFilter(AudioFormat &in_audio_format)
|
||||
{
|
||||
Ffmpeg::FilterGraph graph;
|
||||
|
||||
auto buffer_src =
|
||||
Ffmpeg::FilterContext::MakeAudioBufferSource(in_audio_format,
|
||||
*graph);
|
||||
auto &buffer_src =
|
||||
Ffmpeg::MakeAudioBufferSource(in_audio_format,
|
||||
*graph);
|
||||
|
||||
auto buffer_sink = Ffmpeg::FilterContext::MakeAudioBufferSink(*graph);
|
||||
auto &buffer_sink = Ffmpeg::MakeAudioBufferSink(*graph);
|
||||
|
||||
Ffmpeg::FilterInOut io_sink("out", *buffer_sink);
|
||||
Ffmpeg::FilterInOut io_src("in", *buffer_src);
|
||||
Ffmpeg::FilterInOut io_sink("out", buffer_sink);
|
||||
Ffmpeg::FilterInOut io_src("in", buffer_src);
|
||||
|
||||
auto io = graph.Parse(hdcd_graph, std::move(io_sink),
|
||||
std::move(io_src));
|
||||
@@ -69,8 +69,8 @@ OpenHdcdFilter(AudioFormat &in_audio_format)
|
||||
return std::make_unique<FfmpegFilter>(in_audio_format,
|
||||
out_audio_format,
|
||||
std::move(graph),
|
||||
std::move(buffer_src),
|
||||
std::move(buffer_sink));
|
||||
buffer_src,
|
||||
buffer_sink);
|
||||
}
|
||||
|
||||
class PreparedHdcdFilter final : public PreparedFilter {
|
||||
|
Reference in New Issue
Block a user