aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/analysis/StaticAnalyzer.cpp
diff options
context:
space:
mode:
authorRhett Aultman <roadriverrail@gmail.com>2017-04-29 04:28:03 +0800
committerchriseth <chris@ethereum.org>2017-05-03 17:26:21 +0800
commita6faa5acf324a127aad11b354e48d7bb2bcf0fbc (patch)
tree1ec5c56660c185e945ed2f8c1999fc1c6e172623 /libsolidity/analysis/StaticAnalyzer.cpp
parenta40c8cfb68f75c22c0082714d99e9c3a24a31051 (diff)
downloaddexon-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.cpp12
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)