Browse Source

Numeric mem literals.

cl-refactor
Gav Wood 11 years ago
parent
commit
88d32f8aa5
  1. 17
      libethereum/Instruction.cpp

17
libethereum/Instruction.cpp

@ -568,6 +568,7 @@ void CodeFragment::constructOperation(sp::utree const& _t, CompilerState& _s)
error<IncorrectParameterCount>(); error<IncorrectParameterCount>();
unsigned ii = 0; unsigned ii = 0;
CodeFragment pos; CodeFragment pos;
bytes data;
for (auto const& i: _t) for (auto const& i: _t)
{ {
if (ii == 1) if (ii == 1)
@ -579,19 +580,25 @@ void CodeFragment::constructOperation(sp::utree const& _t, CompilerState& _s)
else if (ii == 2 && !i.tag() && i.which() == sp::utree_type::string_type) else if (ii == 2 && !i.tag() && i.which() == sp::utree_type::string_type)
{ {
auto sr = i.get<sp::basic_string<boost::iterator_range<char const*>, sp::utree_type::string_type>>(); auto sr = i.get<sp::basic_string<boost::iterator_range<char const*>, sp::utree_type::string_type>>();
appendPush(sr.end() - sr.begin()); data = bytes((byte const*)sr.begin(), (byte const*)sr.end());
appendInstruction(Instruction::DUP);
appendPushDataLocation(bytes((byte const*)sr.begin(), (byte const*)sr.end()));
appendFragment(pos, 1);
appendInstruction(Instruction::CODECOPY);
} }
else if (ii >= 2 && !i.tag() && i.which() == sp::utree_type::any_type) else if (ii >= 2 && !i.tag() && i.which() == sp::utree_type::any_type)
{ {
bigint bi = *i.get<bigint*>();
if (bi < 0 || bi > bigint(u256(0) - 1))
error<IntegerOutOfRange>();
data.resize(data.size() + 32);
*(h256*)(&data.back() - 31) = (u256)bi;
} }
else if (ii) else if (ii)
error<InvalidLiteral>(); error<InvalidLiteral>();
++ii; ++ii;
} }
appendPush(data.size());
appendInstruction(Instruction::DUP);
appendPushDataLocation(data);
appendFragment(pos, 1);
appendInstruction(Instruction::CODECOPY);
} }
else else
nonStandard = false; nonStandard = false;

Loading…
Cancel
Save