diff options
author | chriseth <chris@ethereum.org> | 2018-05-04 21:02:04 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-05-04 21:02:04 +0800 |
commit | 150d226603cabd2c50b8324bd58bf06712311af9 (patch) | |
tree | 3190c59d7bc8bd9581e0289af62db8c7875cae19 | |
parent | 81d61ca086e8e45108b7989e7f1494d90077401e (diff) | |
parent | ffe7f224a6c9598284f100f842e3cfba58974d56 (diff) | |
download | dexon-solidity-150d226603cabd2c50b8324bd58bf06712311af9.tar dexon-solidity-150d226603cabd2c50b8324bd58bf06712311af9.tar.gz dexon-solidity-150d226603cabd2c50b8324bd58bf06712311af9.tar.bz2 dexon-solidity-150d226603cabd2c50b8324bd58bf06712311af9.tar.lz dexon-solidity-150d226603cabd2c50b8324bd58bf06712311af9.tar.xz dexon-solidity-150d226603cabd2c50b8324bd58bf06712311af9.tar.zst dexon-solidity-150d226603cabd2c50b8324bd58bf06712311af9.zip |
Merge pull request #4063 from ethereum/emit-non-event
Show proper error when trying to emit a non-event
-rw-r--r-- | Changelog.md | 1 | ||||
-rw-r--r-- | libsolidity/analysis/TypeChecker.cpp | 1 | ||||
-rw-r--r-- | test/libsolidity/syntaxTests/emit_non_event.sol | 10 |
3 files changed, 12 insertions, 0 deletions
diff --git a/Changelog.md b/Changelog.md index 817365b9..7c4ac925 100644 --- a/Changelog.md +++ b/Changelog.md @@ -8,6 +8,7 @@ Features: * Type Checker: Make literals (without explicit type casting) an error for tight packing as experimental 0.5.0 feature. Bugfixes: + * Type Checker: Show proper error when trying to ``emit`` a non-event. * Type Checker: Warn about empty tuple components (this will turn into an error with version 0.5.0). diff --git a/libsolidity/analysis/TypeChecker.cpp b/libsolidity/analysis/TypeChecker.cpp index 82421749..32cf1b18 100644 --- a/libsolidity/analysis/TypeChecker.cpp +++ b/libsolidity/analysis/TypeChecker.cpp @@ -1067,6 +1067,7 @@ void TypeChecker::endVisit(EmitStatement const& _emit) { if ( _emit.eventCall().annotation().kind != FunctionCallKind::FunctionCall || + type(_emit.eventCall().expression())->category() != Type::Category::Function || dynamic_cast<FunctionType const&>(*type(_emit.eventCall().expression())).kind() != FunctionType::Kind::Event ) m_errorReporter.typeError(_emit.eventCall().expression().location(), "Expression has to be an event invocation."); diff --git a/test/libsolidity/syntaxTests/emit_non_event.sol b/test/libsolidity/syntaxTests/emit_non_event.sol new file mode 100644 index 00000000..1df6990d --- /dev/null +++ b/test/libsolidity/syntaxTests/emit_non_event.sol @@ -0,0 +1,10 @@ +contract C { + uint256 Test; + + function f() { + emit Test(); + } +} +// ---- +// TypeError: (56-62): Type is not callable +// TypeError: (56-60): Expression has to be an event invocation. |