Merge pull request #26521 from bojidar-bg/25408-gdscript-constant-bug
Fix GDScript checking for assigning to a constant only in release
This commit is contained in:
commit
bf2c6680ac
1 changed files with 10 additions and 7 deletions
|
@ -2082,7 +2082,7 @@ GDScriptParser::PatternNode *GDScriptParser::_parse_pattern(bool p_static) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
pattern->pt_type = GDScriptParser::PatternNode::PT_BIND;
|
pattern->pt_type = GDScriptParser::PatternNode::PT_BIND;
|
||||||
pattern->bind = tokenizer->get_token_identifier();
|
pattern->bind = tokenizer->get_token_literal();
|
||||||
// Check if variable name is already used
|
// Check if variable name is already used
|
||||||
BlockNode *bl = current_block;
|
BlockNode *bl = current_block;
|
||||||
while (bl) {
|
while (bl) {
|
||||||
|
@ -7842,14 +7842,17 @@ void GDScriptParser::_check_block_types(BlockNode *p_block) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!lh_type.has_type && check_types) {
|
if (check_types) {
|
||||||
|
if (!lh_type.has_type) {
|
||||||
if (op->arguments[0]->type == Node::TYPE_OPERATOR) {
|
if (op->arguments[0]->type == Node::TYPE_OPERATOR) {
|
||||||
_mark_line_as_unsafe(op->line);
|
_mark_line_as_unsafe(op->line);
|
||||||
}
|
}
|
||||||
} else if (lh_type.is_constant) {
|
}
|
||||||
|
if (lh_type.is_constant) {
|
||||||
_set_error("Cannot assign a new value to a constant.", op->line);
|
_set_error("Cannot assign a new value to a constant.", op->line);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
DataType rh_type;
|
DataType rh_type;
|
||||||
if (op->op != OperatorNode::OP_ASSIGN) {
|
if (op->op != OperatorNode::OP_ASSIGN) {
|
||||||
|
|
Loading…
Reference in a new issue