aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity
diff options
context:
space:
mode:
authorLeonardo Alt <leo@ethereum.org>2018-08-02 01:01:50 +0800
committerchriseth <chris@ethereum.org>2018-09-06 23:11:53 +0800
commitc577e043a4d54ac740aab770a6af38d74a7a427d (patch)
tree8f404988ab85b5a9c451d82f153e38609c38a343 /libsolidity
parent507cdf6de20b5c9bc9a0a8de311e9018af552865 (diff)
downloaddexon-solidity-c577e043a4d54ac740aab770a6af38d74a7a427d.tar
dexon-solidity-c577e043a4d54ac740aab770a6af38d74a7a427d.tar.gz
dexon-solidity-c577e043a4d54ac740aab770a6af38d74a7a427d.tar.bz2
dexon-solidity-c577e043a4d54ac740aab770a6af38d74a7a427d.tar.lz
dexon-solidity-c577e043a4d54ac740aab770a6af38d74a7a427d.tar.xz
dexon-solidity-c577e043a4d54ac740aab770a6af38d74a7a427d.tar.zst
dexon-solidity-c577e043a4d54ac740aab770a6af38d74a7a427d.zip
Disallow structs in events without ABIEncoderV2
Diffstat (limited to 'libsolidity')
-rw-r--r--libsolidity/analysis/TypeChecker.cpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/libsolidity/analysis/TypeChecker.cpp b/libsolidity/analysis/TypeChecker.cpp
index 30302908..f6980872 100644
--- a/libsolidity/analysis/TypeChecker.cpp
+++ b/libsolidity/analysis/TypeChecker.cpp
@@ -864,6 +864,7 @@ void TypeChecker::visitManually(
bool TypeChecker::visit(EventDefinition const& _eventDef)
{
+ solAssert(_eventDef.visibility() > Declaration::Visibility::Internal, "");
unsigned numIndexed = 0;
for (ASTPointer<VariableDeclaration> const& var: _eventDef.parameters())
{
@@ -873,6 +874,15 @@ bool TypeChecker::visit(EventDefinition const& _eventDef)
m_errorReporter.typeError(var->location(), "Type is required to live outside storage.");
if (!type(*var)->interfaceType(false))
m_errorReporter.typeError(var->location(), "Internal or recursive type is not allowed as event parameter type.");
+ if (
+ !_eventDef.sourceUnit().annotation().experimentalFeatures.count(ExperimentalFeature::ABIEncoderV2) &&
+ !typeSupportedByOldABIEncoder(*type(*var))
+ )
+ m_errorReporter.typeError(
+ var->location(),
+ "This type is only supported in the new experimental ABI encoder. "
+ "Use \"pragma experimental ABIEncoderV2;\" to enable the feature."
+ );
}
if (_eventDef.isAnonymous() && numIndexed > 4)
m_errorReporter.typeError(_eventDef.location(), "More than 4 indexed arguments for anonymous event.");