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;
|
||||
}
|
||||
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
|
||||
BlockNode *bl = current_block;
|
||||
while (bl) {
|
||||
|
@ -7842,14 +7842,17 @@ void GDScriptParser::_check_block_types(BlockNode *p_block) {
|
|||
return;
|
||||
}
|
||||
|
||||
if (!lh_type.has_type && check_types) {
|
||||
if (check_types) {
|
||||
if (!lh_type.has_type) {
|
||||
if (op->arguments[0]->type == Node::TYPE_OPERATOR) {
|
||||
_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);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
DataType rh_type;
|
||||
if (op->op != OperatorNode::OP_ASSIGN) {
|
||||
|
|
Loading…
Reference in a new issue