Added error checking to the Settings class. Now, only settings

specified in the program will be saved to the rcfile.  Previously,
*any* text in the rcfile was saved on exit, even bogus settings.

Also, any settings given from the commandline which are not meant
to be ever saved in the rcfile are now actually not saved.


git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@187 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
stephena 2003-09-23 17:27:11 +00:00
parent 4651f21bcd
commit ab62868912
3 changed files with 42 additions and 22 deletions

View File

@ -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: Settings.cxx,v 1.7 2003-09-23 00:58:31 stephena Exp $ // $Id: Settings.cxx,v 1.8 2003-09-23 17:27:11 stephena Exp $
//============================================================================ //============================================================================
#include <assert.h> #include <assert.h>
@ -108,7 +108,11 @@ void Settings::loadConfig()
if((key.length() == 0) || (value.length() == 0)) if((key.length() == 0) || (value.length() == 0))
continue; continue;
set(key, value); // Only settings which have been previously set are valid
if(contains(key))
set(key, value);
else
cerr << "Invalid setting: " << key << endl;
} }
in.close(); in.close();
@ -128,7 +132,9 @@ bool Settings::loadCommandLine(Int32 argc, char** argv)
key = key.substr(1, key.length()); key = key.substr(1, key.length());
string value = argv[++i]; string value = argv[++i];
set(key, value); // Settings read from the commandline must not be saved to
// the rc-file, unless they were previously set
set(key, value, false);
} }
return true; return true;
@ -164,20 +170,25 @@ void Settings::saveConfig()
// Write out each of the key and value pairs // Write out each of the key and value pairs
for(uInt32 i = 0; i < mySize; ++i) for(uInt32 i = 0; i < mySize; ++i)
out << mySettings[i].key << " = " << mySettings[i].value << endl; if(mySettings[i].save)
out << mySettings[i].key << " = " << mySettings[i].value << endl;
out.close(); out.close();
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void Settings::set(const string& key, const string& value) void Settings::set(const string& key, const string& value, bool save)
{ {
// See if the setting already exists // See if the setting already exists
for(uInt32 i = 0; i < mySize; ++i) for(uInt32 i = 0; i < mySize; ++i)
{ {
// If a key is already present in the array, then we assume
// that it was set by the emulation core and must be saved
// to the rc-file.
if(key == mySettings[i].key) if(key == mySettings[i].key)
{ {
mySettings[i].value = value; mySettings[i].value = value;
mySettings[i].save = true;
return; return;
} }
} }
@ -200,8 +211,9 @@ void Settings::set(const string& key, const string& value)
} }
// Add new property to the array // Add new property to the array
mySettings[mySize].key = key; mySettings[mySize].key = key;
mySettings[mySize].value = value; mySettings[mySize].value = value;
mySettings[mySize].save = save;
++mySize; ++mySize;
} }
@ -211,12 +223,8 @@ Int32 Settings::getInt(const string& key) const
{ {
// Try to find the named setting and answer its value // Try to find the named setting and answer its value
for(uInt32 i = 0; i < mySize; ++i) for(uInt32 i = 0; i < mySize; ++i)
{
if(key == mySettings[i].key) if(key == mySettings[i].key)
{
return atoi(mySettings[i].value.c_str()); return atoi(mySettings[i].value.c_str());
}
}
return -1; return -1;
} }
@ -246,16 +254,23 @@ string Settings::getString(const string& key) const
{ {
// Try to find the named setting and answer its value // Try to find the named setting and answer its value
for(uInt32 i = 0; i < mySize; ++i) for(uInt32 i = 0; i < mySize; ++i)
{
if(key == mySettings[i].key) if(key == mySettings[i].key)
{
return mySettings[i].value; return mySettings[i].value;
}
}
return ""; return "";
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
bool Settings::contains(const string& key)
{
// Try to find the named setting
for(uInt32 i = 0; i < mySize; ++i)
if(key == mySettings[i].key)
return true;
return false;
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Settings::Settings(const Settings&) Settings::Settings(const Settings&)
{ {

View File

@ -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: Settings.hxx,v 1.6 2003-09-23 00:58:31 stephena Exp $ // $Id: Settings.hxx,v 1.7 2003-09-23 17:27:11 stephena Exp $
//============================================================================ //============================================================================
#ifndef SETTINGS_HXX #ifndef SETTINGS_HXX
@ -32,7 +32,7 @@ class Console;
This class provides an interface for accessing frontend specific settings. This class provides an interface for accessing frontend specific settings.
@author Stephen Anthony @author Stephen Anthony
@version $Id: Settings.hxx,v 1.6 2003-09-23 00:58:31 stephena Exp $ @version $Id: Settings.hxx,v 1.7 2003-09-23 17:27:11 stephena Exp $
*/ */
class Settings class Settings
{ {
@ -93,10 +93,11 @@ class Settings
/** /**
Set the value associated with key to the given value. Set the value associated with key to the given value.
@param key The key of the setting @param key The key of the setting
@param value The value to assign to the setting @param value The value to assign to the setting
@param save Whether this setting should be saved to the rc-file.
*/ */
void set(const string& key, const string& value); void set(const string& key, const string& value, bool save = true);
public: public:
////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////
@ -231,11 +232,15 @@ class Settings
// Assignment operator isn't supported by this class so make it private // Assignment operator isn't supported by this class so make it private
Settings& operator = (const Settings&); Settings& operator = (const Settings&);
// Structure used for storing properties // Test whether the given setting is present in the array
bool contains(const string& key);
// Structure used for storing settings
struct Setting struct Setting
{ {
string key; string key;
string value; string value;
bool save;
}; };
// Pointer to a dynamically allocated array of settings // Pointer to a dynamically allocated array of settings

View File

@ -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: mainSDL.cxx,v 1.52 2003-09-23 00:58:31 stephena Exp $ // $Id: mainSDL.cxx,v 1.53 2003-09-23 17:27:11 stephena Exp $
//============================================================================ //============================================================================
#include <fstream> #include <fstream>
@ -1187,9 +1187,9 @@ void cleanup()
if(SDL_WasInit(SDL_INIT_EVERYTHING)) if(SDL_WasInit(SDL_INIT_EVERYTHING))
{ {
#ifdef HAVE_JOYSTICK #ifdef HAVE_JOYSTICK
if(SDL_JoystickOpened(0)) if(SDL_JoystickOpened(theLeftJoystickNumber))
SDL_JoystickClose(theLeftJoystick); SDL_JoystickClose(theLeftJoystick);
if(SDL_JoystickOpened(1)) if(SDL_JoystickOpened(theRightJoystickNumber))
SDL_JoystickClose(theRightJoystick); SDL_JoystickClose(theRightJoystick);
#endif #endif