mirror of
https://github.com/OpenMW/openmw.git
synced 2025-01-21 23:53:57 +00:00
dba79f4d4d
openmw/apps/openmw/mwworld/worldimp.cpp: In member function ‘virtual bool MWWorld::World::findExteriorPosition(const string&, ESM::Position&)’: openmw/apps/openmw/mwworld/worldimp.cpp:2650:25: warning: catching polymorphic type ‘class std::invalid_argument’ by value [-Wcatch-value=] catch (std::invalid_argument) ^~~~~~~~~~~~~~~~ openmw/apps/openmw/mwworld/worldimp.cpp:2654:25: warning: catching polymorphic type ‘class std::out_of_range’ by value [-Wcatch-value=] catch (std::out_of_range) ^~~~~~~~~~~~ openmw/components/widgets/numericeditbox.cpp: In member function ‘void Gui::NumericEditBox::onEditTextChange(MyGUI::EditBox*)’: openmw/components/widgets/numericeditbox.cpp:41:21: warning: catching polymorphic type ‘class std::invalid_argument’ by value [-Wcatch-value=] catch (std::invalid_argument) ^~~~~~~~~~~~~~~~ openmw/components/widgets/numericeditbox.cpp:45:21: warning: catching polymorphic type ‘class std::out_of_range’ by value [-Wcatch-value=] catch (std::out_of_range) ^~~~~~~~~~~~
94 lines
2.3 KiB
C++
94 lines
2.3 KiB
C++
#include <stdexcept>
|
|
|
|
#include "numericeditbox.hpp"
|
|
|
|
namespace Gui
|
|
{
|
|
|
|
void NumericEditBox::initialiseOverride()
|
|
{
|
|
Base::initialiseOverride();
|
|
eventEditTextChange += MyGUI::newDelegate(this, &NumericEditBox::onEditTextChange);
|
|
|
|
mValue = 0;
|
|
setCaption("0");
|
|
}
|
|
|
|
void NumericEditBox::shutdownOverride()
|
|
{
|
|
Base::shutdownOverride();
|
|
eventEditTextChange -= MyGUI::newDelegate(this, &NumericEditBox::onEditTextChange);
|
|
}
|
|
|
|
void NumericEditBox::onEditTextChange(MyGUI::EditBox *sender)
|
|
{
|
|
std::string newCaption = sender->getCaption();
|
|
if (newCaption.empty())
|
|
{
|
|
return;
|
|
}
|
|
|
|
try
|
|
{
|
|
mValue = std::stoi(newCaption);
|
|
int capped = std::min(mMaxValue, std::max(mValue, mMinValue));
|
|
if (capped != mValue)
|
|
{
|
|
mValue = capped;
|
|
setCaption(MyGUI::utility::toString(mValue));
|
|
}
|
|
}
|
|
catch (const std::invalid_argument&)
|
|
{
|
|
setCaption(MyGUI::utility::toString(mValue));
|
|
}
|
|
catch (const std::out_of_range&)
|
|
{
|
|
setCaption(MyGUI::utility::toString(mValue));
|
|
}
|
|
|
|
eventValueChanged(mValue);
|
|
}
|
|
|
|
void NumericEditBox::setValue(int value)
|
|
{
|
|
if (value != mValue)
|
|
{
|
|
setCaption(MyGUI::utility::toString(value));
|
|
mValue = value;
|
|
}
|
|
}
|
|
|
|
void NumericEditBox::setMinValue(int minValue)
|
|
{
|
|
mMinValue = minValue;
|
|
}
|
|
|
|
void NumericEditBox::setMaxValue(int maxValue)
|
|
{
|
|
mMaxValue = maxValue;
|
|
}
|
|
|
|
void NumericEditBox::onKeyLostFocus(MyGUI::Widget* _new)
|
|
{
|
|
Base::onKeyLostFocus(_new);
|
|
setCaption(MyGUI::utility::toString(mValue));
|
|
}
|
|
|
|
void NumericEditBox::onKeyButtonPressed(MyGUI::KeyCode key, MyGUI::Char character)
|
|
{
|
|
if (key == MyGUI::KeyCode::ArrowUp)
|
|
{
|
|
setValue(std::min(mValue+1, mMaxValue));
|
|
eventValueChanged(mValue);
|
|
}
|
|
else if (key == MyGUI::KeyCode::ArrowDown)
|
|
{
|
|
setValue(std::max(mValue-1, mMinValue));
|
|
eventValueChanged(mValue);
|
|
}
|
|
else if (character == 0 || (character >= '0' && character <= '9'))
|
|
Base::onKeyButtonPressed(key, character);
|
|
}
|
|
|
|
}
|