forked from TrueCloudLab/neoneo-go
compiler: Fix emitting big uint64 constants
Currently we take int64 value from the Go parser and push it to the stack. Using uint64 is not a common practice (usually we just use `int`), but can be a problem while doing bit arithmetic and serializing numbers. Signed-off-by: Evgenii Stratonikov <fyfyrchik@runbox.com>
This commit is contained in:
parent
91c928e8d3
commit
96ee2e2b2d
2 changed files with 13 additions and 1 deletions
|
@ -9,6 +9,7 @@ import (
|
||||||
"go/token"
|
"go/token"
|
||||||
"go/types"
|
"go/types"
|
||||||
"math"
|
"math"
|
||||||
|
"math/big"
|
||||||
"sort"
|
"sort"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
@ -208,9 +209,12 @@ func (c *codegen) emitLoadConst(t types.TypeAndValue) {
|
||||||
case types.Int, types.UntypedInt, types.Uint,
|
case types.Int, types.UntypedInt, types.Uint,
|
||||||
types.Int8, types.Uint8,
|
types.Int8, types.Uint8,
|
||||||
types.Int16, types.Uint16,
|
types.Int16, types.Uint16,
|
||||||
types.Int32, types.Uint32, types.Int64, types.Uint64:
|
types.Int32, types.Uint32, types.Int64:
|
||||||
val, _ := constant.Int64Val(t.Value)
|
val, _ := constant.Int64Val(t.Value)
|
||||||
emit.Int(c.prog.BinWriter, val)
|
emit.Int(c.prog.BinWriter, val)
|
||||||
|
case types.Uint64:
|
||||||
|
val, _ := constant.Int64Val(t.Value)
|
||||||
|
emit.BigInt(c.prog.BinWriter, new(big.Int).SetUint64(uint64(val)))
|
||||||
case types.String, types.UntypedString:
|
case types.String, types.UntypedString:
|
||||||
val := constant.StringVal(t.Value)
|
val := constant.StringVal(t.Value)
|
||||||
emit.String(c.prog.BinWriter, val)
|
emit.String(c.prog.BinWriter, val)
|
||||||
|
|
|
@ -18,6 +18,14 @@ var numericTestCases = []testCase{
|
||||||
`,
|
`,
|
||||||
big.NewInt(6),
|
big.NewInt(6),
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"shift uint64",
|
||||||
|
`package foo
|
||||||
|
func Main() uint64 {
|
||||||
|
return 1 << 63
|
||||||
|
}`,
|
||||||
|
new(big.Int).SetUint64(1 << 63),
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestNumericExprs(t *testing.T) {
|
func TestNumericExprs(t *testing.T) {
|
||||||
|
|
Loading…
Reference in a new issue