diff options
| -rw-r--r-- | core/math/expression.cpp | 4 | ||||
| -rw-r--r-- | doc/classes/Node.xml | 2 | ||||
| -rw-r--r-- | doc/classes/TextureButton.xml | 10 | ||||
| -rw-r--r-- | doc/classes/bool.xml | 2 | ||||
| -rw-r--r-- | editor/editor_help.cpp | 2 | ||||
| -rw-r--r-- | scene/gui/texture_button.cpp | 100 | ||||
| -rw-r--r-- | scene/gui/texture_button.h | 8 | ||||
| -rw-r--r-- | servers/rendering/shader_language.cpp | 51 | ||||
| -rw-r--r-- | tests/core/math/test_expression.h | 2 | 
9 files changed, 97 insertions, 84 deletions
| diff --git a/core/math/expression.cpp b/core/math/expression.cpp index b447d09887..0ddac9744e 100644 --- a/core/math/expression.cpp +++ b/core/math/expression.cpp @@ -361,6 +361,7 @@ Error Expression::_get_token(Token &r_token) {  									is_float = true;  								} else if (c == 'e') {  									reading = READING_EXP; +									is_float = true;  								} else {  									reading = READING_DONE;  								} @@ -397,9 +398,6 @@ Error Expression::_get_token(Token &r_token) {  									exp_beg = true;  								} else if ((c == '-' || c == '+') && !exp_sign && !exp_beg) { -									if (c == '-') { -										is_float = true; -									}  									exp_sign = true;  								} else { diff --git a/doc/classes/Node.xml b/doc/classes/Node.xml index 47be5695a0..d041d20656 100644 --- a/doc/classes/Node.xml +++ b/doc/classes/Node.xml @@ -79,7 +79,7 @@  			<return type="void" />  			<description>  				Called when the node is "ready", i.e. when both the node and its children have entered the scene tree. If the node has children, their [method _ready] callbacks get triggered first, and the parent node will receive the ready notification afterwards. -				Corresponds to the [constant NOTIFICATION_READY] notification in [method Object._notification]. See also the [code]onready[/code] keyword for variables. +				Corresponds to the [constant NOTIFICATION_READY] notification in [method Object._notification]. See also the [code]@onready[/code] annotation for variables.  				Usually used for initialization. For even earlier initialization, [method Object._init] may be used. See also [method _enter_tree].  				[b]Note:[/b] [method _ready] may be called only once for each node. After removing a node from the scene tree and adding again, [code]_ready[/code] will not be called for the second time. This can be bypassed with requesting another call with [method request_ready], which may be called anywhere before adding the node again.  			</description> diff --git a/doc/classes/TextureButton.xml b/doc/classes/TextureButton.xml index 476ab2d1bf..5f081b95f5 100644 --- a/doc/classes/TextureButton.xml +++ b/doc/classes/TextureButton.xml @@ -12,17 +12,17 @@  		<link title="3D Voxel Demo">https://godotengine.org/asset-library/asset/676</link>  	</tutorials>  	<members> -		<member name="expand" type="bool" setter="set_expand" getter="get_expand" default="false"> -			If [code]true[/code], the texture stretches to the edges of the node's bounding rectangle using the [member stretch_mode]. If [code]false[/code], the texture will not scale with the node. -		</member>  		<member name="flip_h" type="bool" setter="set_flip_h" getter="is_flipped_h" default="false">  			If [code]true[/code], texture is flipped horizontally.  		</member>  		<member name="flip_v" type="bool" setter="set_flip_v" getter="is_flipped_v" default="false">  			If [code]true[/code], texture is flipped vertically.  		</member> -		<member name="stretch_mode" type="int" setter="set_stretch_mode" getter="get_stretch_mode" enum="TextureButton.StretchMode" default="0"> -			Controls the texture's behavior when you resize the node's bounding rectangle, [b]only if[/b] [member expand] is [code]true[/code]. Set it to one of the [enum StretchMode] constants. See the constants to learn more. +		<member name="ignore_texture_size" type="bool" setter="set_ignore_texture_size" getter="get_ignore_texture_size" default="false"> +			If [code]true[/code], the size of the texture won't be considered for minimum size calculation, so the [TextureButton] can be shrunk down past the texture size. +		</member> +		<member name="stretch_mode" type="int" setter="set_stretch_mode" getter="get_stretch_mode" enum="TextureButton.StretchMode" default="2"> +			Controls the texture's behavior when you resize the node's bounding rectangle. See the [enum StretchMode] constants for available options.  		</member>  		<member name="texture_click_mask" type="BitMap" setter="set_click_mask" getter="get_click_mask">  			Pure black and white [BitMap] image to use for click detection. On the mask, white pixels represent the button's clickable area. Use it to create buttons with curved shapes. diff --git a/doc/classes/bool.xml b/doc/classes/bool.xml index 49f2d2dd7f..243d19d94f 100644 --- a/doc/classes/bool.xml +++ b/doc/classes/bool.xml @@ -52,7 +52,7 @@  		[codeblocks]  		[gdscript]  		var _can_shoot = true -		onready var _cool_down = $CoolDownTimer +		@onready var _cool_down = $CoolDownTimer  		func shoot():  		    if _can_shoot and Input.is_action_pressed("shoot"): diff --git a/editor/editor_help.cpp b/editor/editor_help.cpp index dfc95fb676..96c0f3a209 100644 --- a/editor/editor_help.cpp +++ b/editor/editor_help.cpp @@ -2007,7 +2007,7 @@ FindBar::FindBar() {  	hide_button = memnew(TextureButton);  	add_child(hide_button);  	hide_button->set_focus_mode(FOCUS_NONE); -	hide_button->set_expand(true); +	hide_button->set_ignore_texture_size(true);  	hide_button->set_stretch_mode(TextureButton::STRETCH_KEEP_CENTERED);  	hide_button->connect("pressed", callable_mp(this, &FindBar::_hide_bar));  } diff --git a/scene/gui/texture_button.cpp b/scene/gui/texture_button.cpp index 89a17ae854..26acfaaa70 100644 --- a/scene/gui/texture_button.cpp +++ b/scene/gui/texture_button.cpp @@ -37,7 +37,7 @@  Size2 TextureButton::get_minimum_size() const {  	Size2 rscale = Control::get_minimum_size(); -	if (!expand) { +	if (!ignore_texture_size) {  		if (normal.is_null()) {  			if (pressed.is_null()) {  				if (hover.is_null()) { @@ -182,50 +182,48 @@ void TextureButton::_notification(int p_what) {  				size = texdraw->get_size();  				_texture_region = Rect2(Point2(), texdraw->get_size());  				_tile = false; -				if (expand) { -					switch (stretch_mode) { -						case STRETCH_KEEP: -							size = texdraw->get_size(); -							break; -						case STRETCH_SCALE: -							size = get_size(); -							break; -						case STRETCH_TILE: -							size = get_size(); -							_tile = true; -							break; -						case STRETCH_KEEP_CENTERED: -							ofs = (get_size() - texdraw->get_size()) / 2; -							size = texdraw->get_size(); -							break; -						case STRETCH_KEEP_ASPECT_CENTERED: -						case STRETCH_KEEP_ASPECT: { -							Size2 _size = get_size(); -							float tex_width = texdraw->get_width() * _size.height / texdraw->get_height(); -							float tex_height = _size.height; - -							if (tex_width > _size.width) { -								tex_width = _size.width; -								tex_height = texdraw->get_height() * tex_width / texdraw->get_width(); -							} +				switch (stretch_mode) { +					case STRETCH_KEEP: +						size = texdraw->get_size(); +						break; +					case STRETCH_SCALE: +						size = get_size(); +						break; +					case STRETCH_TILE: +						size = get_size(); +						_tile = true; +						break; +					case STRETCH_KEEP_CENTERED: +						ofs = (get_size() - texdraw->get_size()) / 2; +						size = texdraw->get_size(); +						break; +					case STRETCH_KEEP_ASPECT_CENTERED: +					case STRETCH_KEEP_ASPECT: { +						Size2 _size = get_size(); +						float tex_width = texdraw->get_width() * _size.height / texdraw->get_height(); +						float tex_height = _size.height; + +						if (tex_width > _size.width) { +							tex_width = _size.width; +							tex_height = texdraw->get_height() * tex_width / texdraw->get_width(); +						} -							if (stretch_mode == STRETCH_KEEP_ASPECT_CENTERED) { -								ofs.x = (_size.width - tex_width) / 2; -								ofs.y = (_size.height - tex_height) / 2; -							} -							size.width = tex_width; -							size.height = tex_height; -						} break; -						case STRETCH_KEEP_ASPECT_COVERED: { -							size = get_size(); -							Size2 tex_size = texdraw->get_size(); -							Size2 scale_size(size.width / tex_size.width, size.height / tex_size.height); -							float scale = scale_size.width > scale_size.height ? scale_size.width : scale_size.height; -							Size2 scaled_tex_size = tex_size * scale; -							Point2 ofs2 = ((scaled_tex_size - size) / scale).abs() / 2.0f; -							_texture_region = Rect2(ofs2, size / scale); -						} break; -					} +						if (stretch_mode == STRETCH_KEEP_ASPECT_CENTERED) { +							ofs.x = (_size.width - tex_width) / 2; +							ofs.y = (_size.height - tex_height) / 2; +						} +						size.width = tex_width; +						size.height = tex_height; +					} break; +					case STRETCH_KEEP_ASPECT_COVERED: { +						size = get_size(); +						Size2 tex_size = texdraw->get_size(); +						Size2 scale_size(size.width / tex_size.width, size.height / tex_size.height); +						float scale = scale_size.width > scale_size.height ? scale_size.width : scale_size.height; +						Size2 scaled_tex_size = tex_size * scale; +						Point2 ofs2 = ((scaled_tex_size - size) / scale).abs() / 2.0f; +						_texture_region = Rect2(ofs2, size / scale); +					} break;  				}  				_position_rect = Rect2(ofs, size); @@ -258,7 +256,7 @@ void TextureButton::_bind_methods() {  	ClassDB::bind_method(D_METHOD("set_disabled_texture", "texture"), &TextureButton::set_disabled_texture);  	ClassDB::bind_method(D_METHOD("set_focused_texture", "texture"), &TextureButton::set_focused_texture);  	ClassDB::bind_method(D_METHOD("set_click_mask", "mask"), &TextureButton::set_click_mask); -	ClassDB::bind_method(D_METHOD("set_expand", "expand"), &TextureButton::set_expand); +	ClassDB::bind_method(D_METHOD("set_ignore_texture_size", "ignore"), &TextureButton::set_ignore_texture_size);  	ClassDB::bind_method(D_METHOD("set_stretch_mode", "mode"), &TextureButton::set_stretch_mode);  	ClassDB::bind_method(D_METHOD("set_flip_h", "enable"), &TextureButton::set_flip_h);  	ClassDB::bind_method(D_METHOD("is_flipped_h"), &TextureButton::is_flipped_h); @@ -271,7 +269,7 @@ void TextureButton::_bind_methods() {  	ClassDB::bind_method(D_METHOD("get_disabled_texture"), &TextureButton::get_disabled_texture);  	ClassDB::bind_method(D_METHOD("get_focused_texture"), &TextureButton::get_focused_texture);  	ClassDB::bind_method(D_METHOD("get_click_mask"), &TextureButton::get_click_mask); -	ClassDB::bind_method(D_METHOD("get_expand"), &TextureButton::get_expand); +	ClassDB::bind_method(D_METHOD("get_ignore_texture_size"), &TextureButton::get_ignore_texture_size);  	ClassDB::bind_method(D_METHOD("get_stretch_mode"), &TextureButton::get_stretch_mode);  	ADD_GROUP("Textures", "texture_"); @@ -281,7 +279,7 @@ void TextureButton::_bind_methods() {  	ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "texture_disabled", PROPERTY_HINT_RESOURCE_TYPE, "Texture2D"), "set_disabled_texture", "get_disabled_texture");  	ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "texture_focused", PROPERTY_HINT_RESOURCE_TYPE, "Texture2D"), "set_focused_texture", "get_focused_texture");  	ADD_PROPERTY(PropertyInfo(Variant::OBJECT, "texture_click_mask", PROPERTY_HINT_RESOURCE_TYPE, "BitMap"), "set_click_mask", "get_click_mask"); -	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "expand", PROPERTY_HINT_RESOURCE_TYPE, "bool"), "set_expand", "get_expand"); +	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "ignore_texture_size", PROPERTY_HINT_RESOURCE_TYPE, "bool"), "set_ignore_texture_size", "get_ignore_texture_size");  	ADD_PROPERTY(PropertyInfo(Variant::INT, "stretch_mode", PROPERTY_HINT_ENUM, "Scale,Tile,Keep,Keep Centered,Keep Aspect,Keep Aspect Centered,Keep Aspect Covered"), "set_stretch_mode", "get_stretch_mode");  	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "flip_h", PROPERTY_HINT_RESOURCE_TYPE, "bool"), "set_flip_h", "is_flipped_h");  	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "flip_v", PROPERTY_HINT_RESOURCE_TYPE, "bool"), "set_flip_v", "is_flipped_v"); @@ -352,12 +350,12 @@ void TextureButton::set_focused_texture(const Ref<Texture2D> &p_focused) {  	focused = p_focused;  }; -bool TextureButton::get_expand() const { -	return expand; +bool TextureButton::get_ignore_texture_size() const { +	return ignore_texture_size;  } -void TextureButton::set_expand(bool p_expand) { -	expand = p_expand; +void TextureButton::set_ignore_texture_size(bool p_ignore) { +	ignore_texture_size = p_ignore;  	update_minimum_size();  	update();  } diff --git a/scene/gui/texture_button.h b/scene/gui/texture_button.h index 1428a79a1d..5762949acd 100644 --- a/scene/gui/texture_button.h +++ b/scene/gui/texture_button.h @@ -54,8 +54,8 @@ private:  	Ref<Texture2D> disabled;  	Ref<Texture2D> focused;  	Ref<BitMap> click_mask; -	bool expand = false; -	StretchMode stretch_mode = STRETCH_SCALE; +	bool ignore_texture_size = false; +	StretchMode stretch_mode = STRETCH_KEEP;  	Rect2 _texture_region;  	Rect2 _position_rect; @@ -85,8 +85,8 @@ public:  	Ref<Texture2D> get_focused_texture() const;  	Ref<BitMap> get_click_mask() const; -	bool get_expand() const; -	void set_expand(bool p_expand); +	bool get_ignore_texture_size() const; +	void set_ignore_texture_size(bool p_ignore);  	void set_stretch_mode(StretchMode p_stretch_mode);  	StretchMode get_stretch_mode() const; diff --git a/servers/rendering/shader_language.cpp b/servers/rendering/shader_language.cpp index a433c666f3..b10022545c 100644 --- a/servers/rendering/shader_language.cpp +++ b/servers/rendering/shader_language.cpp @@ -5255,8 +5255,10 @@ ShaderLanguage::Node *ShaderLanguage::_parse_expression(BlockNode *p_block, cons  					return nullptr;  				} else {  #ifdef DEBUG_ENABLED -					if (check_warnings && HAS_WARNING(ShaderWarning::FORMATTING_ERROR_FLAG)) { -						_add_line_warning(ShaderWarning::FORMATTING_ERROR, RTR("Empty statement. Remove ';' to fix this warning.")); +					if (!p_block || (p_block->block_type != BlockNode::BLOCK_TYPE_FOR_INIT && p_block->block_type != BlockNode::BLOCK_TYPE_FOR_CONDITION)) { +						if (check_warnings && HAS_WARNING(ShaderWarning::FORMATTING_ERROR_FLAG)) { +							_add_line_warning(ShaderWarning::FORMATTING_ERROR, RTR("Empty statement. Remove ';' to fix this warning.")); +						}  					}  #endif // DEBUG_ENABLED  					_set_tkpos(prepos); @@ -6370,6 +6372,8 @@ Error ShaderLanguage::_parse_block(BlockNode *p_block, const FunctionInfo &p_fun  		}  		bool is_struct = shader->structs.has(tk.text); +		bool is_var_init = false; +		bool is_condition = false;  		if (tk.type == TK_CURLY_BRACKET_CLOSE) { //end of block  			if (p_just_one) { @@ -6380,6 +6384,8 @@ Error ShaderLanguage::_parse_block(BlockNode *p_block, const FunctionInfo &p_fun  			return OK;  		} else if (tk.type == TK_CONST || is_token_precision(tk.type) || is_token_nonvoid_datatype(tk.type) || is_struct) { +			is_var_init = true; +  			String struct_name = "";  			if (is_struct) {  				struct_name = tk.text; @@ -7135,6 +7141,14 @@ Error ShaderLanguage::_parse_block(BlockNode *p_block, const FunctionInfo &p_fun  			init_block->block_type = BlockNode::BLOCK_TYPE_FOR_INIT;  			init_block->parent_block = p_block;  			init_block->single_statement = true; +			// Need to find a parent function to correctly proceed unused variable warnings. +			{ +				BlockNode *block = p_block; +				while (block && !block->parent_function) { +					block = block->parent_block; +				} +				init_block->parent_function = block->parent_function; +			}  			cf->blocks.push_back(init_block);  			Error err = _parse_block(init_block, p_function_info, true, false, false);  			if (err != OK) { @@ -7319,25 +7333,13 @@ Error ShaderLanguage::_parse_block(BlockNode *p_block, const FunctionInfo &p_fun  			if (!expr) {  				return ERR_PARSE_ERROR;  			} - -			bool empty = false; +			is_condition = expr->type == Node::TYPE_OPERATOR && expr->get_datatype() == TYPE_BOOL;  			if (expr->type == Node::TYPE_OPERATOR) {  				OperatorNode *op = static_cast<OperatorNode *>(expr);  				if (op->op == OP_EMPTY) { -					empty = true; -				} -			} -			if (p_block->block_type == BlockNode::BLOCK_TYPE_FOR_INIT) { -				if (!empty && expr->type != BlockNode::TYPE_VARIABLE_DECLARATION) { -					_set_error(RTR("The left expression is expected to be a variable declaration.")); -					return ERR_PARSE_ERROR; -				} -			} -			if (p_block->block_type == BlockNode::BLOCK_TYPE_FOR_CONDITION) { -				if (!empty && expr->get_datatype() != TYPE_BOOL) { -					_set_error(RTR("The middle expression is expected to be boolean.")); -					return ERR_PARSE_ERROR; +					is_var_init = true; +					is_condition = true;  				}  			} @@ -7346,6 +7348,10 @@ Error ShaderLanguage::_parse_block(BlockNode *p_block, const FunctionInfo &p_fun  			if (p_block->block_type == BlockNode::BLOCK_TYPE_FOR_CONDITION) {  				if (tk.type == TK_COMMA) { +					if (!is_condition) { +						_set_error(RTR("The middle expression is expected to be a boolean operator.")); +						return ERR_PARSE_ERROR; +					}  					continue;  				}  				if (tk.type != TK_SEMICOLON) { @@ -7366,6 +7372,17 @@ Error ShaderLanguage::_parse_block(BlockNode *p_block, const FunctionInfo &p_fun  			}  		} +		if (p_block) { +			if (p_block->block_type == BlockNode::BLOCK_TYPE_FOR_INIT && !is_var_init) { +				_set_error(RTR("The left expression is expected to be a variable declaration.")); +				return ERR_PARSE_ERROR; +			} +			if (p_block->block_type == BlockNode::BLOCK_TYPE_FOR_CONDITION && !is_condition) { +				_set_error(RTR("The middle expression is expected to be a boolean operator.")); +				return ERR_PARSE_ERROR; +			} +		} +  		if (p_just_one) {  			break;  		} diff --git a/tests/core/math/test_expression.h b/tests/core/math/test_expression.h index 5a894b20f3..6e3be541b0 100644 --- a/tests/core/math/test_expression.h +++ b/tests/core/math/test_expression.h @@ -137,7 +137,7 @@ TEST_CASE("[Expression] Scientific notation") {  			expression.parse("2e5") == OK,  			"The expression should parse successfully.");  	CHECK_MESSAGE( -			Math::is_equal_approx(double(expression.execute()), 25), +			Math::is_equal_approx(double(expression.execute()), 2e5),  			"The expression should return the expected result.");  	CHECK_MESSAGE( |