X7ROOT File Manager
Current Path:
/opt/golang/1.22.0/src/math/big
opt
/
golang
/
1.22.0
/
src
/
math
/
big
/
📁
..
📄
accuracy_string.go
(647 B)
📄
alias_test.go
(8.81 KB)
📄
arith.go
(8.28 KB)
📄
arith_386.s
(4.04 KB)
📄
arith_amd64.go
(278 B)
📄
arith_amd64.s
(9.07 KB)
📄
arith_arm.s
(4 KB)
📄
arith_arm64.s
(11.85 KB)
📄
arith_decl.go
(686 B)
📄
arith_decl_pure.go
(1.01 KB)
📄
arith_decl_s390x.go
(503 B)
📄
arith_loong64.s
(749 B)
📄
arith_mips64x.s
(763 B)
📄
arith_mipsx.s
(759 B)
📄
arith_ppc64x.s
(16.4 KB)
📄
arith_riscv64.s
(750 B)
📄
arith_s390x.s
(20.29 KB)
📄
arith_s390x_test.go
(770 B)
📄
arith_test.go
(19.88 KB)
📄
arith_wasm.s
(613 B)
📄
bits_test.go
(5.07 KB)
📄
calibrate_test.go
(4.63 KB)
📄
decimal.go
(6.63 KB)
📄
decimal_test.go
(3.33 KB)
📄
doc.go
(3.8 KB)
📄
example_rat_test.go
(1.68 KB)
📄
example_test.go
(4.05 KB)
📄
float.go
(44.55 KB)
📄
float_test.go
(51.94 KB)
📄
floatconv.go
(8.35 KB)
📄
floatconv_test.go
(24.27 KB)
📄
floatexample_test.go
(3.63 KB)
📄
floatmarsh.go
(3.65 KB)
📄
floatmarsh_test.go
(4.51 KB)
📄
ftoa.go
(13.5 KB)
📄
gcd_test.go
(2.16 KB)
📄
hilbert_test.go
(2.88 KB)
📄
int.go
(33.21 KB)
📄
int_test.go
(58.47 KB)
📄
intconv.go
(6.7 KB)
📄
intconv_test.go
(10.01 KB)
📄
intmarsh.go
(2.19 KB)
📄
intmarsh_test.go
(3.07 KB)
📄
link_test.go
(1.4 KB)
📄
nat.go
(31.81 KB)
📄
nat_test.go
(26.22 KB)
📄
natconv.go
(14.56 KB)
📄
natconv_test.go
(16.85 KB)
📄
natdiv.go
(34.36 KB)
📄
prime.go
(10.39 KB)
📄
prime_test.go
(7.1 KB)
📄
rat.go
(13.48 KB)
📄
rat_test.go
(18.89 KB)
📄
ratconv.go
(12.35 KB)
📄
ratconv_test.go
(19.31 KB)
📄
ratmarsh.go
(2.23 KB)
📄
ratmarsh_test.go
(3.34 KB)
📄
roundingmode_string.go
(819 B)
📄
sqrt.go
(2.79 KB)
📄
sqrt_test.go
(4.81 KB)
Editing: floatmarsh_test.go
// Copyright 2015 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. package big import ( "bytes" "encoding/gob" "encoding/json" "io" "strings" "testing" ) var floatVals = []string{ "0", "1", "0.1", "2.71828", "1234567890", "3.14e1234", "3.14e-1234", "0.738957395793475734757349579759957975985497e100", "0.73895739579347546656564656573475734957975995797598589749859834759476745986795497e100", "inf", "Inf", } func TestFloatGobEncoding(t *testing.T) { var medium bytes.Buffer enc := gob.NewEncoder(&medium) dec := gob.NewDecoder(&medium) for _, test := range floatVals { for _, sign := range []string{"", "+", "-"} { for _, prec := range []uint{0, 1, 2, 10, 53, 64, 100, 1000} { for _, mode := range []RoundingMode{ToNearestEven, ToNearestAway, ToZero, AwayFromZero, ToNegativeInf, ToPositiveInf} { medium.Reset() // empty buffer for each test case (in case of failures) x := sign + test var tx Float _, _, err := tx.SetPrec(prec).SetMode(mode).Parse(x, 0) if err != nil { t.Errorf("parsing of %s (%dbits, %v) failed (invalid test case): %v", x, prec, mode, err) continue } // If tx was set to prec == 0, tx.Parse(x, 0) assumes precision 64. Correct it. if prec == 0 { tx.SetPrec(0) } if err := enc.Encode(&tx); err != nil { t.Errorf("encoding of %v (%dbits, %v) failed: %v", &tx, prec, mode, err) continue } var rx Float if err := dec.Decode(&rx); err != nil { t.Errorf("decoding of %v (%dbits, %v) failed: %v", &tx, prec, mode, err) continue } if rx.Cmp(&tx) != 0 { t.Errorf("transmission of %s failed: got %s want %s", x, rx.String(), tx.String()) continue } if rx.Prec() != prec { t.Errorf("transmission of %s's prec failed: got %d want %d", x, rx.Prec(), prec) } if rx.Mode() != mode { t.Errorf("transmission of %s's mode failed: got %s want %s", x, rx.Mode(), mode) } if rx.Acc() != tx.Acc() { t.Errorf("transmission of %s's accuracy failed: got %s want %s", x, rx.Acc(), tx.Acc()) } } } } } } func TestFloatCorruptGob(t *testing.T) { var buf bytes.Buffer tx := NewFloat(4 / 3).SetPrec(1000).SetMode(ToPositiveInf) if err := gob.NewEncoder(&buf).Encode(tx); err != nil { t.Fatal(err) } b := buf.Bytes() var rx Float if err := gob.NewDecoder(bytes.NewReader(b)).Decode(&rx); err != nil { t.Fatal(err) } if err := gob.NewDecoder(bytes.NewReader(b[:10])).Decode(&rx); err != io.ErrUnexpectedEOF { t.Errorf("got %v want EOF", err) } b[1] = 0 if err := gob.NewDecoder(bytes.NewReader(b)).Decode(&rx); err == nil { t.Fatal("got nil want version error") } } func TestFloatJSONEncoding(t *testing.T) { for _, test := range floatVals { for _, sign := range []string{"", "+", "-"} { for _, prec := range []uint{0, 1, 2, 10, 53, 64, 100, 1000} { if prec > 53 && testing.Short() { continue } x := sign + test var tx Float _, _, err := tx.SetPrec(prec).Parse(x, 0) if err != nil { t.Errorf("parsing of %s (prec = %d) failed (invalid test case): %v", x, prec, err) continue } b, err := json.Marshal(&tx) if err != nil { t.Errorf("marshaling of %v (prec = %d) failed: %v", &tx, prec, err) continue } var rx Float rx.SetPrec(prec) if err := json.Unmarshal(b, &rx); err != nil { t.Errorf("unmarshaling of %v (prec = %d) failed: %v", &tx, prec, err) continue } if rx.Cmp(&tx) != 0 { t.Errorf("JSON encoding of %v (prec = %d) failed: got %v want %v", &tx, prec, &rx, &tx) } } } } } func TestFloatGobDecodeShortBuffer(t *testing.T) { for _, tc := range [][]byte{ []byte{0x1, 0x0, 0x0, 0x0}, []byte{0x1, 0xfa, 0x0, 0x0, 0x0, 0x0}, } { err := NewFloat(0).GobDecode(tc) if err == nil { t.Error("expected GobDecode to return error for malformed input") } } } func TestFloatGobDecodeInvalid(t *testing.T) { for _, tc := range []struct { buf []byte msg string }{ { []byte{0x1, 0x2a, 0x20, 0x20, 0x20, 0x20, 0x0, 0x20, 0x20, 0x20, 0x0, 0x20, 0x20, 0x20, 0x20, 0x0, 0x0, 0x0, 0x0, 0xc}, "Float.GobDecode: msb not set in last word", }, { []byte{1, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0}, "Float.GobDecode: nonzero finite number with empty mantissa", }, } { err := NewFloat(0).GobDecode(tc.buf) if err == nil || !strings.HasPrefix(err.Error(), tc.msg) { t.Errorf("expected GobDecode error prefix: %s, got: %v", tc.msg, err) } } }
Upload File
Create Folder