mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Add option to recurse referencedSourceUnits
This commit is contained in:
parent
a9bddf71aa
commit
ed592d6ccb
@ -84,12 +84,17 @@ SourceUnitAnnotation& SourceUnit::annotation() const
|
||||
return dynamic_cast<SourceUnitAnnotation&>(*m_annotation);
|
||||
}
|
||||
|
||||
vector<SourceUnit const*> SourceUnit::referencedSourceUnits() const
|
||||
set<SourceUnit const*> SourceUnit::referencedSourceUnits(bool _recurse) const
|
||||
{
|
||||
vector<SourceUnit const*> sourceUnits;
|
||||
set<SourceUnit const*> sourceUnits;
|
||||
for (ImportDirective const* importDirective: filteredNodes<ImportDirective>(nodes()))
|
||||
{
|
||||
sourceUnits.push_back(importDirective->annotation().sourceUnit);
|
||||
sourceUnits.insert(importDirective->annotation().sourceUnit);
|
||||
if (_recurse)
|
||||
{
|
||||
set<SourceUnit const*> referencedSourceUnits = importDirective->annotation().sourceUnit->referencedSourceUnits(true);
|
||||
sourceUnits.insert(referencedSourceUnits.begin(), referencedSourceUnits.end());
|
||||
}
|
||||
}
|
||||
return sourceUnits;
|
||||
}
|
||||
|
@ -136,8 +136,8 @@ public:
|
||||
|
||||
std::vector<ASTPointer<ASTNode>> nodes() const { return m_nodes; }
|
||||
|
||||
/// @returns a vector of referenced SourceUnits.
|
||||
std::vector<SourceUnit const*> referencedSourceUnits() const;
|
||||
/// @returns a set of referenced SourceUnits. Recursively if @a _recurse is true.
|
||||
std::set<SourceUnit const*> referencedSourceUnits(bool _recurse = false) const;
|
||||
|
||||
private:
|
||||
std::vector<ASTPointer<ASTNode>> m_nodes;
|
||||
|
Loading…
Reference in New Issue
Block a user