From 12e9b7eafacbbd20ccb6e8e73238c8dd351fa16f Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Mon, 28 Oct 2013 21:29:36 +0100 Subject: [PATCH] PcmFormat: move definitions to struct SampleTraits --- src/pcm/PcmFormat.cxx | 117 +++++++++++++++++++++++++++++------------- 1 file changed, 81 insertions(+), 36 deletions(-) diff --git a/src/pcm/PcmFormat.cxx b/src/pcm/PcmFormat.cxx index a0de163ba..9df800d44 100644 --- a/src/pcm/PcmFormat.cxx +++ b/src/pcm/PcmFormat.cxx @@ -25,12 +25,47 @@ #include -template -struct DefaultSampleBits { - typedef decltype(*S()) T; - typedef typename std::remove_reference::type U; +template +struct SampleTraits {}; - static constexpr auto value = sizeof(U) * 8; +template<> +struct SampleTraits { + typedef int8_t value_type; + typedef value_type *pointer_type; + typedef const value_type *const_pointer_type; + + static constexpr size_t SAMPLE_SIZE = sizeof(value_type); + static constexpr unsigned BITS = sizeof(value_type) * 8; +}; + +template<> +struct SampleTraits { + typedef int16_t value_type; + typedef value_type *pointer_type; + typedef const value_type *const_pointer_type; + + static constexpr size_t SAMPLE_SIZE = sizeof(value_type); + static constexpr unsigned BITS = sizeof(value_type) * 8; +}; + +template<> +struct SampleTraits { + typedef int32_t value_type; + typedef value_type *pointer_type; + typedef const value_type *const_pointer_type; + + static constexpr size_t SAMPLE_SIZE = sizeof(value_type); + static constexpr unsigned BITS = sizeof(value_type) * 8; +}; + +template<> +struct SampleTraits { + typedef int32_t value_type; + typedef value_type *pointer_type; + typedef const value_type *const_pointer_type; + + static constexpr size_t SAMPLE_SIZE = sizeof(value_type); + static constexpr unsigned BITS = 24; }; static void @@ -55,30 +90,32 @@ pcm_convert_32_to_16(PcmDither &dither, dither.Dither32To16(out, in, in_end); } -template::value> +template> static void -ConvertFromFloat(S dest, const float *src, const float *end) +ConvertFromFloat(typename Traits::pointer_type dest, + const float *src, const float *end) { - typedef decltype(*S()) T; - typedef typename std::remove_reference::type U; + constexpr auto bits = Traits::BITS; const float factor = 1 << (bits - 1); while (src != end) { int sample(*src++ * factor); - *dest++ = PcmClamp(sample); + *dest++ = PcmClamp(sample); } } -template::value> +template> static void -ConvertFromFloat(S dest, const float *src, size_t size) +ConvertFromFloat(typename Traits::pointer_type dest, + const float *src, size_t size) { - ConvertFromFloat(dest, src, pcm_end_pointer(src, size)); + ConvertFromFloat(dest, src, + pcm_end_pointer(src, size)); } -template -static S * +template> +static typename Traits::pointer_type AllocateFromFloat(PcmBuffer &buffer, const float *src, size_t src_size, size_t *dest_size_r) { @@ -86,9 +123,9 @@ AllocateFromFloat(PcmBuffer &buffer, const float *src, size_t src_size, assert(src_size % src_sample_size == 0); const size_t num_samples = src_size / src_sample_size; - *dest_size_r = num_samples * sizeof(S); - S *dest = (S *)buffer.Get(*dest_size_r); - ConvertFromFloat(dest, src, src_size); + *dest_size_r = num_samples * sizeof(typename Traits::value_type); + auto dest = (typename Traits::pointer_type)buffer.Get(*dest_size_r); + ConvertFromFloat(dest, src, src_size); return dest; } @@ -136,7 +173,8 @@ pcm_allocate_float_to_16(PcmBuffer &buffer, const float *src, size_t src_size, size_t *dest_size_r) { - return AllocateFromFloat(buffer, src, src_size, dest_size_r); + return AllocateFromFloat(buffer, src, src_size, + dest_size_r); } const int16_t * @@ -240,8 +278,8 @@ pcm_allocate_float_to_24(PcmBuffer &buffer, const float *src, size_t src_size, size_t *dest_size_r) { - return AllocateFromFloat(buffer, src, src_size, - dest_size_r); + return AllocateFromFloat(buffer, src, src_size, + dest_size_r); } const int32_t * @@ -395,35 +433,39 @@ pcm_convert_to_32(PcmBuffer &buffer, return NULL; } -template::value> +template> static void -ConvertToFloat(float *dest, S src, S end) +ConvertToFloat(float *dest, + typename Traits::const_pointer_type src, + typename Traits::const_pointer_type end) { - constexpr float factor = 0.5 / (1 << (bits - 2)); + constexpr float factor = 0.5 / (1 << (Traits::BITS - 2)); while (src != end) *dest++ = float(*src++) * factor; } -template::value> +template> static void -ConvertToFloat(float *dest, S src, size_t size) +ConvertToFloat(float *dest, + typename Traits::const_pointer_type src, size_t size) { - ConvertToFloat(dest, src, pcm_end_pointer(src, size)); + ConvertToFloat(dest, src, pcm_end_pointer(src, size)); } -template::value> +template> static float * -AllocateToFloat(PcmBuffer &buffer, S src, size_t src_size, +AllocateToFloat(PcmBuffer &buffer, + typename Traits::const_pointer_type src, size_t src_size, size_t *dest_size_r) { - constexpr size_t src_sample_size = sizeof(*S()); + constexpr size_t src_sample_size = Traits::SAMPLE_SIZE; assert(src_size % src_sample_size == 0); const size_t num_samples = src_size / src_sample_size; *dest_size_r = num_samples * sizeof(float); float *dest = (float *)buffer.Get(*dest_size_r); - ConvertToFloat(dest, src, src_size); + ConvertToFloat(dest, src, src_size); return dest; } @@ -432,7 +474,8 @@ pcm_allocate_8_to_float(PcmBuffer &buffer, const int8_t *src, size_t src_size, size_t *dest_size_r) { - return AllocateToFloat(buffer, src, src_size, dest_size_r); + return AllocateToFloat(buffer, src, src_size, + dest_size_r); } static float * @@ -440,7 +483,8 @@ pcm_allocate_16_to_float(PcmBuffer &buffer, const int16_t *src, size_t src_size, size_t *dest_size_r) { - return AllocateToFloat(buffer, src, src_size, dest_size_r); + return AllocateToFloat(buffer, src, src_size, + dest_size_r); } static float * @@ -448,8 +492,8 @@ pcm_allocate_24p32_to_float(PcmBuffer &buffer, const int32_t *src, size_t src_size, size_t *dest_size_r) { - return AllocateToFloat - (buffer, src, src_size, dest_size_r); + return AllocateToFloat(buffer, src, src_size, + dest_size_r); } static float * @@ -457,7 +501,8 @@ pcm_allocate_32_to_float(PcmBuffer &buffer, const int32_t *src, size_t src_size, size_t *dest_size_r) { - return AllocateToFloat(buffer, src, src_size, dest_size_r); + return AllocateToFloat(buffer, src, src_size, + dest_size_r); } const float *