Wrap std::stoi inside BSPF::stringToInt, and handle its exceptions.

This commit is contained in:
Stephen Anthony 2020-02-07 21:00:06 -03:30
parent ae43b33c7b
commit af120a3eaf
7 changed files with 19 additions and 29 deletions

View File

@ -145,6 +145,13 @@ namespace BSPF
return s; return s;
} }
// Convert string to integer, using default value on any error
inline int stringToInt(const string& s, const int defaultValue = 0)
{
try { return std::stoi(s); }
catch(...) { return defaultValue; }
}
// Compare two strings, ignoring case // Compare two strings, ignoring case
inline int compareIgnoreCase(const string& s1, const string& s2) inline int compareIgnoreCase(const string& s1, const string& s2)
{ {

View File

@ -110,7 +110,7 @@ Console::Console(OSystem& osystem, unique_ptr<Cartridge>& cart,
myCart->setStartBankFromPropsFunc([this]() { myCart->setStartBankFromPropsFunc([this]() {
const string& startbank = myProperties.get(PropType::Cart_StartBank); const string& startbank = myProperties.get(PropType::Cart_StartBank);
return (startbank == EmptyString || BSPF::equalsIgnoreCase(startbank, "AUTO")) return (startbank == EmptyString || BSPF::equalsIgnoreCase(startbank, "AUTO"))
? -1 : stoi(startbank); ? -1 : BSPF::stringToInt(startbank);
}); });
// We can only initialize after all the devices/components have been created // We can only initialize after all the devices/components have been created
@ -583,13 +583,7 @@ void Console::togglePhosphor()
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void Console::changePhosphor(int direction) void Console::changePhosphor(int direction)
{ {
int blend = 0; int blend = BSPF::stringToInt(myProperties.get(PropType::Display_PPBlend));
try
{
blend = stoi(myProperties.get(PropType::Display_PPBlend));
}
catch (...) {}
if(direction == +1) // increase blend if(direction == +1) // increase blend
{ {
@ -795,7 +789,7 @@ void Console::changeScanlineAdjust(int direction)
void Console::setTIAProperties() void Console::setTIAProperties()
{ {
Int32 vcenter = BSPF::clamp( Int32 vcenter = BSPF::clamp(
static_cast<Int32>(stoi(myProperties.get(PropType::Display_VCenter))), TIAConstants::minVcenter, TIAConstants::maxVcenter static_cast<Int32>(BSPF::stringToInt(myProperties.get(PropType::Display_VCenter))), TIAConstants::minVcenter, TIAConstants::maxVcenter
); );
if(myDisplayFormat == "NTSC" || myDisplayFormat == "PAL60" || if(myDisplayFormat == "NTSC" || myDisplayFormat == "PAL60" ||

View File

@ -1143,7 +1143,7 @@ void EventHandler::setComboMap()
{ {
string key; string key;
buf >> key; buf >> key;
if(stoi(key) == COMBO_SIZE) if(BSPF::stringToInt(key) == COMBO_SIZE)
{ {
// Fill the combomap table with events for as long as they exist // Fill the combomap table with events for as long as they exist
int combocount = 0; int combocount = 0;
@ -1156,7 +1156,7 @@ void EventHandler::setComboMap()
int eventcount = 0; int eventcount = 0;
while(buf2 >> key && eventcount < EVENTS_PER_COMBO) while(buf2 >> key && eventcount < EVENTS_PER_COMBO)
{ {
myComboTable[combocount][eventcount] = Event::Type(stoi(key)); myComboTable[combocount][eventcount] = Event::Type(BSPF::stringToInt(key));
++eventcount; ++eventcount;
} }
++combocount; ++combocount;
@ -1445,7 +1445,7 @@ void EventHandler::setComboListForEvent(Event::Type event, const StringList& eve
int combo = event - Event::Combo1; int combo = event - Event::Combo1;
for(uInt32 i = 0; i < 8; ++i) for(uInt32 i = 0; i < 8; ++i)
{ {
uInt32 idx = stoi(events[i]); uInt32 idx = BSPF::stringToInt(events[i]);
if(idx < ourEmulActionList.size()) if(idx < ourEmulActionList.size())
myComboTable[combo][i] = EventHandler::ourEmulActionList[idx].event; myComboTable[combo][i] = EventHandler::ourEmulActionList[idx].event;
else else

View File

@ -69,7 +69,7 @@ ProfilingRunner::ProfilingRunner(int argc, char* argv[])
if (splitPoint == string::npos) run.runtime = RUNTIME_DEFAULT; if (splitPoint == string::npos) run.runtime = RUNTIME_DEFAULT;
else { else {
int runtime = stoi(arg.substr(splitPoint+1, string::npos)); int runtime = BSPF::stringToInt(arg.substr(splitPoint+1, string::npos));
run.runtime = runtime > 0 ? runtime : RUNTIME_DEFAULT; run.runtime = runtime > 0 ? runtime : RUNTIME_DEFAULT;
} }
} }

View File

@ -63,7 +63,7 @@ void Properties::set(PropType key, const string& value)
case PropType::Display_PPBlend: case PropType::Display_PPBlend:
{ {
int blend = stoi(myProperties[pos]); int blend = BSPF::stringToInt(myProperties[pos]);
if(blend < 0 || blend > 100) if(blend < 0 || blend > 100)
myProperties[pos] = ourDefaultProperties[pos]; myProperties[pos] = ourDefaultProperties[pos];
break; break;

View File

@ -91,11 +91,7 @@ void TIASurface::initialize(const Console& console,
} }
else else
{ {
try p_blend = BSPF::stringToInt(console.properties().get(PropType::Display_PPBlend));
{
p_blend = stoi(console.properties().get(PropType::Display_PPBlend));
}
catch (...) {}
enable = console.properties().get(PropType::Display_Phosphor) == "YES"; enable = console.properties().get(PropType::Display_Phosphor) == "YES";
} }
enablePhosphor(enable, p_blend); enablePhosphor(enable, p_blend);

View File

@ -460,17 +460,10 @@ void GameInfoDialog::loadEmulationProperties(const Properties& props)
myPPBlend->setEnabled(!alwaysPhosphor && usePhosphor); myPPBlend->setEnabled(!alwaysPhosphor && usePhosphor);
const string& blend = props.get(PropType::Display_PPBlend); const string& blend = props.get(PropType::Display_PPBlend);
try myPPBlend->setValue(BSPF::stringToInt(blend));
{
myPPBlend->setValue(stoi(blend));
}
catch (...)
{
myPPBlend->setValue(0);
}
// set vertical center // set vertical center
Int32 vcenter = stoi(props.get(PropType::Display_VCenter)); Int32 vcenter = BSPF::stringToInt(props.get(PropType::Display_VCenter));
myVCenter->setValueLabel(vcenter); myVCenter->setValueLabel(vcenter);
myVCenter->setValue(vcenter); myVCenter->setValue(vcenter);
myVCenter->setValueUnit(vcenter ? "px" : ""); myVCenter->setValueUnit(vcenter ? "px" : "");
@ -519,7 +512,7 @@ void GameInfoDialog::loadControllerProperties(const Properties& props)
myMouseY->setEnabled(!autoAxis); myMouseY->setEnabled(!autoAxis);
if(m_axis >> m_range) if(m_axis >> m_range)
{ {
myMouseRange->setValue(stoi(m_range)); myMouseRange->setValue(BSPF::stringToInt(m_range));
} }
else else
{ {