| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | /*************************************************************************/ | 
					
						
							|  |  |  | /*  line_edit.cpp                                                        */ | 
					
						
							|  |  |  | /*************************************************************************/ | 
					
						
							|  |  |  | /*                       This file is part of:                           */ | 
					
						
							|  |  |  | /*                           GODOT ENGINE                                */ | 
					
						
							| 
									
										
										
										
											2017-08-27 14:16:55 +02:00
										 |  |  | /*                      https://godotengine.org                          */ | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | /*************************************************************************/ | 
					
						
							| 
									
										
										
										
											2021-01-01 20:13:46 +01:00
										 |  |  | /* Copyright (c) 2007-2021 Juan Linietsky, Ariel Manzur.                 */ | 
					
						
							|  |  |  | /* Copyright (c) 2014-2021 Godot Engine contributors (cf. AUTHORS.md).   */ | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | /*                                                                       */ | 
					
						
							|  |  |  | /* Permission is hereby granted, free of charge, to any person obtaining */ | 
					
						
							|  |  |  | /* a copy of this software and associated documentation files (the       */ | 
					
						
							|  |  |  | /* "Software"), to deal in the Software without restriction, including   */ | 
					
						
							|  |  |  | /* without limitation the rights to use, copy, modify, merge, publish,   */ | 
					
						
							|  |  |  | /* distribute, sublicense, and/or sell copies of the Software, and to    */ | 
					
						
							|  |  |  | /* permit persons to whom the Software is furnished to do so, subject to */ | 
					
						
							|  |  |  | /* the following conditions:                                             */ | 
					
						
							|  |  |  | /*                                                                       */ | 
					
						
							|  |  |  | /* The above copyright notice and this permission notice shall be        */ | 
					
						
							|  |  |  | /* included in all copies or substantial portions of the Software.       */ | 
					
						
							|  |  |  | /*                                                                       */ | 
					
						
							|  |  |  | /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,       */ | 
					
						
							|  |  |  | /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF    */ | 
					
						
							|  |  |  | /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/ | 
					
						
							|  |  |  | /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY  */ | 
					
						
							|  |  |  | /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,  */ | 
					
						
							|  |  |  | /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE     */ | 
					
						
							|  |  |  | /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.                */ | 
					
						
							|  |  |  | /*************************************************************************/ | 
					
						
							| 
									
										
										
										
											2018-01-05 00:50:27 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | #include "line_edit.h"
 | 
					
						
							| 
									
										
										
										
											2019-04-05 14:06:16 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-07 19:33:38 -03:00
										 |  |  | #include "core/object/message_queue.h"
 | 
					
						
							| 
									
										
										
										
											2018-09-11 18:13:45 +02:00
										 |  |  | #include "core/os/keyboard.h"
 | 
					
						
							|  |  |  | #include "core/os/os.h"
 | 
					
						
							| 
									
										
										
										
											2020-11-07 19:33:38 -03:00
										 |  |  | #include "core/string/print_string.h"
 | 
					
						
							|  |  |  | #include "core/string/translation.h"
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | #include "label.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-03 10:36:29 -03:00
										 |  |  | #include "servers/display_server.h"
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | #include "servers/text_server.h"
 | 
					
						
							| 
									
										
										
										
											2016-06-21 14:38:35 +01:00
										 |  |  | #ifdef TOOLS_ENABLED
 | 
					
						
							| 
									
										
										
										
											2018-07-26 23:41:47 +02:00
										 |  |  | #include "editor/editor_scale.h"
 | 
					
						
							| 
									
										
										
										
											2017-03-05 14:21:25 +01:00
										 |  |  | #include "editor/editor_settings.h"
 | 
					
						
							| 
									
										
										
										
											2016-06-21 14:38:35 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2020-03-03 22:51:12 -03:00
										 |  |  | #include "scene/main/window.h"
 | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | void LineEdit::_gui_input(Ref<InputEvent> p_event) { | 
					
						
							|  |  |  | 	Ref<InputEventMouseButton> b = p_event; | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 	if (b.is_valid()) { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 		if (ime_text.length() != 0) { | 
					
						
							|  |  |  | 			// Ignore mouse clicks in IME input mode.
 | 
					
						
							|  |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-11-09 15:46:29 -05:00
										 |  |  | 		if (b->is_pressed() && b->get_button_index() == BUTTON_RIGHT && context_menu_enabled) { | 
					
						
							| 
									
										
										
										
											2020-07-01 14:44:19 -03:00
										 |  |  | 			menu->set_position(get_screen_transform().xform(get_local_mouse_position())); | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			menu->set_size(Vector2(1, 1)); | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 			//menu->set_scale(get_global_transform().get_scale());
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			menu->popup(); | 
					
						
							|  |  |  | 			grab_focus(); | 
					
						
							| 
									
										
										
										
											2019-08-04 15:35:50 +02:00
										 |  |  | 			accept_event(); | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 		if (b->get_button_index() != BUTTON_LEFT) { | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			return; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 		_reset_caret_blink_timer(); | 
					
						
							|  |  |  | 		if (b->is_pressed()) { | 
					
						
							| 
									
										
										
										
											2019-05-21 14:49:53 +02:00
										 |  |  | 			accept_event(); //don't pass event further when clicked on text field
 | 
					
						
							| 
									
										
										
										
											2020-12-15 12:04:21 +00:00
										 |  |  | 			if (!text.is_empty() && is_editable() && _is_over_clear_button(b->get_position())) { | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 				clear_button_status.press_attempt = true; | 
					
						
							|  |  |  | 				clear_button_status.pressing_inside = true; | 
					
						
							| 
									
										
										
										
											2020-11-25 00:42:07 +01:00
										 |  |  | 				update(); | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 				return; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			shift_selection_check_pre(b->get_shift()); | 
					
						
							| 
									
										
										
										
											2016-06-18 16:14:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-03 10:54:24 +02:00
										 |  |  | 			set_cursor_at_pixel_pos(b->get_position().x); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			if (b->get_shift()) { | 
					
						
							|  |  |  | 				selection_fill_at_cursor(); | 
					
						
							|  |  |  | 				selection.creating = true; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 				if (b->is_doubleclick() && selecting_enabled) { | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					selection.enabled = true; | 
					
						
							|  |  |  | 					selection.begin = 0; | 
					
						
							|  |  |  | 					selection.end = text.length(); | 
					
						
							|  |  |  | 					selection.doubleclick = true; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:14:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				selection.drag_attempt = false; | 
					
						
							| 
									
										
										
										
											2016-06-18 16:14:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				if ((cursor_pos < selection.begin) || (cursor_pos > selection.end) || !selection.enabled) { | 
					
						
							| 
									
										
										
										
											2017-12-17 15:40:44 -02:00
										 |  |  | 					deselect(); | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					selection.cursor_start = cursor_pos; | 
					
						
							|  |  |  | 					selection.creating = true; | 
					
						
							|  |  |  | 				} else if (selection.enabled) { | 
					
						
							|  |  |  | 					selection.drag_attempt = true; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			update(); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2020-12-15 12:04:21 +00:00
										 |  |  | 			if (!text.is_empty() && is_editable() && clear_button_enabled) { | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 				bool press_attempt = clear_button_status.press_attempt; | 
					
						
							|  |  |  | 				clear_button_status.press_attempt = false; | 
					
						
							|  |  |  | 				if (press_attempt && clear_button_status.pressing_inside && _is_over_clear_button(b->get_position())) { | 
					
						
							|  |  |  | 					clear(); | 
					
						
							|  |  |  | 					return; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			if ((!selection.creating) && (!selection.doubleclick)) { | 
					
						
							| 
									
										
										
										
											2017-12-17 15:40:44 -02:00
										 |  |  | 				deselect(); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			selection.creating = false; | 
					
						
							|  |  |  | 			selection.doubleclick = false; | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 08:04:48 +02:00
										 |  |  | 			if (DisplayServer::get_singleton()->has_feature(DisplayServer::FEATURE_VIRTUAL_KEYBOARD) && virtual_keyboard_enabled) { | 
					
						
							| 
									
										
										
										
											2020-04-28 19:57:45 +02:00
										 |  |  | 				if (selection.enabled) { | 
					
						
							| 
									
										
										
										
											2020-07-17 17:44:13 +02:00
										 |  |  | 					DisplayServer::get_singleton()->virtual_keyboard_show(text, get_global_rect(), false, max_length, selection.begin, selection.end); | 
					
						
							| 
									
										
										
										
											2020-04-28 19:57:45 +02:00
										 |  |  | 				} else { | 
					
						
							| 
									
										
										
										
											2020-07-17 17:44:13 +02:00
										 |  |  | 					DisplayServer::get_singleton()->virtual_keyboard_show(text, get_global_rect(), false, max_length, cursor_pos); | 
					
						
							| 
									
										
										
										
											2020-04-28 19:57:45 +02:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 		update(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 	Ref<InputEventMouseMotion> m = p_event; | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 	if (m.is_valid()) { | 
					
						
							| 
									
										
										
										
											2020-12-15 12:04:21 +00:00
										 |  |  | 		if (!text.is_empty() && is_editable() && clear_button_enabled) { | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 			bool last_press_inside = clear_button_status.pressing_inside; | 
					
						
							|  |  |  | 			clear_button_status.pressing_inside = clear_button_status.press_attempt && _is_over_clear_button(m->get_position()); | 
					
						
							|  |  |  | 			if (last_press_inside != clear_button_status.pressing_inside) { | 
					
						
							|  |  |  | 				update(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 		if (m->get_button_mask() & BUTTON_LEFT) { | 
					
						
							|  |  |  | 			if (selection.creating) { | 
					
						
							| 
									
										
										
										
											2017-06-03 10:54:24 +02:00
										 |  |  | 				set_cursor_at_pixel_pos(m->get_position().x); | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				selection_fill_at_cursor(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 	Ref<InputEventKey> k = p_event; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 	if (k.is_valid()) { | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 		if (!k->is_pressed()) { | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			return; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2019-05-06 22:59:34 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef APPLE_STYLE_KEYS
 | 
					
						
							|  |  |  | 		if (k->get_control() && !k->get_shift() && !k->get_alt() && !k->get_command()) { | 
					
						
							|  |  |  | 			uint32_t remap_key = KEY_UNKNOWN; | 
					
						
							| 
									
										
										
										
											2018-04-05 20:59:35 +03:00
										 |  |  | 			switch (k->get_keycode()) { | 
					
						
							| 
									
										
										
										
											2019-05-06 22:59:34 +03:00
										 |  |  | 				case KEY_F: { | 
					
						
							|  |  |  | 					remap_key = KEY_RIGHT; | 
					
						
							|  |  |  | 				} break; | 
					
						
							|  |  |  | 				case KEY_B: { | 
					
						
							|  |  |  | 					remap_key = KEY_LEFT; | 
					
						
							|  |  |  | 				} break; | 
					
						
							|  |  |  | 				case KEY_P: { | 
					
						
							|  |  |  | 					remap_key = KEY_UP; | 
					
						
							|  |  |  | 				} break; | 
					
						
							|  |  |  | 				case KEY_N: { | 
					
						
							|  |  |  | 					remap_key = KEY_DOWN; | 
					
						
							|  |  |  | 				} break; | 
					
						
							|  |  |  | 				case KEY_D: { | 
					
						
							|  |  |  | 					remap_key = KEY_DELETE; | 
					
						
							|  |  |  | 				} break; | 
					
						
							|  |  |  | 				case KEY_H: { | 
					
						
							|  |  |  | 					remap_key = KEY_BACKSPACE; | 
					
						
							|  |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2020-02-01 13:35:16 +08:00
										 |  |  | 				case KEY_A: { | 
					
						
							|  |  |  | 					remap_key = KEY_HOME; | 
					
						
							|  |  |  | 				} break; | 
					
						
							|  |  |  | 				case KEY_E: { | 
					
						
							|  |  |  | 					remap_key = KEY_END; | 
					
						
							|  |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2019-05-06 22:59:34 +03:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (remap_key != KEY_UNKNOWN) { | 
					
						
							| 
									
										
										
										
											2018-04-05 20:59:35 +03:00
										 |  |  | 				k->set_keycode(remap_key); | 
					
						
							| 
									
										
										
										
											2019-05-06 22:59:34 +03:00
										 |  |  | 				k->set_control(false); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-05 20:59:35 +03:00
										 |  |  | 		unsigned int code = k->get_keycode(); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 		if (k->get_command() && is_shortcut_keys_enabled()) { | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			bool handled = true; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			switch (code) { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 				case (KEY_QUOTELEFT): { // Swap current input direction (primary cursor)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					if (input_direction == TEXT_DIRECTION_LTR) { | 
					
						
							|  |  |  | 						input_direction = TEXT_DIRECTION_RTL; | 
					
						
							|  |  |  | 					} else { | 
					
						
							|  |  |  | 						input_direction = TEXT_DIRECTION_LTR; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					set_cursor_position(get_cursor_position()); | 
					
						
							|  |  |  | 					update(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				} break; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 				case (KEY_X): { // CUT.
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (editable) { | 
					
						
							|  |  |  | 						cut_text(); | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 				case (KEY_C): { // COPY.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					copy_text(); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-08 20:58:49 +02:00
										 |  |  | 				case (KEY_Y): // PASTE (Yank for unix users).
 | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 				case (KEY_V): { // PASTE.
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (editable) { | 
					
						
							|  |  |  | 						paste_text(); | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 				case (KEY_Z): { // Undo/redo.
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (editable) { | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 						if (k->get_shift()) { | 
					
						
							|  |  |  | 							redo(); | 
					
						
							|  |  |  | 						} else { | 
					
						
							|  |  |  | 							undo(); | 
					
						
							|  |  |  | 						} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					} | 
					
						
							|  |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 				case (KEY_U): { // Delete from start to cursor.
 | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (editable) { | 
					
						
							| 
									
										
										
										
											2017-12-17 15:40:44 -02:00
										 |  |  | 						deselect(); | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						text = text.substr(cursor_pos, text.length() - cursor_pos); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						_shape(); | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 						set_cursor_position(0); | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						_text_changed(); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 				case (KEY_K): { // Delete from cursor_pos to end.
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (editable) { | 
					
						
							| 
									
										
										
										
											2017-12-17 15:40:44 -02:00
										 |  |  | 						deselect(); | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						text = text.substr(0, cursor_pos); | 
					
						
							|  |  |  | 						_text_changed(); | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 				case (KEY_A): { // Select all.
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					select(); | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2018-05-24 15:04:22 +05:30
										 |  |  | #ifdef APPLE_STYLE_KEYS
 | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 				case (KEY_LEFT): { // Go to start of text - like HOME key.
 | 
					
						
							| 
									
										
										
										
											2020-05-05 11:43:40 -03:00
										 |  |  | 					shift_selection_check_pre(k->get_shift()); | 
					
						
							| 
									
										
										
										
											2018-04-23 16:03:08 +05:30
										 |  |  | 					set_cursor_position(0); | 
					
						
							| 
									
										
										
										
											2020-05-05 11:43:40 -03:00
										 |  |  | 					shift_selection_check_post(k->get_shift()); | 
					
						
							| 
									
										
										
										
											2018-04-23 16:03:08 +05:30
										 |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 				case (KEY_RIGHT): { // Go to end of text - like END key.
 | 
					
						
							| 
									
										
										
										
											2020-05-05 11:43:40 -03:00
										 |  |  | 					shift_selection_check_pre(k->get_shift()); | 
					
						
							| 
									
										
										
										
											2018-04-23 16:03:08 +05:30
										 |  |  | 					set_cursor_position(text.length()); | 
					
						
							| 
									
										
										
										
											2020-05-05 11:43:40 -03:00
										 |  |  | 					shift_selection_check_post(k->get_shift()); | 
					
						
							| 
									
										
										
										
											2018-04-23 16:03:08 +05:30
										 |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2020-06-18 17:45:40 -04:00
										 |  |  | 				case (KEY_BACKSPACE): { | 
					
						
							|  |  |  | 					if (!editable) | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					// If selected, delete the selection
 | 
					
						
							|  |  |  | 					if (selection.enabled) { | 
					
						
							|  |  |  | 						selection_delete(); | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					// Otherwise delete from cursor to beginning of text edit
 | 
					
						
							|  |  |  | 					int current_pos = get_cursor_position(); | 
					
						
							|  |  |  | 					if (current_pos != 0) { | 
					
						
							|  |  |  | 						delete_text(0, current_pos); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2018-05-24 15:04:22 +05:30
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2019-01-08 22:52:56 +02:00
										 |  |  | 				default: { | 
					
						
							|  |  |  | 					handled = false; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			if (handled) { | 
					
						
							|  |  |  | 				accept_event(); | 
					
						
							|  |  |  | 				return; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 		_reset_caret_blink_timer(); | 
					
						
							|  |  |  | 		if (!k->get_metakey()) { | 
					
						
							|  |  |  | 			bool handled = true; | 
					
						
							|  |  |  | 			switch (code) { | 
					
						
							| 
									
										
										
										
											2017-08-06 16:26:07 +03:00
										 |  |  | 				case KEY_KP_ENTER: | 
					
						
							|  |  |  | 				case KEY_ENTER: { | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					emit_signal("text_entered", text); | 
					
						
							| 
									
										
										
										
											2020-07-22 08:04:48 +02:00
										 |  |  | 					if (DisplayServer::get_singleton()->has_feature(DisplayServer::FEATURE_VIRTUAL_KEYBOARD) && virtual_keyboard_enabled) { | 
					
						
							| 
									
										
										
										
											2020-03-03 10:36:29 -03:00
										 |  |  | 						DisplayServer::get_singleton()->virtual_keyboard_hide(); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-01-31 18:09:45 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				case KEY_BACKSPACE: { | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					if (!editable) { | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						break; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (selection.enabled) { | 
					
						
							|  |  |  | 						selection_delete(); | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef APPLE_STYLE_KEYS
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (k->get_alt()) { | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (k->get_alt()) { | 
					
						
							|  |  |  | 						handled = false; | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					} else if (k->get_command()) { | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						int cc = cursor_pos; | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						Vector<Vector2i> words = TS->shaped_text_get_word_breaks(text_rid); | 
					
						
							|  |  |  | 						for (int i = words.size() - 1; i >= 0; i--) { | 
					
						
							|  |  |  | 							if (words[i].x < cc) { | 
					
						
							|  |  |  | 								cc = words[i].x; | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 								break; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 							} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						delete_text(cc, cursor_pos); | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 						set_cursor_position(cc); | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					} else { | 
					
						
							|  |  |  | 						delete_char(); | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} break; | 
					
						
							|  |  |  | 				case KEY_KP_4: { | 
					
						
							|  |  |  | 					if (k->get_unicode() != 0) { | 
					
						
							|  |  |  | 						handled = false; | 
					
						
							|  |  |  | 						break; | 
					
						
							| 
									
										
										
										
											2016-01-07 21:38:38 +01:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2020-02-22 20:47:50 +01:00
										 |  |  | 					[[fallthrough]]; | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				case KEY_LEFT: { | 
					
						
							| 
									
										
										
										
											2016-06-23 23:03:32 +02:00
										 |  |  | #ifndef APPLE_STYLE_KEYS
 | 
					
						
							| 
									
										
										
										
											2020-02-09 08:48:35 -06:00
										 |  |  | 					if (!k->get_alt()) { | 
					
						
							| 
									
										
										
										
											2016-06-23 23:03:32 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2020-02-09 08:48:35 -06:00
										 |  |  | 						if (selection.enabled && !k->get_shift()) { | 
					
						
							|  |  |  | 							set_cursor_position(selection.begin); | 
					
						
							|  |  |  | 							deselect(); | 
					
						
							|  |  |  | 							handled = true; | 
					
						
							|  |  |  | 							break; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						shift_selection_check_pre(k->get_shift()); | 
					
						
							| 
									
										
										
										
											2020-02-09 08:48:35 -06:00
										 |  |  | #ifndef APPLE_STYLE_KEYS
 | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef APPLE_STYLE_KEYS
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (k->get_command()) { | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 						set_cursor_position(0); | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					} else if (k->get_alt()) { | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (k->get_alt()) { | 
					
						
							|  |  |  | 						handled = false; | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					} else if (k->get_command()) { | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						int cc = cursor_pos; | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						Vector<Vector2i> words = TS->shaped_text_get_word_breaks(text_rid); | 
					
						
							|  |  |  | 						for (int i = words.size() - 1; i >= 0; i--) { | 
					
						
							|  |  |  | 							if (words[i].x < cc) { | 
					
						
							|  |  |  | 								cc = words[i].x; | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 								break; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 							} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 						set_cursor_position(cc); | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					} else { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						if (mid_grapheme_caret_enabled) { | 
					
						
							|  |  |  | 							set_cursor_position(get_cursor_position() - 1); | 
					
						
							|  |  |  | 						} else { | 
					
						
							|  |  |  | 							set_cursor_position(TS->shaped_text_prev_grapheme_pos(text_rid, get_cursor_position())); | 
					
						
							|  |  |  | 						} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					shift_selection_check_post(k->get_shift()); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} break; | 
					
						
							|  |  |  | 				case KEY_KP_6: { | 
					
						
							|  |  |  | 					if (k->get_unicode() != 0) { | 
					
						
							|  |  |  | 						handled = false; | 
					
						
							|  |  |  | 						break; | 
					
						
							| 
									
										
										
										
											2016-01-07 21:38:38 +01:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2020-02-22 20:47:50 +01:00
										 |  |  | 					[[fallthrough]]; | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				case KEY_RIGHT: { | 
					
						
							| 
									
										
										
										
											2020-02-09 08:48:35 -06:00
										 |  |  | #ifndef APPLE_STYLE_KEYS
 | 
					
						
							|  |  |  | 					if (!k->get_alt()) { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 						if (selection.enabled && !k->get_shift()) { | 
					
						
							|  |  |  | 							set_cursor_position(selection.end); | 
					
						
							|  |  |  | 							deselect(); | 
					
						
							|  |  |  | 							handled = true; | 
					
						
							|  |  |  | 							break; | 
					
						
							|  |  |  | 						} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-09 08:48:35 -06:00
										 |  |  | 						shift_selection_check_pre(k->get_shift()); | 
					
						
							|  |  |  | #ifndef APPLE_STYLE_KEYS
 | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef APPLE_STYLE_KEYS
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (k->get_command()) { | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 						set_cursor_position(text.length()); | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					} else if (k->get_alt()) { | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (k->get_alt()) { | 
					
						
							|  |  |  | 						handled = false; | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					} else if (k->get_command()) { | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						int cc = cursor_pos; | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						Vector<Vector2i> words = TS->shaped_text_get_word_breaks(text_rid); | 
					
						
							|  |  |  | 						for (int i = 0; i < words.size(); i++) { | 
					
						
							|  |  |  | 							if (words[i].y > cc) { | 
					
						
							|  |  |  | 								cc = words[i].y; | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 								break; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 							} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 						set_cursor_position(cc); | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					} else { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						if (mid_grapheme_caret_enabled) { | 
					
						
							|  |  |  | 							set_cursor_position(get_cursor_position() + 1); | 
					
						
							|  |  |  | 						} else { | 
					
						
							|  |  |  | 							set_cursor_position(TS->shaped_text_next_grapheme_pos(text_rid, get_cursor_position())); | 
					
						
							|  |  |  | 						} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					shift_selection_check_post(k->get_shift()); | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2017-12-27 17:04:07 +01:00
										 |  |  | 				case KEY_UP: { | 
					
						
							|  |  |  | 					shift_selection_check_pre(k->get_shift()); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					if (get_cursor_position() == 0) { | 
					
						
							| 
									
										
										
										
											2020-05-10 12:56:01 +02:00
										 |  |  | 						handled = false; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2017-12-27 17:04:07 +01:00
										 |  |  | 					set_cursor_position(0); | 
					
						
							|  |  |  | 					shift_selection_check_post(k->get_shift()); | 
					
						
							|  |  |  | 				} break; | 
					
						
							|  |  |  | 				case KEY_DOWN: { | 
					
						
							|  |  |  | 					shift_selection_check_pre(k->get_shift()); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					if (get_cursor_position() == text.length()) { | 
					
						
							| 
									
										
										
										
											2020-05-10 12:56:01 +02:00
										 |  |  | 						handled = false; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2017-12-27 17:04:07 +01:00
										 |  |  | 					set_cursor_position(text.length()); | 
					
						
							|  |  |  | 					shift_selection_check_post(k->get_shift()); | 
					
						
							|  |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				case KEY_DELETE: { | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					if (!editable) { | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						break; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (k->get_shift() && !k->get_command() && !k->get_alt()) { | 
					
						
							|  |  |  | 						cut_text(); | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-03-15 13:03:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (selection.enabled) { | 
					
						
							|  |  |  | 						selection_delete(); | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					int text_len = text.length(); | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					if (cursor_pos == text_len) { | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 						break; // Nothing to do.
 | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef APPLE_STYLE_KEYS
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (k->get_alt()) { | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (k->get_alt()) { | 
					
						
							|  |  |  | 						handled = false; | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					} else if (k->get_command()) { | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						int cc = cursor_pos; | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						Vector<Vector2i> words = TS->shaped_text_get_word_breaks(text_rid); | 
					
						
							|  |  |  | 						for (int i = 0; i < words.size(); i++) { | 
					
						
							|  |  |  | 							if (words[i].y > cc) { | 
					
						
							|  |  |  | 								cc = words[i].y; | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 								break; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 							} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 						} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						delete_text(cursor_pos, cc); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					} else { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						if (mid_grapheme_caret_enabled) { | 
					
						
							|  |  |  | 							set_cursor_position(cursor_pos + 1); | 
					
						
							|  |  |  | 							delete_char(); | 
					
						
							|  |  |  | 						} else { | 
					
						
							|  |  |  | 							int cc = cursor_pos; | 
					
						
							|  |  |  | 							set_cursor_position(TS->shaped_text_next_grapheme_pos(text_rid, cursor_pos)); | 
					
						
							|  |  |  | 							delete_text(cc, cursor_pos); | 
					
						
							|  |  |  | 						} | 
					
						
							| 
									
										
										
										
											2016-01-07 22:45:28 +01:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} break; | 
					
						
							|  |  |  | 				case KEY_KP_7: { | 
					
						
							|  |  |  | 					if (k->get_unicode() != 0) { | 
					
						
							|  |  |  | 						handled = false; | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2020-02-22 20:47:50 +01:00
										 |  |  | 					[[fallthrough]]; | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				case KEY_HOME: { | 
					
						
							|  |  |  | 					shift_selection_check_pre(k->get_shift()); | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 					set_cursor_position(0); | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					shift_selection_check_post(k->get_shift()); | 
					
						
							|  |  |  | 				} break; | 
					
						
							|  |  |  | 				case KEY_KP_1: { | 
					
						
							|  |  |  | 					if (k->get_unicode() != 0) { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 						handled = false; | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						break; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2020-02-22 20:47:50 +01:00
										 |  |  | 					[[fallthrough]]; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				case KEY_END: { | 
					
						
							|  |  |  | 					shift_selection_check_pre(k->get_shift()); | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 					set_cursor_position(text.length()); | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					shift_selection_check_post(k->get_shift()); | 
					
						
							|  |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2019-06-22 20:22:52 +02:00
										 |  |  | 				case KEY_MENU: { | 
					
						
							|  |  |  | 					if (context_menu_enabled) { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						Point2 pos = Point2(get_cursor_pixel_pos().x, (get_size().y + get_theme_font("font")->get_height(get_theme_font_size("font_size"))) / 2); | 
					
						
							| 
									
										
										
										
											2019-06-22 20:22:52 +02:00
										 |  |  | 						menu->set_position(get_global_transform().xform(pos)); | 
					
						
							|  |  |  | 						menu->set_size(Vector2(1, 1)); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						//menu->set_scale(get_global_transform().get_scale());
 | 
					
						
							| 
									
										
										
										
											2019-06-22 20:22:52 +02:00
										 |  |  | 						menu->popup(); | 
					
						
							|  |  |  | 						menu->grab_focus(); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} break; | 
					
						
							| 
									
										
										
										
											2016-01-07 21:38:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				default: { | 
					
						
							|  |  |  | 					handled = false; | 
					
						
							|  |  |  | 				} break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (handled) { | 
					
						
							|  |  |  | 				accept_event(); | 
					
						
							| 
									
										
										
										
											2021-01-05 14:41:35 +01:00
										 |  |  | 			} else if (!k->get_command()) { | 
					
						
							| 
									
										
										
										
											2018-04-05 20:59:35 +03:00
										 |  |  | 				if (k->get_unicode() >= 32 && k->get_keycode() != KEY_DELETE) { | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 					if (editable) { | 
					
						
							|  |  |  | 						selection_delete(); | 
					
						
							| 
									
										
										
										
											2020-07-27 13:43:20 +03:00
										 |  |  | 						char32_t ucodestr[2] = { (char32_t)k->get_unicode(), 0 }; | 
					
						
							| 
									
										
										
										
											2020-01-10 21:07:00 +01:00
										 |  |  | 						int prev_len = text.length(); | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						append_at_cursor(ucodestr); | 
					
						
							| 
									
										
										
										
											2020-01-10 21:07:00 +01:00
										 |  |  | 						if (text.length() != prev_len) { | 
					
						
							|  |  |  | 							_text_changed(); | 
					
						
							|  |  |  | 						} | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 						accept_event(); | 
					
						
							| 
									
										
										
										
											2016-01-07 21:38:38 +01:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 				} else { | 
					
						
							|  |  |  | 					return; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 			update(); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-20 12:38:03 -03:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | void LineEdit::set_align(Align p_align) { | 
					
						
							| 
									
										
										
										
											2018-10-04 09:17:59 +02:00
										 |  |  | 	ERR_FAIL_INDEX((int)p_align, 4); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	if (align != p_align) { | 
					
						
							|  |  |  | 		align = p_align; | 
					
						
							|  |  |  | 		_shape(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | LineEdit::Align LineEdit::get_align() const { | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 	return align; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | Variant LineEdit::get_drag_data(const Point2 &p_point) { | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	if (selection.drag_attempt && selection.enabled) { | 
					
						
							|  |  |  | 		String t = text.substr(selection.begin, selection.end - selection.begin); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 		Label *l = memnew(Label); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		l->set_text(t); | 
					
						
							|  |  |  | 		set_drag_preview(l); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 		return t; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return Variant(); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2020-05-14 14:29:06 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | bool LineEdit::can_drop_data(const Point2 &p_point, const Variant &p_data) const { | 
					
						
							|  |  |  | 	return p_data.get_type() == Variant::STRING; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2020-05-14 14:29:06 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | void LineEdit::drop_data(const Point2 &p_point, const Variant &p_data) { | 
					
						
							|  |  |  | 	if (p_data.get_type() == Variant::STRING) { | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		set_cursor_at_pixel_pos(p_point.x); | 
					
						
							| 
									
										
										
										
											2014-05-11 12:14:33 +08:00
										 |  |  | 		int selected = selection.end - selection.begin; | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-11 12:14:33 +08:00
										 |  |  | 		text.erase(selection.begin, selected); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 		_shape(); | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		append_at_cursor(p_data); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 		selection.begin = cursor_pos - selected; | 
					
						
							| 
									
										
										
										
											2014-05-11 12:14:33 +08:00
										 |  |  | 		selection.end = cursor_pos; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | Control::CursorShape LineEdit::get_cursor_shape(const Point2 &p_pos) const { | 
					
						
							| 
									
										
										
										
											2020-12-15 12:04:21 +00:00
										 |  |  | 	if (!text.is_empty() && is_editable() && _is_over_clear_button(p_pos)) { | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 		return CURSOR_ARROW; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return Control::get_cursor_shape(p_pos); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool LineEdit::_is_over_clear_button(const Point2 &p_pos) const { | 
					
						
							|  |  |  | 	if (!clear_button_enabled || !has_point(p_pos)) { | 
					
						
							|  |  |  | 		return false; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 	Ref<Texture2D> icon = Control::get_theme_icon("clear"); | 
					
						
							|  |  |  | 	int x_ofs = get_theme_stylebox("normal")->get_offset().x; | 
					
						
							| 
									
										
										
										
											2019-06-26 15:08:25 +02:00
										 |  |  | 	return p_pos.x > get_size().width - icon->get_width() - x_ofs; | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | void LineEdit::_notification(int p_what) { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	switch (p_what) { | 
					
						
							| 
									
										
										
										
											2016-06-21 14:38:35 +01:00
										 |  |  | #ifdef TOOLS_ENABLED
 | 
					
						
							|  |  |  | 		case NOTIFICATION_ENTER_TREE: { | 
					
						
							| 
									
										
										
										
											2017-09-26 16:19:02 +09:00
										 |  |  | 			if (Engine::get_singleton()->is_editor_hint() && !get_tree()->is_node_being_edited(this)) { | 
					
						
							| 
									
										
										
										
											2017-01-05 19:41:36 -03:00
										 |  |  | 				cursor_set_blink_enabled(EDITOR_DEF("text_editor/cursor/caret_blink", false)); | 
					
						
							|  |  |  | 				cursor_set_blink_speed(EDITOR_DEF("text_editor/cursor/caret_blink_speed", 0.65)); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-21 18:28:45 +01:00
										 |  |  | 				if (!EditorSettings::get_singleton()->is_connected("settings_changed", callable_mp(this, &LineEdit::_editor_settings_changed))) { | 
					
						
							|  |  |  | 					EditorSettings::get_singleton()->connect("settings_changed", callable_mp(this, &LineEdit::_editor_settings_changed)); | 
					
						
							| 
									
										
										
										
											2016-06-30 15:12:14 +01:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2016-06-21 14:38:35 +01:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		case NOTIFICATION_RESIZED: { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			_fit_to_width(); | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | 			scroll_offset = 0; | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 			set_cursor_position(get_cursor_position()); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 		} break; | 
					
						
							|  |  |  | 		case NOTIFICATION_LAYOUT_DIRECTION_CHANGED: | 
					
						
							|  |  |  | 		case NOTIFICATION_THEME_CHANGED: { | 
					
						
							|  |  |  | 			_shape(); | 
					
						
							|  |  |  | 			update(); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		} break; | 
					
						
							| 
									
										
										
										
											2019-06-22 14:42:36 +02:00
										 |  |  | 		case NOTIFICATION_TRANSLATION_CHANGED: { | 
					
						
							|  |  |  | 			placeholder_translated = tr(placeholder); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			_shape(); | 
					
						
							| 
									
										
										
										
											2019-06-22 14:42:36 +02:00
										 |  |  | 			update(); | 
					
						
							|  |  |  | 		} break; | 
					
						
							| 
									
										
										
										
											2020-06-29 20:47:18 -03:00
										 |  |  | 		case NOTIFICATION_WM_WINDOW_FOCUS_IN: { | 
					
						
							| 
									
										
										
										
											2016-06-21 00:16:18 +01:00
										 |  |  | 			window_has_focus = true; | 
					
						
							|  |  |  | 			draw_caret = true; | 
					
						
							|  |  |  | 			update(); | 
					
						
							|  |  |  | 		} break; | 
					
						
							| 
									
										
										
										
											2020-06-29 20:47:18 -03:00
										 |  |  | 		case NOTIFICATION_WM_WINDOW_FOCUS_OUT: { | 
					
						
							| 
									
										
										
										
											2016-06-21 00:16:18 +01:00
										 |  |  | 			window_has_focus = false; | 
					
						
							|  |  |  | 			draw_caret = false; | 
					
						
							|  |  |  | 			update(); | 
					
						
							|  |  |  | 		} break; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		case NOTIFICATION_DRAW: { | 
					
						
							| 
									
										
										
										
											2020-06-21 19:15:57 +02:00
										 |  |  | 			if ((!has_focus() && !menu->has_focus() && !caret_force_displayed) || !window_has_focus) { | 
					
						
							| 
									
										
										
										
											2016-06-21 00:16:18 +01:00
										 |  |  | 				draw_caret = false; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 			int width, height; | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			bool rtl = is_layout_rtl(); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 			Size2 size = get_size(); | 
					
						
							|  |  |  | 			width = size.width; | 
					
						
							|  |  |  | 			height = size.height; | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 			RID ci = get_canvas_item(); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 			Ref<StyleBox> style = get_theme_stylebox("normal"); | 
					
						
							| 
									
										
										
										
											2017-07-14 23:40:17 -05:00
										 |  |  | 			if (!is_editable()) { | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 				style = get_theme_stylebox("read_only"); | 
					
						
							| 
									
										
										
										
											2017-07-14 23:40:17 -05:00
										 |  |  | 				draw_caret = false; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2020-11-30 11:48:42 +02:00
										 |  |  | 			Ref<Font> font = get_theme_font("font"); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 			style->draw(ci, Rect2(Point2(), size)); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if (has_focus()) { | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 				get_theme_stylebox("focus")->draw(ci, Rect2(Point2(), size)); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 			int x_ofs = 0; | 
					
						
							| 
									
										
										
										
											2020-12-15 12:04:21 +00:00
										 |  |  | 			bool using_placeholder = text.is_empty() && ime_text.is_empty(); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			float text_width = TS->shaped_text_get_size(text_rid).x; | 
					
						
							| 
									
										
										
										
											2020-11-30 11:48:42 +02:00
										 |  |  | 			float text_height = TS->shaped_text_get_size(text_rid).y + font->get_spacing(Font::SPACING_TOP) + font->get_spacing(Font::SPACING_BOTTOM); | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			switch (align) { | 
					
						
							|  |  |  | 				case ALIGN_FILL: | 
					
						
							|  |  |  | 				case ALIGN_LEFT: { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 					if (rtl) { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 						x_ofs = MAX(style->get_margin(SIDE_LEFT), int(size.width - style->get_margin(SIDE_RIGHT) - (text_width))); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 					} else { | 
					
						
							|  |  |  | 						x_ofs = style->get_offset().x; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 				} break; | 
					
						
							|  |  |  | 				case ALIGN_CENTER: { | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | 					if (scroll_offset != 0) { | 
					
						
							| 
									
										
										
										
											2017-10-01 20:11:46 +02:00
										 |  |  | 						x_ofs = style->get_offset().x; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					} else { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 						x_ofs = MAX(style->get_margin(SIDE_LEFT), int(size.width - (text_width)) / 2); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 				} break; | 
					
						
							|  |  |  | 				case ALIGN_RIGHT: { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 					if (rtl) { | 
					
						
							|  |  |  | 						x_ofs = style->get_offset().x; | 
					
						
							|  |  |  | 					} else { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 						x_ofs = MAX(style->get_margin(SIDE_LEFT), int(size.width - style->get_margin(SIDE_RIGHT) - (text_width))); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 				} break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 			int ofs_max = width - style->get_margin(SIDE_RIGHT); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 			int y_area = height - style->get_minimum_size().height; | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			int y_ofs = style->get_offset().y + (y_area - text_height) / 2; | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 			Color selection_color = get_theme_color("selection_color"); | 
					
						
							|  |  |  | 			Color font_color = is_editable() ? get_theme_color("font_color") : get_theme_color("font_color_uneditable"); | 
					
						
							|  |  |  | 			Color font_color_selected = get_theme_color("font_color_selected"); | 
					
						
							|  |  |  | 			Color cursor_color = get_theme_color("cursor_color"); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 			// Draw placeholder color.
 | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 			if (using_placeholder) { | 
					
						
							| 
									
										
										
										
											2016-06-28 11:45:17 +08:00
										 |  |  | 				font_color.a *= placeholder_alpha; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2016-06-27 19:47:40 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 			bool display_clear_icon = !using_placeholder && is_editable() && clear_button_enabled; | 
					
						
							| 
									
										
										
										
											2018-08-11 12:04:19 +02:00
										 |  |  | 			if (right_icon.is_valid() || display_clear_icon) { | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 				Ref<Texture2D> r_icon = display_clear_icon ? Control::get_theme_icon("clear") : right_icon; | 
					
						
							| 
									
										
										
										
											2019-06-21 18:16:38 -05:00
										 |  |  | 				Color color_icon(1, 1, 1, !is_editable() ? .5 * .9 : .9); | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 				if (display_clear_icon) { | 
					
						
							|  |  |  | 					if (clear_button_status.press_attempt && clear_button_status.pressing_inside) { | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 						color_icon = get_theme_color("clear_button_color_pressed"); | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 					} else { | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 						color_icon = get_theme_color("clear_button_color"); | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				r_icon->draw(ci, Point2(width - r_icon->get_width() - style->get_margin(SIDE_RIGHT), height / 2 - r_icon->get_height() / 2), color_icon); | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 				if (align == ALIGN_CENTER) { | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | 					if (scroll_offset == 0) { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 						x_ofs = MAX(style->get_margin(SIDE_LEFT), int(size.width - text_width - r_icon->get_width() - style->get_margin(SIDE_RIGHT) * 2) / 2); | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 					} | 
					
						
							|  |  |  | 				} else { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 					x_ofs = MAX(style->get_margin(SIDE_LEFT), x_ofs - r_icon->get_width() - style->get_margin(SIDE_RIGHT)); | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2019-04-21 13:55:40 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-24 23:21:35 -03:00
										 |  |  | 				ofs_max -= r_icon->get_width(); | 
					
						
							| 
									
										
										
										
											2017-07-18 14:35:37 -05:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | #ifdef TOOLS_ENABLED
 | 
					
						
							|  |  |  | 			int caret_width = Math::round(EDSCALE); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 			int caret_width = 1; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2020-09-03 14:22:16 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			// Draw selections rects.
 | 
					
						
							|  |  |  | 			Vector2 ofs = Point2(x_ofs + scroll_offset, y_ofs); | 
					
						
							|  |  |  | 			if (selection.enabled) { | 
					
						
							|  |  |  | 				Vector<Vector2> sel = TS->shaped_text_get_selection(text_rid, selection.begin, selection.end); | 
					
						
							|  |  |  | 				for (int i = 0; i < sel.size(); i++) { | 
					
						
							|  |  |  | 					Rect2 rect = Rect2(sel[i].x + ofs.x, ofs.y, sel[i].y - sel[i].x, text_height); | 
					
						
							|  |  |  | 					if (rect.position.x + rect.size.x <= x_ofs || rect.position.x > ofs_max) { | 
					
						
							|  |  |  | 						continue; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					if (rect.position.x < x_ofs) { | 
					
						
							|  |  |  | 						rect.size.x -= (x_ofs - rect.position.x); | 
					
						
							|  |  |  | 						rect.position.x = x_ofs; | 
					
						
							|  |  |  | 					} else if (rect.position.x + rect.size.x > ofs_max) { | 
					
						
							|  |  |  | 						rect.size.x = ofs_max - rect.position.x; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					RenderingServer::get_singleton()->canvas_item_add_rect(ci, rect, selection_color); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2020-12-01 15:03:31 +02:00
										 |  |  | 			const Vector<TextServer::Glyph> visual = TS->shaped_text_get_glyphs(text_rid); | 
					
						
							|  |  |  | 			const TextServer::Glyph *glyphs = visual.ptr(); | 
					
						
							|  |  |  | 			int gl_size = visual.size(); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			// Draw text.
 | 
					
						
							|  |  |  | 			ofs.y += TS->shaped_text_get_ascent(text_rid); | 
					
						
							| 
									
										
										
										
											2020-12-01 15:03:31 +02:00
										 |  |  | 			for (int i = 0; i < gl_size; i++) { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 				bool selected = selection.enabled && glyphs[i].start >= selection.begin && glyphs[i].end <= selection.end; | 
					
						
							|  |  |  | 				for (int j = 0; j < glyphs[i].repeat; j++) { | 
					
						
							| 
									
										
										
										
											2020-12-01 09:11:41 +02:00
										 |  |  | 					if (ceil(ofs.x) >= x_ofs && (ofs.x + glyphs[i].advance) <= ofs_max) { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						if (glyphs[i].font_rid != RID()) { | 
					
						
							|  |  |  | 							TS->font_draw_glyph(glyphs[i].font_rid, ci, glyphs[i].font_size, ofs + Vector2(glyphs[i].x_off, glyphs[i].y_off), glyphs[i].index, selected ? font_color_selected : font_color); | 
					
						
							|  |  |  | 						} else if ((glyphs[i].flags & TextServer::GRAPHEME_IS_VIRTUAL) != TextServer::GRAPHEME_IS_VIRTUAL) { | 
					
						
							|  |  |  | 							TS->draw_hex_code_box(ci, glyphs[i].font_size, ofs + Vector2(glyphs[i].x_off, glyphs[i].y_off), glyphs[i].index, selected ? font_color_selected : font_color); | 
					
						
							| 
									
										
										
										
											2017-08-07 14:09:56 +03:00
										 |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 					ofs.x += glyphs[i].advance; | 
					
						
							| 
									
										
										
										
											2017-08-07 14:09:56 +03:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 				if (ofs.x >= ofs_max) { | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 					break; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			// Draw carets.
 | 
					
						
							|  |  |  | 			ofs.x = x_ofs + scroll_offset; | 
					
						
							|  |  |  | 			if (draw_caret) { | 
					
						
							|  |  |  | 				if (ime_text.length() == 0) { | 
					
						
							|  |  |  | 					// Normal caret.
 | 
					
						
							|  |  |  | 					Rect2 l_caret, t_caret; | 
					
						
							|  |  |  | 					TextServer::Direction l_dir, t_dir; | 
					
						
							|  |  |  | 					TS->shaped_text_get_carets(text_rid, cursor_pos, l_caret, l_dir, t_caret, t_dir); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					if (l_caret == Rect2() && t_caret == Rect2()) { | 
					
						
							|  |  |  | 						// No carets, add one at the start.
 | 
					
						
							|  |  |  | 						int h = get_theme_font("font")->get_height(get_theme_font_size("font_size")); | 
					
						
							|  |  |  | 						int y = style->get_offset().y + (y_area - h) / 2; | 
					
						
							|  |  |  | 						if (rtl) { | 
					
						
							|  |  |  | 							l_dir = TextServer::DIRECTION_RTL; | 
					
						
							|  |  |  | 							l_caret = Rect2(Vector2(ofs_max, y), Size2(caret_width, h)); | 
					
						
							|  |  |  | 						} else { | 
					
						
							|  |  |  | 							l_dir = TextServer::DIRECTION_LTR; | 
					
						
							|  |  |  | 							l_caret = Rect2(Vector2(x_ofs, y), Size2(caret_width, h)); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 						} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						RenderingServer::get_singleton()->canvas_item_add_rect(ci, l_caret, cursor_color); | 
					
						
							|  |  |  | 					} else { | 
					
						
							|  |  |  | 						if (l_caret != Rect2() && l_dir == TextServer::DIRECTION_AUTO) { | 
					
						
							|  |  |  | 							// Draw extra marker on top of mid caret.
 | 
					
						
							|  |  |  | 							Rect2 trect = Rect2(l_caret.position.x - 3 * caret_width, l_caret.position.y, 6 * caret_width, caret_width); | 
					
						
							|  |  |  | 							trect.position += ofs; | 
					
						
							|  |  |  | 							RenderingServer::get_singleton()->canvas_item_add_rect(ci, trect, cursor_color); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 						} | 
					
						
							| 
									
										
										
										
											2017-08-07 14:09:56 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						l_caret.position += ofs; | 
					
						
							|  |  |  | 						l_caret.size.x = caret_width; | 
					
						
							|  |  |  | 						RenderingServer::get_singleton()->canvas_item_add_rect(ci, l_caret, cursor_color); | 
					
						
							| 
									
										
										
										
											2017-08-07 14:09:56 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						t_caret.position += ofs; | 
					
						
							|  |  |  | 						t_caret.size.x = caret_width; | 
					
						
							| 
									
										
										
										
											2017-08-07 14:09:56 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 						RenderingServer::get_singleton()->canvas_item_add_rect(ci, t_caret, cursor_color); | 
					
						
							| 
									
										
										
										
											2017-08-07 14:09:56 +03:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 				} else { | 
					
						
							|  |  |  | 					{ | 
					
						
							|  |  |  | 						// IME intermidiet text range.
 | 
					
						
							|  |  |  | 						Vector<Vector2> sel = TS->shaped_text_get_selection(text_rid, cursor_pos, cursor_pos + ime_text.length()); | 
					
						
							|  |  |  | 						for (int i = 0; i < sel.size(); i++) { | 
					
						
							|  |  |  | 							Rect2 rect = Rect2(sel[i].x + ofs.x, ofs.y, sel[i].y - sel[i].x, text_height); | 
					
						
							|  |  |  | 							if (rect.position.x + rect.size.x <= x_ofs || rect.position.x > ofs_max) { | 
					
						
							|  |  |  | 								continue; | 
					
						
							|  |  |  | 							} | 
					
						
							|  |  |  | 							if (rect.position.x < x_ofs) { | 
					
						
							|  |  |  | 								rect.size.x -= (x_ofs - rect.position.x); | 
					
						
							|  |  |  | 								rect.position.x = x_ofs; | 
					
						
							|  |  |  | 							} else if (rect.position.x + rect.size.x > ofs_max) { | 
					
						
							|  |  |  | 								rect.size.x = ofs_max - rect.position.x; | 
					
						
							|  |  |  | 							} | 
					
						
							|  |  |  | 							rect.size.y = caret_width; | 
					
						
							|  |  |  | 							RenderingServer::get_singleton()->canvas_item_add_rect(ci, rect, cursor_color); | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					{ | 
					
						
							|  |  |  | 						// IME caret.
 | 
					
						
							|  |  |  | 						Vector<Vector2> sel = TS->shaped_text_get_selection(text_rid, cursor_pos + ime_selection.x, cursor_pos + ime_selection.x + ime_selection.y); | 
					
						
							|  |  |  | 						for (int i = 0; i < sel.size(); i++) { | 
					
						
							|  |  |  | 							Rect2 rect = Rect2(sel[i].x + ofs.x, ofs.y, sel[i].y - sel[i].x, text_height); | 
					
						
							|  |  |  | 							if (rect.position.x + rect.size.x <= x_ofs || rect.position.x > ofs_max) { | 
					
						
							|  |  |  | 								continue; | 
					
						
							|  |  |  | 							} | 
					
						
							|  |  |  | 							if (rect.position.x < x_ofs) { | 
					
						
							|  |  |  | 								rect.size.x -= (x_ofs - rect.position.x); | 
					
						
							|  |  |  | 								rect.position.x = x_ofs; | 
					
						
							|  |  |  | 							} else if (rect.position.x + rect.size.x > ofs_max) { | 
					
						
							|  |  |  | 								rect.size.x = ofs_max - rect.position.x; | 
					
						
							|  |  |  | 							} | 
					
						
							|  |  |  | 							rect.size.y = caret_width * 3; | 
					
						
							|  |  |  | 							RenderingServer::get_singleton()->canvas_item_add_rect(ci, rect, cursor_color); | 
					
						
							| 
									
										
										
										
											2019-12-01 14:27:39 +00:00
										 |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
										
										
											2017-08-07 14:09:56 +03:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2016-06-21 00:05:52 +01:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-06-25 23:50:45 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			if (has_focus()) { | 
					
						
							| 
									
										
										
										
											2020-03-07 18:02:54 +02:00
										 |  |  | 				if (get_viewport()->get_window_id() != DisplayServer::INVALID_WINDOW_ID) { | 
					
						
							|  |  |  | 					DisplayServer::get_singleton()->window_set_ime_active(true, get_viewport()->get_window_id()); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 					DisplayServer::get_singleton()->window_set_ime_position(get_global_position() + Point2(using_placeholder ? 0 : x_ofs, y_ofs + TS->shaped_text_get_size(text_rid).y), get_viewport()->get_window_id()); | 
					
						
							| 
									
										
										
										
											2020-03-07 18:02:54 +02:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2017-06-25 23:50:45 +08:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		} break; | 
					
						
							|  |  |  | 		case NOTIFICATION_FOCUS_ENTER: { | 
					
						
							| 
									
										
										
										
											2020-06-21 19:15:57 +02:00
										 |  |  | 			if (!caret_force_displayed) { | 
					
						
							|  |  |  | 				if (caret_blink_enabled) { | 
					
						
							|  |  |  | 					if (caret_blink_timer->is_stopped()) { | 
					
						
							|  |  |  | 						caret_blink_timer->start(); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} else { | 
					
						
							|  |  |  | 					draw_caret = true; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2016-06-21 00:16:18 +01:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-07 18:02:54 +02:00
										 |  |  | 			if (get_viewport()->get_window_id() != DisplayServer::INVALID_WINDOW_ID) { | 
					
						
							|  |  |  | 				DisplayServer::get_singleton()->window_set_ime_active(true, get_viewport()->get_window_id()); | 
					
						
							|  |  |  | 				Point2 cursor_pos = Point2(get_cursor_position(), 1) * get_minimum_size().height; | 
					
						
							|  |  |  | 				DisplayServer::get_singleton()->window_set_ime_position(get_global_position() + cursor_pos, get_viewport()->get_window_id()); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-06-25 23:50:45 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 08:04:48 +02:00
										 |  |  | 			if (DisplayServer::get_singleton()->has_feature(DisplayServer::FEATURE_VIRTUAL_KEYBOARD) && virtual_keyboard_enabled) { | 
					
						
							| 
									
										
										
										
											2020-04-28 19:57:45 +02:00
										 |  |  | 				if (selection.enabled) { | 
					
						
							| 
									
										
										
										
											2020-07-17 17:44:13 +02:00
										 |  |  | 					DisplayServer::get_singleton()->virtual_keyboard_show(text, get_global_rect(), false, max_length, selection.begin, selection.end); | 
					
						
							| 
									
										
										
										
											2020-04-28 19:57:45 +02:00
										 |  |  | 				} else { | 
					
						
							| 
									
										
										
										
											2020-07-17 17:44:13 +02:00
										 |  |  | 					DisplayServer::get_singleton()->virtual_keyboard_show(text, get_global_rect(), false, max_length, cursor_pos); | 
					
						
							| 
									
										
										
										
											2020-04-28 19:57:45 +02:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case NOTIFICATION_FOCUS_EXIT: { | 
					
						
							| 
									
										
										
										
											2020-06-21 19:15:57 +02:00
										 |  |  | 			if (caret_blink_enabled && !caret_force_displayed) { | 
					
						
							| 
									
										
										
										
											2019-09-04 13:06:15 +02:00
										 |  |  | 				caret_blink_timer->stop(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-07 18:02:54 +02:00
										 |  |  | 			if (get_viewport()->get_window_id() != DisplayServer::INVALID_WINDOW_ID) { | 
					
						
							|  |  |  | 				DisplayServer::get_singleton()->window_set_ime_position(Point2(), get_viewport()->get_window_id()); | 
					
						
							|  |  |  | 				DisplayServer::get_singleton()->window_set_ime_active(false, get_viewport()->get_window_id()); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-08-07 14:09:56 +03:00
										 |  |  | 			ime_text = ""; | 
					
						
							|  |  |  | 			ime_selection = Point2(); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			_shape(); | 
					
						
							|  |  |  | 			set_cursor_position(cursor_pos); // Update scroll_offset
 | 
					
						
							| 
									
										
										
										
											2017-06-25 23:50:45 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 08:04:48 +02:00
										 |  |  | 			if (DisplayServer::get_singleton()->has_feature(DisplayServer::FEATURE_VIRTUAL_KEYBOARD) && virtual_keyboard_enabled) { | 
					
						
							| 
									
										
										
										
											2020-03-03 10:36:29 -03:00
										 |  |  | 				DisplayServer::get_singleton()->virtual_keyboard_hide(); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		} break; | 
					
						
							| 
									
										
										
										
											2018-11-23 14:07:48 +02:00
										 |  |  | 		case MainLoop::NOTIFICATION_OS_IME_UPDATE: { | 
					
						
							| 
									
										
										
										
											2019-01-08 22:52:56 +02:00
										 |  |  | 			if (has_focus()) { | 
					
						
							| 
									
										
										
										
											2020-03-03 10:36:29 -03:00
										 |  |  | 				ime_text = DisplayServer::get_singleton()->ime_get_text(); | 
					
						
							|  |  |  | 				ime_selection = DisplayServer::get_singleton()->ime_get_selection(); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 				_shape(); | 
					
						
							|  |  |  | 				set_cursor_position(cursor_pos); // Update scroll_offset
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-08 22:52:56 +02:00
										 |  |  | 				update(); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2018-11-23 14:07:48 +02:00
										 |  |  | 		} break; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::copy_text() { | 
					
						
							| 
									
										
										
										
											2018-08-24 04:35:46 -05:00
										 |  |  | 	if (selection.enabled && !pass) { | 
					
						
							| 
									
										
										
										
											2020-03-03 10:36:29 -03:00
										 |  |  | 		DisplayServer::get_singleton()->clipboard_set(text.substr(selection.begin, selection.end - selection.begin)); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::cut_text() { | 
					
						
							| 
									
										
										
										
											2018-08-24 04:35:46 -05:00
										 |  |  | 	if (selection.enabled && !pass) { | 
					
						
							| 
									
										
										
										
											2020-03-03 10:36:29 -03:00
										 |  |  | 		DisplayServer::get_singleton()->clipboard_set(text.substr(selection.begin, selection.end - selection.begin)); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		selection_delete(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::paste_text() { | 
					
						
							| 
									
										
										
										
											2019-05-31 15:27:53 +02:00
										 |  |  | 	// Strip escape characters like \n and \t as they can't be displayed on LineEdit.
 | 
					
						
							| 
									
										
										
										
											2020-03-03 10:36:29 -03:00
										 |  |  | 	String paste_buffer = DisplayServer::get_singleton()->clipboard_get().strip_escapes(); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	if (paste_buffer != "") { | 
					
						
							| 
									
										
										
										
											2020-01-10 21:07:00 +01:00
										 |  |  | 		int prev_len = text.length(); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 		if (selection.enabled) { | 
					
						
							| 
									
										
										
										
											2020-05-10 12:56:01 +02:00
										 |  |  | 			selection_delete(); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		append_at_cursor(paste_buffer); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-05 16:22:34 +01:00
										 |  |  | 		if (!text_changed_dirty) { | 
					
						
							| 
									
										
										
										
											2020-01-10 21:07:00 +01:00
										 |  |  | 			if (is_inside_tree() && text.length() != prev_len) { | 
					
						
							| 
									
										
										
										
											2018-02-05 16:22:34 +01:00
										 |  |  | 				MessageQueue::get_singleton()->push_call(this, "_text_changed"); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			text_changed_dirty = true; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::undo() { | 
					
						
							| 
									
										
										
										
											2020-04-02 01:20:12 +02:00
										 |  |  | 	if (undo_stack_pos == nullptr) { | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 		if (undo_stack.size() <= 1) { | 
					
						
							|  |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		undo_stack_pos = undo_stack.back(); | 
					
						
							|  |  |  | 	} else if (undo_stack_pos == undo_stack.front()) { | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 	undo_stack_pos = undo_stack_pos->prev(); | 
					
						
							|  |  |  | 	TextOperation op = undo_stack_pos->get(); | 
					
						
							|  |  |  | 	text = op.text; | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | 	scroll_offset = op.scroll_offset; | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 	set_cursor_position(op.cursor_pos); | 
					
						
							| 
									
										
										
										
											2019-04-21 10:51:10 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	_shape(); | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 	_emit_text_change(); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | void LineEdit::redo() { | 
					
						
							| 
									
										
										
										
											2020-04-02 01:20:12 +02:00
										 |  |  | 	if (undo_stack_pos == nullptr) { | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (undo_stack_pos == undo_stack.back()) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	undo_stack_pos = undo_stack_pos->next(); | 
					
						
							|  |  |  | 	TextOperation op = undo_stack_pos->get(); | 
					
						
							|  |  |  | 	text = op.text; | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | 	scroll_offset = op.scroll_offset; | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 	set_cursor_position(op.cursor_pos); | 
					
						
							| 
									
										
										
										
											2019-04-21 10:51:10 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	_shape(); | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 	_emit_text_change(); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::shift_selection_check_pre(bool p_shift) { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	if (!selection.enabled && p_shift) { | 
					
						
							|  |  |  | 		selection.cursor_start = cursor_pos; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (!p_shift) { | 
					
						
							| 
									
										
										
										
											2017-12-17 15:40:44 -02:00
										 |  |  | 		deselect(); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::shift_selection_check_post(bool p_shift) { | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (p_shift) { | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		selection_fill_at_cursor(); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::set_cursor_at_pixel_pos(int p_x) { | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 	Ref<StyleBox> style = get_theme_stylebox("normal"); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	bool rtl = is_layout_rtl(); | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	int x_ofs = 0; | 
					
						
							|  |  |  | 	float text_width = TS->shaped_text_get_size(text_rid).x; | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 	switch (align) { | 
					
						
							|  |  |  | 		case ALIGN_FILL: | 
					
						
							|  |  |  | 		case ALIGN_LEFT: { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			if (rtl) { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				x_ofs = MAX(style->get_margin(SIDE_LEFT), int(get_size().width - style->get_margin(SIDE_RIGHT) - (text_width))); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			} else { | 
					
						
							|  |  |  | 				x_ofs = style->get_offset().x; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 		} break; | 
					
						
							|  |  |  | 		case ALIGN_CENTER: { | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | 			if (scroll_offset != 0) { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 				x_ofs = style->get_offset().x; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				x_ofs = MAX(style->get_margin(SIDE_LEFT), int(get_size().width - (text_width)) / 2); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 		} break; | 
					
						
							|  |  |  | 		case ALIGN_RIGHT: { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			if (rtl) { | 
					
						
							|  |  |  | 				x_ofs = style->get_offset().x; | 
					
						
							|  |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				x_ofs = MAX(style->get_margin(SIDE_LEFT), int(get_size().width - style->get_margin(SIDE_RIGHT) - (text_width))); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2015-08-15 07:47:22 +01:00
										 |  |  | 		} break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-15 12:04:21 +00:00
										 |  |  | 	bool using_placeholder = text.is_empty() && ime_text.is_empty(); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	bool display_clear_icon = !using_placeholder && is_editable() && clear_button_enabled; | 
					
						
							|  |  |  | 	if (right_icon.is_valid() || display_clear_icon) { | 
					
						
							|  |  |  | 		Ref<Texture2D> r_icon = display_clear_icon ? Control::get_theme_icon("clear") : right_icon; | 
					
						
							|  |  |  | 		if (align == ALIGN_CENTER) { | 
					
						
							|  |  |  | 			if (scroll_offset == 0) { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				x_ofs = MAX(style->get_margin(SIDE_LEFT), int(get_size().width - text_width - r_icon->get_width() - style->get_margin(SIDE_RIGHT) * 2) / 2); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 			x_ofs = MAX(style->get_margin(SIDE_LEFT), x_ofs - r_icon->get_width() - style->get_margin(SIDE_RIGHT)); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	int ofs = TS->shaped_text_hit_test_position(text_rid, p_x - x_ofs - scroll_offset); | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 	set_cursor_position(ofs); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | Vector2i LineEdit::get_cursor_pixel_pos() { | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 	Ref<StyleBox> style = get_theme_stylebox("normal"); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	bool rtl = is_layout_rtl(); | 
					
						
							| 
									
										
										
										
											2019-06-22 20:22:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	int x_ofs = 0; | 
					
						
							|  |  |  | 	float text_width = TS->shaped_text_get_size(text_rid).x; | 
					
						
							| 
									
										
										
										
											2019-06-22 20:22:52 +02:00
										 |  |  | 	switch (align) { | 
					
						
							|  |  |  | 		case ALIGN_FILL: | 
					
						
							|  |  |  | 		case ALIGN_LEFT: { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			if (rtl) { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				x_ofs = MAX(style->get_margin(SIDE_LEFT), int(get_size().width - style->get_margin(SIDE_RIGHT) - (text_width))); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			} else { | 
					
						
							|  |  |  | 				x_ofs = style->get_offset().x; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2019-06-22 20:22:52 +02:00
										 |  |  | 		} break; | 
					
						
							|  |  |  | 		case ALIGN_CENTER: { | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | 			if (scroll_offset != 0) { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 				x_ofs = style->get_offset().x; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				x_ofs = MAX(style->get_margin(SIDE_LEFT), int(get_size().width - (text_width)) / 2); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2019-06-22 20:22:52 +02:00
										 |  |  | 		} break; | 
					
						
							|  |  |  | 		case ALIGN_RIGHT: { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			if (rtl) { | 
					
						
							|  |  |  | 				x_ofs = style->get_offset().x; | 
					
						
							|  |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				x_ofs = MAX(style->get_margin(SIDE_LEFT), int(get_size().width - style->get_margin(SIDE_RIGHT) - (text_width))); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2019-06-22 20:22:52 +02:00
										 |  |  | 		} break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-15 12:04:21 +00:00
										 |  |  | 	bool using_placeholder = text.is_empty() && ime_text.is_empty(); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	bool display_clear_icon = !using_placeholder && is_editable() && clear_button_enabled; | 
					
						
							|  |  |  | 	if (right_icon.is_valid() || display_clear_icon) { | 
					
						
							|  |  |  | 		Ref<Texture2D> r_icon = display_clear_icon ? Control::get_theme_icon("clear") : right_icon; | 
					
						
							|  |  |  | 		if (align == ALIGN_CENTER) { | 
					
						
							|  |  |  | 			if (scroll_offset == 0) { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				x_ofs = MAX(style->get_margin(SIDE_LEFT), int(get_size().width - text_width - r_icon->get_width() - style->get_margin(SIDE_RIGHT) * 2) / 2); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 			x_ofs = MAX(style->get_margin(SIDE_LEFT), x_ofs - r_icon->get_width() - style->get_margin(SIDE_RIGHT)); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Vector2i ret; | 
					
						
							|  |  |  | 	Rect2 l_caret, t_caret; | 
					
						
							|  |  |  | 	TextServer::Direction l_dir, t_dir; | 
					
						
							|  |  |  | 	// Get position of the start of caret.
 | 
					
						
							|  |  |  | 	if (ime_text.length() != 0 && ime_selection.x != 0) { | 
					
						
							|  |  |  | 		TS->shaped_text_get_carets(text_rid, cursor_pos + ime_selection.x, l_caret, l_dir, t_caret, t_dir); | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		TS->shaped_text_get_carets(text_rid, cursor_pos, l_caret, l_dir, t_caret, t_dir); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if ((l_caret != Rect2() && (l_dir == TextServer::DIRECTION_AUTO || l_dir == (TextServer::Direction)input_direction)) || (t_caret == Rect2())) { | 
					
						
							|  |  |  | 		ret.x = x_ofs + l_caret.position.x + scroll_offset; | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		ret.x = x_ofs + t_caret.position.x + scroll_offset; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Get position of the end of caret.
 | 
					
						
							|  |  |  | 	if (ime_text.length() != 0) { | 
					
						
							|  |  |  | 		if (ime_selection.y != 0) { | 
					
						
							|  |  |  | 			TS->shaped_text_get_carets(text_rid, cursor_pos + ime_selection.x + ime_selection.y, l_caret, l_dir, t_caret, t_dir); | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			TS->shaped_text_get_carets(text_rid, cursor_pos + ime_text.size(), l_caret, l_dir, t_caret, t_dir); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		if ((l_caret != Rect2() && (l_dir == TextServer::DIRECTION_AUTO || l_dir == (TextServer::Direction)input_direction)) || (t_caret == Rect2())) { | 
					
						
							|  |  |  | 			ret.y = x_ofs + l_caret.position.x + scroll_offset; | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			ret.y = x_ofs + t_caret.position.x + scroll_offset; | 
					
						
							| 
									
										
										
										
											2019-06-22 20:22:52 +02:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		ret.y = ret.x; | 
					
						
							| 
									
										
										
										
											2019-06-22 20:22:52 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	return ret; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::set_mid_grapheme_caret_enabled(const bool p_enabled) { | 
					
						
							|  |  |  | 	mid_grapheme_caret_enabled = p_enabled; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool LineEdit::get_mid_grapheme_caret_enabled() const { | 
					
						
							|  |  |  | 	return mid_grapheme_caret_enabled; | 
					
						
							| 
									
										
										
										
											2019-06-22 20:22:52 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-21 00:05:52 +01:00
										 |  |  | bool LineEdit::cursor_get_blink_enabled() const { | 
					
						
							|  |  |  | 	return caret_blink_enabled; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::cursor_set_blink_enabled(const bool p_enabled) { | 
					
						
							|  |  |  | 	caret_blink_enabled = p_enabled; | 
					
						
							| 
									
										
										
										
											2019-09-04 13:06:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-21 19:15:57 +02:00
										 |  |  | 	if (has_focus() || caret_force_displayed) { | 
					
						
							| 
									
										
										
										
											2019-09-04 13:06:15 +02:00
										 |  |  | 		if (p_enabled) { | 
					
						
							| 
									
										
										
										
											2020-06-21 19:15:57 +02:00
										 |  |  | 			if (caret_blink_timer->is_stopped()) { | 
					
						
							|  |  |  | 				caret_blink_timer->start(); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2019-09-04 13:06:15 +02:00
										 |  |  | 		} else { | 
					
						
							|  |  |  | 			caret_blink_timer->stop(); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-06-21 00:05:52 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-09-04 13:06:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-21 00:05:52 +01:00
										 |  |  | 	draw_caret = true; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-21 19:15:57 +02:00
										 |  |  | bool LineEdit::cursor_get_force_displayed() const { | 
					
						
							|  |  |  | 	return caret_force_displayed; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::cursor_set_force_displayed(const bool p_enabled) { | 
					
						
							|  |  |  | 	caret_force_displayed = p_enabled; | 
					
						
							|  |  |  | 	cursor_set_blink_enabled(caret_blink_enabled); | 
					
						
							|  |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-21 00:05:52 +01:00
										 |  |  | float LineEdit::cursor_get_blink_speed() const { | 
					
						
							|  |  |  | 	return caret_blink_timer->get_wait_time(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::cursor_set_blink_speed(const float p_speed) { | 
					
						
							|  |  |  | 	ERR_FAIL_COND(p_speed <= 0); | 
					
						
							|  |  |  | 	caret_blink_timer->set_wait_time(p_speed); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::_reset_caret_blink_timer() { | 
					
						
							|  |  |  | 	if (caret_blink_enabled) { | 
					
						
							|  |  |  | 		draw_caret = true; | 
					
						
							| 
									
										
										
										
											2019-09-04 13:06:15 +02:00
										 |  |  | 		if (has_focus()) { | 
					
						
							|  |  |  | 			caret_blink_timer->stop(); | 
					
						
							|  |  |  | 			caret_blink_timer->start(); | 
					
						
							|  |  |  | 			update(); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-06-21 00:05:52 +01:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2016-06-21 00:05:52 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::_toggle_draw_caret() { | 
					
						
							|  |  |  | 	draw_caret = !draw_caret; | 
					
						
							| 
									
										
										
										
											2020-06-21 19:15:57 +02:00
										 |  |  | 	if (is_visible_in_tree() && ((has_focus() && window_has_focus) || caret_force_displayed)) { | 
					
						
							| 
									
										
										
										
											2016-06-21 00:05:52 +01:00
										 |  |  | 		update(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | void LineEdit::delete_char() { | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if ((text.length() <= 0) || (cursor_pos == 0)) { | 
					
						
							| 
									
										
										
										
											2020-05-10 12:56:01 +02:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	text.erase(cursor_pos - 1, 1); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	_shape(); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 	set_cursor_position(get_cursor_position() - 1); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-06 20:34:24 -03:00
										 |  |  | 	_text_changed(); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | void LineEdit::delete_text(int p_from_column, int p_to_column) { | 
					
						
							| 
									
										
										
										
											2020-06-06 17:39:53 +02:00
										 |  |  | 	ERR_FAIL_COND_MSG(p_from_column < 0 || p_from_column > p_to_column || p_to_column > text.length(), | 
					
						
							|  |  |  | 			vformat("Positional parameters (from: %d, to: %d) are inverted or outside the text length (%d).", p_from_column, p_to_column, text.length())); | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	text.erase(p_from_column, p_to_column - p_from_column); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	_shape(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	cursor_pos -= CLAMP(cursor_pos - p_from_column, 0, p_to_column - p_from_column); | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	if (cursor_pos >= text.length()) { | 
					
						
							|  |  |  | 		cursor_pos = text.length(); | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-12-01 13:54:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-05 16:22:34 +01:00
										 |  |  | 	if (!text_changed_dirty) { | 
					
						
							|  |  |  | 		if (is_inside_tree()) { | 
					
						
							|  |  |  | 			MessageQueue::get_singleton()->push_call(this, "_text_changed"); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		text_changed_dirty = true; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-06-18 16:15:26 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | void LineEdit::set_text(String p_text) { | 
					
						
							|  |  |  | 	clear_internal(); | 
					
						
							| 
									
										
										
										
											2020-09-01 14:04:37 +02:00
										 |  |  | 	append_at_cursor(p_text); | 
					
						
							| 
									
										
										
										
											2020-01-15 09:42:06 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	update(); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	cursor_pos = 0; | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | 	scroll_offset = 0; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | void LineEdit::set_text_direction(Control::TextDirection p_text_direction) { | 
					
						
							|  |  |  | 	ERR_FAIL_COND((int)p_text_direction < -1 || (int)p_text_direction > 3); | 
					
						
							|  |  |  | 	if (text_direction != p_text_direction) { | 
					
						
							|  |  |  | 		text_direction = p_text_direction; | 
					
						
							|  |  |  | 		if (text_direction != TEXT_DIRECTION_AUTO && text_direction != TEXT_DIRECTION_INHERITED) { | 
					
						
							|  |  |  | 			input_direction = text_direction; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		_shape(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		menu_dir->set_item_checked(menu_dir->get_item_index(MENU_DIR_INHERITED), text_direction == TEXT_DIRECTION_INHERITED); | 
					
						
							|  |  |  | 		menu_dir->set_item_checked(menu_dir->get_item_index(MENU_DIR_AUTO), text_direction == TEXT_DIRECTION_AUTO); | 
					
						
							|  |  |  | 		menu_dir->set_item_checked(menu_dir->get_item_index(MENU_DIR_LTR), text_direction == TEXT_DIRECTION_LTR); | 
					
						
							|  |  |  | 		menu_dir->set_item_checked(menu_dir->get_item_index(MENU_DIR_RTL), text_direction == TEXT_DIRECTION_RTL); | 
					
						
							|  |  |  | 		update(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Control::TextDirection LineEdit::get_text_direction() const { | 
					
						
							|  |  |  | 	return text_direction; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::clear_opentype_features() { | 
					
						
							|  |  |  | 	opentype_features.clear(); | 
					
						
							|  |  |  | 	_shape(); | 
					
						
							|  |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::set_opentype_feature(const String &p_name, int p_value) { | 
					
						
							|  |  |  | 	int32_t tag = TS->name_to_tag(p_name); | 
					
						
							|  |  |  | 	if (!opentype_features.has(tag) || (int)opentype_features[tag] != p_value) { | 
					
						
							|  |  |  | 		opentype_features[tag] = p_value; | 
					
						
							|  |  |  | 		_shape(); | 
					
						
							|  |  |  | 		update(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int LineEdit::get_opentype_feature(const String &p_name) const { | 
					
						
							|  |  |  | 	int32_t tag = TS->name_to_tag(p_name); | 
					
						
							|  |  |  | 	if (!opentype_features.has(tag)) { | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return opentype_features[tag]; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::set_language(const String &p_language) { | 
					
						
							|  |  |  | 	if (language != p_language) { | 
					
						
							|  |  |  | 		language = p_language; | 
					
						
							|  |  |  | 		_shape(); | 
					
						
							|  |  |  | 		update(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | String LineEdit::get_language() const { | 
					
						
							|  |  |  | 	return language; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::set_draw_control_chars(bool p_draw_control_chars) { | 
					
						
							|  |  |  | 	if (draw_control_chars != p_draw_control_chars) { | 
					
						
							|  |  |  | 		draw_control_chars = p_draw_control_chars; | 
					
						
							|  |  |  | 		menu->set_item_checked(menu->get_item_index(MENU_DISPLAY_UCC), draw_control_chars); | 
					
						
							|  |  |  | 		_shape(); | 
					
						
							|  |  |  | 		update(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool LineEdit::get_draw_control_chars() const { | 
					
						
							|  |  |  | 	return draw_control_chars; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::set_structured_text_bidi_override(Control::StructuredTextParser p_parser) { | 
					
						
							|  |  |  | 	if (st_parser != p_parser) { | 
					
						
							|  |  |  | 		st_parser = p_parser; | 
					
						
							|  |  |  | 		_shape(); | 
					
						
							|  |  |  | 		update(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Control::StructuredTextParser LineEdit::get_structured_text_bidi_override() const { | 
					
						
							|  |  |  | 	return st_parser; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::set_structured_text_bidi_override_options(Array p_args) { | 
					
						
							|  |  |  | 	st_args = p_args; | 
					
						
							|  |  |  | 	_shape(); | 
					
						
							|  |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Array LineEdit::get_structured_text_bidi_override_options() const { | 
					
						
							|  |  |  | 	return st_args; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | void LineEdit::clear() { | 
					
						
							|  |  |  | 	clear_internal(); | 
					
						
							| 
									
										
										
										
											2016-09-06 20:34:24 -03:00
										 |  |  | 	_text_changed(); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | String LineEdit::get_text() const { | 
					
						
							|  |  |  | 	return text; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-27 19:47:40 +08:00
										 |  |  | void LineEdit::set_placeholder(String p_text) { | 
					
						
							| 
									
										
										
										
											2019-06-22 14:42:36 +02:00
										 |  |  | 	placeholder = p_text; | 
					
						
							|  |  |  | 	placeholder_translated = tr(placeholder); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	_shape(); | 
					
						
							| 
									
										
										
										
											2016-06-27 19:47:40 +08:00
										 |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | String LineEdit::get_placeholder() const { | 
					
						
							|  |  |  | 	return placeholder; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-28 11:45:17 +08:00
										 |  |  | void LineEdit::set_placeholder_alpha(float p_alpha) { | 
					
						
							|  |  |  | 	placeholder_alpha = p_alpha; | 
					
						
							|  |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | float LineEdit::get_placeholder_alpha() const { | 
					
						
							|  |  |  | 	return placeholder_alpha; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | void LineEdit::set_cursor_position(int p_pos) { | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (p_pos > (int)text.length()) { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 		p_pos = text.length(); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (p_pos < 0) { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 		p_pos = 0; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	cursor_pos = p_pos; | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	// Fit to window.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-05 21:20:42 -03:00
										 |  |  | 	if (!is_inside_tree()) { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 		scroll_offset = 0; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 	Ref<StyleBox> style = get_theme_stylebox("normal"); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	bool rtl = is_layout_rtl(); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	int x_ofs = 0; | 
					
						
							|  |  |  | 	float text_width = TS->shaped_text_get_size(text_rid).x; | 
					
						
							|  |  |  | 	switch (align) { | 
					
						
							|  |  |  | 		case ALIGN_FILL: | 
					
						
							|  |  |  | 		case ALIGN_LEFT: { | 
					
						
							|  |  |  | 			if (rtl) { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				x_ofs = MAX(style->get_margin(SIDE_LEFT), int(get_size().width - style->get_margin(SIDE_RIGHT) - (text_width))); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			} else { | 
					
						
							|  |  |  | 				x_ofs = style->get_offset().x; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case ALIGN_CENTER: { | 
					
						
							|  |  |  | 			if (scroll_offset != 0) { | 
					
						
							|  |  |  | 				x_ofs = style->get_offset().x; | 
					
						
							|  |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				x_ofs = MAX(style->get_margin(SIDE_LEFT), int(get_size().width - (text_width)) / 2); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case ALIGN_RIGHT: { | 
					
						
							|  |  |  | 			if (rtl) { | 
					
						
							|  |  |  | 				x_ofs = style->get_offset().x; | 
					
						
							|  |  |  | 			} else { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				x_ofs = MAX(style->get_margin(SIDE_LEFT), int(get_size().width - style->get_margin(SIDE_RIGHT) - (text_width))); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-09-02 12:36:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 	int ofs_max = get_size().width - style->get_margin(SIDE_RIGHT); | 
					
						
							| 
									
										
										
										
											2020-12-15 12:04:21 +00:00
										 |  |  | 	bool using_placeholder = text.is_empty() && ime_text.is_empty(); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	bool display_clear_icon = !using_placeholder && is_editable() && clear_button_enabled; | 
					
						
							|  |  |  | 	if (right_icon.is_valid() || display_clear_icon) { | 
					
						
							|  |  |  | 		Ref<Texture2D> r_icon = display_clear_icon ? Control::get_theme_icon("clear") : right_icon; | 
					
						
							|  |  |  | 		if (align == ALIGN_CENTER) { | 
					
						
							|  |  |  | 			if (scroll_offset == 0) { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 				x_ofs = MAX(style->get_margin(SIDE_LEFT), int(get_size().width - text_width - r_icon->get_width() - style->get_margin(SIDE_RIGHT) * 2) / 2); | 
					
						
							| 
									
										
										
										
											2015-09-02 12:36:52 +01:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 		} else { | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 			x_ofs = MAX(style->get_margin(SIDE_LEFT), x_ofs - r_icon->get_width() - style->get_margin(SIDE_RIGHT)); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 		ofs_max -= r_icon->get_width(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	// Note: Use too coordinates to fit IME input range.
 | 
					
						
							|  |  |  | 	Vector2i primary_catret_offset = get_cursor_pixel_pos(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (MIN(primary_catret_offset.x, primary_catret_offset.y) <= x_ofs) { | 
					
						
							|  |  |  | 		scroll_offset += (x_ofs - MIN(primary_catret_offset.x, primary_catret_offset.y)); | 
					
						
							|  |  |  | 	} else if (MAX(primary_catret_offset.x, primary_catret_offset.y) >= ofs_max) { | 
					
						
							|  |  |  | 		scroll_offset += (ofs_max - MAX(primary_catret_offset.x, primary_catret_offset.y)); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	scroll_offset = MIN(0, scroll_offset); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | int LineEdit::get_cursor_position() const { | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	return cursor_pos; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | void LineEdit::set_scroll_offset(int p_pos) { | 
					
						
							|  |  |  | 	scroll_offset = p_pos; | 
					
						
							|  |  |  | 	if (scroll_offset < 0) { | 
					
						
							|  |  |  | 		scroll_offset = 0; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | int LineEdit::get_scroll_offset() const { | 
					
						
							|  |  |  | 	return scroll_offset; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | void LineEdit::append_at_cursor(String p_text) { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	if ((max_length <= 0) || (text.length() + p_text.length() <= max_length)) { | 
					
						
							|  |  |  | 		String pre = text.substr(0, cursor_pos); | 
					
						
							|  |  |  | 		String post = text.substr(cursor_pos, text.length() - cursor_pos); | 
					
						
							|  |  |  | 		text = pre + p_text + post; | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 		_shape(); | 
					
						
							|  |  |  | 		TextServer::Direction dir = TS->shaped_text_get_dominant_direciton_in_range(text_rid, cursor_pos, cursor_pos + p_text.length()); | 
					
						
							|  |  |  | 		if (dir != TextServer::DIRECTION_AUTO) { | 
					
						
							|  |  |  | 			input_direction = (TextDirection)dir; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 		set_cursor_position(cursor_pos + p_text.length()); | 
					
						
							| 
									
										
										
										
											2020-01-10 21:07:00 +01:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		emit_signal("text_change_rejected"); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::clear_internal() { | 
					
						
							| 
									
										
										
										
											2019-03-31 16:32:24 +01:00
										 |  |  | 	deselect(); | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 	_clear_undo_stack(); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	cursor_pos = 0; | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | 	scroll_offset = 0; | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	undo_text = ""; | 
					
						
							|  |  |  | 	text = ""; | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	_shape(); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Size2 LineEdit::get_minimum_size() const { | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 	Ref<StyleBox> style = get_theme_stylebox("normal"); | 
					
						
							|  |  |  | 	Ref<Font> font = get_theme_font("font"); | 
					
						
							| 
									
										
										
										
											2020-09-03 14:22:16 +03:00
										 |  |  | 	int font_size = get_theme_font_size("font_size"); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-24 23:21:35 -03:00
										 |  |  | 	Size2 min_size; | 
					
						
							| 
									
										
										
										
											2016-09-06 20:34:24 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 	// Minimum size of text.
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	int space_size = font->get_char_size('m', 0, font_size).x; | 
					
						
							| 
									
										
										
										
											2020-03-12 09:37:40 -03:00
										 |  |  | 	min_size.width = get_theme_constant("minimum_spaces") * space_size; | 
					
						
							| 
									
										
										
										
											2016-09-06 20:34:24 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (expand_to_text_length) { | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 		// Add a space because some fonts are too exact, and because cursor needs a bit more when at the end.
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 		min_size.width = MAX(min_size.width, full_width + space_size); | 
					
						
							| 
									
										
										
										
											2016-09-06 20:34:24 -03:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-30 11:48:42 +02:00
										 |  |  | 	min_size.height = MAX(TS->shaped_text_get_size(text_rid).y + font->get_spacing(Font::SPACING_TOP) + font->get_spacing(Font::SPACING_BOTTOM), font->get_height(font_size)); | 
					
						
							| 
									
										
										
										
											2019-09-24 23:21:35 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Take icons into account.
 | 
					
						
							| 
									
										
										
										
											2020-12-15 12:04:21 +00:00
										 |  |  | 	bool using_placeholder = text.is_empty() && ime_text.is_empty(); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	bool display_clear_icon = !using_placeholder && is_editable() && clear_button_enabled; | 
					
						
							|  |  |  | 	if (right_icon.is_valid() || display_clear_icon) { | 
					
						
							|  |  |  | 		Ref<Texture2D> r_icon = display_clear_icon ? Control::get_theme_icon("clear") : right_icon; | 
					
						
							|  |  |  | 		min_size.width += r_icon->get_width(); | 
					
						
							|  |  |  | 		min_size.height = MAX(min_size.height, r_icon->get_height()); | 
					
						
							| 
									
										
										
										
											2019-09-24 23:21:35 -03:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-09-06 20:34:24 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-24 23:21:35 -03:00
										 |  |  | 	return style->get_minimum_size() + min_size; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-17 15:40:44 -02:00
										 |  |  | void LineEdit::deselect() { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	selection.begin = 0; | 
					
						
							|  |  |  | 	selection.end = 0; | 
					
						
							|  |  |  | 	selection.cursor_start = 0; | 
					
						
							|  |  |  | 	selection.enabled = false; | 
					
						
							|  |  |  | 	selection.creating = false; | 
					
						
							|  |  |  | 	selection.doubleclick = false; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::selection_delete() { | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (selection.enabled) { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 		delete_text(selection.begin, selection.end); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-17 15:40:44 -02:00
										 |  |  | 	deselect(); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::set_max_length(int p_max_length) { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	ERR_FAIL_COND(p_max_length < 0); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	max_length = p_max_length; | 
					
						
							|  |  |  | 	set_text(text); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int LineEdit::get_max_length() const { | 
					
						
							|  |  |  | 	return max_length; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::selection_fill_at_cursor() { | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (!selecting_enabled) { | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	selection.begin = cursor_pos; | 
					
						
							|  |  |  | 	selection.end = selection.cursor_start; | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	if (selection.end < selection.begin) { | 
					
						
							| 
									
										
										
										
											2019-01-14 20:04:47 -02:00
										 |  |  | 		int aux = selection.end; | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 		selection.end = selection.begin; | 
					
						
							|  |  |  | 		selection.begin = aux; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	selection.enabled = (selection.begin != selection.end); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::select_all() { | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (!selecting_enabled) { | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (!text.length()) { | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	selection.begin = 0; | 
					
						
							|  |  |  | 	selection.end = text.length(); | 
					
						
							|  |  |  | 	selection.enabled = true; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-04-28 20:24:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | void LineEdit::set_editable(bool p_editable) { | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (editable == p_editable) { | 
					
						
							| 
									
										
										
										
											2019-04-21 20:09:52 -03:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-04-21 20:09:52 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	editable = p_editable; | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 	_generate_context_menu(); | 
					
						
							| 
									
										
										
										
											2019-04-21 20:09:52 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-15 09:42:06 +08:00
										 |  |  | 	minimum_size_changed(); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool LineEdit::is_editable() const { | 
					
						
							|  |  |  | 	return editable; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::set_secret(bool p_secret) { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	if (pass != p_secret) { | 
					
						
							|  |  |  | 		pass = p_secret; | 
					
						
							|  |  |  | 		_shape(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-04-28 20:24:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | bool LineEdit::is_secret() const { | 
					
						
							|  |  |  | 	return pass; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-28 20:24:48 +02:00
										 |  |  | void LineEdit::set_secret_character(const String &p_string) { | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 	// An empty string as the secret character would crash the engine.
 | 
					
						
							|  |  |  | 	// It also wouldn't make sense to use multiple characters as the secret character.
 | 
					
						
							| 
									
										
										
										
											2019-08-08 22:11:48 +02:00
										 |  |  | 	ERR_FAIL_COND_MSG(p_string.length() != 1, "Secret character must be exactly one character long (" + itos(p_string.length()) + " characters given)."); | 
					
						
							| 
									
										
										
										
											2018-04-28 20:24:48 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	if (secret_character != p_string) { | 
					
						
							|  |  |  | 		secret_character = p_string; | 
					
						
							|  |  |  | 		_shape(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-04-28 20:24:48 +02:00
										 |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | String LineEdit::get_secret_character() const { | 
					
						
							|  |  |  | 	return secret_character; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | void LineEdit::select(int p_from, int p_to) { | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (!selecting_enabled) { | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	if (p_from == 0 && p_to == 0) { | 
					
						
							| 
									
										
										
										
											2017-12-17 15:40:44 -02:00
										 |  |  | 		deselect(); | 
					
						
							| 
									
										
										
										
											2014-02-27 22:16:00 +08:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	int len = text.length(); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (p_from < 0) { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 		p_from = 0; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	if (p_from > len) { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 		p_from = len; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	if (p_to < 0 || p_to > len) { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 		p_to = len; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (p_from >= p_to) { | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	selection.enabled = true; | 
					
						
							|  |  |  | 	selection.begin = p_from; | 
					
						
							|  |  |  | 	selection.end = p_to; | 
					
						
							|  |  |  | 	selection.creating = false; | 
					
						
							|  |  |  | 	selection.doubleclick = false; | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-17 10:29:54 -03:00
										 |  |  | bool LineEdit::is_text_field() const { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	return true; | 
					
						
							| 
									
										
										
										
											2015-10-17 10:29:54 -03:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | void LineEdit::menu_option(int p_option) { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	switch (p_option) { | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | 		case MENU_CUT: { | 
					
						
							| 
									
										
										
										
											2016-09-19 14:17:48 +02:00
										 |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				cut_text(); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_COPY: { | 
					
						
							|  |  |  | 			copy_text(); | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_PASTE: { | 
					
						
							| 
									
										
										
										
											2016-09-19 14:17:48 +02:00
										 |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				paste_text(); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_CLEAR: { | 
					
						
							| 
									
										
										
										
											2016-09-19 14:17:48 +02:00
										 |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				clear(); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_SELECT_ALL: { | 
					
						
							|  |  |  | 			select_all(); | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_UNDO: { | 
					
						
							| 
									
										
										
										
											2017-07-17 20:00:01 +07:00
										 |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				undo(); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | 		} break; | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 		case MENU_REDO: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				redo(); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_DIR_INHERITED: { | 
					
						
							|  |  |  | 			set_text_direction(TEXT_DIRECTION_INHERITED); | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_DIR_AUTO: { | 
					
						
							|  |  |  | 			set_text_direction(TEXT_DIRECTION_AUTO); | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_DIR_LTR: { | 
					
						
							|  |  |  | 			set_text_direction(TEXT_DIRECTION_LTR); | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_DIR_RTL: { | 
					
						
							|  |  |  | 			set_text_direction(TEXT_DIRECTION_RTL); | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_DISPLAY_UCC: { | 
					
						
							|  |  |  | 			set_draw_control_chars(!get_draw_control_chars()); | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_LRM: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x200E)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_RLM: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x200F)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_LRE: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x202A)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_RLE: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x202B)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_LRO: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x202D)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_RLO: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x202E)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_PDF: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x202C)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_ALM: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x061C)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_LRI: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x2066)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_RLI: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x2067)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_FSI: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x2068)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_PDI: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x2069)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_ZWJ: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x200D)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_ZWNJ: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x200C)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_WJ: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x2060)); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} break; | 
					
						
							|  |  |  | 		case MENU_INSERT_SHY: { | 
					
						
							|  |  |  | 			if (editable) { | 
					
						
							|  |  |  | 				append_at_cursor(String::chr(0x00AD)); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-09 15:46:29 -05:00
										 |  |  | void LineEdit::set_context_menu_enabled(bool p_enable) { | 
					
						
							|  |  |  | 	context_menu_enabled = p_enable; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool LineEdit::is_context_menu_enabled() { | 
					
						
							|  |  |  | 	return context_menu_enabled; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | PopupMenu *LineEdit::get_menu() const { | 
					
						
							|  |  |  | 	return menu; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | void LineEdit::_editor_settings_changed() { | 
					
						
							| 
									
										
										
										
											2018-04-29 19:49:26 +02:00
										 |  |  | #ifdef TOOLS_ENABLED
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	cursor_set_blink_enabled(EDITOR_DEF("text_editor/cursor/caret_blink", false)); | 
					
						
							|  |  |  | 	cursor_set_blink_speed(EDITOR_DEF("text_editor/cursor/caret_blink_speed", 0.65)); | 
					
						
							| 
									
										
										
										
											2016-06-21 14:38:35 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2018-04-29 19:49:26 +02:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2016-06-21 14:38:35 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-07 08:52:42 +02:00
										 |  |  | void LineEdit::set_expand_to_text_length(bool p_enabled) { | 
					
						
							|  |  |  | 	expand_to_text_length = p_enabled; | 
					
						
							| 
									
										
										
										
											2016-09-06 20:34:24 -03:00
										 |  |  | 	minimum_size_changed(); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	set_cursor_position(cursor_pos); | 
					
						
							| 
									
										
										
										
											2016-09-06 20:34:24 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | bool LineEdit::get_expand_to_text_length() const { | 
					
						
							| 
									
										
										
										
											2016-09-06 20:34:24 -03:00
										 |  |  | 	return expand_to_text_length; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | void LineEdit::set_clear_button_enabled(bool p_enabled) { | 
					
						
							| 
									
										
										
										
											2020-01-15 09:42:06 +08:00
										 |  |  | 	if (clear_button_enabled == p_enabled) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 	clear_button_enabled = p_enabled; | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	_fit_to_width(); | 
					
						
							| 
									
										
										
										
											2020-01-15 09:42:06 +08:00
										 |  |  | 	minimum_size_changed(); | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool LineEdit::is_clear_button_enabled() const { | 
					
						
							|  |  |  | 	return clear_button_enabled; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | void LineEdit::set_shortcut_keys_enabled(bool p_enabled) { | 
					
						
							|  |  |  | 	shortcut_keys_enabled = p_enabled; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_generate_context_menu(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool LineEdit::is_shortcut_keys_enabled() const { | 
					
						
							|  |  |  | 	return shortcut_keys_enabled; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 08:04:48 +02:00
										 |  |  | void LineEdit::set_virtual_keyboard_enabled(bool p_enable) { | 
					
						
							|  |  |  | 	virtual_keyboard_enabled = p_enable; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool LineEdit::is_virtual_keyboard_enabled() const { | 
					
						
							|  |  |  | 	return virtual_keyboard_enabled; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | void LineEdit::set_selecting_enabled(bool p_enabled) { | 
					
						
							|  |  |  | 	selecting_enabled = p_enabled; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (!selecting_enabled) { | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 		deselect(); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	_generate_context_menu(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool LineEdit::is_selecting_enabled() const { | 
					
						
							|  |  |  | 	return selecting_enabled; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-11 15:43:37 -03:00
										 |  |  | void LineEdit::set_right_icon(const Ref<Texture2D> &p_icon) { | 
					
						
							| 
									
										
										
										
											2018-08-11 12:04:19 +02:00
										 |  |  | 	if (right_icon == p_icon) { | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	right_icon = p_icon; | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	_fit_to_width(); | 
					
						
							| 
									
										
										
										
											2020-01-15 09:42:06 +08:00
										 |  |  | 	minimum_size_changed(); | 
					
						
							| 
									
										
										
										
											2018-08-11 12:04:19 +02:00
										 |  |  | 	update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-11 15:43:37 -03:00
										 |  |  | Ref<Texture2D> LineEdit::get_right_icon() { | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 	return right_icon; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2016-09-06 20:34:24 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | void LineEdit::_text_changed() { | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 	_emit_text_change(); | 
					
						
							|  |  |  | 	_clear_redo(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::_emit_text_change() { | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	emit_signal("text_changed", text); | 
					
						
							| 
									
										
										
										
											2016-09-06 20:34:24 -03:00
										 |  |  | 	_change_notify("text"); | 
					
						
							| 
									
										
										
										
											2018-02-05 16:22:34 +01:00
										 |  |  | 	text_changed_dirty = false; | 
					
						
							| 
									
										
										
										
											2016-09-06 20:34:24 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | void LineEdit::_shape() { | 
					
						
							|  |  |  | 	Size2 old_size = TS->shaped_text_get_size(text_rid); | 
					
						
							|  |  |  | 	TS->shaped_text_clear(text_rid); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	String t; | 
					
						
							|  |  |  | 	if (text.length() == 0) { | 
					
						
							|  |  |  | 		t = placeholder_translated; | 
					
						
							|  |  |  | 	} else if (pass) { | 
					
						
							|  |  |  | 		t = secret_character.repeat(text.length() + ime_text.length()); | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		if (ime_text.length() > 0) { | 
					
						
							|  |  |  | 			t = text.substr(0, cursor_pos) + ime_text + text.substr(cursor_pos, text.length()); | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			t = text; | 
					
						
							| 
									
										
										
										
											2020-01-29 14:46:49 -05:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	if (text_direction == Control::TEXT_DIRECTION_INHERITED) { | 
					
						
							|  |  |  | 		TS->shaped_text_set_direction(text_rid, is_layout_rtl() ? TextServer::DIRECTION_RTL : TextServer::DIRECTION_LTR); | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		TS->shaped_text_set_direction(text_rid, (TextServer::Direction)text_direction); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	TS->shaped_text_set_preserve_control(text_rid, draw_control_chars); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const Ref<Font> &font = get_theme_font("font"); | 
					
						
							|  |  |  | 	int font_size = get_theme_font_size("font_size"); | 
					
						
							|  |  |  | 	TS->shaped_text_add_string(text_rid, t, font->get_rids(), font_size, opentype_features, (language != "") ? language : TranslationServer::get_singleton()->get_tool_locale()); | 
					
						
							|  |  |  | 	TS->shaped_text_set_bidi_override(text_rid, structured_text_parser(st_parser, st_args, t)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	full_width = TS->shaped_text_get_size(text_rid).x; | 
					
						
							|  |  |  | 	_fit_to_width(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Size2 size = TS->shaped_text_get_size(text_rid); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if ((expand_to_text_length && old_size.x != size.x) || (old_size.y != size.y)) { | 
					
						
							|  |  |  | 		minimum_size_changed(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-01-29 14:46:49 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | void LineEdit::_fit_to_width() { | 
					
						
							|  |  |  | 	if (align == ALIGN_FILL) { | 
					
						
							|  |  |  | 		Ref<StyleBox> style = get_theme_stylebox("normal"); | 
					
						
							| 
									
										
										
										
											2020-12-22 16:24:29 +00:00
										 |  |  | 		int t_width = get_size().width - style->get_margin(SIDE_RIGHT) - style->get_margin(SIDE_LEFT); | 
					
						
							| 
									
										
										
										
											2020-12-15 12:04:21 +00:00
										 |  |  | 		bool using_placeholder = text.is_empty() && ime_text.is_empty(); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 		bool display_clear_icon = !using_placeholder && is_editable() && clear_button_enabled; | 
					
						
							|  |  |  | 		if (right_icon.is_valid() || display_clear_icon) { | 
					
						
							|  |  |  | 			Ref<Texture2D> r_icon = display_clear_icon ? Control::get_theme_icon("clear") : right_icon; | 
					
						
							|  |  |  | 			t_width -= r_icon->get_width(); | 
					
						
							| 
									
										
										
										
											2019-06-22 14:42:36 +02:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 		TS->shaped_text_fit_to_width(text_rid, MAX(t_width, full_width)); | 
					
						
							| 
									
										
										
										
											2019-06-22 14:42:36 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | void LineEdit::_clear_redo() { | 
					
						
							|  |  |  | 	_create_undo_state(); | 
					
						
							| 
									
										
										
										
											2020-04-02 01:20:12 +02:00
										 |  |  | 	if (undo_stack_pos == nullptr) { | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	undo_stack_pos = undo_stack_pos->next(); | 
					
						
							|  |  |  | 	while (undo_stack_pos) { | 
					
						
							|  |  |  | 		List<TextOperation>::Element *elem = undo_stack_pos; | 
					
						
							|  |  |  | 		undo_stack_pos = undo_stack_pos->next(); | 
					
						
							|  |  |  | 		undo_stack.erase(elem); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	_create_undo_state(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::_clear_undo_stack() { | 
					
						
							|  |  |  | 	undo_stack.clear(); | 
					
						
							| 
									
										
										
										
											2020-04-02 01:20:12 +02:00
										 |  |  | 	undo_stack_pos = nullptr; | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 	_create_undo_state(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::_create_undo_state() { | 
					
						
							|  |  |  | 	TextOperation op; | 
					
						
							|  |  |  | 	op.text = text; | 
					
						
							|  |  |  | 	op.cursor_pos = cursor_pos; | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | 	op.scroll_offset = scroll_offset; | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 	undo_stack.push_back(op); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | void LineEdit::_generate_context_menu() { | 
					
						
							|  |  |  | 	// Reorganize context menu.
 | 
					
						
							|  |  |  | 	menu->clear(); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (editable) { | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 		menu->add_item(RTR("Cut"), MENU_CUT, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_X : 0); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 	menu->add_item(RTR("Copy"), MENU_COPY, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_C : 0); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (editable) { | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 		menu->add_item(RTR("Paste"), MENU_PASTE, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_V : 0); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 	menu->add_separator(); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	if (is_selecting_enabled()) { | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 		menu->add_item(RTR("Select All"), MENU_SELECT_ALL, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_A : 0); | 
					
						
							| 
									
										
										
										
											2020-05-14 16:41:43 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 	if (editable) { | 
					
						
							|  |  |  | 		menu->add_item(RTR("Clear"), MENU_CLEAR); | 
					
						
							|  |  |  | 		menu->add_separator(); | 
					
						
							|  |  |  | 		menu->add_item(RTR("Undo"), MENU_UNDO, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_Z : 0); | 
					
						
							|  |  |  | 		menu->add_item(RTR("Redo"), MENU_REDO, is_shortcut_keys_enabled() ? KEY_MASK_CMD | KEY_MASK_SHIFT | KEY_Z : 0); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	menu->add_separator(); | 
					
						
							|  |  |  | 	menu->add_submenu_item(RTR("Text writing direction"), "DirMenu"); | 
					
						
							|  |  |  | 	menu->add_separator(); | 
					
						
							|  |  |  | 	menu->add_check_item(RTR("Display control characters"), MENU_DISPLAY_UCC); | 
					
						
							|  |  |  | 	if (editable) { | 
					
						
							|  |  |  | 		menu->add_submenu_item(RTR("Insert control character"), "CTLMenu"); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool LineEdit::_set(const StringName &p_name, const Variant &p_value) { | 
					
						
							|  |  |  | 	String str = p_name; | 
					
						
							|  |  |  | 	if (str.begins_with("opentype_features/")) { | 
					
						
							|  |  |  | 		String name = str.get_slicec('/', 1); | 
					
						
							|  |  |  | 		int32_t tag = TS->name_to_tag(name); | 
					
						
							|  |  |  | 		double value = p_value; | 
					
						
							|  |  |  | 		if (value == -1) { | 
					
						
							|  |  |  | 			if (opentype_features.has(tag)) { | 
					
						
							|  |  |  | 				opentype_features.erase(tag); | 
					
						
							|  |  |  | 				_shape(); | 
					
						
							|  |  |  | 				update(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			if ((double)opentype_features[tag] != value) { | 
					
						
							|  |  |  | 				opentype_features[tag] = value; | 
					
						
							|  |  |  | 				_shape(); | 
					
						
							|  |  |  | 				update(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		_change_notify(); | 
					
						
							|  |  |  | 		return true; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool LineEdit::_get(const StringName &p_name, Variant &r_ret) const { | 
					
						
							|  |  |  | 	String str = p_name; | 
					
						
							|  |  |  | 	if (str.begins_with("opentype_features/")) { | 
					
						
							|  |  |  | 		String name = str.get_slicec('/', 1); | 
					
						
							|  |  |  | 		int32_t tag = TS->name_to_tag(name); | 
					
						
							|  |  |  | 		if (opentype_features.has(tag)) { | 
					
						
							|  |  |  | 			r_ret = opentype_features[tag]; | 
					
						
							|  |  |  | 			return true; | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			r_ret = -1; | 
					
						
							|  |  |  | 			return true; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LineEdit::_get_property_list(List<PropertyInfo> *p_list) const { | 
					
						
							|  |  |  | 	for (const Variant *ftr = opentype_features.next(nullptr); ftr != nullptr; ftr = opentype_features.next(ftr)) { | 
					
						
							|  |  |  | 		String name = TS->tag_to_name(*ftr); | 
					
						
							|  |  |  | 		p_list->push_back(PropertyInfo(Variant::FLOAT, "opentype_features/" + name)); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	p_list->push_back(PropertyInfo(Variant::NIL, "opentype_features/_new", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_EDITOR)); | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | void LineEdit::_bind_methods() { | 
					
						
							| 
									
										
										
										
											2018-02-05 16:22:34 +01:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("_text_changed"), &LineEdit::_text_changed); | 
					
						
							| 
									
										
										
										
											2016-06-21 14:38:35 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-13 12:47:24 +01:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_align", "align"), &LineEdit::set_align); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_align"), &LineEdit::get_align); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("_gui_input"), &LineEdit::_gui_input); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("clear"), &LineEdit::clear); | 
					
						
							| 
									
										
										
										
											2017-12-17 15:40:44 -02:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("select", "from", "to"), &LineEdit::select, DEFVAL(0), DEFVAL(-1)); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("select_all"), &LineEdit::select_all); | 
					
						
							| 
									
										
										
										
											2017-12-17 15:40:44 -02:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("deselect"), &LineEdit::deselect); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_text", "text"), &LineEdit::set_text); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_text"), &LineEdit::get_text); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("get_draw_control_chars"), &LineEdit::get_draw_control_chars); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("set_draw_control_chars", "enable"), &LineEdit::set_draw_control_chars); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("set_text_direction", "direction"), &LineEdit::set_text_direction); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_text_direction"), &LineEdit::get_text_direction); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("set_opentype_feature", "tag", "value"), &LineEdit::set_opentype_feature); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_opentype_feature", "tag"), &LineEdit::get_opentype_feature); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("clear_opentype_features"), &LineEdit::clear_opentype_features); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("set_language", "language"), &LineEdit::set_language); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_language"), &LineEdit::get_language); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("set_structured_text_bidi_override", "parser"), &LineEdit::set_structured_text_bidi_override); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_structured_text_bidi_override"), &LineEdit::get_structured_text_bidi_override); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("set_structured_text_bidi_override_options", "args"), &LineEdit::set_structured_text_bidi_override_options); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_structured_text_bidi_override_options"), &LineEdit::get_structured_text_bidi_override_options); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_placeholder", "text"), &LineEdit::set_placeholder); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_placeholder"), &LineEdit::get_placeholder); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("set_placeholder_alpha", "alpha"), &LineEdit::set_placeholder_alpha); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_placeholder_alpha"), &LineEdit::get_placeholder_alpha); | 
					
						
							| 
									
										
										
										
											2017-09-10 15:37:49 +02:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_cursor_position", "position"), &LineEdit::set_cursor_position); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_cursor_position"), &LineEdit::get_cursor_position); | 
					
						
							| 
									
										
										
										
											2020-11-11 09:26:55 +01:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("get_scroll_offset"), &LineEdit::get_scroll_offset); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_expand_to_text_length", "enabled"), &LineEdit::set_expand_to_text_length); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_expand_to_text_length"), &LineEdit::get_expand_to_text_length); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("cursor_set_blink_enabled", "enabled"), &LineEdit::cursor_set_blink_enabled); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("cursor_get_blink_enabled"), &LineEdit::cursor_get_blink_enabled); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_mid_grapheme_caret_enabled", "enabled"), &LineEdit::set_mid_grapheme_caret_enabled); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_mid_grapheme_caret_enabled"), &LineEdit::get_mid_grapheme_caret_enabled); | 
					
						
							| 
									
										
										
										
											2020-06-21 19:15:57 +02:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("cursor_set_force_displayed", "enabled"), &LineEdit::cursor_set_force_displayed); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("cursor_get_force_displayed"), &LineEdit::cursor_get_force_displayed); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("cursor_set_blink_speed", "blink_speed"), &LineEdit::cursor_set_blink_speed); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("cursor_get_blink_speed"), &LineEdit::cursor_get_blink_speed); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("set_max_length", "chars"), &LineEdit::set_max_length); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_max_length"), &LineEdit::get_max_length); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("append_at_cursor", "text"), &LineEdit::append_at_cursor); | 
					
						
							| 
									
										
										
										
											2020-06-06 17:39:53 +02:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("delete_char_at_cursor"), &LineEdit::delete_char); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("delete_text", "from_column", "to_column"), &LineEdit::delete_text); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_editable", "enabled"), &LineEdit::set_editable); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("is_editable"), &LineEdit::is_editable); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("set_secret", "enabled"), &LineEdit::set_secret); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("is_secret"), &LineEdit::is_secret); | 
					
						
							| 
									
										
										
										
											2018-04-28 20:24:48 +02:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_secret_character", "character"), &LineEdit::set_secret_character); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_secret_character"), &LineEdit::get_secret_character); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("menu_option", "option"), &LineEdit::menu_option); | 
					
						
							| 
									
										
										
										
											2017-08-09 13:19:41 +02:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("get_menu"), &LineEdit::get_menu); | 
					
						
							| 
									
										
										
										
											2017-11-09 15:46:29 -05:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_context_menu_enabled", "enable"), &LineEdit::set_context_menu_enabled); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("is_context_menu_enabled"), &LineEdit::is_context_menu_enabled); | 
					
						
							| 
									
										
										
										
											2020-07-22 08:04:48 +02:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_virtual_keyboard_enabled", "enable"), &LineEdit::set_virtual_keyboard_enabled); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("is_virtual_keyboard_enabled"), &LineEdit::is_virtual_keyboard_enabled); | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_clear_button_enabled", "enable"), &LineEdit::set_clear_button_enabled); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("is_clear_button_enabled"), &LineEdit::is_clear_button_enabled); | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_shortcut_keys_enabled", "enable"), &LineEdit::set_shortcut_keys_enabled); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("is_shortcut_keys_enabled"), &LineEdit::is_shortcut_keys_enabled); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("set_selecting_enabled", "enable"), &LineEdit::set_selecting_enabled); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("is_selecting_enabled"), &LineEdit::is_selecting_enabled); | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 	ClassDB::bind_method(D_METHOD("set_right_icon", "icon"), &LineEdit::set_right_icon); | 
					
						
							|  |  |  | 	ClassDB::bind_method(D_METHOD("get_right_icon"), &LineEdit::get_right_icon); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-09 16:39:43 +01:00
										 |  |  | 	ADD_SIGNAL(MethodInfo("text_changed", PropertyInfo(Variant::STRING, "new_text"))); | 
					
						
							| 
									
										
										
										
											2020-01-10 21:07:00 +01:00
										 |  |  | 	ADD_SIGNAL(MethodInfo("text_change_rejected")); | 
					
						
							| 
									
										
										
										
											2018-01-09 16:39:43 +01:00
										 |  |  | 	ADD_SIGNAL(MethodInfo("text_entered", PropertyInfo(Variant::STRING, "new_text"))); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-20 17:45:01 +02:00
										 |  |  | 	BIND_ENUM_CONSTANT(ALIGN_LEFT); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(ALIGN_CENTER); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(ALIGN_RIGHT); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(ALIGN_FILL); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_CUT); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_COPY); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_PASTE); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_CLEAR); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_SELECT_ALL); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_UNDO); | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 	BIND_ENUM_CONSTANT(MENU_REDO); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	BIND_ENUM_CONSTANT(MENU_DIR_INHERITED); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_DIR_AUTO); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_DIR_LTR); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_DIR_RTL); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_DISPLAY_UCC); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_LRM); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_RLM); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_LRE); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_RLE); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_LRO); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_RLO); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_PDF); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_ALM); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_LRI); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_RLI); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_FSI); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_PDI); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_ZWJ); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_ZWNJ); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_WJ); | 
					
						
							|  |  |  | 	BIND_ENUM_CONSTANT(MENU_INSERT_SHY); | 
					
						
							| 
									
										
										
										
											2017-08-20 17:45:01 +02:00
										 |  |  | 	BIND_ENUM_CONSTANT(MENU_MAX); | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-08 11:30:02 -03:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::STRING, "text"), "set_text", "get_text"); | 
					
						
							|  |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::INT, "align", PROPERTY_HINT_ENUM, "Left,Center,Right,Fill"), "set_align", "get_align"); | 
					
						
							|  |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::INT, "max_length"), "set_max_length", "get_max_length"); | 
					
						
							|  |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "editable"), "set_editable", "is_editable"); | 
					
						
							|  |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "secret"), "set_secret", "is_secret"); | 
					
						
							|  |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::STRING, "secret_character"), "set_secret_character", "get_secret_character"); | 
					
						
							|  |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "expand_to_text_length"), "set_expand_to_text_length", "get_expand_to_text_length"); | 
					
						
							| 
									
										
										
										
											2018-01-12 00:35:12 +02:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "context_menu_enabled"), "set_context_menu_enabled", "is_context_menu_enabled"); | 
					
						
							| 
									
										
										
										
											2020-07-22 08:04:48 +02:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "virtual_keyboard_enabled"), "set_virtual_keyboard_enabled", "is_virtual_keyboard_enabled"); | 
					
						
							| 
									
										
										
										
											2018-07-26 13:45:38 +02:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "clear_button_enabled"), "set_clear_button_enabled", "is_clear_button_enabled"); | 
					
						
							| 
									
										
										
										
											2019-08-07 17:09:46 -07:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "shortcut_keys_enabled"), "set_shortcut_keys_enabled", "is_shortcut_keys_enabled"); | 
					
						
							|  |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "selecting_enabled"), "set_selecting_enabled", "is_selecting_enabled"); | 
					
						
							| 
									
										
										
										
											2019-09-08 22:46:57 -03:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "right_icon", PROPERTY_HINT_RESOURCE_TYPE, "Texture"), "set_right_icon", "get_right_icon"); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::INT, "text_direction", PROPERTY_HINT_ENUM, "Auto,LTR,RTL,Inherited"), "set_text_direction", "get_text_direction"); | 
					
						
							|  |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::STRING, "language"), "set_language", "get_language"); | 
					
						
							|  |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "draw_control_chars"), "set_draw_control_chars", "get_draw_control_chars"); | 
					
						
							|  |  |  | 	ADD_GROUP("Structured Text", "structured_text_"); | 
					
						
							|  |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::INT, "structured_text_bidi_override", PROPERTY_HINT_ENUM, "Default,URI,File,Email,List,None,Custom"), "set_structured_text_bidi_override", "get_structured_text_bidi_override"); | 
					
						
							|  |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "structured_text_bidi_override_options"), "set_structured_text_bidi_override_options", "get_structured_text_bidi_override_options"); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	ADD_GROUP("Placeholder", "placeholder_"); | 
					
						
							| 
									
										
										
										
											2018-11-08 11:30:02 -03:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::STRING, "placeholder_text"), "set_placeholder", "get_placeholder"); | 
					
						
							| 
									
										
										
											
												Variant: Added 64-bit packed arrays, renamed Variant::REAL to FLOAT.
- Renames PackedIntArray to PackedInt32Array.
- Renames PackedFloatArray to PackedFloat32Array.
- Adds PackedInt64Array and PackedFloat64Array.
- Renames Variant::REAL to Variant::FLOAT for consistency.
Packed arrays are for storing large amount of data and creating stuff like
meshes, buffers. textures, etc. Forcing them to be 64 is a huge waste of
memory. That said, many users requested the ability to have 64 bits packed
arrays for their games, so this is just an optional added type.
For Variant, the float datatype is always 64 bits, and exposed as `float`.
We still have `real_t` which is the datatype that can change from 32 to 64
bits depending on a compile flag (not entirely working right now, but that's
the idea). It affects math related datatypes and code only.
Neither Variant nor PackedArray make use of real_t, which is only intended
for math precision, so the term is removed from there to keep only float.
											
										 
											2020-02-24 15:20:53 -03:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::FLOAT, "placeholder_alpha", PROPERTY_HINT_RANGE, "0,1,0.001"), "set_placeholder_alpha", "get_placeholder_alpha"); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	ADD_GROUP("Caret", "caret_"); | 
					
						
							| 
									
										
										
										
											2017-02-12 01:11:37 +01:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "caret_blink"), "cursor_set_blink_enabled", "cursor_get_blink_enabled"); | 
					
						
							| 
									
										
										
											
												Variant: Added 64-bit packed arrays, renamed Variant::REAL to FLOAT.
- Renames PackedIntArray to PackedInt32Array.
- Renames PackedFloatArray to PackedFloat32Array.
- Adds PackedInt64Array and PackedFloat64Array.
- Renames Variant::REAL to Variant::FLOAT for consistency.
Packed arrays are for storing large amount of data and creating stuff like
meshes, buffers. textures, etc. Forcing them to be 64 is a huge waste of
memory. That said, many users requested the ability to have 64 bits packed
arrays for their games, so this is just an optional added type.
For Variant, the float datatype is always 64 bits, and exposed as `float`.
We still have `real_t` which is the datatype that can change from 32 to 64
bits depending on a compile flag (not entirely working right now, but that's
the idea). It affects math related datatypes and code only.
Neither Variant nor PackedArray make use of real_t, which is only intended
for math precision, so the term is removed from there to keep only float.
											
										 
											2020-02-24 15:20:53 -03:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::FLOAT, "caret_blink_speed", PROPERTY_HINT_RANGE, "0.1,10,0.01"), "cursor_set_blink_speed", "cursor_get_blink_speed"); | 
					
						
							| 
									
										
										
										
											2018-01-12 00:35:12 +02:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::INT, "caret_position"), "set_cursor_position", "get_cursor_position"); | 
					
						
							| 
									
										
										
										
											2020-06-21 19:15:57 +02:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "caret_force_displayed"), "cursor_set_force_displayed", "cursor_get_force_displayed"); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "caret_mid_grapheme"), "set_mid_grapheme_caret_enabled", "get_mid_grapheme_caret_enabled"); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | LineEdit::LineEdit() { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	text_rid = TS->create_shaped_text(); | 
					
						
							| 
									
										
										
										
											2017-10-29 23:14:33 +00:00
										 |  |  | 	_create_undo_state(); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-20 10:48:14 +01:00
										 |  |  | 	clear_button_status.press_attempt = false; | 
					
						
							|  |  |  | 	clear_button_status.pressing_inside = false; | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-17 15:40:44 -02:00
										 |  |  | 	deselect(); | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	set_focus_mode(FOCUS_ALL); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 	set_default_cursor_shape(CURSOR_IBEAM); | 
					
						
							| 
									
										
										
										
											2017-01-08 19:54:19 -03:00
										 |  |  | 	set_mouse_filter(MOUSE_FILTER_STOP); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-21 00:05:52 +01:00
										 |  |  | 	caret_blink_timer = memnew(Timer); | 
					
						
							|  |  |  | 	add_child(caret_blink_timer); | 
					
						
							|  |  |  | 	caret_blink_timer->set_wait_time(0.65); | 
					
						
							| 
									
										
										
										
											2020-02-21 18:28:45 +01:00
										 |  |  | 	caret_blink_timer->connect("timeout", callable_mp(this, &LineEdit::_toggle_draw_caret)); | 
					
						
							| 
									
										
										
										
											2016-06-21 00:05:52 +01:00
										 |  |  | 	cursor_set_blink_enabled(false); | 
					
						
							| 
									
										
										
										
											2016-03-09 00:00:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-05 16:44:50 +01:00
										 |  |  | 	menu = memnew(PopupMenu); | 
					
						
							| 
									
										
										
										
											2016-05-16 20:25:17 -03:00
										 |  |  | 	add_child(menu); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	menu_dir = memnew(PopupMenu); | 
					
						
							|  |  |  | 	menu_dir->set_name("DirMenu"); | 
					
						
							|  |  |  | 	menu_dir->add_radio_check_item(RTR("Same as layout direction"), MENU_DIR_INHERITED); | 
					
						
							|  |  |  | 	menu_dir->add_radio_check_item(RTR("Auto-detect direction"), MENU_DIR_AUTO); | 
					
						
							|  |  |  | 	menu_dir->add_radio_check_item(RTR("Left-to-right"), MENU_DIR_LTR); | 
					
						
							|  |  |  | 	menu_dir->add_radio_check_item(RTR("Right-to-left"), MENU_DIR_RTL); | 
					
						
							|  |  |  | 	menu_dir->set_item_checked(menu_dir->get_item_index(MENU_DIR_INHERITED), true); | 
					
						
							|  |  |  | 	menu->add_child(menu_dir); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	menu_ctl = memnew(PopupMenu); | 
					
						
							|  |  |  | 	menu_ctl->set_name("CTLMenu"); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Left-to-right mark (LRM)"), MENU_INSERT_LRM); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Right-to-left mark (RLM)"), MENU_INSERT_RLM); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Start of left-to-right embedding (LRE)"), MENU_INSERT_LRE); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Start of right-to-left embedding (RLE)"), MENU_INSERT_RLE); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Start of left-to-right override (LRO)"), MENU_INSERT_LRO); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Start of right-to-left override (RLO)"), MENU_INSERT_RLO); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Pop direction formatting (PDF)"), MENU_INSERT_PDF); | 
					
						
							|  |  |  | 	menu_ctl->add_separator(); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Arabic letter mark (ALM)"), MENU_INSERT_ALM); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Left-to-right isolate (LRI)"), MENU_INSERT_LRI); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Right-to-left isolate (RLI)"), MENU_INSERT_RLI); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("First strong isolate (FSI)"), MENU_INSERT_FSI); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Pop direction isolate (PDI)"), MENU_INSERT_PDI); | 
					
						
							|  |  |  | 	menu_ctl->add_separator(); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Zero width joiner (ZWJ)"), MENU_INSERT_ZWJ); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Zero width non-joiner (ZWNJ)"), MENU_INSERT_ZWNJ); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Word joiner (WJ)"), MENU_INSERT_WJ); | 
					
						
							|  |  |  | 	menu_ctl->add_item(RTR("Soft hyphen (SHY)"), MENU_INSERT_SHY); | 
					
						
							|  |  |  | 	menu->add_child(menu_ctl); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	set_editable(true); // Initialise to opposite first, so we get past the early-out in set_editable.
 | 
					
						
							| 
									
										
										
										
											2020-02-21 18:28:45 +01:00
										 |  |  | 	menu->connect("id_pressed", callable_mp(this, &LineEdit::menu_option)); | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	menu_dir->connect("id_pressed", callable_mp(this, &LineEdit::menu_option)); | 
					
						
							|  |  |  | 	menu_ctl->connect("id_pressed", callable_mp(this, &LineEdit::menu_option)); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | LineEdit::~LineEdit() { | 
					
						
							| 
									
										
										
										
											2020-09-09 16:00:32 +03:00
										 |  |  | 	TS->free(text_rid); | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | } |