2008-07-20 09:28:17 +02:00
|
|
|
#include "layout.h"
|
|
|
|
#include "../vgmstream.h"
|
|
|
|
#include "../coding/acm_decoder.h"
|
|
|
|
#include "../coding/coding.h"
|
|
|
|
|
|
|
|
void render_vgmstream_mus_acm(sample * buffer, int32_t sample_count, VGMSTREAM * vgmstream) {
|
|
|
|
int samples_written=0;
|
|
|
|
mus_acm_codec_data *data = vgmstream->codec_data;
|
|
|
|
|
|
|
|
while (samples_written<sample_count) {
|
|
|
|
ACMStream *acm = data->files[data->current_file];
|
|
|
|
int samples_to_do;
|
|
|
|
int samples_this_block = acm->total_values / acm->info.channels;
|
|
|
|
|
|
|
|
if (vgmstream->loop_flag && vgmstream_do_loop(vgmstream)) {
|
2008-07-21 01:28:16 +02:00
|
|
|
data->current_file = data->loop_start_file;
|
|
|
|
acm_reset(data->files[data->current_file]);
|
|
|
|
vgmstream->samples_into_block = 0;
|
2008-07-20 09:28:17 +02:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
samples_to_do = vgmstream_samples_to_do(samples_this_block, 1, vgmstream);
|
|
|
|
|
2008-07-21 01:28:16 +02:00
|
|
|
/*printf("samples_to_do=%d,samples_this_block=%d,samples_written=%d,sample_count=%d\n",samples_to_do,samples_this_block,samples_written,sample_count);*/
|
|
|
|
|
2008-07-20 09:28:17 +02:00
|
|
|
if (samples_written+samples_to_do > sample_count)
|
|
|
|
samples_to_do=sample_count-samples_written;
|
|
|
|
|
|
|
|
if (samples_to_do == 0)
|
|
|
|
{
|
|
|
|
data->current_file++;
|
2008-07-21 01:28:16 +02:00
|
|
|
/*printf("next %d, %d samples\n",data->current_file,data->files[data->current_file]->total_values/data->files[data->current_file]->info.channels);*/
|
2008-07-20 09:28:17 +02:00
|
|
|
/* check for loop */
|
|
|
|
acm_reset(data->files[data->current_file]);
|
2008-07-21 01:28:16 +02:00
|
|
|
vgmstream->samples_into_block = 0;
|
2008-07-20 09:28:17 +02:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2008-07-21 01:28:16 +02:00
|
|
|
/*printf("decode %d samples file %d\n",samples_to_do,data->current_file);*/
|
2008-07-20 09:28:17 +02:00
|
|
|
decode_acm(acm,
|
|
|
|
buffer+samples_written*vgmstream->channels,
|
|
|
|
samples_to_do, vgmstream->channels);
|
|
|
|
|
|
|
|
samples_written += samples_to_do;
|
|
|
|
vgmstream->current_sample += samples_to_do;
|
|
|
|
vgmstream->samples_into_block+=samples_to_do;
|
|
|
|
}
|
|
|
|
}
|