|  | @@ -44,7 +44,7 @@
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  #ifdef TOOLS_ENABLED
 |  |  #ifdef TOOLS_ENABLED
 | 
											
												
													
														|  |  #include "editor/plugins/control_editor_plugin.h"
 |  |  #include "editor/plugins/control_editor_plugin.h"
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // TOOLS_ENABLED
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // Editor plugin interoperability.
 |  |  // Editor plugin interoperability.
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -140,14 +140,6 @@ void Control::_edit_set_rect(const Rect2 &p_edit_rect) {
 | 
											
												
													
														|  |  	set_size(p_edit_rect.size.snappedf(1), ControlEditorToolbar::get_singleton()->is_anchors_mode_enabled());
 |  |  	set_size(p_edit_rect.size.snappedf(1), ControlEditorToolbar::get_singleton()->is_anchors_mode_enabled());
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -Rect2 Control::_edit_get_rect() const {
 |  | 
 | 
											
												
													
														|  | -	return Rect2(Point2(), get_size());
 |  | 
 | 
											
												
													
														|  | -}
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -bool Control::_edit_use_rect() const {
 |  | 
 | 
											
												
													
														|  | -	return true;
 |  | 
 | 
											
												
													
														|  | -}
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  |  void Control::_edit_set_rotation(real_t p_rotation) {
 |  |  void Control::_edit_set_rotation(real_t p_rotation) {
 | 
											
												
													
														|  |  	set_rotation(p_rotation);
 |  |  	set_rotation(p_rotation);
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
										
											
												
													
														|  | @@ -178,7 +170,17 @@ bool Control::_edit_use_pivot() const {
 | 
											
												
													
														|  |  Size2 Control::_edit_get_minimum_size() const {
 |  |  Size2 Control::_edit_get_minimum_size() const {
 | 
											
												
													
														|  |  	return get_combined_minimum_size();
 |  |  	return get_combined_minimum_size();
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // TOOLS_ENABLED
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +#ifdef DEBUG_ENABLED
 | 
											
												
													
														|  | 
 |  | +Rect2 Control::_edit_get_rect() const {
 | 
											
												
													
														|  | 
 |  | +	return Rect2(Point2(), get_size());
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +bool Control::_edit_use_rect() const {
 | 
											
												
													
														|  | 
 |  | +	return true;
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +#endif // DEBUG_ENABLED
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  void Control::reparent(Node *p_parent, bool p_keep_global_transform) {
 |  |  void Control::reparent(Node *p_parent, bool p_keep_global_transform) {
 | 
											
												
													
														|  |  	ERR_MAIN_THREAD_GUARD;
 |  |  	ERR_MAIN_THREAD_GUARD;
 | 
											
										
											
												
													
														|  | @@ -239,7 +241,7 @@ void Control::get_argument_options(const StringName &p_function, int p_idx, List
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  	CanvasItem::get_argument_options(p_function, p_idx, r_options);
 |  |  	CanvasItem::get_argument_options(p_function, p_idx, r_options);
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // TOOLS_ENABLED
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  PackedStringArray Control::get_configuration_warnings() const {
 |  |  PackedStringArray Control::get_configuration_warnings() const {
 | 
											
												
													
														|  |  	ERR_READ_THREAD_GUARD_V(PackedStringArray());
 |  |  	ERR_READ_THREAD_GUARD_V(PackedStringArray());
 | 
											
										
											
												
													
														|  | @@ -663,7 +665,7 @@ Rect2 Control::get_parent_anchorable_rect() const {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  #else
 |  |  #else
 | 
											
												
													
														|  |  		parent_rect = get_viewport()->get_visible_rect();
 |  |  		parent_rect = get_viewport()->get_visible_rect();
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // TOOLS_ENABLED
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	return parent_rect;
 |  |  	return parent_rect;
 | 
											
										
											
												
													
														|  | @@ -1396,7 +1398,7 @@ void Control::set_position(const Point2 &p_point, bool p_keep_offsets) {
 | 
											
												
													
														|  |  		data.pos_cache = p_point;
 |  |  		data.pos_cache = p_point;
 | 
											
												
													
														|  |  		return;
 |  |  		return;
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // TOOLS_ENABLED
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	if (p_keep_offsets) {
 |  |  	if (p_keep_offsets) {
 | 
											
												
													
														|  |  		_compute_anchors(Rect2(p_point, data.size_cache), data.offset, data.anchor);
 |  |  		_compute_anchors(Rect2(p_point, data.size_cache), data.offset, data.anchor);
 | 
											
										
											
												
													
														|  | @@ -1440,7 +1442,7 @@ void Control::_set_size(const Size2 &p_size) {
 | 
											
												
													
														|  |  	if (data.size_warning && (data.anchor[SIDE_LEFT] != data.anchor[SIDE_RIGHT] || data.anchor[SIDE_TOP] != data.anchor[SIDE_BOTTOM])) {
 |  |  	if (data.size_warning && (data.anchor[SIDE_LEFT] != data.anchor[SIDE_RIGHT] || data.anchor[SIDE_TOP] != data.anchor[SIDE_BOTTOM])) {
 | 
											
												
													
														|  |  		WARN_PRINT("Nodes with non-equal opposite anchors will have their size overridden after _ready(). \nIf you want to set size, change the anchors or consider using set_deferred().");
 |  |  		WARN_PRINT("Nodes with non-equal opposite anchors will have their size overridden after _ready(). \nIf you want to set size, change the anchors or consider using set_deferred().");
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // DEBUG_ENABLED
 | 
											
												
													
														|  |  	set_size(p_size);
 |  |  	set_size(p_size);
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -1462,7 +1464,7 @@ void Control::set_size(const Size2 &p_size, bool p_keep_offsets) {
 | 
											
												
													
														|  |  		data.size_cache = new_size;
 |  |  		data.size_cache = new_size;
 | 
											
												
													
														|  |  		return;
 |  |  		return;
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // TOOLS_ENABLED
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	if (p_keep_offsets) {
 |  |  	if (p_keep_offsets) {
 | 
											
												
													
														|  |  		_compute_anchors(Rect2(data.pos_cache, new_size), data.offset, data.anchor);
 |  |  		_compute_anchors(Rect2(data.pos_cache, new_size), data.offset, data.anchor);
 | 
											
										
											
												
													
														|  | @@ -2745,7 +2747,7 @@ Variant Control::get_theme_item(Theme::DataType p_data_type, const StringName &p
 | 
											
												
													
														|  |  Ref<Texture2D> Control::get_editor_theme_icon(const StringName &p_name) const {
 |  |  Ref<Texture2D> Control::get_editor_theme_icon(const StringName &p_name) const {
 | 
											
												
													
														|  |  	return get_theme_icon(p_name, SNAME("EditorIcons"));
 |  |  	return get_theme_icon(p_name, SNAME("EditorIcons"));
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // TOOLS_ENABLED
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  bool Control::has_theme_icon(const StringName &p_name, const StringName &p_theme_type) const {
 |  |  bool Control::has_theme_icon(const StringName &p_name, const StringName &p_theme_type) const {
 | 
											
												
													
														|  |  	ERR_READ_THREAD_GUARD_V(false);
 |  |  	ERR_READ_THREAD_GUARD_V(false);
 | 
											
										
											
												
													
														|  | @@ -3087,7 +3089,7 @@ bool Control::is_layout_rtl() const {
 | 
											
												
													
														|  |  				const_cast<Control *>(this)->data.is_rtl = true;
 |  |  				const_cast<Control *>(this)->data.is_rtl = true;
 | 
											
												
													
														|  |  				return data.is_rtl;
 |  |  				return data.is_rtl;
 | 
											
												
													
														|  |  			}
 |  |  			}
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // TOOLS_ENABLED
 | 
											
												
													
														|  |  			Node *parent_node = get_parent();
 |  |  			Node *parent_node = get_parent();
 | 
											
												
													
														|  |  			while (parent_node) {
 |  |  			while (parent_node) {
 | 
											
												
													
														|  |  				Control *parent_control = Object::cast_to<Control>(parent_node);
 |  |  				Control *parent_control = Object::cast_to<Control>(parent_node);
 | 
											
										
											
												
													
														|  | @@ -3162,7 +3164,7 @@ bool Control::is_auto_translating() const {
 | 
											
												
													
														|  |  	ERR_READ_THREAD_GUARD_V(false);
 |  |  	ERR_READ_THREAD_GUARD_V(false);
 | 
											
												
													
														|  |  	return can_auto_translate();
 |  |  	return can_auto_translate();
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // DISABLE_DEPRECATED
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  void Control::set_tooltip_auto_translate_mode(AutoTranslateMode p_mode) {
 |  |  void Control::set_tooltip_auto_translate_mode(AutoTranslateMode p_mode) {
 | 
											
												
													
														|  |  	ERR_MAIN_THREAD_GUARD;
 |  |  	ERR_MAIN_THREAD_GUARD;
 | 
											
										
											
												
													
														|  | @@ -3215,7 +3217,7 @@ void Control::_notification(int p_notification) {
 | 
											
												
													
														|  |  		case NOTIFICATION_EDITOR_POST_SAVE: {
 |  |  		case NOTIFICATION_EDITOR_POST_SAVE: {
 | 
											
												
													
														|  |  			saving = false;
 |  |  			saving = false;
 | 
											
												
													
														|  |  		} break;
 |  |  		} break;
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // TOOLS_ENABLED
 | 
											
												
													
														|  |  		case NOTIFICATION_POSTINITIALIZE: {
 |  |  		case NOTIFICATION_POSTINITIALIZE: {
 | 
											
												
													
														|  |  			data.initialized = true;
 |  |  			data.initialized = true;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
										
											
												
													
														|  | @@ -3261,7 +3263,7 @@ void Control::_notification(int p_notification) {
 | 
											
												
													
														|  |  		case NOTIFICATION_READY: {
 |  |  		case NOTIFICATION_READY: {
 | 
											
												
													
														|  |  #ifdef DEBUG_ENABLED
 |  |  #ifdef DEBUG_ENABLED
 | 
											
												
													
														|  |  			connect(SceneStringName(ready), callable_mp(this, &Control::_clear_size_warning), CONNECT_DEFERRED | CONNECT_ONE_SHOT);
 |  |  			connect(SceneStringName(ready), callable_mp(this, &Control::_clear_size_warning), CONNECT_DEFERRED | CONNECT_ONE_SHOT);
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // DEBUG_ENABLED
 | 
											
												
													
														|  |  		} break;
 |  |  		} break;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  		case NOTIFICATION_ENTER_CANVAS: {
 |  |  		case NOTIFICATION_ENTER_CANVAS: {
 | 
											
										
											
												
													
														|  | @@ -3573,7 +3575,7 @@ void Control::_bind_methods() {
 | 
											
												
													
														|  |  #ifndef DISABLE_DEPRECATED
 |  |  #ifndef DISABLE_DEPRECATED
 | 
											
												
													
														|  |  	ClassDB::bind_method(D_METHOD("set_auto_translate", "enable"), &Control::set_auto_translate);
 |  |  	ClassDB::bind_method(D_METHOD("set_auto_translate", "enable"), &Control::set_auto_translate);
 | 
											
												
													
														|  |  	ClassDB::bind_method(D_METHOD("is_auto_translating"), &Control::is_auto_translating);
 |  |  	ClassDB::bind_method(D_METHOD("is_auto_translating"), &Control::is_auto_translating);
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // DISABLE_DEPRECATED
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	ClassDB::bind_method(D_METHOD("set_localize_numeral_system", "enable"), &Control::set_localize_numeral_system);
 |  |  	ClassDB::bind_method(D_METHOD("set_localize_numeral_system", "enable"), &Control::set_localize_numeral_system);
 | 
											
												
													
														|  |  	ClassDB::bind_method(D_METHOD("is_localizing_numeral_system"), &Control::is_localizing_numeral_system);
 |  |  	ClassDB::bind_method(D_METHOD("is_localizing_numeral_system"), &Control::is_localizing_numeral_system);
 | 
											
										
											
												
													
														|  | @@ -3628,7 +3630,7 @@ void Control::_bind_methods() {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  #ifndef DISABLE_DEPRECATED
 |  |  #ifndef DISABLE_DEPRECATED
 | 
											
												
													
														|  |  	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "auto_translate", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NONE), "set_auto_translate", "is_auto_translating");
 |  |  	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "auto_translate", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NONE), "set_auto_translate", "is_auto_translating");
 | 
											
												
													
														|  | -#endif
 |  | 
 | 
											
												
													
														|  | 
 |  | +#endif // DISABLE_DEPRECATED
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	ADD_GROUP("Tooltip", "tooltip_");
 |  |  	ADD_GROUP("Tooltip", "tooltip_");
 | 
											
												
													
														|  |  	ADD_PROPERTY(PropertyInfo(Variant::STRING, "tooltip_text", PROPERTY_HINT_MULTILINE_TEXT), "set_tooltip_text", "get_tooltip_text");
 |  |  	ADD_PROPERTY(PropertyInfo(Variant::STRING, "tooltip_text", PROPERTY_HINT_MULTILINE_TEXT), "set_tooltip_text", "get_tooltip_text");
 |