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;
}
// 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
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]() {
const string& startbank = myProperties.get(PropType::Cart_StartBank);
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
@ -583,13 +583,7 @@ void Console::togglePhosphor()
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void Console::changePhosphor(int direction)
{
int blend = 0;
try
{
blend = stoi(myProperties.get(PropType::Display_PPBlend));
}
catch (...) {}
int blend = BSPF::stringToInt(myProperties.get(PropType::Display_PPBlend));
if(direction == +1) // increase blend
{
@ -795,7 +789,7 @@ void Console::changeScanlineAdjust(int direction)
void Console::setTIAProperties()
{
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" ||

View File

@ -1143,7 +1143,7 @@ void EventHandler::setComboMap()
{
string 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
int combocount = 0;
@ -1156,7 +1156,7 @@ void EventHandler::setComboMap()
int eventcount = 0;
while(buf2 >> key && eventcount < EVENTS_PER_COMBO)
{
myComboTable[combocount][eventcount] = Event::Type(stoi(key));
myComboTable[combocount][eventcount] = Event::Type(BSPF::stringToInt(key));
++eventcount;
}
++combocount;
@ -1445,7 +1445,7 @@ void EventHandler::setComboListForEvent(Event::Type event, const StringList& eve
int combo = event - Event::Combo1;
for(uInt32 i = 0; i < 8; ++i)
{
uInt32 idx = stoi(events[i]);
uInt32 idx = BSPF::stringToInt(events[i]);
if(idx < ourEmulActionList.size())
myComboTable[combo][i] = EventHandler::ourEmulActionList[idx].event;
else

View File

@ -69,7 +69,7 @@ ProfilingRunner::ProfilingRunner(int argc, char* argv[])
if (splitPoint == string::npos) run.runtime = RUNTIME_DEFAULT;
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;
}
}

View File

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

View File

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

View File

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