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:
George Marques 2019-03-03 11:31:27 -03:00 committed by GitHub
commit bf2c6680ac
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -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) {