mirror of https://github.com/stella-emu/stella.git
Only save the cheatlist file (stella.cht) when something has changed.
During development, sometimes Stella would crash, and for some reason take the cheatfile contents with it. Now, at least, this should occur very rarely, since cheats won't be changed most of the time. git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1062 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
baedc94f5e
commit
4eb94a3a2b
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: CheatManager.cxx,v 1.9 2006-03-11 21:22:47 stephena Exp $
|
// $Id: CheatManager.cxx,v 1.10 2006-03-22 15:12:02 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
@ -28,7 +28,9 @@
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
CheatManager::CheatManager(OSystem* osystem)
|
CheatManager::CheatManager(OSystem* osystem)
|
||||||
: myOSystem(osystem)
|
: myOSystem(osystem),
|
||||||
|
myCurrentCheat(""),
|
||||||
|
myListIsDirty(false)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -260,11 +262,15 @@ void CheatManager::loadCheatDatabase()
|
||||||
}
|
}
|
||||||
|
|
||||||
in.close();
|
in.close();
|
||||||
|
myListIsDirty = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void CheatManager::saveCheatDatabase()
|
void CheatManager::saveCheatDatabase()
|
||||||
{
|
{
|
||||||
|
if(!myListIsDirty)
|
||||||
|
return;
|
||||||
|
|
||||||
string cheatfile = myOSystem->baseDir() + BSPF_PATH_SEPARATOR + "stella.cht";
|
string cheatfile = myOSystem->baseDir() + BSPF_PATH_SEPARATOR + "stella.cht";
|
||||||
ofstream out(cheatfile.c_str(), ios::out);
|
ofstream out(cheatfile.c_str(), ios::out);
|
||||||
if(!out)
|
if(!out)
|
||||||
|
@ -283,6 +289,7 @@ void CheatManager::saveCheatDatabase()
|
||||||
void CheatManager::loadCheats(const string& md5sum)
|
void CheatManager::loadCheats(const string& md5sum)
|
||||||
{
|
{
|
||||||
clear();
|
clear();
|
||||||
|
myCurrentCheat = "";
|
||||||
|
|
||||||
// Set up any cheatcodes that was on the command line
|
// Set up any cheatcodes that was on the command line
|
||||||
// (and remove the key from the settings, so they won't get set again)
|
// (and remove the key from the settings, so they won't get set again)
|
||||||
|
@ -294,6 +301,10 @@ void CheatManager::loadCheats(const string& md5sum)
|
||||||
if(iter == myCheatMap.end() && cheats == "")
|
if(iter == myCheatMap.end() && cheats == "")
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
// Remember the cheats for this ROM
|
||||||
|
myCurrentCheat = iter->second;
|
||||||
|
|
||||||
|
// Parse the cheat list, constructing cheats and adding them to the manager
|
||||||
parse(iter->second + cheats);
|
parse(iter->second + cheats);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -310,15 +321,24 @@ void CheatManager::saveCheats(const string& md5sum)
|
||||||
cheats << ",";
|
cheats << ",";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool changed = cheats.str() != myCurrentCheat;
|
||||||
|
|
||||||
|
// Only update the list if absolutely necessary
|
||||||
|
if(changed)
|
||||||
|
{
|
||||||
CheatCodeMap::iterator iter = myCheatMap.find(md5sum);
|
CheatCodeMap::iterator iter = myCheatMap.find(md5sum);
|
||||||
|
|
||||||
// Erase old entry
|
// Erase old entry and add a new one only if it's changed
|
||||||
if(iter != myCheatMap.end())
|
if(iter != myCheatMap.end())
|
||||||
myCheatMap.erase(iter);
|
myCheatMap.erase(iter);
|
||||||
|
|
||||||
// Add new entry only if there are any cheats defined
|
// Add new entry only if there are any cheats defined
|
||||||
if(cheats.str() != "")
|
if(cheats.str() != "")
|
||||||
myCheatMap.insert(make_pair(md5sum, cheats.str()));
|
myCheatMap.insert(make_pair(md5sum, cheats.str()));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update the dirty flag
|
||||||
|
myListIsDirty = myListIsDirty || changed;
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: CheatManager.hxx,v 1.6 2005-12-18 18:37:01 stephena Exp $
|
// $Id: CheatManager.hxx,v 1.7 2006-03-22 15:12:02 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#ifndef CHEAT_MANAGER_HXX
|
#ifndef CHEAT_MANAGER_HXX
|
||||||
|
@ -36,7 +36,7 @@ typedef map<string,string> CheatCodeMap;
|
||||||
the list of all cheats currently in use.
|
the list of all cheats currently in use.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: CheatManager.hxx,v 1.6 2005-12-18 18:37:01 stephena Exp $
|
@version $Id: CheatManager.hxx,v 1.7 2006-03-22 15:12:02 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class CheatManager
|
class CheatManager
|
||||||
{
|
{
|
||||||
|
@ -158,6 +158,13 @@ class CheatManager
|
||||||
|
|
||||||
CheatCodeMap myCheatMap;
|
CheatCodeMap myCheatMap;
|
||||||
string myCheatFile;
|
string myCheatFile;
|
||||||
|
|
||||||
|
// This is set each time a new cheat/ROM is loaded, for later
|
||||||
|
// comparison to see if the cheatcode list has actually been modified
|
||||||
|
string myCurrentCheat;
|
||||||
|
|
||||||
|
// Indicates that the list has been modified, and should be saved to disk
|
||||||
|
bool myListIsDirty;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: OSystem.cxx,v 1.64 2006-03-17 19:44:18 stephena Exp $
|
// $Id: OSystem.cxx,v 1.65 2006-03-22 15:12:02 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
|
@ -266,6 +266,9 @@ void OSystem::createSound()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
bool OSystem::createConsole(const string& romfile)
|
bool OSystem::createConsole(const string& romfile)
|
||||||
{
|
{
|
||||||
|
// Delete any lingering console object
|
||||||
|
delete myConsole; myConsole = NULL;
|
||||||
|
|
||||||
bool retval = false, showmessage = false;
|
bool retval = false, showmessage = false;
|
||||||
|
|
||||||
// If a blank ROM has been given, we reload the current one (assuming one exists)
|
// If a blank ROM has been given, we reload the current one (assuming one exists)
|
||||||
|
@ -287,8 +290,6 @@ bool OSystem::createConsole(const string& romfile)
|
||||||
string md5;
|
string md5;
|
||||||
if(openROM(myRomFile, md5, &image, &size))
|
if(openROM(myRomFile, md5, &image, &size))
|
||||||
{
|
{
|
||||||
delete myConsole; myConsole = NULL;
|
|
||||||
|
|
||||||
// Create an instance of the 2600 game console
|
// Create an instance of the 2600 game console
|
||||||
// The Console c'tor takes care of updating the eventhandler state
|
// The Console c'tor takes care of updating the eventhandler state
|
||||||
myConsole = new Console(image, size, md5, this);
|
myConsole = new Console(image, size, md5, this);
|
||||||
|
|
Loading…
Reference in New Issue