aboutsummaryrefslogtreecommitdiffstats
path: root/libyul/optimiser/FunctionGrouper.cpp
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2019-01-22 20:49:41 +0800
committerGitHub <noreply@github.com>2019-01-22 20:49:41 +0800
commit10d17f245839f208ec5085309022a32cd2502f55 (patch)
treeb2c9f68980d0d418cd6f511e9f3f3f71369abe25 /libyul/optimiser/FunctionGrouper.cpp
parent1df8f40cd2fd7b47698d847907b8ca7b47eb488d (diff)
parent0ecafe032a84cb6960545dd7f18733430c1f782d (diff)
downloaddexon-solidity-10d17f245839f208ec5085309022a32cd2502f55.tar
dexon-solidity-10d17f245839f208ec5085309022a32cd2502f55.tar.gz
dexon-solidity-10d17f245839f208ec5085309022a32cd2502f55.tar.bz2
dexon-solidity-10d17f245839f208ec5085309022a32cd2502f55.tar.lz
dexon-solidity-10d17f245839f208ec5085309022a32cd2502f55.tar.xz
dexon-solidity-10d17f245839f208ec5085309022a32cd2502f55.tar.zst
dexon-solidity-10d17f245839f208ec5085309022a32cd2502f55.zip
Merge pull request #5836 from ethereum/develop
Merge develop into release for 0.5.3.
Diffstat (limited to 'libyul/optimiser/FunctionGrouper.cpp')
-rw-r--r--libyul/optimiser/FunctionGrouper.cpp15
1 files changed, 15 insertions, 0 deletions
diff --git a/libyul/optimiser/FunctionGrouper.cpp b/libyul/optimiser/FunctionGrouper.cpp
index 02ce22cd..b9852fcd 100644
--- a/libyul/optimiser/FunctionGrouper.cpp
+++ b/libyul/optimiser/FunctionGrouper.cpp
@@ -33,6 +33,9 @@ using namespace dev::solidity;
void FunctionGrouper::operator()(Block& _block)
{
+ if (alreadyGrouped(_block))
+ return;
+
vector<Statement> reordered;
reordered.emplace_back(Block{_block.location, {}});
@@ -45,3 +48,15 @@ void FunctionGrouper::operator()(Block& _block)
}
_block.statements = std::move(reordered);
}
+
+bool FunctionGrouper::alreadyGrouped(Block const& _block)
+{
+ if (_block.statements.empty())
+ return false;
+ if (_block.statements.front().type() != typeid(Block))
+ return false;
+ for (size_t i = 1; i < _block.statements.size(); ++i)
+ if (_block.statements.at(i).type() != typeid(FunctionDefinition))
+ return false;
+ return true;
+}