Merge pull request #56194 from cdemirer/fix-operation-result-type-inference
This commit is contained in:
commit
1989120d3f
1 changed files with 20 additions and 8 deletions
|
@ -3788,6 +3788,7 @@ GDScriptParser::DataType GDScriptAnalyzer::get_operation_type(Variant::Operator
|
|||
// Unary version.
|
||||
GDScriptParser::DataType nil_type;
|
||||
nil_type.builtin_type = Variant::NIL;
|
||||
nil_type.type_source = GDScriptParser::DataType::ANNOTATED_INFERRED;
|
||||
return get_operation_type(p_operation, p_a, nil_type, r_valid, p_source);
|
||||
}
|
||||
|
||||
|
@ -3797,20 +3798,31 @@ GDScriptParser::DataType GDScriptAnalyzer::get_operation_type(Variant::Operator
|
|||
|
||||
Variant::Type a_type = p_a.builtin_type;
|
||||
Variant::Type b_type = p_b.builtin_type;
|
||||
|
||||
Variant::ValidatedOperatorEvaluator op_eval = Variant::get_validated_operator_evaluator(p_operation, a_type, b_type);
|
||||
|
||||
if (op_eval == nullptr) {
|
||||
bool hard_operation = p_a.is_hard_type() && p_b.is_hard_type();
|
||||
bool validated = op_eval != nullptr;
|
||||
|
||||
if (hard_operation && !validated) {
|
||||
r_valid = false;
|
||||
return result;
|
||||
} else if (hard_operation && validated) {
|
||||
r_valid = true;
|
||||
result.type_source = GDScriptParser::DataType::ANNOTATED_INFERRED;
|
||||
result.kind = GDScriptParser::DataType::BUILTIN;
|
||||
result.builtin_type = Variant::get_operator_return_type(p_operation, a_type, b_type);
|
||||
} else if (!hard_operation && !validated) {
|
||||
r_valid = true;
|
||||
result.type_source = GDScriptParser::DataType::UNDETECTED;
|
||||
result.kind = GDScriptParser::DataType::VARIANT;
|
||||
result.builtin_type = Variant::NIL;
|
||||
} else if (!hard_operation && validated) {
|
||||
r_valid = true;
|
||||
result.type_source = GDScriptParser::DataType::INFERRED;
|
||||
result.kind = GDScriptParser::DataType::BUILTIN;
|
||||
result.builtin_type = Variant::get_operator_return_type(p_operation, a_type, b_type);
|
||||
}
|
||||
|
||||
r_valid = true;
|
||||
result.type_source = GDScriptParser::DataType::ANNOTATED_INFERRED;
|
||||
|
||||
result.kind = GDScriptParser::DataType::BUILTIN;
|
||||
result.builtin_type = Variant::get_operator_return_type(p_operation, a_type, b_type);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue