decoder/gme: move gme_container_scan() down

This commit is contained in:
Max Kellermann 2016-11-22 15:51:38 +01:00
parent 2ab168735f
commit 72c96052b4

View File

@ -103,38 +103,6 @@ ParseContainerPath(Path path_fs)
return { path_fs.GetDirectoryName(), track - 1 }; return { path_fs.GetDirectoryName(), track - 1 };
} }
static std::forward_list<std::string>
gme_container_scan(Path path_fs)
{
std::forward_list<std::string> list;
Music_Emu *emu;
const char *gme_err = gme_open_file(path_fs.c_str(), &emu,
GME_SAMPLE_RATE);
if (gme_err != nullptr) {
LogWarning(gme_domain, gme_err);
return list;
}
const unsigned num_songs = gme_track_count(emu);
gme_delete(emu);
/* if it only contains a single tune, don't treat as container */
if (num_songs < 2)
return list;
const char *subtune_suffix = uri_get_suffix(path_fs.c_str());
auto tail = list.before_begin();
for (unsigned i = 1; i <= num_songs; ++i) {
char track_name[64];
snprintf(track_name, sizeof(track_name),
SUBTUNE_PREFIX "%03u.%s", i, subtune_suffix);
tail = list.emplace_after(tail, track_name);
}
return list;
}
static void static void
gme_file_decode(DecoderClient &client, Path path_fs) gme_file_decode(DecoderClient &client, Path path_fs)
{ {
@ -298,6 +266,38 @@ gme_scan_file(Path path_fs,
return ScanMusicEmu(emu, container.track, handler, handler_ctx); return ScanMusicEmu(emu, container.track, handler, handler_ctx);
} }
static std::forward_list<std::string>
gme_container_scan(Path path_fs)
{
std::forward_list<std::string> list;
Music_Emu *emu;
const char *gme_err = gme_open_file(path_fs.c_str(), &emu,
GME_SAMPLE_RATE);
if (gme_err != nullptr) {
LogWarning(gme_domain, gme_err);
return list;
}
const unsigned num_songs = gme_track_count(emu);
gme_delete(emu);
/* if it only contains a single tune, don't treat as container */
if (num_songs < 2)
return list;
const char *subtune_suffix = uri_get_suffix(path_fs.c_str());
auto tail = list.before_begin();
for (unsigned i = 1; i <= num_songs; ++i) {
char track_name[64];
snprintf(track_name, sizeof(track_name),
SUBTUNE_PREFIX "%03u.%s", i, subtune_suffix);
tail = list.emplace_after(tail, track_name);
}
return list;
}
static const char *const gme_suffixes[] = { static const char *const gme_suffixes[] = {
"ay", "gbs", "gym", "hes", "kss", "nsf", "ay", "gbs", "gym", "hes", "kss", "nsf",
"nsfe", "sap", "spc", "vgm", "vgz", "nsfe", "sap", "spc", "vgm", "vgz",