mirror of
https://github.com/Fledge68/WiiFlow_Lite.git
synced 2025-01-12 11:59:08 +01:00
- added options to copy real nand config and miis to emunand on page 3 of emu nand settings. if set to 'on' then when you launch a emu nand game sysconfig and/or miis from real nand will be copied to emu nand before launching the game. this solves issue #90 to keep your controllers synced in emu nand mode.
This commit is contained in:
parent
8b92b14656
commit
0787670dea
Binary file not shown.
BIN
out/boot.dol
BIN
out/boot.dol
Binary file not shown.
Before Width: | Height: | Size: 3.4 MiB After Width: | Height: | Size: 3.4 MiB |
@ -6,7 +6,7 @@
|
|||||||
#else
|
#else
|
||||||
#define APP_NAME "WiiFlow Lite"
|
#define APP_NAME "WiiFlow Lite"
|
||||||
#endif
|
#endif
|
||||||
#define APP_VERSION "5.3.0 beta 3"
|
#define APP_VERSION "5.3.0 beta 5"
|
||||||
|
|
||||||
#define APP_DATA_DIR "wiiflow"
|
#define APP_DATA_DIR "wiiflow"
|
||||||
#ifdef APP_WIIFLOW
|
#ifdef APP_WIIFLOW
|
||||||
|
@ -1636,8 +1636,8 @@ void CMenu::_launchChannel(dir_discHdr *hdr)
|
|||||||
/* copy real NAND sysconf, settings.txt, & RFL_DB.dat if you want to, they are replaced if they already exist */
|
/* copy real NAND sysconf, settings.txt, & RFL_DB.dat if you want to, they are replaced if they already exist */
|
||||||
NandHandle.PreNandCfg(m_cfg.getBool(CHANNEL_DOMAIN, "real_nand_miis", false),
|
NandHandle.PreNandCfg(m_cfg.getBool(CHANNEL_DOMAIN, "real_nand_miis", false),
|
||||||
m_cfg.getBool(CHANNEL_DOMAIN, "real_nand_config", false));
|
m_cfg.getBool(CHANNEL_DOMAIN, "real_nand_config", false));
|
||||||
m_cfg.setBool(CHANNEL_DOMAIN, "real_nand_miis", false);
|
//m_cfg.setBool(CHANNEL_DOMAIN, "real_nand_miis", false);
|
||||||
m_cfg.setBool(CHANNEL_DOMAIN, "real_nand_config", false);
|
//m_cfg.setBool(CHANNEL_DOMAIN, "real_nand_config", false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* configs no longer needed */
|
/* configs no longer needed */
|
||||||
|
@ -44,6 +44,10 @@ s16 m_nandemuBtnSavePartitionP;
|
|||||||
|
|
||||||
s16 m_nandemuLblInstallWad;
|
s16 m_nandemuLblInstallWad;
|
||||||
s16 m_nandemuBtnInstallWad;
|
s16 m_nandemuBtnInstallWad;
|
||||||
|
s16 m_nandemuLblRealConfig;
|
||||||
|
s16 m_nandemuBtnRealConfig;
|
||||||
|
s16 m_nandemuLblRealMiis;
|
||||||
|
s16 m_nandemuBtnRealMiis;
|
||||||
|
|
||||||
s16 m_nandfileLblMessage;
|
s16 m_nandfileLblMessage;
|
||||||
s16 m_nandemuLblMessage;
|
s16 m_nandemuLblMessage;
|
||||||
@ -403,6 +407,12 @@ void CMenu::_hideNandEmu(bool instant)
|
|||||||
m_btnMgr.hide(m_nandemuLblInstallWad, instant);
|
m_btnMgr.hide(m_nandemuLblInstallWad, instant);
|
||||||
m_btnMgr.hide(m_nandemuBtnInstallWad, instant);
|
m_btnMgr.hide(m_nandemuBtnInstallWad, instant);
|
||||||
|
|
||||||
|
m_btnMgr.hide(m_nandemuLblRealConfig, instant);
|
||||||
|
m_btnMgr.hide(m_nandemuBtnRealConfig, instant);
|
||||||
|
|
||||||
|
m_btnMgr.hide(m_nandemuLblRealMiis, instant);
|
||||||
|
m_btnMgr.hide(m_nandemuBtnRealMiis, instant);
|
||||||
|
|
||||||
m_btnMgr.hide(m_nandemuBtnExtract, instant);
|
m_btnMgr.hide(m_nandemuBtnExtract, instant);
|
||||||
m_btnMgr.hide(m_nandemuBtnDisable, instant);
|
m_btnMgr.hide(m_nandemuBtnDisable, instant);
|
||||||
m_btnMgr.hide(m_nandemuLblInit, instant);
|
m_btnMgr.hide(m_nandemuLblInit, instant);
|
||||||
@ -455,6 +465,12 @@ void CMenu::_hideNandEmuPg(void)
|
|||||||
m_btnMgr.hide(m_nandemuLblSavePartitionVal);
|
m_btnMgr.hide(m_nandemuLblSavePartitionVal);
|
||||||
m_btnMgr.hide(m_nandemuBtnSavePartitionP);
|
m_btnMgr.hide(m_nandemuBtnSavePartitionP);
|
||||||
m_btnMgr.hide(m_nandemuBtnSavePartitionM);
|
m_btnMgr.hide(m_nandemuBtnSavePartitionM);
|
||||||
|
|
||||||
|
m_btnMgr.hide(m_nandemuLblRealConfig);
|
||||||
|
m_btnMgr.hide(m_nandemuBtnRealConfig);
|
||||||
|
|
||||||
|
m_btnMgr.hide(m_nandemuLblRealMiis);
|
||||||
|
m_btnMgr.hide(m_nandemuBtnRealMiis);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -518,10 +534,19 @@ void CMenu::_showNandEmu(void)
|
|||||||
const char *partitionname = DeviceName[m_cfg.getInt(WII_DOMAIN, "savepartition")];
|
const char *partitionname = DeviceName[m_cfg.getInt(WII_DOMAIN, "savepartition")];
|
||||||
m_btnMgr.setText(m_nandemuLblSavePartitionVal, upperCase(partitionname));
|
m_btnMgr.setText(m_nandemuLblSavePartitionVal, upperCase(partitionname));
|
||||||
|
|
||||||
|
m_btnMgr.setText(m_nandemuBtnRealConfig, m_cfg.getBool(CHANNEL_DOMAIN, "real_nand_config", false) ? _t("on", L"On") : _t("off", L"Off"));
|
||||||
|
m_btnMgr.setText(m_nandemuBtnRealMiis, m_cfg.getBool(CHANNEL_DOMAIN, "real_nand_miis", false) ? _t("on", L"On") : _t("off", L"Off"));
|
||||||
|
|
||||||
m_btnMgr.show(m_nandemuLblSavePartition);
|
m_btnMgr.show(m_nandemuLblSavePartition);
|
||||||
m_btnMgr.show(m_nandemuLblSavePartitionVal);
|
m_btnMgr.show(m_nandemuLblSavePartitionVal);
|
||||||
m_btnMgr.show(m_nandemuBtnSavePartitionP);
|
m_btnMgr.show(m_nandemuBtnSavePartitionP);
|
||||||
m_btnMgr.show(m_nandemuBtnSavePartitionM);
|
m_btnMgr.show(m_nandemuBtnSavePartitionM);
|
||||||
|
|
||||||
|
m_btnMgr.show(m_nandemuLblRealConfig);
|
||||||
|
m_btnMgr.show(m_nandemuBtnRealConfig);
|
||||||
|
|
||||||
|
m_btnMgr.show(m_nandemuLblRealMiis);
|
||||||
|
m_btnMgr.show(m_nandemuBtnRealMiis);
|
||||||
}
|
}
|
||||||
|
|
||||||
for(u8 i = 0; i < ARRAY_SIZE(m_nandemuLblUser); ++i)
|
for(u8 i = 0; i < ARRAY_SIZE(m_nandemuLblUser); ++i)
|
||||||
@ -578,19 +603,21 @@ int CMenu::_NandEmuCfg(void)
|
|||||||
m_btnMgr.up();
|
m_btnMgr.up();
|
||||||
else if(BTN_DOWN_PRESSED && !m_thrdWorking)
|
else if(BTN_DOWN_PRESSED && !m_thrdWorking)
|
||||||
m_btnMgr.down();
|
m_btnMgr.down();
|
||||||
else if(BTN_A_PRESSED && (m_btnMgr.selected(m_nandemuBtnEmulationP) || m_btnMgr.selected(m_nandemuBtnEmulationM)))
|
else if(BTN_A_PRESSED)
|
||||||
|
{
|
||||||
|
if(m_btnMgr.selected(m_nandemuBtnEmulationP) || m_btnMgr.selected(m_nandemuBtnEmulationM))
|
||||||
{
|
{
|
||||||
s8 direction = m_btnMgr.selected(m_nandemuBtnEmulationP) ? 1 : -1;
|
s8 direction = m_btnMgr.selected(m_nandemuBtnEmulationP) ? 1 : -1;
|
||||||
m_cfg.setInt(CHANNEL_DOMAIN, "emulation", loopNum(m_cfg.getInt(CHANNEL_DOMAIN, "emulation", 0) + direction, ARRAY_SIZE(CMenu::_NandEmu)));
|
m_cfg.setInt(CHANNEL_DOMAIN, "emulation", loopNum(m_cfg.getInt(CHANNEL_DOMAIN, "emulation", 0) + direction, ARRAY_SIZE(CMenu::_NandEmu)));
|
||||||
_showNandEmu();
|
_showNandEmu();
|
||||||
}
|
}
|
||||||
else if(BTN_A_PRESSED && (m_btnMgr.selected(m_nandemuBtnSaveEmulationP) || m_btnMgr.selected(m_nandemuBtnSaveEmulationM)))
|
else if(m_btnMgr.selected(m_nandemuBtnSaveEmulationP) || m_btnMgr.selected(m_nandemuBtnSaveEmulationM))
|
||||||
{
|
{
|
||||||
s8 direction = m_btnMgr.selected(m_nandemuBtnSaveEmulationP) ? 1 : -1;
|
s8 direction = m_btnMgr.selected(m_nandemuBtnSaveEmulationP) ? 1 : -1;
|
||||||
m_cfg.setInt(WII_DOMAIN, "save_emulation", loopNum(m_cfg.getInt(WII_DOMAIN, "save_emulation", 0) + direction, ARRAY_SIZE(CMenu::_GlobalSaveEmu)));
|
m_cfg.setInt(WII_DOMAIN, "save_emulation", loopNum(m_cfg.getInt(WII_DOMAIN, "save_emulation", 0) + direction, ARRAY_SIZE(CMenu::_GlobalSaveEmu)));
|
||||||
_showNandEmu();
|
_showNandEmu();
|
||||||
}
|
}
|
||||||
else if(BTN_A_PRESSED && (m_btnMgr.selected(m_nandemuBtnSavePartitionP) || m_btnMgr.selected(m_nandemuBtnSavePartitionM)))
|
else if(m_btnMgr.selected(m_nandemuBtnSavePartitionP) || m_btnMgr.selected(m_nandemuBtnSavePartitionM))
|
||||||
{
|
{
|
||||||
s8 direction = m_btnMgr.selected(m_nandemuBtnSavePartitionP) ? 1 : -1;
|
s8 direction = m_btnMgr.selected(m_nandemuBtnSavePartitionP) ? 1 : -1;
|
||||||
currentPartition = m_cfg.getInt(WII_DOMAIN, "savepartition");
|
currentPartition = m_cfg.getInt(WII_DOMAIN, "savepartition");
|
||||||
@ -600,7 +627,7 @@ int CMenu::_NandEmuCfg(void)
|
|||||||
_checkEmuNandSettings();// refresh emunands in case the partition was changed
|
_checkEmuNandSettings();// refresh emunands in case the partition was changed
|
||||||
_showNandEmu();
|
_showNandEmu();
|
||||||
}
|
}
|
||||||
else if(BTN_A_PRESSED && (m_btnMgr.selected(m_nandemuBtnNandDump) || m_btnMgr.selected(m_nandemuBtnAll) || m_btnMgr.selected(m_nandemuBtnMissing)))
|
else if(m_btnMgr.selected(m_nandemuBtnNandDump) || m_btnMgr.selected(m_nandemuBtnAll) || m_btnMgr.selected(m_nandemuBtnMissing))
|
||||||
{
|
{
|
||||||
m_nanddump = m_btnMgr.selected(m_nandemuBtnNandDump) ? true : false;
|
m_nanddump = m_btnMgr.selected(m_nandemuBtnNandDump) ? true : false;
|
||||||
m_saveall = m_btnMgr.selected(m_nandemuBtnAll) ? true : false;
|
m_saveall = m_btnMgr.selected(m_nandemuBtnAll) ? true : false;
|
||||||
@ -641,32 +668,43 @@ int CMenu::_NandEmuCfg(void)
|
|||||||
LWP_CreateThread(&thread, _NandDumper, this, 0, 32768, 40);
|
LWP_CreateThread(&thread, _NandDumper, this, 0, 32768, 40);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(BTN_A_PRESSED && (m_btnMgr.selected(m_nandemuBtnNandSelectP) || m_btnMgr.selected(m_nandemuBtnNandSelectM)))
|
else if(m_btnMgr.selected(m_nandemuBtnNandSelectP) || m_btnMgr.selected(m_nandemuBtnNandSelectM))
|
||||||
{
|
{
|
||||||
s8 direction = m_btnMgr.selected(m_nandemuBtnNandSelectP) ? 1 : -1;
|
s8 direction = m_btnMgr.selected(m_nandemuBtnNandSelectP) ? 1 : -1;
|
||||||
curEmuNand = loopNum(curEmuNand + direction, emuNands.size());
|
curEmuNand = loopNum(curEmuNand + direction, emuNands.size());
|
||||||
m_cfg.setString(CHANNEL_DOMAIN, "current_emunand", emuNands[curEmuNand]);
|
m_cfg.setString(CHANNEL_DOMAIN, "current_emunand", emuNands[curEmuNand]);
|
||||||
_showNandEmu();
|
_showNandEmu();
|
||||||
}
|
}
|
||||||
else if(BTN_A_PRESSED && (m_btnMgr.selected(m_nandemuBtnSaveNandSelectP) || m_btnMgr.selected(m_nandemuBtnSaveNandSelectM)))
|
else if(m_btnMgr.selected(m_nandemuBtnSaveNandSelectP) || m_btnMgr.selected(m_nandemuBtnSaveNandSelectM))
|
||||||
{
|
{
|
||||||
s8 direction = m_btnMgr.selected(m_nandemuBtnSaveNandSelectP) ? 1 : -1;
|
s8 direction = m_btnMgr.selected(m_nandemuBtnSaveNandSelectP) ? 1 : -1;
|
||||||
curSavesNand = loopNum(curSavesNand + direction, savesNands.size());
|
curSavesNand = loopNum(curSavesNand + direction, savesNands.size());
|
||||||
m_cfg.setString(WII_DOMAIN, "current_save_emunand", savesNands[curSavesNand]);
|
m_cfg.setString(WII_DOMAIN, "current_save_emunand", savesNands[curSavesNand]);
|
||||||
_showNandEmu();
|
_showNandEmu();
|
||||||
}
|
}
|
||||||
else if(BTN_A_PRESSED && m_btnMgr.selected(m_nandemuBtnInstallWad))
|
else if(m_btnMgr.selected(m_nandemuBtnInstallWad))
|
||||||
{
|
{
|
||||||
_hideNandEmu();
|
_hideNandEmu();
|
||||||
_wadExplorer();
|
_wadExplorer();
|
||||||
nandemuPage = 1;
|
nandemuPage = 1;
|
||||||
_showNandEmu();
|
_showNandEmu();
|
||||||
}
|
}
|
||||||
else if(BTN_A_PRESSED && m_btnMgr.selected(m_nandemuBtnBack))
|
else if (m_btnMgr.selected(m_nandemuBtnRealConfig))
|
||||||
|
{
|
||||||
|
m_cfg.setBool(CHANNEL_DOMAIN, "real_nand_config", !m_cfg.getBool(CHANNEL_DOMAIN, "real_nand_config"));
|
||||||
|
_showNandEmu();
|
||||||
|
}
|
||||||
|
else if (m_btnMgr.selected(m_nandemuBtnRealMiis))
|
||||||
|
{
|
||||||
|
m_cfg.setBool(CHANNEL_DOMAIN, "real_nand_miis", !m_cfg.getBool(CHANNEL_DOMAIN, "real_nand_miis"));
|
||||||
|
_showNandEmu();
|
||||||
|
}
|
||||||
|
else if(m_btnMgr.selected(m_nandemuBtnBack))
|
||||||
{
|
{
|
||||||
m_cfg.save();
|
m_cfg.save();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if(m_thrdMessageAdded)
|
if(m_thrdMessageAdded)
|
||||||
{
|
{
|
||||||
@ -1055,6 +1093,10 @@ void CMenu::_initNandEmuMenu()
|
|||||||
m_nandemuLblSavePartitionVal = _addLabel("NANDEMU/SAVE_PART_BTN", theme.btnFont, L"", 468,130, 104, 48, theme.btnFontColor, FTGX_JUSTIFY_CENTER | FTGX_ALIGN_MIDDLE, theme.btnTexC);
|
m_nandemuLblSavePartitionVal = _addLabel("NANDEMU/SAVE_PART_BTN", theme.btnFont, L"", 468,130, 104, 48, theme.btnFontColor, FTGX_JUSTIFY_CENTER | FTGX_ALIGN_MIDDLE, theme.btnTexC);
|
||||||
m_nandemuBtnSavePartitionM = _addPicButton("NANDEMU/SAVE_PART_MINUS", theme.btnTexMinus, theme.btnTexMinusS, 420, 130, 48, 48);
|
m_nandemuBtnSavePartitionM = _addPicButton("NANDEMU/SAVE_PART_MINUS", theme.btnTexMinus, theme.btnTexMinusS, 420, 130, 48, 48);
|
||||||
m_nandemuBtnSavePartitionP = _addPicButton("NANDEMU/SAVE_PART_PLUS", theme.btnTexPlus, theme.btnTexPlusS, 572, 130, 48, 48);
|
m_nandemuBtnSavePartitionP = _addPicButton("NANDEMU/SAVE_PART_PLUS", theme.btnTexPlus, theme.btnTexPlusS, 572, 130, 48, 48);
|
||||||
|
m_nandemuLblRealConfig = _addLabel("NANDEMU/REAL_CONFIG", theme.lblFont, L"", 20, 185, 385, 56, theme.lblFontColor, FTGX_JUSTIFY_LEFT | FTGX_ALIGN_MIDDLE);
|
||||||
|
m_nandemuBtnRealConfig = _addButton("NANDEMU/REAL_CONFIG_BTN", theme.btnFont, L"", 420, 190, 200, 48, theme.btnFontColor);
|
||||||
|
m_nandemuLblRealMiis = _addLabel("NANDEMU/REAL_MIIS", theme.lblFont, L"", 20, 245, 385, 56, theme.lblFontColor, FTGX_JUSTIFY_LEFT | FTGX_ALIGN_MIDDLE);
|
||||||
|
m_nandemuBtnRealMiis = _addButton("NANDEMU/REAL_MIIS_BTN", theme.btnFont, L"", 420, 250, 200, 48, theme.btnFontColor);
|
||||||
|
|
||||||
m_nandemuBtnBack = _addButton("NANDEMU/BACK_BTN", theme.btnFont, L"", 420, 400, 200, 48, theme.btnFontColor);
|
m_nandemuBtnBack = _addButton("NANDEMU/BACK_BTN", theme.btnFont, L"", 420, 400, 200, 48, theme.btnFontColor);
|
||||||
m_nandemuLblPage = _addLabel("NANDEMU/PAGE_BTN", theme.btnFont, L"", 68, 400, 104, 48, theme.btnFontColor, FTGX_JUSTIFY_CENTER | FTGX_ALIGN_MIDDLE, theme.btnTexC);
|
m_nandemuLblPage = _addLabel("NANDEMU/PAGE_BTN", theme.btnFont, L"", 68, 400, 104, 48, theme.btnFontColor, FTGX_JUSTIFY_CENTER | FTGX_ALIGN_MIDDLE, theme.btnTexC);
|
||||||
@ -1103,6 +1145,10 @@ void CMenu::_initNandEmuMenu()
|
|||||||
|
|
||||||
_setHideAnim(m_nandemuLblInstallWad, "NANDEMU/INSTALL_WAD", 50, 0, -2.f, 0.f);
|
_setHideAnim(m_nandemuLblInstallWad, "NANDEMU/INSTALL_WAD", 50, 0, -2.f, 0.f);
|
||||||
_setHideAnim(m_nandemuBtnInstallWad, "NANDEMU/INSTALL_WAD_BTN", -50, 0, 1.f, 0.f);
|
_setHideAnim(m_nandemuBtnInstallWad, "NANDEMU/INSTALL_WAD_BTN", -50, 0, 1.f, 0.f);
|
||||||
|
_setHideAnim(m_nandemuLblRealConfig, "NANDEMU/REAL_CONFIG", 50, 0, -2.f, 0.f);
|
||||||
|
_setHideAnim(m_nandemuBtnRealConfig, "NANDEMU/REAL_CONFIG_BTN", -50, 0, 1.f, 0.f);
|
||||||
|
_setHideAnim(m_nandemuLblRealMiis, "NANDEMU/REAL_MIIS", 50, 0, -2.f, 0.f);
|
||||||
|
_setHideAnim(m_nandemuBtnRealMiis, "NANDEMU/REAL_MIIS_BTN", -50, 0, 1.f, 0.f);
|
||||||
|
|
||||||
_setHideAnim(m_nandemuBtnBack, "NANDEMU/BACK_BTN", 0, 0, 1.f, -1.f);
|
_setHideAnim(m_nandemuBtnBack, "NANDEMU/BACK_BTN", 0, 0, 1.f, -1.f);
|
||||||
_setHideAnim(m_nandemuLblPage, "NANDEMU/PAGE_BTN", 0, 0, 1.f, -1.f);
|
_setHideAnim(m_nandemuLblPage, "NANDEMU/PAGE_BTN", 0, 0, 1.f, -1.f);
|
||||||
@ -1131,5 +1177,7 @@ void CMenu::_textNandEmu(void)
|
|||||||
m_btnMgr.setText(m_nandemuBtnNandDump, _t("cfgne6", L"Start"));
|
m_btnMgr.setText(m_nandemuBtnNandDump, _t("cfgne6", L"Start"));
|
||||||
m_btnMgr.setText(m_nandemuLblInstallWad, _t("cfgne98", L"Install Wad"));
|
m_btnMgr.setText(m_nandemuLblInstallWad, _t("cfgne98", L"Install Wad"));
|
||||||
m_btnMgr.setText(m_nandemuBtnInstallWad, _t("cfgne99", L"Go"));
|
m_btnMgr.setText(m_nandemuBtnInstallWad, _t("cfgne99", L"Go"));
|
||||||
|
m_btnMgr.setText(m_nandemuLblRealConfig, _t("cfgne40", L"Use Real NAND Config"));
|
||||||
|
m_btnMgr.setText(m_nandemuLblRealMiis, _t("cfgne41", L"Use Real NAND Miis"));
|
||||||
m_btnMgr.setText(m_nandemuBtnBack, _t("cfgne7", L"Back"));
|
m_btnMgr.setText(m_nandemuBtnBack, _t("cfgne7", L"Back"));
|
||||||
}
|
}
|
||||||
|
@ -206,6 +206,8 @@ cfgne35=Back
|
|||||||
cfgne36=Path =
|
cfgne36=Path =
|
||||||
cfgne37=Select NAND
|
cfgne37=Select NAND
|
||||||
cfgne38=Saves NAND Partition
|
cfgne38=Saves NAND Partition
|
||||||
|
cfgne40=Use Real NAND Config
|
||||||
|
cfgne41=Use Real NAND Miis
|
||||||
cfgne98=Install Wad
|
cfgne98=Install Wad
|
||||||
cfgne99=Go
|
cfgne99=Go
|
||||||
cfgp1=Game Partition
|
cfgp1=Game Partition
|
||||||
|
Loading…
x
Reference in New Issue
Block a user