diff options
author | Rhett Aultman <roadriverrail@gmail.com> | 2017-04-29 04:28:03 +0800 |
---|---|---|
committer | chriseth <chris@ethereum.org> | 2017-05-03 17:26:21 +0800 |
commit | a6faa5acf324a127aad11b354e48d7bb2bcf0fbc (patch) | |
tree | 1ec5c56660c185e945ed2f8c1999fc1c6e172623 /libsolidity/analysis/StaticAnalyzer.cpp | |
parent | a40c8cfb68f75c22c0082714d99e9c3a24a31051 (diff) | |
download | dexon-solidity-a6faa5acf324a127aad11b354e48d7bb2bcf0fbc.tar.gz dexon-solidity-a6faa5acf324a127aad11b354e48d7bb2bcf0fbc.tar.zst dexon-solidity-a6faa5acf324a127aad11b354e48d7bb2bcf0fbc.zip |
Treat returns with expressions as return param use
There are many cases of code where the return parameters exist mostly
as a form of documentation. This change ensures that they do not have
to be used in the function body so long as there is a return supplying
values
Diffstat (limited to 'libsolidity/analysis/StaticAnalyzer.cpp')
-rw-r--r-- | libsolidity/analysis/StaticAnalyzer.cpp | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/libsolidity/analysis/StaticAnalyzer.cpp b/libsolidity/analysis/StaticAnalyzer.cpp index 55e7cb59..21c97c3b 100644 --- a/libsolidity/analysis/StaticAnalyzer.cpp +++ b/libsolidity/analysis/StaticAnalyzer.cpp @@ -50,6 +50,7 @@ bool StaticAnalyzer::visit(FunctionDefinition const& _function) { if (_function.isImplemented()) m_inFunction = true; + m_currentFunction = &_function; m_localVarUseCount.clear(); m_nonPayablePublic = _function.isPublic() && !_function.isPayable(); return true; @@ -96,6 +97,17 @@ bool StaticAnalyzer::visit(VariableDeclaration const& _variable) return true; } +bool StaticAnalyzer::visit(Return const& _return) +{ + // If the return has an expression, it counts as + // a "use" of the return parameters. + if (m_inFunction && _return.expression() != NULL) + for (auto const& var: m_currentFunction->returnParameterList()->parameters()) + if (var->name() != "") + m_localVarUseCount[var.get()] += 1; + return true; +} + bool StaticAnalyzer::visit(ExpressionStatement const& _statement) { if (_statement.expression().annotation().isPure) |