-fixed bug which tried to launch a dml game from sd card

even if the copy process failed because of not enough space
on it (resulted in black screen then)
This commit is contained in:
fix94.1 2012-04-03 15:49:52 +00:00
parent 4b70662739
commit 45350b8b71

View File

@ -225,32 +225,22 @@ int CMenu::_GCcopyGame(void *obj)
memset(folder, 0, sizeof(folder)); memset(folder, 0, sizeof(folder));
snprintf(folder, sizeof(folder), DML_DIR, DeviceName[SD]); snprintf(folder, sizeof(folder), DML_DIR, DeviceName[SD]);
snprintf(target, sizeof(target), "%s/%s", folder, m.m_cf.getHdr()->path); snprintf(target, sizeof(target), "%s/%s", folder, m.m_cf.getHdr()->path);
int ret;
if(fsop_GetFreeSpaceKb((char*)"sd:/")<fsop_GetFolderKb(source)) LWP_MutexLock(m.m_mutex);
{ m._setThrdMsg(L"", 0);
LWP_MutexLock(m.m_mutex); gprintf("Copying from:\n%s\nto:\n%s\n",source,target);
m._setThrdMsg(wfmt(m._fmt("wbfsop10", L"Not enough space: %d blocks needed, %d available"), fsop_GetFolderKb(source), fsop_GetFreeSpaceKb((char*)"sd:/")), 0.f); LWP_MutexUnlock(m.m_mutex);
LWP_MutexUnlock(m.m_mutex); if (!fsop_DirExist(folder))
ret = -1; makedir(folder);
} fsop_CopyFolder(source, target, CMenu::_addDiscProgress, obj);
else LWP_MutexLock(m.m_mutex);
{ m._setThrdMsg(m._t("wbfsop14", L"Game copied, press Back to boot the game."), 1.f);
LWP_MutexLock(m.m_mutex); gprintf("Game copied.\n");
m._setThrdMsg(L"", 0); LWP_MutexUnlock(m.m_mutex);
gprintf("Copying from:\n%s\nto:\n%s\n",source,target); slotLight(true);
LWP_MutexUnlock(m.m_mutex);
if (!fsop_DirExist(folder))
makedir(folder);
fsop_CopyFolder(source, target, CMenu::_addDiscProgress, obj);
LWP_MutexLock(m.m_mutex);
m._setThrdMsg(m._t("wbfsop14", L"Game copied, press Back to boot the game."), 1.f);
gprintf("Game copied.\n");
LWP_MutexUnlock(m.m_mutex);
slotLight(true);
ret = 0;
}
m.m_thrdWorking = false; m.m_thrdWorking = false;
return ret; return 0;
} }
bool CMenu::_wbfsOp(CMenu::WBFS_OP op) bool CMenu::_wbfsOp(CMenu::WBFS_OP op)
@ -401,6 +391,17 @@ bool CMenu::_wbfsOp(CMenu::WBFS_OP op)
case CMenu::WO_FORMAT: case CMenu::WO_FORMAT:
break; break;
case CMenu::WO_COPY_GAME: case CMenu::WO_COPY_GAME:
char folder[50];
char source[300];
snprintf(folder, sizeof(folder), m_DMLgameDir.c_str(), DeviceName[currentPartition]);
snprintf(source, sizeof(source), "%s/%s", folder, m_cf.getHdr()->path);
if(fsop_GetFreeSpaceKb((char*)"sd:/")<fsop_GetFolderKb(source))
{
m_btnMgr.hide(m_wbfsBtnGo);
_setThrdMsg(wfmt(_fmt("wbfsop10", L"Not enough space: %d blocks needed, %d available"), fsop_GetFolderKb(source), fsop_GetFreeSpaceKb((char*)"sd:/")), 0.f);
break;
}
m_btnMgr.show(m_wbfsPBar); m_btnMgr.show(m_wbfsPBar);
m_btnMgr.setProgress(m_wbfsPBar, 0.f); m_btnMgr.setProgress(m_wbfsPBar, 0.f);
m_btnMgr.hide(m_wbfsBtnGo); m_btnMgr.hide(m_wbfsBtnGo);