diff options
author | Max Kellermann <max@duempel.org> | 2014-08-12 16:09:07 +0200 |
---|---|---|
committer | Max Kellermann <max@duempel.org> | 2014-08-12 16:40:51 +0200 |
commit | 7244dc45110118631c16448907c344163bcb402c (patch) | |
tree | cd6a05d27069d6f5234cb8f0af7c7c5034362cef /src/filter/plugins | |
parent | 56f61a6d59cfc6a97005d85599963cafdfdeaba8 (diff) | |
download | mpd-7244dc45110118631c16448907c344163bcb402c.tar.gz mpd-7244dc45110118631c16448907c344163bcb402c.tar.xz mpd-7244dc45110118631c16448907c344163bcb402c.zip |
Filter: FilterPCM() returns ConstBuffer
API simplification. We can now avoid abusing a "size_t*" as
additional return value.
Diffstat (limited to 'src/filter/plugins')
-rw-r--r-- | src/filter/plugins/AutoConvertFilterPlugin.cxx | 17 | ||||
-rw-r--r-- | src/filter/plugins/ChainFilterPlugin.cxx | 16 | ||||
-rw-r--r-- | src/filter/plugins/ConvertFilterPlugin.cxx | 18 | ||||
-rw-r--r-- | src/filter/plugins/NormalizeFilterPlugin.cxx | 20 | ||||
-rw-r--r-- | src/filter/plugins/NullFilterPlugin.cxx | 7 | ||||
-rw-r--r-- | src/filter/plugins/ReplayGainFilterPlugin.cxx | 13 | ||||
-rw-r--r-- | src/filter/plugins/RouteFilterPlugin.cxx | 20 | ||||
-rw-r--r-- | src/filter/plugins/VolumeFilterPlugin.cxx | 13 |
8 files changed, 53 insertions, 71 deletions
diff --git a/src/filter/plugins/AutoConvertFilterPlugin.cxx b/src/filter/plugins/AutoConvertFilterPlugin.cxx index cdeeefdc6..8586cb86e 100644 --- a/src/filter/plugins/AutoConvertFilterPlugin.cxx +++ b/src/filter/plugins/AutoConvertFilterPlugin.cxx @@ -25,6 +25,7 @@ #include "filter/FilterRegistry.hxx" #include "AudioFormat.hxx" #include "config/ConfigData.hxx" +#include "util/ConstBuffer.hxx" #include <assert.h> @@ -48,9 +49,8 @@ public: virtual AudioFormat Open(AudioFormat &af, Error &error) override; virtual void Close() override; - virtual const void *FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, - Error &error) override; + virtual ConstBuffer<void> FilterPCM(ConstBuffer<void> src, + Error &error) override; }; AudioFormat @@ -111,17 +111,16 @@ AutoConvertFilter::Close() filter->Close(); } -const void * -AutoConvertFilter::FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, Error &error) +ConstBuffer<void> +AutoConvertFilter::FilterPCM(ConstBuffer<void> src, Error &error) { if (convert != nullptr) { - src = convert->FilterPCM(src, src_size, &src_size, error); - if (src == nullptr) + src = convert->FilterPCM(src, error); + if (src.IsNull()) return nullptr; } - return filter->FilterPCM(src, src_size, dest_size_r, error); + return filter->FilterPCM(src, error); } Filter * diff --git a/src/filter/plugins/ChainFilterPlugin.cxx b/src/filter/plugins/ChainFilterPlugin.cxx index 7dc6db667..7342beb14 100644 --- a/src/filter/plugins/ChainFilterPlugin.cxx +++ b/src/filter/plugins/ChainFilterPlugin.cxx @@ -25,6 +25,7 @@ #include "AudioFormat.hxx" #include "util/Error.hxx" #include "util/Domain.hxx" +#include "util/ConstBuffer.hxx" #include <list> @@ -54,8 +55,8 @@ public: virtual AudioFormat Open(AudioFormat &af, Error &error) override; virtual void Close(); - virtual const void *FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, Error &error); + virtual ConstBuffer<void> FilterPCM(ConstBuffer<void> src, + Error &error); private: /** @@ -143,21 +144,18 @@ ChainFilter::Close() child.filter->Close(); } -const void * -ChainFilter::FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, Error &error) +ConstBuffer<void> +ChainFilter::FilterPCM(ConstBuffer<void> src, Error &error) { for (auto &child : children) { /* feed the output of the previous filter as input into the current one */ - src = child.filter->FilterPCM(src, src_size, &src_size, - error); - if (src == nullptr) + src = child.filter->FilterPCM(src, error); + if (src.IsNull()) return nullptr; } /* return the output of the last filter */ - *dest_size_r = src_size; return src; } diff --git a/src/filter/plugins/ConvertFilterPlugin.cxx b/src/filter/plugins/ConvertFilterPlugin.cxx index 535330cfe..5c6a07ba1 100644 --- a/src/filter/plugins/ConvertFilterPlugin.cxx +++ b/src/filter/plugins/ConvertFilterPlugin.cxx @@ -54,9 +54,8 @@ public: virtual AudioFormat Open(AudioFormat &af, Error &error) override; virtual void Close() override; - virtual const void *FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, - Error &error) override; + virtual ConstBuffer<void> FilterPCM(ConstBuffer<void> src, + Error &error) override; }; static Filter * @@ -119,21 +118,16 @@ ConvertFilter::Close() poison_undefined(&out_audio_format, sizeof(out_audio_format)); } -const void * -ConvertFilter::FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, Error &error) +ConstBuffer<void> +ConvertFilter::FilterPCM(ConstBuffer<void> src, Error &error) { assert(in_audio_format.IsValid()); - if (!out_audio_format.IsValid()) { + if (!out_audio_format.IsValid()) /* optimized special case: no-op */ - *dest_size_r = src_size; return src; - } - auto result = state->Convert({src, src_size}, error); - *dest_size_r = result.size; - return result.data; + return state->Convert(src, error); } const struct filter_plugin convert_filter_plugin = { diff --git a/src/filter/plugins/NormalizeFilterPlugin.cxx b/src/filter/plugins/NormalizeFilterPlugin.cxx index 58eb0c6a2..a69df2b81 100644 --- a/src/filter/plugins/NormalizeFilterPlugin.cxx +++ b/src/filter/plugins/NormalizeFilterPlugin.cxx @@ -24,6 +24,7 @@ #include "pcm/PcmBuffer.hxx" #include "AudioFormat.hxx" #include "AudioCompress/compress.h" +#include "util/ConstBuffer.hxx" #include <string.h> @@ -35,8 +36,8 @@ class NormalizeFilter final : public Filter { public: virtual AudioFormat Open(AudioFormat &af, Error &error) override; virtual void Close(); - virtual const void *FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, Error &error); + virtual ConstBuffer<void> FilterPCM(ConstBuffer<void> src, + Error &error) override; }; static Filter * @@ -63,17 +64,14 @@ NormalizeFilter::Close() Compressor_delete(compressor); } -const void * -NormalizeFilter::FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, gcc_unused Error &error) +ConstBuffer<void> +NormalizeFilter::FilterPCM(ConstBuffer<void> src, gcc_unused Error &error) { - int16_t *dest = (int16_t *)buffer.Get(src_size); - memcpy(dest, src, src_size); + int16_t *dest = (int16_t *)buffer.Get(src.size); + memcpy(dest, src.data, src.size); - Compressor_Process_int16(compressor, dest, src_size / 2); - - *dest_size_r = src_size; - return dest; + Compressor_Process_int16(compressor, dest, src.size / 2); + return { (const void *)dest, src.size }; } const struct filter_plugin normalize_filter_plugin = { diff --git a/src/filter/plugins/NullFilterPlugin.cxx b/src/filter/plugins/NullFilterPlugin.cxx index f79aa19f7..ebd8e4ec5 100644 --- a/src/filter/plugins/NullFilterPlugin.cxx +++ b/src/filter/plugins/NullFilterPlugin.cxx @@ -30,6 +30,7 @@ #include "filter/FilterRegistry.hxx" #include "AudioFormat.hxx" #include "Compiler.h" +#include "util/ConstBuffer.hxx" class NullFilter final : public Filter { public: @@ -40,10 +41,8 @@ public: virtual void Close() override {} - virtual const void *FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, - gcc_unused Error &error) override { - *dest_size_r = src_size; + virtual ConstBuffer<void> FilterPCM(ConstBuffer<void> src, + gcc_unused Error &error) override { return src; } }; diff --git a/src/filter/plugins/ReplayGainFilterPlugin.cxx b/src/filter/plugins/ReplayGainFilterPlugin.cxx index a5d9668cc..651352ac9 100644 --- a/src/filter/plugins/ReplayGainFilterPlugin.cxx +++ b/src/filter/plugins/ReplayGainFilterPlugin.cxx @@ -114,8 +114,8 @@ public: virtual AudioFormat Open(AudioFormat &af, Error &error) override; virtual void Close(); - virtual const void *FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, Error &error); + virtual ConstBuffer<void> FilterPCM(ConstBuffer<void> src, + Error &error) override; }; void @@ -170,13 +170,10 @@ ReplayGainFilter::Close() pv.Close(); } -const void * -ReplayGainFilter::FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, gcc_unused Error &error) +ConstBuffer<void> +ReplayGainFilter::FilterPCM(ConstBuffer<void> src, gcc_unused Error &error) { - const auto dest = pv.Apply({src, src_size}); - *dest_size_r = dest.size; - return dest.data; + return pv.Apply(src); } const struct filter_plugin replay_gain_filter_plugin = { diff --git a/src/filter/plugins/RouteFilterPlugin.cxx b/src/filter/plugins/RouteFilterPlugin.cxx index d4bb0be9c..a252af97d 100644 --- a/src/filter/plugins/RouteFilterPlugin.cxx +++ b/src/filter/plugins/RouteFilterPlugin.cxx @@ -49,6 +49,7 @@ #include "pcm/PcmBuffer.hxx" #include "util/StringUtil.hxx" #include "util/Error.hxx" +#include "util/ConstBuffer.hxx" #include <algorithm> @@ -121,8 +122,8 @@ public: virtual AudioFormat Open(AudioFormat &af, Error &error) override; virtual void Close(); - virtual const void *FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, Error &error); + virtual ConstBuffer<void> FilterPCM(ConstBuffer<void> src, + Error &error) override; }; bool @@ -238,20 +239,19 @@ RouteFilter::Close() output_buffer.Clear(); } -const void * -RouteFilter::FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, gcc_unused Error &error) +ConstBuffer<void> +RouteFilter::FilterPCM(ConstBuffer<void> src, gcc_unused Error &error) { - size_t number_of_frames = src_size / input_frame_size; + size_t number_of_frames = src.size / input_frame_size; const size_t bytes_per_frame_per_channel = input_format.GetSampleSize(); // A moving pointer that always refers to channel 0 in the input, at the currently handled frame - const uint8_t *base_source = (const uint8_t *)src; + const uint8_t *base_source = (const uint8_t *)src.data; // Grow our reusable buffer, if needed, and set the moving pointer - *dest_size_r = number_of_frames * output_frame_size; - void *const result = output_buffer.Get(*dest_size_r); + const size_t result_size = number_of_frames * output_frame_size; + void *const result = output_buffer.Get(result_size); // A moving pointer that always refers to the currently filled channel of the currently handled frame, in the output uint8_t *chan_destination = (uint8_t *)result; @@ -287,7 +287,7 @@ RouteFilter::FilterPCM(const void *src, size_t src_size, } // Here it is, ladies and gentlemen! Rerouted data! - return result; + return { result, result_size }; } const struct filter_plugin route_filter_plugin = { diff --git a/src/filter/plugins/VolumeFilterPlugin.cxx b/src/filter/plugins/VolumeFilterPlugin.cxx index c9b7aa89e..7b6ccc51e 100644 --- a/src/filter/plugins/VolumeFilterPlugin.cxx +++ b/src/filter/plugins/VolumeFilterPlugin.cxx @@ -45,8 +45,8 @@ public: virtual AudioFormat Open(AudioFormat &af, Error &error) override; virtual void Close(); - virtual const void *FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, Error &error); + virtual ConstBuffer<void> FilterPCM(ConstBuffer<void> src, + Error &error) override; }; static constexpr Domain volume_domain("pcm_volume"); @@ -73,13 +73,10 @@ VolumeFilter::Close() pv.Close(); } -const void * -VolumeFilter::FilterPCM(const void *src, size_t src_size, - size_t *dest_size_r, gcc_unused Error &error) +ConstBuffer<void> +VolumeFilter::FilterPCM(ConstBuffer<void> src, gcc_unused Error &error) { - const auto dest = pv.Apply({src, src_size}); - *dest_size_r = dest.size; - return dest.data; + return pv.Apply(src); } const struct filter_plugin volume_filter_plugin = { |