diff options
author | Alex Beregszaszi <alex@rtfs.hu> | 2017-07-13 07:17:25 +0800 |
---|---|---|
committer | Alex Beregszaszi <alex@rtfs.hu> | 2017-07-19 21:56:40 +0800 |
commit | ed592d6ccb9a8a088dc8153baae78f771304a257 (patch) | |
tree | 610837786dbcaacd99d4c65a0884f6c4cfff0f75 /libsolidity/ast/AST.cpp | |
parent | a9bddf71aaca7fb6e00292b788479a465b867faf (diff) | |
download | dexon-solidity-ed592d6ccb9a8a088dc8153baae78f771304a257.tar.gz dexon-solidity-ed592d6ccb9a8a088dc8153baae78f771304a257.tar.zst dexon-solidity-ed592d6ccb9a8a088dc8153baae78f771304a257.zip |
Add option to recurse referencedSourceUnits
Diffstat (limited to 'libsolidity/ast/AST.cpp')
-rw-r--r-- | libsolidity/ast/AST.cpp | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/libsolidity/ast/AST.cpp b/libsolidity/ast/AST.cpp index c5fb35f6..a126e6ed 100644 --- a/libsolidity/ast/AST.cpp +++ b/libsolidity/ast/AST.cpp @@ -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; } |