all repos — mgba @ 6a04f022518e31d4cf641b3b3a3ae5ac76dc2fa7

mGBA Game Boy Advance Emulator

Libretro: Build fixes for non-GB and coe cleanup
Vicki Pfau vi@endrift.com
Fri, 28 Aug 2020 18:33:31 -0700
commit

6a04f022518e31d4cf641b3b3a3ae5ac76dc2fa7

parent

9dc6dc7e658be648d875d31098a577b58ad73c3a

1 files changed, 14 insertions(+), 21 deletions(-)

jump to
M src/platform/libretro/libretro.csrc/platform/libretro/libretro.c

@@ -78,6 +78,7 @@ .volume = 0x100,

}; struct retro_variable var; +#ifdef M_CORE_GB enum GBModel model; const char* modelName;

@@ -101,6 +102,7 @@ mCoreConfigSetDefaultValue(&core->config, "gb.model", modelName);

mCoreConfigSetDefaultValue(&core->config, "sgb.model", modelName); mCoreConfigSetDefaultValue(&core->config, "cgb.model", modelName); } +#endif var.key = "mgba_use_bios"; var.value = 0;

@@ -114,21 +116,18 @@ if (environCallback(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value) {

opts.skipBios = strcmp(var.value, "ON") == 0; } +#ifdef M_CORE_GB var.key = "mgba_sgb_borders"; var.value = 0; if (environCallback(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value) { - if (strcmp(var.value, "ON") == 0) { - mCoreConfigSetDefaultIntValue(&core->config, "sgb.borders", true); - } else { - mCoreConfigSetDefaultIntValue(&core->config, "sgb.borders", false); - } + mCoreConfigSetDefaultIntValue(&core->config, "sgb.borders", strcmp(var.value, "ON") == 0); } +#endif var.key = "mgba_frameskip"; var.value = 0; if (environCallback(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value) { opts.frameskip = strtol(var.value, NULL, 10); - } var.key = "mgba_idle_optimization";

@@ -179,7 +178,11 @@ }

void retro_get_system_info(struct retro_system_info* info) { info->need_fullpath = false; - info->valid_extensions = "gba|gb|gbc"; +#ifdef M_CORE_GB + info->valid_extensions = "gba|gb|gbc|sgb"; +#else + info->valid_extensions = "gba"; +#endif info->library_version = projectVersion; info->library_name = projectName; info->block_extract = false;

@@ -287,25 +290,15 @@ .key = "mgba_allow_opposing_directions",

.value = 0 }; if (environCallback(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value) { - struct GBA* gba = core->board; - struct GB* gb = core->board; - switch (core->platform(core)) { - case PLATFORM_GBA: - gba->allowOpposingDirections = strcmp(var.value, "yes") == 0; - break; - case PLATFORM_GB: - gb->allowOpposingDirections = strcmp(var.value, "yes") == 0; - break; - default: - break; - } + mCoreConfigSetIntValue(&core->config, "allowOpposingDirections", strcmp(var.value, "yes") == 0); + core->reloadConfigOption(core, "allowOpposingDirections", NULL); } var.key = "mgba_frameskip"; var.value = 0; if (environCallback(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value) { - mCoreConfigSetUIntValue(&core->config, "frameskip", strtol(var.value, NULL, 10)); - mCoreLoadConfig(core); + mCoreConfigSetIntValue(&core->config, "frameskip", strtol(var.value, NULL, 10)); + core->reloadConfigOption(core, "frameskip", NULL); } }