Fix member call on null pointer when type-checking built-in unary operators

This commit is contained in:
Kamil Śliwak 2023-03-06 19:20:06 +01:00
parent f341cfbfb6
commit c95108169d

View File

@ -1780,11 +1780,10 @@ bool TypeChecker::visit(UnaryOperation const& _operation)
_operation.annotation().userDefinedFunction = operatorDefinition; _operation.annotation().userDefinedFunction = operatorDefinition;
TypePointers const& returnParameterTypes = _operation.userDefinedFunctionType()->returnParameterTypes(); if (operatorDefinition && !_operation.userDefinedFunctionType()->returnParameterTypes().empty())
if (operatorDefinition && !returnParameterTypes.empty())
// Use the actual result type from operator definition. Ignore all values but the // Use the actual result type from operator definition. Ignore all values but the
// first one - in valid code there will be only one anyway. // first one - in valid code there will be only one anyway.
resultType = returnParameterTypes[0]; resultType = _operation.userDefinedFunctionType()->returnParameterTypes()[0];
_operation.annotation().type = resultType; _operation.annotation().type = resultType;
_operation.annotation().isConstant = false; _operation.annotation().isConstant = false;
_operation.annotation().isPure = _operation.annotation().isPure =