From 08f77c2b607a32e818ee0e0375adec840eb521c0 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Mon, 26 Oct 2015 16:48:38 +0100 Subject: decoder/gme: add option "accuracy" --- NEWS | 1 + doc/user.xml | 22 ++++++++++++++++++++++ src/decoder/plugins/GmeDecoderPlugin.cxx | 25 ++++++++++++++++++++++++- 3 files changed, 47 insertions(+), 1 deletion(-) diff --git a/NEWS b/NEWS index 4f1171630..c5d581a7b 100644 --- a/NEWS +++ b/NEWS @@ -14,6 +14,7 @@ ver 0.20 (not yet released) * decoder - ffmpeg: support ReplayGain and MixRamp - ffmpeg: support stream tags + - gme: add option "accuracy" - mad: reduce memory usage while scanning tags - mpcdec: read the bit rate * playlist diff --git a/doc/user.xml b/doc/user.xml index 3d4a70241..f66f6e397 100644 --- a/doc/user.xml +++ b/doc/user.xml @@ -1749,6 +1749,28 @@ buffer_size: 16384 Video game music file emulator based on game-music-emu. + + + + + + Setting + Description + + + + + + accuracy + yes|no + + + Enable more accurate sound emulation. + + + + +
diff --git a/src/decoder/plugins/GmeDecoderPlugin.cxx b/src/decoder/plugins/GmeDecoderPlugin.cxx index dccf21d43..ca8677ef8 100644 --- a/src/decoder/plugins/GmeDecoderPlugin.cxx +++ b/src/decoder/plugins/GmeDecoderPlugin.cxx @@ -20,6 +20,7 @@ #include "config.h" #include "GmeDecoderPlugin.hxx" #include "../DecoderAPI.hxx" +#include "config/Block.cxx" #include "CheckAudioFormat.hxx" #include "tag/TagHandler.hxx" #include "fs/Path.hxx" @@ -52,6 +53,23 @@ struct GmeContainerPath { unsigned track; }; +#if GME_VERSION >= 0x000600 +static int gme_accuracy; +#endif + +static bool +gme_plugin_init(gcc_unused const ConfigBlock &block) +{ +#if GME_VERSION >= 0x000600 + auto accuracy = block.GetBlockParam("accuracy"); + gme_accuracy = accuracy != nullptr + ? (int)accuracy->GetBoolValue() + : -1; +#endif + + return true; +} + gcc_pure static unsigned ParseSubtuneName(const char *base) @@ -123,6 +141,11 @@ gme_file_decode(Decoder &decoder, Path path_fs) return; } +#if GME_VERSION >= 0x000600 + if (gme_accuracy >= 0) + gme_enable_accuracy(emu, gme_accuracy); +#endif + gme_info_t *ti; gme_err = gme_track_info(emu, &ti, container.track); if (gme_err != nullptr) { @@ -274,7 +297,7 @@ static const char *const gme_suffixes[] = { extern const struct DecoderPlugin gme_decoder_plugin; const struct DecoderPlugin gme_decoder_plugin = { "gme", - nullptr, + gme_plugin_init, nullptr, nullptr, gme_file_decode, -- cgit v1.2.3