aboutsummaryrefslogtreecommitdiffstats
path: root/libyul/backends/evm/EVMObjectCompiler.cpp
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-12-10 23:14:33 +0800
committerGitHub <noreply@github.com>2018-12-10 23:14:33 +0800
commit871ea22bb9158e23254406d21673cfbeda2d7138 (patch)
treed2a3e88b0c22ee008a0bd480fdf78581d7f5eb67 /libyul/backends/evm/EVMObjectCompiler.cpp
parent055c5fe173b90b7d07f1170de5d7018140296f89 (diff)
parentb05d33d7714c5dbbb034d29b2eea8171807d093b (diff)
downloaddexon-solidity-871ea22bb9158e23254406d21673cfbeda2d7138.tar
dexon-solidity-871ea22bb9158e23254406d21673cfbeda2d7138.tar.gz
dexon-solidity-871ea22bb9158e23254406d21673cfbeda2d7138.tar.bz2
dexon-solidity-871ea22bb9158e23254406d21673cfbeda2d7138.tar.lz
dexon-solidity-871ea22bb9158e23254406d21673cfbeda2d7138.tar.xz
dexon-solidity-871ea22bb9158e23254406d21673cfbeda2d7138.tar.zst
dexon-solidity-871ea22bb9158e23254406d21673cfbeda2d7138.zip
Merge pull request #5008 from liangdzou/yul_stack_reuse
Reuse stack slots in Yul codegen
Diffstat (limited to 'libyul/backends/evm/EVMObjectCompiler.cpp')
-rw-r--r--libyul/backends/evm/EVMObjectCompiler.cpp11
1 files changed, 6 insertions, 5 deletions
diff --git a/libyul/backends/evm/EVMObjectCompiler.cpp b/libyul/backends/evm/EVMObjectCompiler.cpp
index e7e8ad99..13d4b756 100644
--- a/libyul/backends/evm/EVMObjectCompiler.cpp
+++ b/libyul/backends/evm/EVMObjectCompiler.cpp
@@ -27,13 +27,13 @@
using namespace yul;
using namespace std;
-void EVMObjectCompiler::compile(Object& _object, AbstractAssembly& _assembly, bool _yul, bool _evm15)
+void EVMObjectCompiler::compile(Object& _object, AbstractAssembly& _assembly, bool _yul, bool _evm15, bool _optimize)
{
EVMObjectCompiler compiler(_assembly, _yul, _evm15);
- compiler.run(_object);
+ compiler.run(_object, _optimize);
}
-void EVMObjectCompiler::run(Object& _object)
+void EVMObjectCompiler::run(Object& _object, bool _optimize)
{
map<YulString, AbstractAssembly::SubID> subIDs;
@@ -42,7 +42,7 @@ void EVMObjectCompiler::run(Object& _object)
{
auto subAssemblyAndID = m_assembly.createSubAssembly();
subIDs[subObject->name] = subAssemblyAndID.second;
- compile(*subObject, *subAssemblyAndID.first, m_yul, m_evm15);
+ compile(*subObject, *subAssemblyAndID.first, m_yul, m_evm15, _optimize);
}
else
{
@@ -51,5 +51,6 @@ void EVMObjectCompiler::run(Object& _object)
}
yulAssert(_object.analysisInfo, "No analysis info.");
- CodeTransform{m_assembly, *_object.analysisInfo, m_yul, m_evm15}(*_object.code);
+ yulAssert(_object.code, "No code.");
+ CodeTransform{m_assembly, *_object.analysisInfo, *_object.code, _optimize, m_yul, m_evm15}(*_object.code);
}