aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity
diff options
context:
space:
mode:
authorchriseth <c@ethdev.com>2015-10-16 20:34:43 +0800
committerchriseth <c@ethdev.com>2015-10-16 20:36:30 +0800
commitead0478f268f486ea8e9eccac729c93cf4a94ee1 (patch)
tree6e8eda5685a5da25143b59adc2e49e265f2dc983 /libsolidity
parent52eaa477d4bd9ad2f591148727d1ac9fd500d283 (diff)
downloaddexon-solidity-ead0478f268f486ea8e9eccac729c93cf4a94ee1.tar
dexon-solidity-ead0478f268f486ea8e9eccac729c93cf4a94ee1.tar.gz
dexon-solidity-ead0478f268f486ea8e9eccac729c93cf4a94ee1.tar.bz2
dexon-solidity-ead0478f268f486ea8e9eccac729c93cf4a94ee1.tar.lz
dexon-solidity-ead0478f268f486ea8e9eccac729c93cf4a94ee1.tar.xz
dexon-solidity-ead0478f268f486ea8e9eccac729c93cf4a94ee1.tar.zst
dexon-solidity-ead0478f268f486ea8e9eccac729c93cf4a94ee1.zip
Fix errors when struct array type is used on its own.
Diffstat (limited to 'libsolidity')
-rw-r--r--libsolidity/ExpressionCompiler.cpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/libsolidity/ExpressionCompiler.cpp b/libsolidity/ExpressionCompiler.cpp
index fde88a00..112521f9 100644
--- a/libsolidity/ExpressionCompiler.cpp
+++ b/libsolidity/ExpressionCompiler.cpp
@@ -950,6 +950,12 @@ bool ExpressionCompiler::visit(IndexAccess const& _indexAccess)
break;
}
}
+ else if (baseType.category() == Type::Category::TypeType)
+ {
+ solAssert(baseType.sizeOnStack() == 0, "");
+ solAssert(_indexAccess.annotation().type->sizeOnStack() == 0, "");
+ // no-op - this seems to be a lone array type (`structType[];`)
+ }
else
solAssert(false, "Index access only allowed for mappings or arrays.");
@@ -1003,6 +1009,10 @@ void ExpressionCompiler::endVisit(Identifier const& _identifier)
{
// no-op
}
+ else if (dynamic_cast<StructDefinition const*>(declaration))
+ {
+ // no-op
+ }
else
{
BOOST_THROW_EXCEPTION(InternalCompilerError() << errinfo_comment("Identifier type not expected in expression context."));