mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Group append() functions in libevmasm
This commit is contained in:
parent
608f36d77b
commit
535026b492
@ -69,6 +69,21 @@ void Assembly::append(Assembly const& _a, int _deposit)
|
|||||||
append(Instruction::POP);
|
append(Instruction::POP);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
AssemblyItem const& Assembly::append(AssemblyItem const& _i)
|
||||||
|
{
|
||||||
|
assertThrow(m_deposit >= 0, AssemblyException, "Stack underflow.");
|
||||||
|
m_deposit += _i.deposit();
|
||||||
|
m_items.push_back(_i);
|
||||||
|
if (m_items.back().location().isEmpty() && !m_currentSourceLocation.isEmpty())
|
||||||
|
m_items.back().setLocation(m_currentSourceLocation);
|
||||||
|
return back();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Assembly::injectStart(AssemblyItem const& _i)
|
||||||
|
{
|
||||||
|
m_items.insert(m_items.begin(), _i);
|
||||||
|
}
|
||||||
|
|
||||||
unsigned Assembly::bytesRequired(unsigned subTagSize) const
|
unsigned Assembly::bytesRequired(unsigned subTagSize) const
|
||||||
{
|
{
|
||||||
for (unsigned tagSize = subTagSize; true; ++tagSize)
|
for (unsigned tagSize = subTagSize; true; ++tagSize)
|
||||||
@ -323,16 +338,6 @@ Json::Value Assembly::assemblyJSON(StringMap const& _sourceCodes) const
|
|||||||
return root;
|
return root;
|
||||||
}
|
}
|
||||||
|
|
||||||
AssemblyItem const& Assembly::append(AssemblyItem const& _i)
|
|
||||||
{
|
|
||||||
assertThrow(m_deposit >= 0, AssemblyException, "Stack underflow.");
|
|
||||||
m_deposit += _i.deposit();
|
|
||||||
m_items.push_back(_i);
|
|
||||||
if (m_items.back().location().isEmpty() && !m_currentSourceLocation.isEmpty())
|
|
||||||
m_items.back().setLocation(m_currentSourceLocation);
|
|
||||||
return back();
|
|
||||||
}
|
|
||||||
|
|
||||||
AssemblyItem Assembly::namedTag(string const& _name)
|
AssemblyItem Assembly::namedTag(string const& _name)
|
||||||
{
|
{
|
||||||
assertThrow(!_name.empty(), AssemblyException, "Empty named tag.");
|
assertThrow(!_name.empty(), AssemblyException, "Empty named tag.");
|
||||||
@ -348,11 +353,6 @@ AssemblyItem Assembly::newPushLibraryAddress(string const& _identifier)
|
|||||||
return AssemblyItem(PushLibraryAddress, h);
|
return AssemblyItem(PushLibraryAddress, h);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Assembly::injectStart(AssemblyItem const& _i)
|
|
||||||
{
|
|
||||||
m_items.insert(m_items.begin(), _i);
|
|
||||||
}
|
|
||||||
|
|
||||||
Assembly& Assembly::optimise(bool _enable, EVMVersion _evmVersion, bool _isCreation, size_t _runs)
|
Assembly& Assembly::optimise(bool _enable, EVMVersion _evmVersion, bool _isCreation, size_t _runs)
|
||||||
{
|
{
|
||||||
OptimiserSettings settings;
|
OptimiserSettings settings;
|
||||||
|
@ -59,8 +59,10 @@ public:
|
|||||||
AssemblyItem newPushSubSize(u256 const& _subId) { return AssemblyItem(PushSubSize, _subId); }
|
AssemblyItem newPushSubSize(u256 const& _subId) { return AssemblyItem(PushSubSize, _subId); }
|
||||||
AssemblyItem newPushLibraryAddress(std::string const& _identifier);
|
AssemblyItem newPushLibraryAddress(std::string const& _identifier);
|
||||||
|
|
||||||
|
// These two are only used by liblll
|
||||||
void append(Assembly const& _a);
|
void append(Assembly const& _a);
|
||||||
void append(Assembly const& _a, int _deposit);
|
void append(Assembly const& _a, int _deposit);
|
||||||
|
|
||||||
AssemblyItem const& append(AssemblyItem const& _i);
|
AssemblyItem const& append(AssemblyItem const& _i);
|
||||||
AssemblyItem const& append(std::string const& _data) { return append(newPushString(_data)); }
|
AssemblyItem const& append(std::string const& _data) { return append(newPushString(_data)); }
|
||||||
AssemblyItem const& append(bytes const& _data) { return append(newData(_data)); }
|
AssemblyItem const& append(bytes const& _data) { return append(newData(_data)); }
|
||||||
|
Loading…
Reference in New Issue
Block a user