|
@ -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; |
|
|