added optional arguments to suppress messages on state load/save

the argument was added in the following functions
state.cpp:FCEUI_LoadState
state.cpp:FCEUI_SaveState
state.cpp:FCEUSS_Save
state.cpp:FCEUSS_Load
This helped with the periodic saving where you don't really want the
save message popping up every time there's a save.
This commit is contained in:
xhainingx 2013-04-18 19:40:57 +00:00
parent 992166852c
commit c497432785
4 changed files with 24 additions and 19 deletions

View File

@ -161,8 +161,8 @@ int FCEUI_SelectState(int, int);
extern void FCEUI_SelectStateNext(int); extern void FCEUI_SelectStateNext(int);
//"fname" overrides the default save state filename code if non-NULL. //"fname" overrides the default save state filename code if non-NULL.
void FCEUI_SaveState(const char *fname); void FCEUI_SaveState(const char *fname, bool display_message=true);
void FCEUI_LoadState(const char *fname); void FCEUI_LoadState(const char *fname, bool display_message=true);
void FCEUD_SaveStateAs(void); void FCEUD_SaveStateAs(void);
void FCEUD_LoadStateFrom(void); void FCEUD_LoadStateFrom(void);

View File

@ -198,9 +198,9 @@ int LoadGame(const char *path)
int state_to_load; int state_to_load;
g_config->getOption("SDL.AutoLoadState", &state_to_load); g_config->getOption("SDL.AutoLoadState", &state_to_load);
if (state_to_load != INVALID_STATE){ if (state_to_load >= 0 && state_to_load < 10){
FCEUI_SelectState(state_to_load, 0); FCEUI_SelectState(state_to_load, 0);
FCEUI_LoadState(NULL); FCEUI_LoadState(NULL, false);
} }
ParseGIInput(GameInfo); ParseGIInput(GameInfo);
@ -247,7 +247,7 @@ CloseGame()
g_config->getOption("SDL.AutoSaveState", &state_to_save); g_config->getOption("SDL.AutoSaveState", &state_to_save);
if (state_to_save < 10 && state_to_save >= 0){ if (state_to_save < 10 && state_to_save >= 0){
FCEUI_SelectState(state_to_save, 0); FCEUI_SelectState(state_to_save, 0);
FCEUI_SaveState(NULL); FCEUI_SaveState(NULL, false);
} }
FCEUI_CloseGame(); FCEUI_CloseGame();
@ -276,7 +276,7 @@ static void DoFun(int frameskip, int periodic_saves)
//TODO peroidic saves, working on it right now //TODO peroidic saves, working on it right now
if (periodic_saves && FCEUD_GetTime() % PERIODIC_SAVE_INTERVAL < 30){ if (periodic_saves && FCEUD_GetTime() % PERIODIC_SAVE_INTERVAL < 30){
FCEUI_SaveState(NULL); FCEUI_SaveState(NULL, false);
} }
#ifdef FRAMESKIP #ifdef FRAMESKIP
fskipc = (fskipc + 1) % (frameskip + 1); fskipc = (fskipc + 1) % (frameskip + 1);

View File

