diff options
author | chriseth <chris@ethereum.org> | 2017-12-07 19:21:52 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-12-07 19:21:52 +0800 |
commit | 316e4089b3c2317abdf1c5b43e214d1f69e16160 (patch) | |
tree | 637d4e153c17c88d0d38a3163f8eefff2ad51039 /libsolidity/inlineasm/AsmAnalysis.cpp | |
parent | 1343770dfe2f2231d1180dc41ff42164172bbeec (diff) | |
parent | d57afb20fa32be3d5575b8c5dcd98f39ce4e90d0 (diff) | |
download | dexon-solidity-316e4089b3c2317abdf1c5b43e214d1f69e16160.tar dexon-solidity-316e4089b3c2317abdf1c5b43e214d1f69e16160.tar.gz dexon-solidity-316e4089b3c2317abdf1c5b43e214d1f69e16160.tar.bz2 dexon-solidity-316e4089b3c2317abdf1c5b43e214d1f69e16160.tar.lz dexon-solidity-316e4089b3c2317abdf1c5b43e214d1f69e16160.tar.xz dexon-solidity-316e4089b3c2317abdf1c5b43e214d1f69e16160.tar.zst dexon-solidity-316e4089b3c2317abdf1c5b43e214d1f69e16160.zip |
Merge pull request #3283 from ethereum/jump-warning
Improve the jump warning
Diffstat (limited to 'libsolidity/inlineasm/AsmAnalysis.cpp')
-rw-r--r-- | libsolidity/inlineasm/AsmAnalysis.cpp | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/libsolidity/inlineasm/AsmAnalysis.cpp b/libsolidity/inlineasm/AsmAnalysis.cpp index 5c03342d..049af65f 100644 --- a/libsolidity/inlineasm/AsmAnalysis.cpp +++ b/libsolidity/inlineasm/AsmAnalysis.cpp @@ -56,6 +56,7 @@ bool AsmAnalyzer::operator()(Label const& _label) { solAssert(!m_julia, ""); m_info.stackHeightInfo[&_label] = m_stackHeight; + warnOnInstructions(solidity::Instruction::JUMPDEST, _label.location); return true; } @@ -523,11 +524,11 @@ void AsmAnalyzer::warnOnInstructions(solidity::Instruction _instr, SourceLocatio "the Metropolis hard fork. Before that it acts as an invalid instruction." ); - if (_instr == solidity::Instruction::JUMP || _instr == solidity::Instruction::JUMPI) + if (_instr == solidity::Instruction::JUMP || _instr == solidity::Instruction::JUMPI || _instr == solidity::Instruction::JUMPDEST) m_errorReporter.warning( _location, - "Jump instructions are low-level EVM features that can lead to " + "Jump instructions and labels are low-level EVM features that can lead to " "incorrect stack access. Because of that they are discouraged. " - "Please consider using \"switch\" or \"for\" statements instead." + "Please consider using \"switch\", \"if\" or \"for\" statements instead." ); } |