diff options
author | chriseth <chris@ethereum.org> | 2018-12-10 23:14:33 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-12-10 23:14:33 +0800 |
commit | 871ea22bb9158e23254406d21673cfbeda2d7138 (patch) | |
tree | d2a3e88b0c22ee008a0bd480fdf78581d7f5eb67 /libyul/backends/evm/EVMObjectCompiler.cpp | |
parent | 055c5fe173b90b7d07f1170de5d7018140296f89 (diff) | |
parent | b05d33d7714c5dbbb034d29b2eea8171807d093b (diff) | |
download | dexon-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.cpp | 11 |
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); } |