diff options
-rw-r--r-- | editor/gui/editor_spin_slider.cpp | 21 | ||||
-rw-r--r-- | scene/gui/spin_box.cpp | 20 |
2 files changed, 30 insertions, 11 deletions
diff --git a/editor/gui/editor_spin_slider.cpp b/editor/gui/editor_spin_slider.cpp index a1b0ecad6b..750837cce9 100644 --- a/editor/gui/editor_spin_slider.cpp +++ b/editor/gui/editor_spin_slider.cpp @@ -525,17 +525,24 @@ String EditorSpinSlider::get_suffix() const { } void EditorSpinSlider::_evaluate_input_text() { - // Replace comma with dot to support it as decimal separator (GH-6028). - // This prevents using functions like `pow()`, but using functions - // in EditorSpinSlider is a barely known (and barely used) feature. - // Instead, we'd rather support German/French keyboard layouts out of the box. - const String text = TS->parse_number(value_input->get_text().replace(",", ".")); - Ref<Expression> expr; expr.instantiate(); + + // Convert commas ',' to dots '.' for French/German etc. keyboard layouts. + String text = value_input->get_text().replace(",", "."); + text = text.replace(";", ","); + text = TS->parse_number(text); + Error err = expr->parse(text); if (err != OK) { - return; + // If the expression failed try without converting commas to dots - they might have been for parameter separation. + text = value_input->get_text(); + text = TS->parse_number(text); + + err = expr->parse(text); + if (err != OK) { + return; + } } Variant v = expr->execute(Array(), nullptr, false, true); diff --git a/scene/gui/spin_box.cpp b/scene/gui/spin_box.cpp index 07429c6a61..e13fd21949 100644 --- a/scene/gui/spin_box.cpp +++ b/scene/gui/spin_box.cpp @@ -62,12 +62,24 @@ void SpinBox::_text_submitted(const String &p_string) { Ref<Expression> expr; expr.instantiate(); - String num = TS->parse_number(p_string); + // Convert commas ',' to dots '.' for French/German etc. keyboard layouts. + String text = p_string.replace(",", "."); + text = text.replace(";", ","); + text = TS->parse_number(text); // Ignore the prefix and suffix in the expression. - Error err = expr->parse(num.trim_prefix(prefix + " ").trim_suffix(" " + suffix)); + text = text.trim_prefix(prefix + " ").trim_suffix(" " + suffix); + + Error err = expr->parse(text); if (err != OK) { - _update_text(); - return; + // If the expression failed try without converting commas to dots - they might have been for parameter separation. + text = p_string; + text = TS->parse_number(text); + text = text.trim_prefix(prefix + " ").trim_suffix(" " + suffix); + + err = expr->parse(text); + if (err != OK) { + return; + } } Variant value = expr->execute(Array(), nullptr, false, true); |