summaryrefslogtreecommitdiff
path: root/scene/gui
diff options
context:
space:
mode:
authorRĂ©mi Verschelde <rverschelde@gmail.com>2019-08-30 09:47:51 +0200
committerGitHub <noreply@github.com>2019-08-30 09:47:51 +0200
commit8d78c43ce9b96353daa8a19b0385136dfa111bb8 (patch)
tree1d32fe83f4af4152dca374da86f871249bf7cdaa /scene/gui
parent2ddcd824df91fa570c79532d1a3da7c9503728e5 (diff)
parent86a31e9e385c7909a0cdd24a5ee790c3dca03b98 (diff)
Merge pull request #31781 from Calinou/spinbox-use-expressions
Calculate the SpinBox value using the Expression class
Diffstat (limited to 'scene/gui')
-rw-r--r--scene/gui/spin_box.cpp20
1 files changed, 12 insertions, 8 deletions
diff --git a/scene/gui/spin_box.cpp b/scene/gui/spin_box.cpp
index 6ada0cba97..3c63f6b2c7 100644
--- a/scene/gui/spin_box.cpp
+++ b/scene/gui/spin_box.cpp
@@ -29,6 +29,7 @@
/*************************************************************************/
#include "spin_box.h"
+#include "core/math/expression.h"
#include "core/os/input.h"
Size2 SpinBox::get_minimum_size() const {
@@ -50,15 +51,18 @@ void SpinBox::_value_changed(double) {
void SpinBox::_text_entered(const String &p_string) {
- /*
- if (!p_string.is_numeric())
+ Ref<Expression> expr;
+ expr.instance();
+ Error err = expr->parse(p_string);
+ if (err != OK) {
return;
- */
- String value = p_string;
- if (prefix != "" && p_string.begins_with(prefix))
- value = p_string.substr(prefix.length(), p_string.length() - prefix.length());
- set_value(value.to_double());
- _value_changed(0);
+ }
+
+ Variant value = expr->execute(Array(), NULL, false);
+ if (value.get_type() != Variant::NIL) {
+ set_value(value);
+ _value_changed(0);
+ }
}
LineEdit *SpinBox::get_line_edit() {