aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/ast/AST.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'libsolidity/ast/AST.cpp')
-rw-r--r--libsolidity/ast/AST.cpp84
1 files changed, 69 insertions, 15 deletions
diff --git a/libsolidity/ast/AST.cpp b/libsolidity/ast/AST.cpp
index 7ceab752..65535388 100644
--- a/libsolidity/ast/AST.cpp
+++ b/libsolidity/ast/AST.cpp
@@ -74,29 +74,83 @@ map<FixedHash<4>, FunctionTypePointer> ContractDefinition::interfaceFunctions()
FunctionDefinition const* ContractDefinition::constructor() const
{
- for (ASTPointer<FunctionDefinition> const& f: m_definedFunctions)
+ for (FunctionDefinition const* f: definedFunctions())
if (f->isConstructor())
- return f.get();
+ return f;
return nullptr;
}
FunctionDefinition const* ContractDefinition::fallbackFunction() const
{
for (ContractDefinition const* contract: annotation().linearizedBaseContracts)
- for (ASTPointer<FunctionDefinition> const& f: contract->definedFunctions())
+ for (FunctionDefinition const* f: contract->definedFunctions())
if (f->name().empty())
- return f.get();
+ return f;
return nullptr;
}
-vector<ASTPointer<EventDefinition>> const& ContractDefinition::interfaceEvents() const
+vector<StructDefinition const*> ContractDefinition::definedStructs() const
+{
+ vector<StructDefinition const*> ret;
+ for (auto const& node: m_subNodes)
+ if (auto v = dynamic_cast<StructDefinition const*>(node.get()))
+ ret.push_back(v);
+ return ret;
+}
+
+vector<EnumDefinition const*> ContractDefinition::definedEnums() const
+{
+ vector<EnumDefinition const*> ret;
+ for (auto const& node: m_subNodes)
+ if (auto v = dynamic_cast<EnumDefinition const*>(node.get()))
+ ret.push_back(v);
+ return ret;
+}
+
+vector<VariableDeclaration const*> ContractDefinition::stateVariables() const
+{
+ vector<VariableDeclaration const*> ret;
+ for (auto const& node: m_subNodes)
+ if (auto v = dynamic_cast<VariableDeclaration const*>(node.get()))
+ ret.push_back(v);
+ return ret;
+}
+
+vector<ModifierDefinition const*> ContractDefinition::functionModifiers() const
+{
+ vector<ModifierDefinition const*> ret;
+ for (auto const& node: m_subNodes)
+ if (auto v = dynamic_cast<ModifierDefinition const*>(node.get()))
+ ret.push_back(v);
+ return ret;
+}
+
+vector<FunctionDefinition const*> ContractDefinition::definedFunctions() const
+{
+ vector<FunctionDefinition const*> ret;
+ for (auto const& node: m_subNodes)
+ if (auto v = dynamic_cast<FunctionDefinition const*>(node.get()))
+ ret.push_back(v);
+ return ret;
+}
+
+vector<EventDefinition const*> ContractDefinition::events() const
+{
+ vector<EventDefinition const*> ret;
+ for (auto const& node: m_subNodes)
+ if (auto v = dynamic_cast<EventDefinition const*>(node.get()))
+ ret.push_back(v);
+ return ret;
+}
+
+vector<EventDefinition const*> const& ContractDefinition::interfaceEvents() const
{
if (!m_interfaceEvents)
{
set<string> eventsSeen;
- m_interfaceEvents.reset(new vector<ASTPointer<EventDefinition>>());
+ m_interfaceEvents.reset(new vector<EventDefinition const*>());
for (ContractDefinition const* contract: annotation().linearizedBaseContracts)
- for (ASTPointer<EventDefinition> const& e: contract->events())
+ for (EventDefinition const* e: contract->events())
if (eventsSeen.count(e->name()) == 0)
{
eventsSeen.insert(e->name());
@@ -116,10 +170,10 @@ vector<pair<FixedHash<4>, FunctionTypePointer>> const& ContractDefinition::inter
for (ContractDefinition const* contract: annotation().linearizedBaseContracts)
{
vector<FunctionTypePointer> functions;
- for (ASTPointer<FunctionDefinition> const& f: contract->definedFunctions())
+ for (FunctionDefinition const* f: contract->definedFunctions())
if (f->isPartOfExternalInterface())
functions.push_back(make_shared<FunctionType>(*f, false));
- for (ASTPointer<VariableDeclaration> const& v: contract->stateVariables())
+ for (VariableDeclaration const* v: contract->stateVariables())
if (v->isPartOfExternalInterface())
functions.push_back(make_shared<FunctionType>(*v));
for (FunctionTypePointer const& fun: functions)
@@ -176,14 +230,14 @@ vector<Declaration const*> const& ContractDefinition::inheritableMembers() const
}
};
- for (ASTPointer<FunctionDefinition> const& f: definedFunctions())
- addInheritableMember(f.get());
+ for (FunctionDefinition const* f: definedFunctions())
+ addInheritableMember(f);
- for (ASTPointer<VariableDeclaration> const& v: stateVariables())
- addInheritableMember(v.get());
+ for (VariableDeclaration const* v: stateVariables())
+ addInheritableMember(v);
- for (ASTPointer<StructDefinition> const& s: definedStructs())
- addInheritableMember(s.get());
+ for (StructDefinition const* s: definedStructs())
+ addInheritableMember(s);
}
return *m_inheritableMembers;
}