aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLefteris Karapetsas <lefteris@refu.co>2015-02-27 18:35:25 +0800
committerLefteris Karapetsas <lefteris@refu.co>2015-03-02 18:51:13 +0800
commitefe8f9f8a054a7a7489db44e236e5424becf9db7 (patch)
tree5cb75003f96c654f6ff6eb81a5376da3bda44f58
parent7db2b6fbdb7188596fbb05bea32d686c32e26c7f (diff)
downloaddexon-solidity-efe8f9f8a054a7a7489db44e236e5424becf9db7.tar
dexon-solidity-efe8f9f8a054a7a7489db44e236e5424becf9db7.tar.gz
dexon-solidity-efe8f9f8a054a7a7489db44e236e5424becf9db7.tar.bz2
dexon-solidity-efe8f9f8a054a7a7489db44e236e5424becf9db7.tar.lz
dexon-solidity-efe8f9f8a054a7a7489db44e236e5424becf9db7.tar.xz
dexon-solidity-efe8f9f8a054a7a7489db44e236e5424becf9db7.tar.zst
dexon-solidity-efe8f9f8a054a7a7489db44e236e5424becf9db7.zip
Use lambda to avoid code duplication in inheritableMembers
-rw-r--r--AST.cpp25
1 files changed, 11 insertions, 14 deletions
diff --git a/AST.cpp b/AST.cpp
index d18a296d..24a94a79 100644
--- a/AST.cpp
+++ b/AST.cpp
@@ -217,26 +217,23 @@ vector<ASTPointer<Declaration>> const& ContractDefinition::getInheritableMembers
m_inheritableMembers.reset(new vector<ASTPointer<Declaration>>());
for (ContractDefinition const* contract: getLinearizedBaseContracts())
{
- for (ASTPointer<FunctionDefinition> const& f: contract->getDefinedFunctions())
- if (memberSeen.count(f->getName()) == 0 && f->isVisibleInDerivedContracts())
+ auto addInheritableMember = [&](ASTPointer<Declaration> const& _decl)
+ {
+ if (memberSeen.count(_decl->getName()) == 0 && _decl->isVisibleInDerivedContracts())
{
- memberSeen.insert(f->getName());
- m_inheritableMembers->push_back(f);
+ memberSeen.insert(_decl->getName());
+ m_inheritableMembers->push_back(_decl);
}
+ };
+
+ for (ASTPointer<FunctionDefinition> const& f: contract->getDefinedFunctions())
+ addInheritableMember(f);
for (ASTPointer<VariableDeclaration> const& v: contract->getStateVariables())
- if (memberSeen.count(v->getName()) == 0 && v->isVisibleInDerivedContracts())
- {
- memberSeen.insert(v->getName());
- m_inheritableMembers->push_back(v);
- }
+ addInheritableMember(v);
for (ASTPointer<StructDefinition> const& s: contract->getDefinedStructs())
- if (memberSeen.count(s->getName()) == 0 && s->isVisibleInDerivedContracts())
- {
- memberSeen.insert(s->getName());
- m_inheritableMembers->push_back(s);
- }
+ addInheritableMember(s);
}
}
return *m_inheritableMembers;