From 77c14692c9b7cb85efb8e1fb1a6024284a75d53c Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Wed, 4 Nov 2020 16:50:10 +0100 Subject: [PATCH] filter/AutoConvert: eliminate AutoConvertFilter if possible If no conversion is necessary, return the child Filter as-is. This allows removing all nullptr checks from AutoConvertFilter. --- .../plugins/AutoConvertFilterPlugin.cxx | 29 ++++++++----------- 1 file changed, 12 insertions(+), 17 deletions(-) diff --git a/src/filter/plugins/AutoConvertFilterPlugin.cxx b/src/filter/plugins/AutoConvertFilterPlugin.cxx index 0fe11cff3..d3eb38447 100644 --- a/src/filter/plugins/AutoConvertFilterPlugin.cxx +++ b/src/filter/plugins/AutoConvertFilterPlugin.cxx @@ -47,9 +47,7 @@ public: void Reset() noexcept override { filter->Reset(); - - if (convert) - convert->Reset(); + convert->Reset(); } ConstBuffer FilterPCM(ConstBuffer src) override; @@ -81,13 +79,14 @@ PreparedAutoConvertFilter::Open(AudioFormat &in_audio_format) /* need to convert? */ - std::unique_ptr convert; - if (in_audio_format != child_audio_format) { - /* yes - create a convert_filter */ + if (in_audio_format == child_audio_format) + /* no */ + return new_filter; - convert = convert_filter_new(in_audio_format, - child_audio_format); - } + /* yes - create a convert_filter */ + + auto convert = convert_filter_new(in_audio_format, + child_audio_format); return std::make_unique(std::move(new_filter), std::move(convert)); @@ -96,20 +95,16 @@ PreparedAutoConvertFilter::Open(AudioFormat &in_audio_format) ConstBuffer AutoConvertFilter::FilterPCM(ConstBuffer src) { - if (convert != nullptr) - src = convert->FilterPCM(src); - + src = convert->FilterPCM(src); return filter->FilterPCM(src); } ConstBuffer AutoConvertFilter::Flush() { - if (convert != nullptr) { - auto result = convert->Flush(); - if (!result.IsNull()) - return filter->FilterPCM(result); - } + auto result = convert->Flush(); + if (!result.IsNull()) + return filter->FilterPCM(result); return filter->Flush(); }