From 56b74ad990d8d6180fe47fbb271469b2825d2d42 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Fri, 9 Feb 2018 19:04:45 +0100 Subject: [PATCH] filter/convert: add method IsActive() --- src/filter/plugins/ConvertFilterPlugin.cxx | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/src/filter/plugins/ConvertFilterPlugin.cxx b/src/filter/plugins/ConvertFilterPlugin.cxx index 1ede2c03e..bcc70fcd5 100644 --- a/src/filter/plugins/ConvertFilterPlugin.cxx +++ b/src/filter/plugins/ConvertFilterPlugin.cxx @@ -57,6 +57,11 @@ public: } ConstBuffer FilterPCM(ConstBuffer src) override; + +private: + bool IsActive() const noexcept { + return out_audio_format != in_audio_format; + } }; class PreparedConvertFilter final : public PreparedFilter { @@ -80,7 +85,7 @@ ConvertFilter::Set(const AudioFormat &_out_audio_format) /* no change */ return; - if (out_audio_format != in_audio_format) { + if (IsActive()) { out_audio_format = in_audio_format; state.Close(); } @@ -111,7 +116,7 @@ ConvertFilter::~ConvertFilter() { assert(in_audio_format.IsValid()); - if (out_audio_format != in_audio_format) + if (IsActive()) state.Close(); } @@ -120,11 +125,10 @@ ConvertFilter::FilterPCM(ConstBuffer src) { assert(in_audio_format.IsValid()); - if (out_audio_format == in_audio_format) + return IsActive() + ? state.Convert(src) /* optimized special case: no-op */ - return src; - - return state.Convert(src); + : src; } const FilterPlugin convert_filter_plugin = {