aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex Beregszaszi <alex@rtfs.hu>2016-11-01 07:17:09 +0800
committerAlex Beregszaszi <alex@rtfs.hu>2016-11-01 07:17:55 +0800
commit75b1ae89102d1f917b59b3fa67046181cd74aa7e (patch)
tree58ed4e8106c9f96bdcbbe9a48d5d4fbb0960cf92
parent6d97a56af17d65425d72c5df973b2fa4fac74a7a (diff)
downloaddexon-solidity-75b1ae89102d1f917b59b3fa67046181cd74aa7e.tar.gz
dexon-solidity-75b1ae89102d1f917b59b3fa67046181cd74aa7e.tar.zst
dexon-solidity-75b1ae89102d1f917b59b3fa67046181cd74aa7e.zip
LLL: only support variable length bigendian numbers in LIT
-rw-r--r--liblll/CodeFragment.cpp15
1 files changed, 2 insertions, 13 deletions
diff --git a/liblll/CodeFragment.cpp b/liblll/CodeFragment.cpp
index f143ca43..1bf587ce 100644
--- a/liblll/CodeFragment.cpp
+++ b/liblll/CodeFragment.cpp
@@ -297,21 +297,10 @@ void CodeFragment::constructOperation(sp::utree const& _t, CompilerState& _s)
bigint bi = *i.get<bigint*>();
if (bi < 0)
error<IntegerOutOfRange>();
- else if (bi > bigint(u256(0) - 1))
- {
- if (ii == 2 && _t.size() == 3)
- {
- // One big int - allow it as hex.
- data.resize(bytesRequired(bi));
- toBigEndian(bi, data);
- }
- else
- error<IntegerOutOfRange>();
- }
else
{
- data.resize(data.size() + 32);
- *(h256*)(&data.back() - 31) = (u256)bi;
+ bytes tmp = toCompactBigEndian(bi);
+ data.insert(data.end(), tmp.begin(), tmp.end());
}
}
else if (ii)