summaryrefslogtreecommitdiffstats
path: root/scene/gui/text_edit.cpp
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2023-09-11 15:36:21 +0200
committerRémi Verschelde <rverschelde@gmail.com>2023-09-11 15:36:21 +0200
commitafd01030a85b5e7d7cf8c04e14045658de4d7d9c (patch)
tree447473f34b52d8ffc8dda8d52e0db77c0d8cc29d /scene/gui/text_edit.cpp
parentdf5376c4c0b6be9bb395d6d3c717fff9abbb57fa (diff)
parentaac10705d76c7a41809e045fa77c81ffa7beca56 (diff)
downloadredot-engine-afd01030a85b5e7d7cf8c04e14045658de4d7d9c.tar.gz
Merge pull request #80956 from MarcusElg/deselectmulticaret
Deselect multi caret when alt clicking on it
Diffstat (limited to 'scene/gui/text_edit.cpp')
-rw-r--r--scene/gui/text_edit.cpp20
1 files changed, 18 insertions, 2 deletions
diff --git a/scene/gui/text_edit.cpp b/scene/gui/text_edit.cpp
index 1d5cee61a3..1184e071ac 100644
--- a/scene/gui/text_edit.cpp
+++ b/scene/gui/text_edit.cpp
@@ -1752,11 +1752,27 @@ void TextEdit::gui_input(const Ref<InputEvent> &p_gui_input) {
const int triple_click_tolerance = 5;
bool is_triple_click = (!mb->is_double_click() && (OS::get_singleton()->get_ticks_msec() - last_dblclk) < triple_click_timeout && mb->get_position().distance_to(last_dblclk_pos) < triple_click_tolerance);
- if (!is_mouse_over_selection() && !mb->is_double_click() && !is_triple_click) {
+ if (!mb->is_double_click() && !is_triple_click) {
if (mb->is_alt_pressed()) {
prev_line = row;
prev_col = col;
+ // Remove caret at clicked location.
+ if (carets.size() > 1) {
+ for (int i = 0; i < carets.size(); i++) {
+ // Deselect if clicked on caret or its selection.
+ if ((get_caret_column(i) == col && get_caret_line(i) == row) || is_mouse_over_selection(true, i)) {
+ remove_caret(i);
+ last_dblclk = 0;
+ return;
+ }
+ }
+ }
+
+ if (is_mouse_over_selection()) {
+ return;
+ }
+
caret = add_caret(row, col);
if (caret == -1) {
return;
@@ -1766,7 +1782,7 @@ void TextEdit::gui_input(const Ref<InputEvent> &p_gui_input) {
carets.write[caret].selection.selecting_column = col;
last_dblclk = 0;
- } else if (!mb->is_shift_pressed()) {
+ } else if (!mb->is_shift_pressed() && !is_mouse_over_selection()) {
caret = 0;
remove_secondary_carets();
}