aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity
diff options
context:
space:
mode:
authorchriseth <c@ethdev.com>2015-10-07 22:40:54 +0800
committerchriseth <c@ethdev.com>2015-10-07 22:40:54 +0800
commitb6ddde9372c897c1eafc24ee16e3aa6aeec3f2f6 (patch)
treea4f46b14f7290c78b47c46ea152f4a0305e348dc /libsolidity
parent5053e153ece086ce3b5e4d9a3324a526306a1579 (diff)
downloaddexon-solidity-b6ddde9372c897c1eafc24ee16e3aa6aeec3f2f6.tar.gz
dexon-solidity-b6ddde9372c897c1eafc24ee16e3aa6aeec3f2f6.tar.zst
dexon-solidity-b6ddde9372c897c1eafc24ee16e3aa6aeec3f2f6.zip
Allow four indexed arguments for anynomous events.
Diffstat (limited to 'libsolidity')
-rw-r--r--libsolidity/TypeChecker.cpp4
1 files changed, 3 insertions, 1 deletions
diff --git a/libsolidity/TypeChecker.cpp b/libsolidity/TypeChecker.cpp
index fe6fb970..2afa5649 100644
--- a/libsolidity/TypeChecker.cpp
+++ b/libsolidity/TypeChecker.cpp
@@ -554,7 +554,9 @@ bool TypeChecker::visit(EventDefinition const& _eventDef)
{
if (var->isIndexed())
numIndexed++;
- if (numIndexed > 3)
+ if (_eventDef.isAnonymous() && numIndexed > 4)
+ typeError(_eventDef, "More than 4 indexed arguments for anonymous event.");
+ else if (!_eventDef.isAnonymous() && numIndexed > 3)
typeError(_eventDef, "More than 3 indexed arguments for event.");
if (!type(*var)->canLiveOutsideStorage())
typeError(*var, "Type is required to live outside storage.");