mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Reduce the types of errors outputted by ConstantEvaluator
This commit is contained in:
parent
5226d54ed1
commit
7ff9a85592
@ -33,7 +33,7 @@ void ConstantEvaluator::endVisit(UnaryOperation const& _operation)
|
||||
{
|
||||
TypePointer const& subType = _operation.subExpression().annotation().type;
|
||||
if (!dynamic_cast<RationalNumberType const*>(subType.get()))
|
||||
m_errorReporter.fatalTypeError(_operation.subExpression().location(), "Invalid constant expression.");
|
||||
return;
|
||||
TypePointer t = subType->unaryOperatorResult(_operation.getOperator());
|
||||
_operation.annotation().type = t;
|
||||
}
|
||||
@ -44,9 +44,9 @@ void ConstantEvaluator::endVisit(BinaryOperation const& _operation)
|
||||
TypePointer const& leftType = _operation.leftExpression().annotation().type;
|
||||
TypePointer const& rightType = _operation.rightExpression().annotation().type;
|
||||
if (!dynamic_cast<RationalNumberType const*>(leftType.get()))
|
||||
m_errorReporter.fatalTypeError(_operation.leftExpression().location(), "Invalid constant expression.");
|
||||
return;
|
||||
if (!dynamic_cast<RationalNumberType const*>(rightType.get()))
|
||||
m_errorReporter.fatalTypeError(_operation.rightExpression().location(), "Invalid constant expression.");
|
||||
return;
|
||||
TypePointer commonType = leftType->binaryOperatorResult(_operation.getOperator(), rightType);
|
||||
if (!commonType)
|
||||
{
|
||||
@ -71,8 +71,6 @@ void ConstantEvaluator::endVisit(BinaryOperation const& _operation)
|
||||
void ConstantEvaluator::endVisit(Literal const& _literal)
|
||||
{
|
||||
_literal.annotation().type = Type::forLiteral(_literal);
|
||||
if (!_literal.annotation().type)
|
||||
m_errorReporter.fatalTypeError(_literal.location(), "Invalid literal value.");
|
||||
}
|
||||
|
||||
void ConstantEvaluator::endVisit(Identifier const& _identifier)
|
||||
@ -81,11 +79,11 @@ void ConstantEvaluator::endVisit(Identifier const& _identifier)
|
||||
if (!variableDeclaration)
|
||||
return;
|
||||
if (!variableDeclaration->isConstant())
|
||||
m_errorReporter.fatalTypeError(_identifier.location(), "Identifier must be declared constant.");
|
||||
return;
|
||||
|
||||
ASTPointer<Expression> value = variableDeclaration->value();
|
||||
ASTPointer<Expression> const& value = variableDeclaration->value();
|
||||
if (!value)
|
||||
m_errorReporter.fatalTypeError(_identifier.location(), "Constant identifier declaration must have a constant value.");
|
||||
return;
|
||||
|
||||
if (!value->annotation().type)
|
||||
{
|
||||
|
@ -7419,25 +7419,25 @@ BOOST_AUTO_TEST_CASE(array_length_invalid_expression)
|
||||
uint[-true] ids;
|
||||
}
|
||||
)";
|
||||
CHECK_ERROR(text, TypeError, "Invalid constant expression.");
|
||||
CHECK_ERROR(text, TypeError, "Invalid array length, expected integer literal or constant expression.");
|
||||
text = R"(
|
||||
contract C {
|
||||
uint[true/1] ids;
|
||||
}
|
||||
)";
|
||||
CHECK_ERROR(text, TypeError, "Invalid constant expression.");
|
||||
CHECK_ERROR(text, TypeError, "Invalid array length, expected integer literal or constant expression.");
|
||||
text = R"(
|
||||
contract C {
|
||||
uint[1/true] ids;
|
||||
}
|
||||
)";
|
||||
CHECK_ERROR(text, TypeError, "Invalid constant expression.");
|
||||
CHECK_ERROR(text, TypeError, "Invalid array length, expected integer literal or constant expression.");
|
||||
text = R"(
|
||||
contract C {
|
||||
uint[1.111111E1111111111111] ids;
|
||||
}
|
||||
)";
|
||||
CHECK_ERROR(text, TypeError, "Invalid literal value.");
|
||||
CHECK_ERROR(text, TypeError, "Invalid array length, expected integer literal or constant expression.");
|
||||
text = R"(
|
||||
contract C {
|
||||
uint[3/0] ids;
|
||||
|
Loading…
Reference in New Issue
Block a user