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:
Evgenii Stratonikov 2023-10-05 15:57:50 +03:00
parent 91c928e8d3
commit 96ee2e2b2d
2 changed files with 13 additions and 1 deletions

View file

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

View file

@ -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) {