decoder/mikmod: merged open()/close() into decode()

These functions are trivial, we don't need them separate.
This commit is contained in:
Max Kellermann 2009-11-14 01:53:50 +01:00
parent 2d236e281f
commit 0c5329aedc

View File

@ -131,38 +131,10 @@ typedef struct _mod_Data {
SBYTE audio_buffer[MIKMOD_FRAME_SIZE]; SBYTE audio_buffer[MIKMOD_FRAME_SIZE];
} mod_Data; } mod_Data;
static bool
mod_open(mod_Data *data, const char *path)
{
char *path2;
MODULE *moduleHandle;
path2 = g_strdup(path);
moduleHandle = Player_Load(path2, 128, 0);
g_free(path2);
if (moduleHandle == NULL)
return false;
/* Prevent module from looping forever */
moduleHandle->loop = 0;
data->moduleHandle = moduleHandle;
Player_Start(data->moduleHandle);
return true;
}
static void mod_close(mod_Data * data)
{
Player_Stop();
Player_Free(data->moduleHandle);
}
static void static void
mod_decode(struct decoder *decoder, const char *path) mod_decode(struct decoder *decoder, const char *path)
{ {
char *path2;
mod_Data data; mod_Data data;
struct audio_format audio_format; struct audio_format audio_format;
float total_time = 0.0; float total_time = 0.0;
@ -170,11 +142,18 @@ mod_decode(struct decoder *decoder, const char *path)
float secPerByte; float secPerByte;
enum decoder_command cmd = DECODE_COMMAND_NONE; enum decoder_command cmd = DECODE_COMMAND_NONE;
if (!mod_open(&data, path)) { path2 = g_strdup(path);
data.moduleHandle = Player_Load(path2, 128, 0);
g_free(path2);
if (data.moduleHandle == NULL) {
g_warning("failed to open mod: %s\n", path); g_warning("failed to open mod: %s\n", path);
return; return;
} }
/* Prevent module from looping forever */
data.moduleHandle->loop = 0;
audio_format_init(&audio_format, 44100, 16, 2); audio_format_init(&audio_format, 44100, 16, 2);
assert(audio_format_valid(&audio_format)); assert(audio_format_valid(&audio_format));
@ -184,6 +163,7 @@ mod_decode(struct decoder *decoder, const char *path)
decoder_initialized(decoder, &audio_format, false, 0); decoder_initialized(decoder, &audio_format, false, 0);
Player_Start(data.moduleHandle);
while (cmd == DECODE_COMMAND_NONE && Player_Active()) { while (cmd == DECODE_COMMAND_NONE && Player_Active()) {
ret = VC_WriteBytes(data.audio_buffer, MIKMOD_FRAME_SIZE); ret = VC_WriteBytes(data.audio_buffer, MIKMOD_FRAME_SIZE);
total_time += ret * secPerByte; total_time += ret * secPerByte;
@ -192,7 +172,8 @@ mod_decode(struct decoder *decoder, const char *path)
total_time, 0, NULL); total_time, 0, NULL);
} }
mod_close(&data); Player_Stop();
Player_Free(data.moduleHandle);
} }
static struct tag *modTagDup(const char *file) static struct tag *modTagDup(const char *file)