mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-07-23 22:29:39 -06:00
Merge pull request #2018 from JosJuice/gameini-region-wildcard
Support game INIs that match all regions
This commit is contained in:
@ -96,16 +96,7 @@ bool BootCore(const std::string& _rFilename)
|
||||
return false;
|
||||
|
||||
// Load game specific settings
|
||||
std::string unique_id = StartUp.GetUniqueID();
|
||||
std::string revision_specific = StartUp.m_strRevisionSpecificUniqueID;
|
||||
StartUp.m_strGameIniDefault = File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP + unique_id + ".ini";
|
||||
if (revision_specific != "")
|
||||
StartUp.m_strGameIniDefaultRevisionSpecific = File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP + revision_specific + ".ini";
|
||||
else
|
||||
StartUp.m_strGameIniDefaultRevisionSpecific = "";
|
||||
StartUp.m_strGameIniLocal = File::GetUserPath(D_GAMESETTINGS_IDX) + unique_id + ".ini";
|
||||
|
||||
if (unique_id.size() == 6)
|
||||
if (StartUp.GetUniqueID().size() == 6)
|
||||
{
|
||||
IniFile game_ini = StartUp.LoadGameIni();
|
||||
|
||||
|
@ -178,7 +178,7 @@ bool SCoreStartupParameter::AutoSetup(EBootBS2 _BootBS2)
|
||||
}
|
||||
m_strName = pVolume->GetName();
|
||||
m_strUniqueID = pVolume->GetUniqueID();
|
||||
m_strRevisionSpecificUniqueID = pVolume->GetRevisionSpecificUniqueID();
|
||||
m_revision = pVolume->GetRevision();
|
||||
|
||||
// Check if we have a Wii disc
|
||||
bWii = pVolume.get()->IsWiiDisc();
|
||||
@ -373,28 +373,60 @@ void SCoreStartupParameter::CheckMemcardPath(std::string& memcardPath, std::stri
|
||||
}
|
||||
}
|
||||
|
||||
IniFile SCoreStartupParameter::LoadGameIni() const
|
||||
{
|
||||
IniFile game_ini;
|
||||
game_ini.Load(m_strGameIniDefault);
|
||||
if (m_strGameIniDefaultRevisionSpecific != "")
|
||||
game_ini.Load(m_strGameIniDefaultRevisionSpecific, true);
|
||||
game_ini.Load(m_strGameIniLocal, true);
|
||||
return game_ini;
|
||||
}
|
||||
|
||||
IniFile SCoreStartupParameter::LoadDefaultGameIni() const
|
||||
{
|
||||
IniFile game_ini;
|
||||
game_ini.Load(m_strGameIniDefault);
|
||||
if (m_strGameIniDefaultRevisionSpecific != "")
|
||||
game_ini.Load(m_strGameIniDefaultRevisionSpecific, true);
|
||||
LoadGameIni(&game_ini, File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP, GetUniqueID(), m_revision);
|
||||
return game_ini;
|
||||
}
|
||||
|
||||
IniFile SCoreStartupParameter::LoadLocalGameIni() const
|
||||
{
|
||||
IniFile game_ini;
|
||||
game_ini.Load(m_strGameIniLocal);
|
||||
LoadGameIni(&game_ini, File::GetUserPath(D_GAMESETTINGS_IDX), GetUniqueID(), m_revision);
|
||||
return game_ini;
|
||||
}
|
||||
|
||||
IniFile SCoreStartupParameter::LoadGameIni() const
|
||||
{
|
||||
IniFile game_ini;
|
||||
LoadGameIni(&game_ini, File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP, GetUniqueID(), m_revision);
|
||||
LoadGameIni(&game_ini, File::GetUserPath(D_GAMESETTINGS_IDX), GetUniqueID(), m_revision);
|
||||
return game_ini;
|
||||
}
|
||||
|
||||
IniFile SCoreStartupParameter::LoadDefaultGameIni(const std::string& id, int revision)
|
||||
{
|
||||
IniFile game_ini;
|
||||
LoadGameIni(&game_ini, File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP, id, revision);
|
||||
return game_ini;
|
||||
}
|
||||
|
||||
IniFile SCoreStartupParameter::LoadLocalGameIni(const std::string& id, int revision)
|
||||
{
|
||||
IniFile game_ini;
|
||||
LoadGameIni(&game_ini, File::GetUserPath(D_GAMESETTINGS_IDX), id, revision);
|
||||
return game_ini;
|
||||
}
|
||||
|
||||
IniFile SCoreStartupParameter::LoadGameIni(const std::string& id, int revision)
|
||||
{
|
||||
IniFile game_ini;
|
||||
LoadGameIni(&game_ini, File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP, id, revision);
|
||||
LoadGameIni(&game_ini, File::GetUserPath(D_GAMESETTINGS_IDX), id, revision);
|
||||
return game_ini;
|
||||
}
|
||||
|
||||
void SCoreStartupParameter::LoadGameIni(IniFile* game_ini, const std::string& path,
|
||||
const std::string& id, int revision)
|
||||
{
|
||||
// INIs that match all regions
|
||||
if (id.size() >= 4)
|
||||
game_ini->Load(path + id.substr(0, 3) + ".ini", true);
|
||||
|
||||
// Regular INIs
|
||||
game_ini->Load(path + id + ".ini", true);
|
||||
|
||||
// INIs with specific revisions
|
||||
game_ini->Load(path + id + StringFromFormat("r%d", revision) + ".ini", true);
|
||||
}
|
||||
|
@ -236,11 +236,8 @@ struct SCoreStartupParameter
|
||||
std::string m_strDVDRoot;
|
||||
std::string m_strApploader;
|
||||
std::string m_strUniqueID;
|
||||
std::string m_strRevisionSpecificUniqueID;
|
||||
std::string m_strName;
|
||||
std::string m_strGameIniDefault;
|
||||
std::string m_strGameIniDefaultRevisionSpecific;
|
||||
std::string m_strGameIniLocal;
|
||||
int m_revision;
|
||||
|
||||
std::string m_perfDir;
|
||||
|
||||
@ -251,7 +248,15 @@ struct SCoreStartupParameter
|
||||
bool AutoSetup(EBootBS2 _BootBS2);
|
||||
const std::string &GetUniqueID() const { return m_strUniqueID; }
|
||||
void CheckMemcardPath(std::string& memcardPath, std::string gameRegion, bool isSlotA);
|
||||
|
||||
IniFile LoadDefaultGameIni() const;
|
||||
IniFile LoadLocalGameIni() const;
|
||||
IniFile LoadGameIni() const;
|
||||
|
||||
static IniFile LoadDefaultGameIni(const std::string& id, int revision);
|
||||
static IniFile LoadLocalGameIni(const std::string& id, int revision);
|
||||
static IniFile LoadGameIni(const std::string& id, int revision);
|
||||
|
||||
private:
|
||||
static void LoadGameIni(IniFile* game_ini, const std::string& path, const std::string& id, int revision);
|
||||
};
|
||||
|
@ -28,7 +28,6 @@ public:
|
||||
return std::unique_ptr<u8[]>();
|
||||
}
|
||||
virtual std::string GetUniqueID() const = 0;
|
||||
virtual std::string GetRevisionSpecificUniqueID() const { return ""; }
|
||||
virtual std::string GetMakerID() const = 0;
|
||||
virtual int GetRevision() const { return 0; }
|
||||
// TODO: eliminate?
|
||||
|
@ -56,11 +56,6 @@ std::string CVolumeGC::GetUniqueID() const
|
||||
return ID;
|
||||
}
|
||||
|
||||
std::string CVolumeGC::GetRevisionSpecificUniqueID() const
|
||||
{
|
||||
return GetUniqueID() + StringFromFormat("r%d", GetRevision());
|
||||
}
|
||||
|
||||
IVolume::ECountry CVolumeGC::GetCountry() const
|
||||
{
|
||||
if (!m_pReader)
|
||||
|
@ -25,7 +25,6 @@ public:
|
||||
~CVolumeGC();
|
||||
bool Read(u64 _Offset, u64 _Length, u8* _pBuffer, bool decrypt = false) const override;
|
||||
std::string GetUniqueID() const override;
|
||||
std::string GetRevisionSpecificUniqueID() const override;
|
||||
std::string GetMakerID() const override;
|
||||
int GetRevision() const override;
|
||||
std::vector<std::string> GetNames() const override;
|
||||
|
@ -126,10 +126,7 @@ GameFile::GameFile(const QString& fileName)
|
||||
|
||||
if (m_valid)
|
||||
{
|
||||
IniFile ini;
|
||||
ini.Load(File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP + m_unique_id.toStdString() + ".ini");
|
||||
ini.Load(File::GetUserPath(D_GAMESETTINGS_IDX) + m_unique_id.toStdString() + ".ini", true);
|
||||
|
||||
IniFile ini = SCoreStartupParameter::LoadGameIni(m_unique_id.toStdString(), m_revision);
|
||||
std::string issues_temp;
|
||||
ini.GetIfExists("EmuState", "EmulationStateId", &m_emu_state);
|
||||
ini.GetIfExists("EmuState", "EmulationIssues", &issues_temp);
|
||||
|
@ -159,9 +159,10 @@ void wxCheatsWindow::OnEvent_Close(wxCloseEvent& ev)
|
||||
void wxCheatsWindow::UpdateGUI()
|
||||
{
|
||||
// load code
|
||||
m_gameini_default = SConfig::GetInstance().m_LocalCoreStartupParameter.LoadDefaultGameIni();
|
||||
m_gameini_local = SConfig::GetInstance().m_LocalCoreStartupParameter.LoadLocalGameIni();
|
||||
m_gameini_local_path = SConfig::GetInstance().m_LocalCoreStartupParameter.m_strGameIniLocal;
|
||||
SCoreStartupParameter parameters = SConfig::GetInstance().m_LocalCoreStartupParameter;
|
||||
m_gameini_default = parameters.LoadDefaultGameIni();
|
||||
m_gameini_local = parameters.LoadLocalGameIni();
|
||||
m_gameini_local_path = File::GetUserPath(D_GAMESETTINGS_IDX) + parameters.GetUniqueID() + ".ini";
|
||||
Load_ARCodes();
|
||||
Load_GeckoCodes();
|
||||
|
||||
|
@ -462,24 +462,10 @@ void CGameListCtrl::InsertItemInReportView(long _Index)
|
||||
titlestxt.close();
|
||||
}
|
||||
|
||||
std::string GameIni[3];
|
||||
GameIni[0] = File::GetUserPath(D_GAMESETTINGS_IDX) + rISOFile.GetUniqueID() + ".ini";
|
||||
GameIni[1] = File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP + rISOFile.GetUniqueID() + std::to_string(rISOFile.GetRevision()) + ".ini";
|
||||
GameIni[2] = File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP + rISOFile.GetUniqueID() + ".ini";
|
||||
std::string title;
|
||||
IniFile gameini;
|
||||
for (int i = 0; i < 3; ++i)
|
||||
{
|
||||
if (File::Exists(GameIni[i]))
|
||||
{
|
||||
gameini.Load(GameIni[i]);
|
||||
if (gameini.GetIfExists("EmuState", "Title", &title))
|
||||
{
|
||||
name = title;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
IniFile gameini = SCoreStartupParameter::LoadGameIni(rISOFile.GetUniqueID(), rISOFile.GetRevision());
|
||||
if (gameini.GetIfExists("EmuState", "Title", &title))
|
||||
name = title;
|
||||
|
||||
SetItem(_Index, COLUMN_TITLE, StrToWxStr(name), -1);
|
||||
|
||||
|
@ -121,13 +121,9 @@ GameListItem::GameListItem(const std::string& _rFileName)
|
||||
|
||||
if (IsValid())
|
||||
{
|
||||
IniFile ini;
|
||||
ini.Load(File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP + m_UniqueID + ".ini");
|
||||
ini.Load(File::GetUserPath(D_GAMESETTINGS_IDX) + m_UniqueID + ".ini", true);
|
||||
|
||||
IniFile::Section* emu_state = ini.GetOrCreateSection("EmuState");
|
||||
emu_state->Get("EmulationStateId", &m_emu_state);
|
||||
emu_state->Get("EmulationIssues", &m_issues);
|
||||
IniFile ini = SCoreStartupParameter::LoadGameIni(m_UniqueID, m_Revision);
|
||||
ini.GetIfExists("EmuState", "EmulationStateId", &m_emu_state);
|
||||
ini.GetIfExists("EmuState", "EmulationIssues", &m_issues);
|
||||
}
|
||||
|
||||
if (!m_pImage.empty())
|
||||
|
@ -163,11 +163,9 @@ CISOProperties::CISOProperties(const std::string fileName, wxWindow* parent, wxW
|
||||
}
|
||||
}
|
||||
|
||||
// Load game ini
|
||||
// Is it really necessary to use GetTitleID in case GetUniqueID fails?
|
||||
std::string _iniFilename = OpenISO->GetUniqueID();
|
||||
std::string _iniFilenameRevisionSpecific = OpenISO->GetRevisionSpecificUniqueID();
|
||||
|
||||
if (!_iniFilename.length())
|
||||
if (_iniFilename.empty())
|
||||
{
|
||||
u8 title_id[8];
|
||||
if (OpenISO->GetTitleID(title_id))
|
||||
@ -176,14 +174,11 @@ CISOProperties::CISOProperties(const std::string fileName, wxWindow* parent, wxW
|
||||
}
|
||||
}
|
||||
|
||||
// Load game INIs
|
||||
GameIniFileDefault = File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP + _iniFilename + ".ini";
|
||||
std::string GameIniFileDefaultRevisionSpecific = File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP + _iniFilenameRevisionSpecific + ".ini";
|
||||
GameIniFileLocal = File::GetUserPath(D_GAMESETTINGS_IDX) + _iniFilename + ".ini";
|
||||
|
||||
GameIniDefault.Load(GameIniFileDefault);
|
||||
if (_iniFilenameRevisionSpecific != "")
|
||||
GameIniDefault.Load(GameIniFileDefaultRevisionSpecific, true);
|
||||
GameIniLocal.Load(GameIniFileLocal);
|
||||
GameIniDefault = SCoreStartupParameter::LoadDefaultGameIni(_iniFilename, OpenISO->GetRevision());
|
||||
GameIniLocal = SCoreStartupParameter::LoadLocalGameIni(_iniFilename, OpenISO->GetRevision());
|
||||
|
||||
// Setup GUI
|
||||
OpenGameListItem = new GameListItem(fileName);
|
||||
|
@ -17,7 +17,6 @@ InputConfig::~InputConfig()
|
||||
bool InputConfig::LoadConfig(bool isGC)
|
||||
{
|
||||
IniFile inifile;
|
||||
IniFile game_ini;
|
||||
bool useProfile[MAX_BBMOTES] = {false, false, false, false, false};
|
||||
std::string num[MAX_BBMOTES] = {"1", "2", "3", "4", "BB"};
|
||||
std::string profile[MAX_BBMOTES];
|
||||
@ -37,8 +36,7 @@ bool InputConfig::LoadConfig(bool isGC)
|
||||
path = "Profiles/Wiimote/";
|
||||
}
|
||||
|
||||
game_ini.Load(File::GetSysDirectory() + GAMESETTINGS_DIR DIR_SEP + SConfig::GetInstance().m_LocalCoreStartupParameter.GetUniqueID() + ".ini");
|
||||
game_ini.Load(File::GetUserPath(D_GAMESETTINGS_IDX) + SConfig::GetInstance().m_LocalCoreStartupParameter.GetUniqueID() + ".ini", true);
|
||||
IniFile game_ini = SConfig::GetInstance().m_LocalCoreStartupParameter.LoadGameIni();
|
||||
IniFile::Section* control_section = game_ini.GetOrCreateSection("Controls");
|
||||
|
||||
for (int i = 0; i < 4; i++)
|
||||
@ -53,7 +51,7 @@ bool InputConfig::LoadConfig(bool isGC)
|
||||
}
|
||||
else
|
||||
{
|
||||
// TODO: Having a PanicAlert for this is dumb.
|
||||
// TODO: PanicAlert shouldn't be used for this.
|
||||
PanicAlertT("Selected controller profile does not exist");
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user