mirror of
https://github.com/Fledge68/WiiFlow_Lite.git
synced 2025-01-11 19:39:09 +01:00
Merged common game and channel IOS loading code.
This commit is contained in:
parent
cac7aa5fa5
commit
f3ee24fe65
@ -940,6 +940,7 @@ public:
|
|||||||
void _directlaunch(const std::string &id);
|
void _directlaunch(const std::string &id);
|
||||||
private:
|
private:
|
||||||
bool _loadFile(SmartBuf &buffer, u32 &size, const char *path, const char *file);
|
bool _loadFile(SmartBuf &buffer, u32 &size, const char *path, const char *file);
|
||||||
|
int _loadIOS(u8 ios, string id);
|
||||||
void _launch(dir_discHdr *hdr);
|
void _launch(dir_discHdr *hdr);
|
||||||
void _launchGame(dir_discHdr *hdr, bool dvd);
|
void _launchGame(dir_discHdr *hdr, bool dvd);
|
||||||
void _launchChannel(dir_discHdr *hdr);
|
void _launchChannel(dir_discHdr *hdr);
|
||||||
|
@ -798,12 +798,83 @@ void CMenu::_launchHomebrew(const char *filepath, safe_vector<std::string> argum
|
|||||||
m_exit = true;
|
m_exit = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum {LOAD_IOS_FAILED = 0, LOAD_IOS_SUCCEEDED, LOAD_IOS_NOT_NEEDED};
|
||||||
|
|
||||||
|
int CMenu::_loadIOS(u8 ios, string id)
|
||||||
|
{
|
||||||
|
int gameIOS = 0;
|
||||||
|
int userIOS = 0;
|
||||||
|
|
||||||
|
if (m_gcfg2.getInt(id, "ios", &userIOS) && _installed_cios.size() > 0)
|
||||||
|
{
|
||||||
|
for(CIOSItr itr = _installed_cios.begin(); itr != _installed_cios.end(); itr++)
|
||||||
|
{
|
||||||
|
if(itr->second == userIOS || itr->first == userIOS)
|
||||||
|
{
|
||||||
|
gameIOS = itr->first;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else gameIOS = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Reload IOS, if requested
|
||||||
|
if (gameIOS != mainIOS)
|
||||||
|
{
|
||||||
|
if(gameIOS < 0x64)
|
||||||
|
{
|
||||||
|
if ( _installed_cios.size() <= 0)
|
||||||
|
{
|
||||||
|
error(sfmt("No cios found!"));
|
||||||
|
Sys_LoadMenu();
|
||||||
|
}
|
||||||
|
u8 IOS[3];
|
||||||
|
IOS[0] = gameIOS == 0 ? ios : gameIOS;
|
||||||
|
IOS[1] = 56;
|
||||||
|
IOS[2] = 57;
|
||||||
|
bool found = false;
|
||||||
|
for(u8 num = 0; num < 3; num++)
|
||||||
|
{
|
||||||
|
if(found)
|
||||||
|
break;
|
||||||
|
if(IOS[num] == 0)
|
||||||
|
continue;
|
||||||
|
for(CIOSItr itr = _installed_cios.begin(); itr != _installed_cios.end(); itr++)
|
||||||
|
{
|
||||||
|
if(itr->second == IOS[num] || itr->first == IOS[num])
|
||||||
|
{
|
||||||
|
gameIOS = itr->first;
|
||||||
|
found = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(!found)
|
||||||
|
{
|
||||||
|
error(sfmt("Couldn't find a cIOS using base %i, or 56/57", IOS[0]));
|
||||||
|
return LOAD_IOS_FAILED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (gameIOS != mainIOS)
|
||||||
|
{
|
||||||
|
gprintf("Reloading IOS into %d\n", gameIOS);
|
||||||
|
cleanup(true);
|
||||||
|
if(!loadIOS(gameIOS, true))
|
||||||
|
{
|
||||||
|
error(sfmt("Couldn't load IOS %i", gameIOS));
|
||||||
|
return LOAD_IOS_FAILED;
|
||||||
|
}
|
||||||
|
return LOAD_IOS_SUCCEEDED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return LOAD_IOS_NOT_NEEDED;
|
||||||
|
}
|
||||||
|
|
||||||
static const char systems[11] = { 'C', 'E', 'F', 'J', 'L', 'M', 'N', 'P', 'Q', 'W', 'H' };
|
static const char systems[11] = { 'C', 'E', 'F', 'J', 'L', 'M', 'N', 'P', 'Q', 'W', 'H' };
|
||||||
|
|
||||||
void CMenu::_launchChannel(dir_discHdr *hdr)
|
void CMenu::_launchChannel(dir_discHdr *hdr)
|
||||||
{
|
{
|
||||||
Channels channel;
|
Channels channel;
|
||||||
u8 ios = channel.GetRequestedIOS(hdr->hdr.chantitle);
|
|
||||||
u8 *data = NULL;
|
u8 *data = NULL;
|
||||||
|
|
||||||
string id = string((const char *) hdr->hdr.id);
|
string id = string((const char *) hdr->hdr.id);
|
||||||
@ -837,24 +908,8 @@ void CMenu::_launchChannel(dir_discHdr *hdr)
|
|||||||
bool disableIOSreload = m_gcfg2.testOptBool(id, "reload_block", m_cfg.getBool("GENERAL", "reload_block", false));
|
bool disableIOSreload = m_gcfg2.testOptBool(id, "reload_block", m_cfg.getBool("GENERAL", "reload_block", false));
|
||||||
int aspectRatio = min((u32)m_gcfg2.getInt(id, "aspect_ratio", 0), ARRAY_SIZE(CMenu::_AspectRatio) - 1u)-1;
|
int aspectRatio = min((u32)m_gcfg2.getInt(id, "aspect_ratio", 0), ARRAY_SIZE(CMenu::_AspectRatio) - 1u)-1;
|
||||||
|
|
||||||
int gameIOS = 0;
|
|
||||||
|
|
||||||
if(!forwarder)
|
if(!forwarder)
|
||||||
{
|
{
|
||||||
int userIOS = 0;
|
|
||||||
if (m_gcfg2.getInt(id, "ios", &userIOS) && _installed_cios.size() > 0)
|
|
||||||
{
|
|
||||||
for(CIOSItr itr = _installed_cios.begin(); itr != _installed_cios.end(); itr++)
|
|
||||||
{
|
|
||||||
if(itr->second == userIOS || itr->first == userIOS)
|
|
||||||
{
|
|
||||||
gameIOS = itr->first;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
else gameIOS = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
hooktype = (u32) m_gcfg2.getInt(id, "hooktype", 0);
|
hooktype = (u32) m_gcfg2.getInt(id, "hooktype", 0);
|
||||||
debuggerselect = m_gcfg2.getBool(id, "debugger", false) ? 1 : 0;
|
debuggerselect = m_gcfg2.getBool(id, "debugger", false) ? 1 : 0;
|
||||||
|
|
||||||
@ -894,57 +949,11 @@ void CMenu::_launchChannel(dir_discHdr *hdr)
|
|||||||
if (cheat) _loadFile(cheatFile, cheatSize, m_cheatDir.c_str(), fmt("%s.gct", hdr->hdr.id));
|
if (cheat) _loadFile(cheatFile, cheatSize, m_cheatDir.c_str(), fmt("%s.gct", hdr->hdr.id));
|
||||||
ocarina_load_code((u8 *) &hdr->hdr.id, cheatFile.get(), cheatSize);
|
ocarina_load_code((u8 *) &hdr->hdr.id, cheatFile.get(), cheatSize);
|
||||||
|
|
||||||
|
int result = _loadIOS(channel.GetRequestedIOS(hdr->hdr.chantitle), id);
|
||||||
// Reload IOS, if requested
|
if (result == LOAD_IOS_FAILED)
|
||||||
if (gameIOS != mainIOS)
|
return;
|
||||||
{
|
if (result == LOAD_IOS_SUCCEEDED)
|
||||||
if(gameIOS < 0x64)
|
iosLoaded = true;
|
||||||
{
|
|
||||||
if ( _installed_cios.size() <= 0)
|
|
||||||
{
|
|
||||||
error(sfmt("No cios found!"));
|
|
||||||
Sys_LoadMenu();
|
|
||||||
}
|
|
||||||
u8 IOS[3];
|
|
||||||
IOS[0] = gameIOS == 0 ? ios : gameIOS;
|
|
||||||
IOS[1] = 56;
|
|
||||||
IOS[2] = 57;
|
|
||||||
bool found = false;
|
|
||||||
for(u8 num = 0; num < 3; num++)
|
|
||||||
{
|
|
||||||
if(found)
|
|
||||||
break;
|
|
||||||
if(IOS[num] == 0)
|
|
||||||
continue;
|
|
||||||
for(CIOSItr itr = _installed_cios.begin(); itr != _installed_cios.end(); itr++)
|
|
||||||
{
|
|
||||||
if(itr->second == IOS[num] || itr->first == IOS[num])
|
|
||||||
{
|
|
||||||
gameIOS = itr->first;
|
|
||||||
found = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if(!found)
|
|
||||||
{
|
|
||||||
error(sfmt("Couldn't find a cIOS using base %i, or 56/57", IOS[0]));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (gameIOS != mainIOS)
|
|
||||||
{
|
|
||||||
gprintf("Reloading IOS into %d\n", gameIOS);
|
|
||||||
cleanup(true);
|
|
||||||
if(!loadIOS(gameIOS, true))
|
|
||||||
{
|
|
||||||
error(sfmt("Couldn't load IOS %i", gameIOS));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
iosLoaded = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!emu_disabled)
|
if(!emu_disabled)
|
||||||
@ -1160,22 +1169,6 @@ void CMenu::_launchGame(dir_discHdr *hdr, bool dvd)
|
|||||||
if (!dvd && get_frag_list((u8 *) hdr->hdr.id, (char *) hdr->path, currentPartition == 0 ? 0x200 : sector_size) < 0)
|
if (!dvd && get_frag_list((u8 *) hdr->hdr.id, (char *) hdr->path, currentPartition == 0 ? 0x200 : sector_size) < 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
int gameIOS = 0;
|
|
||||||
int userIOS = 0;
|
|
||||||
if (m_gcfg2.getInt(id, "ios", &userIOS) && _installed_cios.size() > 0)
|
|
||||||
{
|
|
||||||
for(CIOSItr itr = _installed_cios.begin(); itr != _installed_cios.end(); itr++)
|
|
||||||
{
|
|
||||||
if(itr->second == userIOS || itr->first == userIOS)
|
|
||||||
{
|
|
||||||
gameIOS = itr->first;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
gameIOS = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
u8 patchVidMode = min((u32)m_gcfg2.getInt(id, "patch_video_modes", 0), ARRAY_SIZE(CMenu::_vidModePatch) - 1u);
|
u8 patchVidMode = min((u32)m_gcfg2.getInt(id, "patch_video_modes", 0), ARRAY_SIZE(CMenu::_vidModePatch) - 1u);
|
||||||
hooktype = (u32) m_gcfg2.getInt(id, "hooktype", 0); // hooktype is defined in patchcode.h
|
hooktype = (u32) m_gcfg2.getInt(id, "hooktype", 0); // hooktype is defined in patchcode.h
|
||||||
debuggerselect = m_gcfg2.getBool(id, "debugger", false) ? 1 : 0; // debuggerselect is defined in fst.h
|
debuggerselect = m_gcfg2.getBool(id, "debugger", false) ? 1 : 0; // debuggerselect is defined in fst.h
|
||||||
@ -1188,7 +1181,6 @@ void CMenu::_launchGame(dir_discHdr *hdr, bool dvd)
|
|||||||
|
|
||||||
SmartBuf cheatFile, gameconfig;
|
SmartBuf cheatFile, gameconfig;
|
||||||
u32 cheatSize = 0, gameconfigSize = 0;
|
u32 cheatSize = 0, gameconfigSize = 0;
|
||||||
bool iosLoaded = false;
|
|
||||||
|
|
||||||
CheckGameSoundThread();
|
CheckGameSoundThread();
|
||||||
if (videoMode == 0) videoMode = (u8)min((u32)m_cfg.getInt("GENERAL", "video_mode", 0), ARRAY_SIZE(CMenu::_videoModes) - 1);
|
if (videoMode == 0) videoMode = (u8)min((u32)m_cfg.getInt("GENERAL", "video_mode", 0), ARRAY_SIZE(CMenu::_videoModes) - 1);
|
||||||
@ -1217,55 +1209,15 @@ void CMenu::_launchGame(dir_discHdr *hdr, bool dvd)
|
|||||||
|
|
||||||
net_wc24cleanup();
|
net_wc24cleanup();
|
||||||
|
|
||||||
// Reload IOS, if requested
|
bool iosLoaded = false;
|
||||||
if (!dvd && gameIOS != mainIOS)
|
|
||||||
|
if (!dvd)
|
||||||
{
|
{
|
||||||
if(gameIOS < 0x64)
|
int result = _loadIOS(GetRequestedGameIOS(hdr), id);
|
||||||
{
|
if (result == LOAD_IOS_FAILED)
|
||||||
if ( _installed_cios.size() <= 0)
|
return;
|
||||||
{
|
if (result == LOAD_IOS_SUCCEEDED)
|
||||||
error(sfmt("No cios found!"));
|
|
||||||
Sys_LoadMenu();
|
|
||||||
}
|
|
||||||
u8 IOS[3];
|
|
||||||
IOS[0] = gameIOS == 0 ? GetRequestedGameIOS(hdr) : gameIOS;
|
|
||||||
IOS[1] = 56;
|
|
||||||
IOS[2] = 57;
|
|
||||||
gprintf("Game requested IOS: %u\n", IOS[0]);
|
|
||||||
bool found = false;
|
|
||||||
for(u8 num = 0; num < 3; num++)
|
|
||||||
{
|
|
||||||
if(found)
|
|
||||||
break;
|
|
||||||
if(IOS[num] == 0)
|
|
||||||
continue;
|
|
||||||
for(CIOSItr itr = _installed_cios.begin(); itr != _installed_cios.end(); itr++)
|
|
||||||
{
|
|
||||||
if(itr->second == IOS[num] || itr->first == IOS[num])
|
|
||||||
{
|
|
||||||
gameIOS = itr->first;
|
|
||||||
found = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if(!found)
|
|
||||||
{
|
|
||||||
error(sfmt("Couldn't find a cIOS using base %i, or 56/57", IOS[0]));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (gameIOS != mainIOS)
|
|
||||||
{
|
|
||||||
gprintf("Reloading IOS into %d\n", gameIOS);
|
|
||||||
cleanup(true);
|
|
||||||
if(!loadIOS(gameIOS, true))
|
|
||||||
{
|
|
||||||
error(sfmt("Couldn't load IOS %i", gameIOS));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
iosLoaded = true;
|
iosLoaded = true;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(emuSave)
|
if(emuSave)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user