aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-05-04 21:02:04 +0800
committerGitHub <noreply@github.com>2018-05-04 21:02:04 +0800
commit150d226603cabd2c50b8324bd58bf06712311af9 (patch)
tree3190c59d7bc8bd9581e0289af62db8c7875cae19
parent81d61ca086e8e45108b7989e7f1494d90077401e (diff)
parentffe7f224a6c9598284f100f842e3cfba58974d56 (diff)
downloaddexon-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.md1
-rw-r--r--libsolidity/analysis/TypeChecker.cpp1
-rw-r--r--test/libsolidity/syntaxTests/emit_non_event.sol10
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.