|
@ -99,6 +99,8 @@ void Assembly::append(Assembly const& _a) |
|
|
{ |
|
|
{ |
|
|
if (i.type() == Tag || i.type() == PushTag) |
|
|
if (i.type() == Tag || i.type() == PushTag) |
|
|
i.m_data += m_usedTags; |
|
|
i.m_data += m_usedTags; |
|
|
|
|
|
else if (i.type() == PushSub || i.type() == PushSubSize) |
|
|
|
|
|
i.m_data += m_subs.size(); |
|
|
append(i); |
|
|
append(i); |
|
|
} |
|
|
} |
|
|
m_deposit = newDeposit; |
|
|
m_deposit = newDeposit; |
|
@ -108,7 +110,7 @@ void Assembly::append(Assembly const& _a) |
|
|
for (auto const& i: _a.m_strings) |
|
|
for (auto const& i: _a.m_strings) |
|
|
m_strings.insert(i); |
|
|
m_strings.insert(i); |
|
|
for (auto const& i: _a.m_subs) |
|
|
for (auto const& i: _a.m_subs) |
|
|
m_subs.insert(i); |
|
|
m_subs.push_back(i); |
|
|
|
|
|
|
|
|
assert(!_a.m_baseDeposit); |
|
|
assert(!_a.m_baseDeposit); |
|
|
assert(!_a.m_totalDeposit); |
|
|
assert(!_a.m_totalDeposit); |
|
@ -245,12 +247,12 @@ ostream& Assembly::streamRLP(ostream& _out, string const& _prefix, StringMap con |
|
|
{ |
|
|
{ |
|
|
_out << _prefix << ".data:" << endl; |
|
|
_out << _prefix << ".data:" << endl; |
|
|
for (auto const& i: m_data) |
|
|
for (auto const& i: m_data) |
|
|
if (!m_subs.count(i.first)) |
|
|
if (u256(i.first) >= m_subs.size()) |
|
|
_out << _prefix << " " << hex << (unsigned)(u256)i.first << ": " << toHex(i.second) << endl; |
|
|
_out << _prefix << " " << hex << (unsigned)(u256)i.first << ": " << toHex(i.second) << endl; |
|
|
for (auto const& i: m_subs) |
|
|
for (size_t i = 0; i < m_subs.size(); ++i) |
|
|
{ |
|
|
{ |
|
|
_out << _prefix << " " << hex << (unsigned)(u256)i.first << ": " << endl; |
|
|
_out << _prefix << " " << hex << i << ": " << endl; |
|
|
i.second.streamRLP(_out, _prefix + " ", _sourceCodes); |
|
|
m_subs[i].streamRLP(_out, _prefix + " ", _sourceCodes); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
return _out; |
|
|
return _out; |
|
@ -493,8 +495,8 @@ Assembly& Assembly::optimise(bool _enable) |
|
|
|
|
|
|
|
|
copt << total << " optimisations done."; |
|
|
copt << total << " optimisations done."; |
|
|
|
|
|
|
|
|
for (auto& i: m_subs) |
|
|
for (auto& sub: m_subs) |
|
|
i.second.optimise(true); |
|
|
sub.optimise(true); |
|
|
|
|
|
|
|
|
return *this; |
|
|
return *this; |
|
|
} |
|
|
} |
|
@ -511,8 +513,8 @@ bytes Assembly::assemble() const |
|
|
unsigned bytesPerTag = dev::bytesRequired(totalBytes); |
|
|
unsigned bytesPerTag = dev::bytesRequired(totalBytes); |
|
|
byte tagPush = (byte)Instruction::PUSH1 - 1 + bytesPerTag; |
|
|
byte tagPush = (byte)Instruction::PUSH1 - 1 + bytesPerTag; |
|
|
|
|
|
|
|
|
for (auto const& i: m_subs) |
|
|
for (size_t i = 0; i < m_subs.size(); ++i) |
|
|
m_data[i.first] = i.second.assemble(); |
|
|
m_data[u256(i)] = m_subs[i].assemble(); |
|
|
|
|
|
|
|
|
unsigned bytesRequiredIncludingData = bytesRequired(); |
|
|
unsigned bytesRequiredIncludingData = bytesRequired(); |
|
|
unsigned bytesPerDataRef = dev::bytesRequired(bytesRequiredIncludingData); |
|
|
unsigned bytesPerDataRef = dev::bytesRequired(bytesRequiredIncludingData); |
|
|