aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/ast/AST.cpp
diff options
context:
space:
mode:
authorAlex Beregszaszi <alex@rtfs.hu>2017-07-11 18:31:04 +0800
committerGitHub <noreply@github.com>2017-07-11 18:31:04 +0800
commit0b17ff1bdde6a56d3c9b48e8c40da7ad4e9a43f5 (patch)
tree7dc51a4d8abd1da74e090f94469f2bd9c9fed53e /libsolidity/ast/AST.cpp
parent6fa5d47f8fcd7076464ce8ed83c9d89883586f7a (diff)
parent01a1296e90e48d64d5494ab4ba9231911ec72ac9 (diff)
downloaddexon-solidity-0b17ff1bdde6a56d3c9b48e8c40da7ad4e9a43f5.tar
dexon-solidity-0b17ff1bdde6a56d3c9b48e8c40da7ad4e9a43f5.tar.gz
dexon-solidity-0b17ff1bdde6a56d3c9b48e8c40da7ad4e9a43f5.tar.bz2
dexon-solidity-0b17ff1bdde6a56d3c9b48e8c40da7ad4e9a43f5.tar.lz
dexon-solidity-0b17ff1bdde6a56d3c9b48e8c40da7ad4e9a43f5.tar.xz
dexon-solidity-0b17ff1bdde6a56d3c9b48e8c40da7ad4e9a43f5.tar.zst
dexon-solidity-0b17ff1bdde6a56d3c9b48e8c40da7ad4e9a43f5.zip
Merge pull request #2554 from ethereum/minMaxValue
Some helper functions.
Diffstat (limited to 'libsolidity/ast/AST.cpp')
-rw-r--r--libsolidity/ast/AST.cpp17
1 files changed, 17 insertions, 0 deletions
diff --git a/libsolidity/ast/AST.cpp b/libsolidity/ast/AST.cpp
index 403f4b79..724a908f 100644
--- a/libsolidity/ast/AST.cpp
+++ b/libsolidity/ast/AST.cpp
@@ -416,6 +416,23 @@ bool VariableDeclaration::isCallableParameter() const
return false;
}
+bool VariableDeclaration::isLocalOrReturn() const
+{
+ return isReturnParameter() || (isLocalVariable() && !isCallableParameter());
+}
+
+bool VariableDeclaration::isReturnParameter() const
+{
+ auto const* callable = dynamic_cast<CallableDeclaration const*>(scope());
+ if (!callable)
+ return false;
+ if (callable->returnParameterList())
+ for (auto const& variable: callable->returnParameterList()->parameters())
+ if (variable.get() == this)
+ return true;
+ return false;
+}
+
bool VariableDeclaration::isExternalCallableParameter() const
{
auto const* callable = dynamic_cast<CallableDeclaration const*>(scope());