From 86f6e8cc1ea0dcb6306efeffe69700ed07ed8740 Mon Sep 17 00:00:00 2001 From: Pierre Bourdon Date: Wed, 18 Sep 2013 12:27:50 +0200 Subject: [PATCH] Better fix for issue 6614: ISOProperties should store integer settings for PHack booleans. INIFile is stupid, please kill it with fire. --- Source/Core/DolphinWX/Src/ISOProperties.cpp | 33 ++++++++++----------- Source/Core/VideoCommon/Src/VideoConfig.cpp | 5 +--- 2 files changed, 17 insertions(+), 21 deletions(-) diff --git a/Source/Core/DolphinWX/Src/ISOProperties.cpp b/Source/Core/DolphinWX/Src/ISOProperties.cpp index 583aeea495..500a3014fc 100644 --- a/Source/Core/DolphinWX/Src/ISOProperties.cpp +++ b/Source/Core/DolphinWX/Src/ISOProperties.cpp @@ -1008,40 +1008,39 @@ void CISOProperties::LoadGameConfig() SetCheckboxValueFromGameini("Video", "ZTPSpeedupHack", UseZTPSpeedupHack); // First set values from default gameini, then apply values from local gameini - bool bTemp; - GameIniDefault.Get("Video", "ProjectionHack", &bTemp); - PHackEnable->SetValue(bTemp); - if (GameIniLocal.Get("Video", "ProjectionHack", &bTemp)) - PHackEnable->SetValue(bTemp); + int iTemp; + GameIniDefault.Get("Video", "ProjectionHack", &iTemp); + PHackEnable->SetValue(iTemp); + if (GameIniLocal.Get("Video", "ProjectionHack", &iTemp)) + PHackEnable->SetValue(iTemp); GameIniDefault.Get("Video", "PH_SZNear", &PHack_Data.PHackSZNear); - if (GameIniLocal.Get("Video", "PH_SZNear", &bTemp)) - PHack_Data.PHackSZNear = bTemp; + if (GameIniLocal.GetIfExists("Video", "PH_SZNear", &iTemp)) + PHack_Data.PHackSZNear = iTemp; GameIniDefault.Get("Video", "PH_SZFar", &PHack_Data.PHackSZFar); - if (GameIniLocal.Get("Video", "PH_SZFar", &bTemp)) - PHack_Data.PHackSZFar = bTemp; + if (GameIniLocal.GetIfExists("Video", "PH_SZFar", &iTemp)) + PHack_Data.PHackSZFar = iTemp; GameIniDefault.Get("Video", "PH_ExtraParam", &PHack_Data.PHackExP); - if (GameIniLocal.Get("Video", "PH_ExtraParam", &bTemp)) - PHack_Data.PHackExP = bTemp; + if (GameIniLocal.GetIfExists("Video", "PH_ExtraParam", &iTemp)) + PHack_Data.PHackExP = iTemp; std::string sTemp; GameIniDefault.Get("Video", "PH_ZNear", &PHack_Data.PHZNear); - if (GameIniLocal.Get("Video", "PH_ZNear", &sTemp)) + if (GameIniLocal.GetIfExists("Video", "PH_ZNear", &sTemp)) PHack_Data.PHZNear = sTemp; GameIniDefault.Get("Video", "PH_ZFar", &PHack_Data.PHZFar); - if (GameIniLocal.Get("Video", "PH_ZFar", &sTemp)) + if (GameIniLocal.GetIfExists("Video", "PH_ZFar", &sTemp)) PHack_Data.PHZFar = sTemp; - int iTemp; GameIniDefault.Get("EmuState", "EmulationStateId", &iTemp, 0/*Not Set*/); EmuState->SetSelection(iTemp); - if (GameIniLocal.Get("EmuState", "EmulationStateId", &iTemp, 0/*Not Set*/)) + if (GameIniLocal.GetIfExists("EmuState", "EmulationStateId", &iTemp)) EmuState->SetSelection(iTemp); GameIniDefault.Get("EmuState", "EmulationIssues", &sTemp); if (!sTemp.empty()) EmuIssues->SetValue(StrToWxStr(sTemp)); - if (GameIniLocal.Get("EmuState", "EmulationIssues", &sTemp)) + if (GameIniLocal.GetIfExists("EmuState", "EmulationIssues", &sTemp)) EmuIssues->SetValue(StrToWxStr(sTemp)); EmuIssues->Enable(EmuState->GetSelection() != 0); @@ -1103,7 +1102,7 @@ bool CISOProperties::SaveGameConfig() GameIniLocal.DeleteKey((section), (key)); \ } while (0) - SAVE_IF_NOT_DEFAULT("Video", "ProjectionHack", PHackEnable->GetValue(), false); + SAVE_IF_NOT_DEFAULT("Video", "ProjectionHack", (int)PHackEnable->GetValue(), 0); SAVE_IF_NOT_DEFAULT("Video", "PH_SZNear", (PHack_Data.PHackSZNear ? 1 : 0), 0); SAVE_IF_NOT_DEFAULT("Video", "PH_SZFar", (PHack_Data.PHackSZFar ? 1 : 0), 0); SAVE_IF_NOT_DEFAULT("Video", "PH_ExtraParam", (PHack_Data.PHackExP ? 1 : 0), 0); diff --git a/Source/Core/VideoCommon/Src/VideoConfig.cpp b/Source/Core/VideoCommon/Src/VideoConfig.cpp index 9403af8d23..e81807985a 100644 --- a/Source/Core/VideoCommon/Src/VideoConfig.cpp +++ b/Source/Core/VideoCommon/Src/VideoConfig.cpp @@ -202,10 +202,7 @@ void VideoConfig::GameIniLoad(const char* default_ini_file, const char* local_in CHECK_SETTING("Video_Hacks", "EFBCopyCacheEnable", bEFBCopyCacheEnable); CHECK_SETTING("Video_Hacks", "EFBEmulateFormatChanges", bEFBEmulateFormatChanges); - // XXX: iPhackvalue[0] aka. projection hack enabled is an integer. WTF. - bool phack_enabled = iPhackvalue[0]; - CHECK_SETTING("Video", "ProjectionHack", phack_enabled); - iPhackvalue[0] = phack_enabled; + CHECK_SETTING("Video", "ProjectionHack", iPhackvalue[0]); CHECK_SETTING("Video", "PH_SZNear", iPhackvalue[1]); CHECK_SETTING("Video", "PH_SZFar", iPhackvalue[2]); CHECK_SETTING("Video", "PH_ExtraParam", iPhackvalue[3]);