@ -446,7 +446,7 @@ bool FCEUSS_SaveMS(EMUFILE* outstream, int compressionLevel)
} }
void FCEUSS_Save(const char *fname) void FCEUSS_Save(const char *fname, bool display_message)
{ {
EMUFILE* st = 0; EMUFILE* st = 0;
char fn[2048]; char fn[2048];
@ -480,7 +480,7 @@ void FCEUSS_Save(const char *fname)
st = FCEUD_UTF8_fstream(fn,"wb"); st = FCEUD_UTF8_fstream(fn,"wb");
} }
if(st == NULL || st->get_fp() == NULL) if(display_message && st == NULL || st->get_fp() == NULL)
{ {
FCEU_DispMessage("State %d save error.",0,CurrentState); FCEU_DispMessage("State %d save error.",0,CurrentState);
return; return;
@ -519,7 +519,7 @@ void FCEUSS_Save(const char *fname)
delete st; delete st;
if(!fname) if(display_message && !fname)
{ {
SaveStateStatus[CurrentState]=1; SaveStateStatus[CurrentState]=1;
FCEU_DispMessage("State %d saved.",0,CurrentState); FCEU_DispMessage("State %d saved.",0,CurrentState);
@ -701,7 +701,7 @@ bool FCEUSS_LoadFP(EMUFILE* is, ENUM_SSLOADPARAMS params)
} }
bool FCEUSS_Load(const char *fname) bool FCEUSS_Load(const char *fname, bool display_message)
{ {
EMUFILE* st; EMUFILE* st;
char fn[2048]; char fn[2048];
@ -730,7 +730,7 @@ bool FCEUSS_Load(const char *fname)
strcpy(lastLoadstateMade,fn); strcpy(lastLoadstateMade,fn);
} }
if(st == NULL || (st->get_fp() == NULL)) if(display_message && st == NULL || (st->get_fp() == NULL))
{ {
FCEU_DispMessage("State %d load error.",0,CurrentState); FCEU_DispMessage("State %d load error.",0,CurrentState);
//FCEU_DispMessage("State %d load error. Filename: %s",0,CurrentState, fn); //FCEU_DispMessage("State %d load error. Filename: %s",0,CurrentState, fn);
@ -747,12 +747,16 @@ bool FCEUSS_Load(const char *fname)
{ {
char szFilename[260]={0}; char szFilename[260]={0};
splitpath(fname, 0, 0, szFilename, 0); splitpath(fname, 0, 0, szFilename, 0);
if (display_message){
FCEU_DispMessage("State %s loaded.",0,szFilename); FCEU_DispMessage("State %s loaded.",0,szFilename);
}
//FCEU_DispMessage("State %s loaded. Filename: %s",0,szFilename, fn); //FCEU_DispMessage("State %s loaded. Filename: %s",0,szFilename, fn);
} }
else else
{ {
if (display_message) {
FCEU_DispMessage("State %d loaded.",0,CurrentState); FCEU_DispMessage("State %d loaded.",0,CurrentState);
}
//FCEU_DispMessage("State %d loaded. Filename: %s",0,CurrentState, fn); //FCEU_DispMessage("State %d loaded. Filename: %s",0,CurrentState, fn);
SaveStateStatus[CurrentState]=1; SaveStateStatus[CurrentState]=1;
} }
@ -913,13 +917,13 @@ int FCEUI_SelectState(int w, int show)
return oldstate; return oldstate;
} }
void FCEUI_SaveState(const char *fname) void FCEUI_SaveState(const char *fname, bool display_message)
{ {
if(!FCEU_IsValidUI(FCEUI_SAVESTATE)) return; if(!FCEU_IsValidUI(FCEUI_SAVESTATE)) return;
StateShow=0; StateShow=0;
FCEUSS_Save(fname); FCEUSS_Save(fname, display_message);
} }
int loadStateFailed = 0; // hack, this function should return a value instead int loadStateFailed = 0; // hack, this function should return a value instead
@ -933,7 +937,8 @@ bool file_exists(const char * filename)
} }
return false; return false;
} }
void FCEUI_LoadState(const char *fname) void FCEUI_LoadState(const char *fname, bool display_message)
{ {
if(!FCEU_IsValidUI(FCEUI_LOADSTATE)) return; if(!FCEU_IsValidUI(FCEUI_LOADSTATE)) return;
@ -956,7 +961,7 @@ void FCEUI_LoadState(const char *fname)
loadStateFailed = 1; loadStateFailed = 1;
return; // state doesn't exist; exit cleanly return; // state doesn't exist; exit cleanly
} }
if(FCEUSS_Load(fname)) if(FCEUSS_Load(fname, display_message))
{ {
//mbg todo netplay //mbg todo netplay
#if 0 #if 0

View File

@ -24,8 +24,8 @@ enum ENUM_SSLOADPARAMS
SSLOADPARAM_BACKUP, SSLOADPARAM_BACKUP,
}; };
void FCEUSS_Save(const char *); void FCEUSS_Save(const char *, bool display_message=true);
bool FCEUSS_Load(const char *); bool FCEUSS_Load(const char *, bool display_message=true);
//zlib values: 0 (none) through 9 (max) or -1 (default) //zlib values: 0 (none) through 9 (max) or -1 (default)
bool FCEUSS_SaveMS(EMUFILE* outstream, int compressionLevel); bool FCEUSS_SaveMS(EMUFILE* outstream, int compressionLevel);