decoder/flac: convert flac_convert_*() to templates
This commit is contained in:
parent
62e96e9a58
commit
590d6faeb0
@ -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:
|
||||||
|
Loading…
Reference in New Issue
Block a user