diff options
author | chriseth <chris@ethereum.org> | 2018-12-05 01:57:07 +0800 |
---|---|---|
committer | chriseth <chris@ethereum.org> | 2018-12-06 21:32:04 +0800 |
commit | f6ed29b88b0a721984173df04f04ad4c48d8711d (patch) | |
tree | 58d4f4345cea8c3f4b4d236203102638b835d9b3 /libsolidity/codegen/AsmCodeGen.cpp | |
parent | 4721cf332f0ca8af5fa16244c651cd6a635b3cdc (diff) | |
download | dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.tar dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.tar.gz dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.tar.bz2 dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.tar.lz dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.tar.xz dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.tar.zst dexon-solidity-f6ed29b88b0a721984173df04f04ad4c48d8711d.zip |
Extend abstract assembly to be able to handle sub-objects.
Diffstat (limited to 'libsolidity/codegen/AsmCodeGen.cpp')
-rw-r--r-- | libsolidity/codegen/AsmCodeGen.cpp | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/libsolidity/codegen/AsmCodeGen.cpp b/libsolidity/codegen/AsmCodeGen.cpp index 4ca0c4e2..dfcc900b 100644 --- a/libsolidity/codegen/AsmCodeGen.cpp +++ b/libsolidity/codegen/AsmCodeGen.cpp @@ -27,10 +27,13 @@ #include <libyul/backends/evm/EVMCodeTransform.h> #include <libevmasm/Assembly.h> +#include <libevmasm/AssemblyItem.h> #include <libevmasm/Instruction.h> #include <liblangutil/SourceLocation.h> +#include <libdevcore/FixedHash.h> + #include <memory> #include <functional> @@ -131,6 +134,39 @@ void EthAssemblyAdapter::appendAssemblySize() m_assembly.appendProgramSize(); } +pair<shared_ptr<AbstractAssembly>, AbstractAssembly::SubID> EthAssemblyAdapter::createSubAssembly() +{ + shared_ptr<eth::Assembly> assembly{make_shared<eth::Assembly>()}; + auto sub = m_assembly.newSub(assembly); + return {make_shared<EthAssemblyAdapter>(*assembly), size_t(sub.data())}; +} + +void EthAssemblyAdapter::appendDataOffset(AbstractAssembly::SubID _sub) +{ + auto it = m_dataHashBySubId.find(_sub); + if (it == m_dataHashBySubId.end()) + m_assembly.pushSubroutineOffset(size_t(_sub)); + else + m_assembly << eth::AssemblyItem(eth::PushData, it->second); +} + +void EthAssemblyAdapter::appendDataSize(AbstractAssembly::SubID _sub) +{ + auto it = m_dataHashBySubId.find(_sub); + if (it == m_dataHashBySubId.end()) + m_assembly.pushSubroutineSize(size_t(_sub)); + else + m_assembly << u256(m_assembly.data(h256(it->second)).size()); +} + +AbstractAssembly::SubID EthAssemblyAdapter::appendData(bytes const& _data) +{ + eth::AssemblyItem pushData = m_assembly.newData(_data); + SubID subID = m_nextDataCounter++; + m_dataHashBySubId[subID] = pushData.data(); + return subID; +} + EthAssemblyAdapter::LabelID EthAssemblyAdapter::assemblyTagToIdentifier(eth::AssemblyItem const& _tag) { u256 id = _tag.data(); |