From 2ad46d1baddbe0121d8eefd4f7863da28320cc07 Mon Sep 17 00:00:00 2001 From: Jamiras Date: Fri, 19 May 2023 19:24:31 -0600 Subject: [PATCH] fix remembering video settings --- bin/Cores/cores.json | 1 + src/components/Video.cpp | 28 +++++++++++++++++----------- src/components/Video.h | 2 ++ 3 files changed, 20 insertions(+), 11 deletions(-) diff --git a/bin/Cores/cores.json b/bin/Cores/cores.json index b53cf82..f4a145b 100644 --- a/bin/Cores/cores.json +++ b/bin/Cores/cores.json @@ -132,6 +132,7 @@ }, "dolphin_libretro":{ "name": "Dolphin", + "extensions": "iso|m3u", "systems": [16,19], "platforms": "none" }, diff --git a/src/components/Video.cpp b/src/components/Video.cpp index 4ad319c..0f33179 100644 --- a/src/components/Video.cpp +++ b/src/components/Video.cpp @@ -30,12 +30,8 @@ along with RALibretro. If not, see . #define TAG "[VID] " -bool Video::init(libretro::LoggerComponent* logger, libretro::VideoContextComponent *ctx, Config* config) +Video::Video() { - _logger = logger; - _ctx = ctx; - _config = config; - _enabled = true; _pixelFormat = RETRO_PIXEL_FORMAT_UNKNOWN; @@ -51,11 +47,21 @@ bool Video::init(libretro::LoggerComponent* logger, libretro::VideoContextCompon _preserveAspect = false; _linearFilter = false; - _program = createProgram(&_posAttribute, &_uvAttribute, &_texUniform); - _hw.enabled = false; _hw.frameBuffer = _hw.renderBuffer = 0; _hw.callback = nullptr; +} + +bool Video::init(libretro::LoggerComponent* logger, libretro::VideoContextComponent *ctx, Config* config) +{ + _logger = logger; + _ctx = ctx; + _config = config; + + // NOTE: Video::init is called after Video::deserializeSettings. Make sure not to overwrite anyting + // stored in the .cfg file. + + _program = createProgram(&_posAttribute, &_uvAttribute, &_texUniform); if (!Gl::ok()) { @@ -414,11 +420,11 @@ std::string Video::serializeSettings() { std::string json("{"); - json.append("\"_preserveAspect\":"); + json.append("\"preserveAspect\":"); json.append(_preserveAspect ? "true" : "false"); json.append(","); - json.append("\"_linearFilter\":"); + json.append("\"linearFilter\":"); json.append(_linearFilter ? "true" : "false"); json.append("}"); @@ -446,11 +452,11 @@ bool Video::deserializeSettings(const char* json) } else if (event == JSONSAX_BOOLEAN) { - if (ud->key == "_preserveAspect") + if (ud->key == "preserveAspect" || ud->key == "_preserveAspect") { ud->self->_preserveAspect = num != 0; } - if (ud->key == "_linearFilter") + if (ud->key == "linearFilter" || ud->key == "_linearFilter") { ud->self->_linearFilter = num != 0; } diff --git a/src/components/Video.h b/src/components/Video.h index 89405ec..f9acb26 100644 --- a/src/components/Video.h +++ b/src/components/Video.h @@ -28,6 +28,8 @@ along with RALibretro. If not, see . class Video: public libretro::VideoComponent { public: + Video(); + bool init(libretro::LoggerComponent* logger, libretro::VideoContextComponent* ctx, Config* config); void destroy();