aboutsummaryrefslogtreecommitdiffstats
path: root/test/libyul/YulOptimizerTest.cpp
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-10-19 17:10:08 +0800
committerGitHub <noreply@github.com>2018-10-19 17:10:08 +0800
commitc676b009e1de3e8f87d43342d6f82d687acbe7fa (patch)
tree5bae94b8833d752c70117cf4b21f8c6a6b983d83 /test/libyul/YulOptimizerTest.cpp
parent5c274a9251f3beba5c23518e080f968930c69501 (diff)
parent465845b7a7e41345c47722bf7f2fcbd8b48248db (diff)
downloaddexon-solidity-c676b009e1de3e8f87d43342d6f82d687acbe7fa.tar
dexon-solidity-c676b009e1de3e8f87d43342d6f82d687acbe7fa.tar.gz
dexon-solidity-c676b009e1de3e8f87d43342d6f82d687acbe7fa.tar.bz2
dexon-solidity-c676b009e1de3e8f87d43342d6f82d687acbe7fa.tar.lz
dexon-solidity-c676b009e1de3e8f87d43342d6f82d687acbe7fa.tar.xz
dexon-solidity-c676b009e1de3e8f87d43342d6f82d687acbe7fa.tar.zst
dexon-solidity-c676b009e1de3e8f87d43342d6f82d687acbe7fa.zip
Merge pull request #5267 from ethereum/ssatransform
SSA transform - first step.
Diffstat (limited to 'test/libyul/YulOptimizerTest.cpp')
-rw-r--r--test/libyul/YulOptimizerTest.cpp7
1 files changed, 7 insertions, 0 deletions
diff --git a/test/libyul/YulOptimizerTest.cpp b/test/libyul/YulOptimizerTest.cpp
index fabc05ca..6782f412 100644
--- a/test/libyul/YulOptimizerTest.cpp
+++ b/test/libyul/YulOptimizerTest.cpp
@@ -35,6 +35,7 @@
#include <libyul/optimiser/ExpressionSimplifier.h>
#include <libyul/optimiser/UnusedPruner.h>
#include <libyul/optimiser/ExpressionJoiner.h>
+#include <libyul/optimiser/SSATransform.h>
#include <libsolidity/parsing/Scanner.h>
#include <libsolidity/inlineasm/AsmPrinter.h>
@@ -171,6 +172,12 @@ bool YulOptimizerTest::run(ostream& _stream, string const& _linePrefix, bool con
disambiguate();
ExpressionJoiner::run(*m_ast);\
}
+ else if (m_optimizerStep == "ssaTransform")
+ {
+ disambiguate();
+ NameDispenser nameDispenser(*m_ast);
+ SSATransform::run(*m_ast, nameDispenser);
+ }
else
{
FormattedScope(_stream, _formatted, {formatting::BOLD, formatting::RED}) << _linePrefix << "Invalid optimizer step: " << m_optimizerStep << endl;