Merge pull request #37598 from ThakeeNathees/GDScript-type-resolve-bug-fix

GDScript class var type resolve bug fixed
This commit is contained in:
Rémi Verschelde 2020-05-09 21:59:26 +02:00 committed by GitHub
commit cf0953fefa
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -2734,6 +2734,7 @@ void GDScriptParser::_transform_match_statment(MatchNode *p_match_statement) {
IdentifierNode *id2 = alloc_node<IdentifierNode>(); IdentifierNode *id2 = alloc_node<IdentifierNode>();
id2->name = local_var->name; id2->name = local_var->name;
id2->datatype = local_var->datatype;
id2->declared_block = branch->body; id2->declared_block = branch->body;
id2->set_datatype(local_var->assign->get_datatype()); id2->set_datatype(local_var->assign->get_datatype());
@ -4960,6 +4961,7 @@ void GDScriptParser::_parse_class(ClassNode *p_class) {
IdentifierNode *id = alloc_node<IdentifierNode>(); IdentifierNode *id = alloc_node<IdentifierNode>();
id->name = member.identifier; id->name = member.identifier;
id->datatype = member.data_type;
OperatorNode *op = alloc_node<OperatorNode>(); OperatorNode *op = alloc_node<OperatorNode>();
op->op = OperatorNode::OP_INIT_ASSIGN; op->op = OperatorNode::OP_INIT_ASSIGN;
@ -5002,6 +5004,7 @@ void GDScriptParser::_parse_class(ClassNode *p_class) {
IdentifierNode *id = alloc_node<IdentifierNode>(); IdentifierNode *id = alloc_node<IdentifierNode>();
id->name = member.identifier; id->name = member.identifier;
id->datatype = member.data_type;
OperatorNode *op = alloc_node<OperatorNode>(); OperatorNode *op = alloc_node<OperatorNode>();
op->op = OperatorNode::OP_INIT_ASSIGN; op->op = OperatorNode::OP_INIT_ASSIGN;
@ -6647,6 +6650,7 @@ GDScriptParser::DataType GDScriptParser::_reduce_node_type(Node *p_node) {
IdentifierNode *id = alloc_node<IdentifierNode>(); IdentifierNode *id = alloc_node<IdentifierNode>();
id->name = cn->value.operator StringName(); id->name = cn->value.operator StringName();
id->datatype = cn->datatype;
op->op = OperatorNode::OP_INDEX_NAMED; op->op = OperatorNode::OP_INDEX_NAMED;
op->arguments.write[1] = id; op->arguments.write[1] = id;