Savestates: fixed errors handling (broken by previous commit)
This commit is contained in:
parent
c497432785
commit
510b8a770b
|
@ -2245,7 +2245,7 @@ LRESULT FAR PASCAL AppWndProc(HWND hWnd,UINT msg,WPARAM wParam,LPARAM lParam)
|
|||
|
||||
//Load last auto-save
|
||||
case FCEUX_CONTEXT_REWINDTOLASTAUTO:
|
||||
FCEUI_Autosave();
|
||||
FCEUI_RewindToLastAutosave();
|
||||
break;
|
||||
|
||||
//Create a backup movie file
|
||||
|
|
|
@ -150,7 +150,7 @@ static void FCEU_CloseGame(void)
|
|||
if (AutoResumePlay)
|
||||
{
|
||||
// save "-resume" savestate
|
||||
FCEUSS_Save(FCEU_MakeFName(FCEUMKF_RESUMESTATE, 0, 0).c_str());
|
||||
FCEUSS_Save(FCEU_MakeFName(FCEUMKF_RESUMESTATE, 0, 0).c_str(), false);
|
||||
}
|
||||
|
||||
#ifdef WIN32
|
||||
|
@ -497,10 +497,8 @@ FCEUGI *FCEUI_LoadGameVirtual(const char *name, int OverwriteVidMode, bool silen
|
|||
if (AutoResumePlay)
|
||||
{
|
||||
// load "-resume" savestate
|
||||
if (FCEUSS_Load(FCEU_MakeFName(FCEUMKF_RESUMESTATE, 0, 0).c_str()))
|
||||
if (FCEUSS_Load(FCEU_MakeFName(FCEUMKF_RESUMESTATE, 0, 0).c_str(), false))
|
||||
FCEU_DispMessage("Old play session resumed.", 0);
|
||||
else
|
||||
FCEU_DispMessage("", 0);
|
||||
}
|
||||
|
||||
ResetScreenshotsCounter();
|
||||
|
@ -968,7 +966,7 @@ void UpdateAutosave(void) {
|
|||
AutosaveCounter = 0;
|
||||
AutosaveIndex = (AutosaveIndex + 1) % AutosaveQty;
|
||||
f = strdup(FCEU_MakeFName(FCEUMKF_AUTOSTATE, AutosaveIndex, 0).c_str());
|
||||
FCEUSS_Save(f);
|
||||
FCEUSS_Save(f, false);
|
||||
AutoSS = true; //Flag that an auto-savestate was made
|
||||
free(f);
|
||||
f = NULL;
|
||||
|
@ -976,7 +974,7 @@ void UpdateAutosave(void) {
|
|||
}
|
||||
}
|
||||
|
||||
void FCEUI_Autosave(void) {
|
||||
void FCEUI_RewindToLastAutosave(void) {
|
||||
if (!EnableAutosave || !AutoSS)
|
||||
return;
|
||||
|
||||
|
|
|
@ -31,7 +31,7 @@ void PowerNES(void);
|
|||
void SetAutoFireOffset(int offset);
|
||||
void SetAutoFirePattern(int onframes, int offframes);
|
||||
void AutoFire(void);
|
||||
void FCEUI_Autosave(void);
|
||||
void FCEUI_RewindToLastAutosave(void);
|
||||
|
||||
//mbg 7/23/06
|
||||
char *FCEUI_GetAboutString();
|
||||
|
|
|
@ -759,7 +759,7 @@ struct EMUCMDTABLE FCEUI_CommandTable[]=
|
|||
{ EMUCMD_VSUNI_TOGGLE_DIP_7, EMUCMDTYPE_VSUNI, CommandToggleDip, 0, 0, "Toggle Dipswitch 7", 0 },
|
||||
{ EMUCMD_VSUNI_TOGGLE_DIP_8, EMUCMDTYPE_VSUNI, CommandToggleDip, 0, 0, "Toggle Dipswitch 8", 0 },
|
||||
{ EMUCMD_VSUNI_TOGGLE_DIP_9, EMUCMDTYPE_VSUNI, CommandToggleDip, 0, 0, "Toggle Dipswitch 9", 0 },
|
||||
{ EMUCMD_MISC_AUTOSAVE, EMUCMDTYPE_MISC, FCEUI_Autosave, 0, 0, "Load Last Auto-save", 0},
|
||||
{ EMUCMD_MISC_AUTOSAVE, EMUCMDTYPE_MISC, FCEUI_RewindToLastAutosave, 0, 0, "Load Last Auto-save", 0},
|
||||
{ EMUCMD_MISC_SHOWSTATES, EMUCMDTYPE_MISC, ViewSlots, 0, 0, "View save slots", 0 },
|
||||
{ EMUCMD_MISC_USE_INPUT_PRESET_1, EMUCMDTYPE_MISC, CommandUsePreset, 0, 0, "Use Input Preset 1", EMUCMDFLAG_TASEDITOR },
|
||||
{ EMUCMD_MISC_USE_INPUT_PRESET_2, EMUCMDTYPE_MISC, CommandUsePreset, 0, 0, "Use Input Preset 2", EMUCMDFLAG_TASEDITOR },
|
||||
|
|
|
@ -451,8 +451,9 @@ void FCEUSS_Save(const char *fname, bool display_message)
|
|||
EMUFILE* st = 0;
|
||||
char fn[2048];
|
||||
|
||||
if(geniestage==1)
|
||||
if (geniestage==1)
|
||||
{
|
||||
if (display_message)
|
||||
FCEU_DispMessage("Cannot save FCS in GG screen.",0);
|
||||
return;
|
||||
}
|
||||
|
@ -480,9 +481,10 @@ void FCEUSS_Save(const char *fname, bool display_message)
|
|||
st = FCEUD_UTF8_fstream(fn,"wb");
|
||||
}
|
||||
|
||||
if(display_message && st == NULL || st->get_fp() == NULL)
|
||||
if (st == NULL || st->get_fp() == NULL)
|
||||
{
|
||||
FCEU_DispMessage("State %d save error.",0,CurrentState);
|
||||
if (display_message)
|
||||
FCEU_DispMessage("State %d save error.", 0, CurrentState);
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -519,10 +521,11 @@ void FCEUSS_Save(const char *fname, bool display_message)
|
|||
|
||||
delete st;
|
||||
|
||||
if(display_message && !fname)
|
||||
if(!fname)
|
||||
{
|
||||
SaveStateStatus[CurrentState]=1;
|
||||
FCEU_DispMessage("State %d saved.",0,CurrentState);
|
||||
SaveStateStatus[CurrentState] = 1;
|
||||
if (display_message)
|
||||
FCEU_DispMessage("State %d saved.", 0, CurrentState);
|
||||
}
|
||||
redoSS = false; //we have a new savestate so redo is not possible
|
||||
}
|
||||
|
@ -713,52 +716,56 @@ bool FCEUSS_Load(const char *fname, bool display_message)
|
|||
// MovieFlushHeader();
|
||||
//}
|
||||
|
||||
if(geniestage==1)
|
||||
if (geniestage == 1)
|
||||
{
|
||||
if (display_message)
|
||||
FCEU_DispMessage("Cannot load FCS in GG screen.",0);
|
||||
return false;
|
||||
}
|
||||
if(fname)
|
||||
if (fname)
|
||||
{
|
||||
st=FCEUD_UTF8_fstream(fname, "rb");
|
||||
st = FCEUD_UTF8_fstream(fname, "rb");
|
||||
strcpy(fn, fname);
|
||||
}
|
||||
else
|
||||
} else
|
||||
{
|
||||
strcpy(fn, FCEU_MakeFName(FCEUMKF_STATE,CurrentState,fname).c_str());
|
||||
st=FCEUD_UTF8_fstream(fn,"rb");
|
||||
strcpy(lastLoadstateMade,fn);
|
||||
}
|
||||
|
||||
if(display_message && st == NULL || (st->get_fp() == NULL))
|
||||
if (st == NULL || (st->get_fp() == NULL))
|
||||
{
|
||||
FCEU_DispMessage("State %d load error.",0,CurrentState);
|
||||
//FCEU_DispMessage("State %d load error. Filename: %s",0,CurrentState, fn);
|
||||
SaveStateStatus[CurrentState]=0;
|
||||
if (display_message)
|
||||
{
|
||||
FCEU_DispMessage("State %d load error.", 0, CurrentState);
|
||||
//FCEU_DispMessage("State %d load error. Filename: %s", 0, CurrentState, fn);
|
||||
}
|
||||
SaveStateStatus[CurrentState] = 0;
|
||||
return false;
|
||||
}
|
||||
|
||||
//If in bot mode, don't do a backup when loading.
|
||||
//Otherwise you eat at the hard disk, since so many
|
||||
//states are being loaded.
|
||||
if(FCEUSS_LoadFP(st, backupSavestates ? SSLOADPARAM_BACKUP : SSLOADPARAM_NOBACKUP))
|
||||
if (FCEUSS_LoadFP(st, backupSavestates ? SSLOADPARAM_BACKUP : SSLOADPARAM_NOBACKUP))
|
||||
{
|
||||
if(fname)
|
||||
if (fname)
|
||||
{
|
||||
char szFilename[260]={0};
|
||||
splitpath(fname, 0, 0, szFilename, 0);
|
||||
if (display_message){
|
||||
FCEU_DispMessage("State %s loaded.",0,szFilename);
|
||||
}
|
||||
//FCEU_DispMessage("State %s loaded. Filename: %s",0,szFilename, fn);
|
||||
}
|
||||
else
|
||||
if (display_message)
|
||||
{
|
||||
if (display_message) {
|
||||
FCEU_DispMessage("State %d loaded.",0,CurrentState);
|
||||
FCEU_DispMessage("State %s loaded.", 0, szFilename);
|
||||
//FCEU_DispMessage("State %s loaded. Filename: %s", 0, szFilename, fn);
|
||||
}
|
||||
//FCEU_DispMessage("State %d loaded. Filename: %s",0,CurrentState, fn);
|
||||
SaveStateStatus[CurrentState]=1;
|
||||
} else
|
||||
{
|
||||
if (display_message)
|
||||
{
|
||||
FCEU_DispMessage("State %d loaded.", 0, CurrentState);
|
||||
//FCEU_DispMessage("State %d loaded. Filename: %s", 0, CurrentState, fn);
|
||||
}
|
||||
SaveStateStatus[CurrentState] = 1;
|
||||
}
|
||||
delete st;
|
||||
|
||||
|
@ -793,15 +800,16 @@ bool FCEUSS_Load(const char *fname, bool display_message)
|
|||
cur_input_display = FCEU_GetJoyJoy(); //Input display should show the last buttons pressed (stored in the savestate)
|
||||
|
||||
return true;
|
||||
}
|
||||
else
|
||||
} else
|
||||
{
|
||||
if(!fname)
|
||||
SaveStateStatus[CurrentState] = 1;
|
||||
|
||||
if (display_message)
|
||||
{
|
||||
SaveStateStatus[CurrentState]=1;
|
||||
FCEU_DispMessage("Error(s) reading state %d!", 0, CurrentState);
|
||||
//FCEU_DispMessage("Error(s) reading state %d! Filename: %s", 0, CurrentState, fn);
|
||||
}
|
||||
FCEU_DispMessage("Error(s) reading state %d!",0,CurrentState);
|
||||
//FCEU_DispMessage("Error(s) reading state %d! Filename: %s",0,CurrentState, fn);
|
||||
delete st;
|
||||
return 0;
|
||||
}
|
||||
|
@ -921,7 +929,7 @@ void FCEUI_SaveState(const char *fname, bool display_message)
|
|||
{
|
||||
if(!FCEU_IsValidUI(FCEUI_SAVESTATE)) return;
|
||||
|
||||
StateShow=0;
|
||||
StateShow = 0;
|
||||
|
||||
FCEUSS_Save(fname, display_message);
|
||||
}
|
||||
|
@ -938,7 +946,6 @@ bool file_exists(const char * filename)
|
|||
return false;
|
||||
}
|
||||
void FCEUI_LoadState(const char *fname, bool display_message)
|
||||
|
||||
{
|
||||
if(!FCEU_IsValidUI(FCEUI_LOADSTATE)) return;
|
||||
|
||||
|
@ -950,7 +957,8 @@ void FCEUI_LoadState(const char *fname, bool display_message)
|
|||
information expected in newer save states, desynchronization won't occur(at least not
|
||||
from this ;)).
|
||||
*/
|
||||
if (backupSavestates) BackupLoadState(); //If allowed, backup the current state before loading a new one
|
||||
if (backupSavestates)
|
||||
BackupLoadState(); // If allowed, backup the current state before loading a new one
|
||||
|
||||
if (!movie_readonly && autoMovieBackup && freshMovie) //If auto-backup is on, movie has not been altered this session and the movie is in read+write mode
|
||||
{
|
||||
|
@ -961,7 +969,7 @@ void FCEUI_LoadState(const char *fname, bool display_message)
|
|||
loadStateFailed = 1;
|
||||
return; // state doesn't exist; exit cleanly
|
||||
}
|
||||
if(FCEUSS_Load(fname, display_message))
|
||||
if (FCEUSS_Load(fname, display_message))
|
||||
{
|
||||
//mbg todo netplay
|
||||
#if 0
|
||||
|
@ -989,8 +997,7 @@ void FCEUI_LoadState(const char *fname, bool display_message)
|
|||
}
|
||||
#endif
|
||||
freshMovie = false; //The movie has been altered so it is no longer fresh
|
||||
}
|
||||
else
|
||||
} else
|
||||
{
|
||||
loadStateFailed = 1;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue