Fix segfault with undeclared array types

This commit is contained in:
Federico Bond 2018-02-11 19:44:23 -03:00
parent 2095e7a32d
commit 75a3a707a2
2 changed files with 15 additions and 0 deletions

View File

@ -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())

View File

@ -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"(