diff options
author | chriseth <chris@ethereum.org> | 2018-12-13 00:00:50 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-12-13 00:00:50 +0800 |
commit | 87237281bf252b7afcf5d1295e75a03bf41ac864 (patch) | |
tree | bb04e0727932ff612735060893a5c37b2a30a99e /libsolidity/analysis | |
parent | 7e9a29090c29a8fb678f348fa7333a7658d70cf6 (diff) | |
parent | 8c49d86e6b2422757fe5579711ef7cdf1718b81c (diff) | |
download | dexon-solidity-87237281bf252b7afcf5d1295e75a03bf41ac864.tar dexon-solidity-87237281bf252b7afcf5d1295e75a03bf41ac864.tar.gz dexon-solidity-87237281bf252b7afcf5d1295e75a03bf41ac864.tar.bz2 dexon-solidity-87237281bf252b7afcf5d1295e75a03bf41ac864.tar.lz dexon-solidity-87237281bf252b7afcf5d1295e75a03bf41ac864.tar.xz dexon-solidity-87237281bf252b7afcf5d1295e75a03bf41ac864.tar.zst dexon-solidity-87237281bf252b7afcf5d1295e75a03bf41ac864.zip |
Merge pull request #5630 from ethereum/warn_functions_empty_body
Supress unused var and state mut warnings for functions with empty body
Diffstat (limited to 'libsolidity/analysis')
-rw-r--r-- | libsolidity/analysis/StaticAnalyzer.cpp | 28 | ||||
-rw-r--r-- | libsolidity/analysis/ViewPureChecker.cpp | 1 |
2 files changed, 15 insertions, 14 deletions
diff --git a/libsolidity/analysis/StaticAnalyzer.cpp b/libsolidity/analysis/StaticAnalyzer.cpp index 38391841..4d0f3461 100644 --- a/libsolidity/analysis/StaticAnalyzer.cpp +++ b/libsolidity/analysis/StaticAnalyzer.cpp @@ -63,21 +63,21 @@ bool StaticAnalyzer::visit(FunctionDefinition const& _function) void StaticAnalyzer::endVisit(FunctionDefinition const&) { - m_currentFunction = nullptr; - m_constructor = false; - for (auto const& var: m_localVarUseCount) - if (var.second == 0) - { - if (var.first.second->isCallableParameter()) - m_errorReporter.warning( - var.first.second->location(), - "Unused function parameter. Remove or comment out the variable name to silence this warning." - ); - else - m_errorReporter.warning(var.first.second->location(), "Unused local variable."); - } - + if (m_currentFunction && !m_currentFunction->body().statements().empty()) + for (auto const& var: m_localVarUseCount) + if (var.second == 0) + { + if (var.first.second->isCallableParameter()) + m_errorReporter.warning( + var.first.second->location(), + "Unused function parameter. Remove or comment out the variable name to silence this warning." + ); + else + m_errorReporter.warning(var.first.second->location(), "Unused local variable."); + } m_localVarUseCount.clear(); + m_constructor = false; + m_currentFunction = nullptr; } bool StaticAnalyzer::visit(Identifier const& _identifier) diff --git a/libsolidity/analysis/ViewPureChecker.cpp b/libsolidity/analysis/ViewPureChecker.cpp index 1112d682..bd3071b3 100644 --- a/libsolidity/analysis/ViewPureChecker.cpp +++ b/libsolidity/analysis/ViewPureChecker.cpp @@ -156,6 +156,7 @@ void ViewPureChecker::endVisit(FunctionDefinition const& _funDef) m_bestMutabilityAndLocation.mutability < _funDef.stateMutability() && _funDef.stateMutability() != StateMutability::Payable && _funDef.isImplemented() && + !_funDef.body().statements().empty() && !_funDef.isConstructor() && !_funDef.isFallback() && !_funDef.annotation().superFunction |