mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Fix segfault with undeclared array types
This commit is contained in:
parent
2095e7a32d
commit
75a3a707a2
@ -153,6 +153,11 @@ void ReferencesResolver::endVisit(Mapping const& _typeName)
|
|||||||
void ReferencesResolver::endVisit(ArrayTypeName const& _typeName)
|
void ReferencesResolver::endVisit(ArrayTypeName const& _typeName)
|
||||||
{
|
{
|
||||||
TypePointer baseType = _typeName.baseType().annotation().type;
|
TypePointer baseType = _typeName.baseType().annotation().type;
|
||||||
|
if (!baseType)
|
||||||
|
{
|
||||||
|
solAssert(!m_errorReporter.errors().empty(), "");
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (baseType->storageBytes() == 0)
|
if (baseType->storageBytes() == 0)
|
||||||
fatalTypeError(_typeName.baseType().location(), "Illegal base type of storage size zero for array.");
|
fatalTypeError(_typeName.baseType().location(), "Illegal base type of storage size zero for array.");
|
||||||
if (Expression const* length = _typeName.length())
|
if (Expression const* length = _typeName.length())
|
||||||
|
@ -2196,6 +2196,16 @@ BOOST_AUTO_TEST_CASE(array_copy_with_different_types_dynamic_static)
|
|||||||
CHECK_ERROR(text, TypeError, "Type uint256[] storage ref is not implicitly convertible to expected type uint256[80] storage ref.");
|
CHECK_ERROR(text, TypeError, "Type uint256[] storage ref is not implicitly convertible to expected type uint256[80] storage ref.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(array_of_undeclared_type)
|
||||||
|
{
|
||||||
|
char const* text = R"(
|
||||||
|
contract c {
|
||||||
|
a[] public foo;
|
||||||
|
}
|
||||||
|
)";
|
||||||
|
CHECK_ERROR(text, DeclarationError, "Identifier not found or not unique.");
|
||||||
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(storage_variable_initialization_with_incorrect_type_int)
|
BOOST_AUTO_TEST_CASE(storage_variable_initialization_with_incorrect_type_int)
|
||||||
{
|
{
|
||||||
char const* text = R"(
|
char const* text = R"(
|
||||||
|
Loading…
Reference in New Issue
Block a user