decoder/flac: convert flac_convert_*() to templates

This commit is contained in:
Max Kellermann 2016-07-11 23:27:57 +02:00
parent 62e96e9a58
commit 590d6faeb0

View File

@ -22,56 +22,32 @@
#include <assert.h> #include <assert.h>
static void flac_convert_stereo16(int16_t *dest, template<typename T>
const FLAC__int32 * const buf[], static void
size_t n_frames) FlacImportStereo(T *dest, const FLAC__int32 *const src[], size_t n_frames)
{ {
for (size_t i = 0; i != n_frames; ++i) { for (size_t i = 0; i != n_frames; ++i) {
*dest++ = buf[0][i]; *dest++ = (T)src[0][i];
*dest++ = buf[1][i]; *dest++ = (T)src[1][i];
} }
} }
template<typename T>
static void static void
flac_convert_16(int16_t *dest, FlacImportAny(T *dest, const FLAC__int32 *const src[], size_t n_frames,
unsigned int num_channels, unsigned n_channels)
const FLAC__int32 * const buf[],
size_t n_frames)
{ {
unsigned int c_chan;
for (size_t i = 0; i != n_frames; ++i) for (size_t i = 0; i != n_frames; ++i)
for (c_chan = 0; c_chan < num_channels; c_chan++) for (unsigned c = 0; c != n_channels; ++c)
*dest++ = buf[c_chan][i]; *dest++ = src[c][i];
} }
/** template<typename T>
* Note: this function also handles 24 bit files!
*/
static void static void
flac_convert_32(int32_t *dest, FlacImport(T *dest, const FLAC__int32 *const src[], size_t n_frames,
unsigned int num_channels, unsigned n_channels)
const FLAC__int32 * const buf[],
size_t n_frames)
{ {
unsigned int c_chan; FlacImportAny(dest, src, n_frames, n_channels);
for (size_t i = 0; i != n_frames; ++i)
for (c_chan = 0; c_chan < num_channels; c_chan++)
*dest++ = buf[c_chan][i];
}
static void
flac_convert_8(int8_t *dest,
unsigned int num_channels,
const FLAC__int32 * const buf[],
size_t n_frames)
{
unsigned int c_chan;
for (size_t i = 0; i != n_frames; ++i)
for (c_chan = 0; c_chan < num_channels; c_chan++)
*dest++ = buf[c_chan][i];
} }
void void
@ -83,21 +59,18 @@ flac_convert(void *dest,
switch (sample_format) { switch (sample_format) {
case SampleFormat::S16: case SampleFormat::S16:
if (num_channels == 2) if (num_channels == 2)
flac_convert_stereo16((int16_t *)dest, buf, n_frames); FlacImportStereo((int16_t *)dest, buf, n_frames);
else else
flac_convert_16((int16_t*)dest, num_channels, buf, FlacImportAny((int16_t *)dest, buf, n_frames, num_channels);
n_frames);
break; break;
case SampleFormat::S24_P32: case SampleFormat::S24_P32:
case SampleFormat::S32: case SampleFormat::S32:
flac_convert_32((int32_t*)dest, num_channels, buf, FlacImport((int32_t *)dest, buf, n_frames, num_channels);
n_frames);
break; break;
case SampleFormat::S8: case SampleFormat::S8:
flac_convert_8((int8_t*)dest, num_channels, buf, FlacImport((int8_t *)dest, buf, n_frames, num_channels);
n_frames);
break; break;
case SampleFormat::FLOAT: case SampleFormat::FLOAT: