X7ROOT File Manager
Current Path:
/opt/golang/1.19.4/src/math/big
opt
/
golang
/
1.19.4
/
src
/
math
/
big
/
📁
..
📄
accuracy_string.go
(414 B)
📄
alias_test.go
(8.81 KB)
📄
arith.go
(8.28 KB)
📄
arith_386.s
(4.07 KB)
📄
arith_amd64.go
(306 B)
📄
arith_amd64.s
(9.09 KB)
📄
arith_arm.s
(4.03 KB)
📄
arith_arm64.s
(11.88 KB)
📄
arith_decl.go
(594 B)
📄
arith_decl_pure.go
(1.04 KB)
📄
arith_decl_s390x.go
(531 B)
📄
arith_loong64.s
(745 B)
📄
arith_mips64x.s
(817 B)
📄
arith_mipsx.s
(809 B)
📄
arith_ppc64x.s
(16.36 KB)
📄
arith_riscv64.s
(786 B)
📄
arith_s390x.s
(20.32 KB)
📄
arith_s390x_test.go
(812 B)
📄
arith_test.go
(19.88 KB)
📄
arith_wasm.s
(641 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.79 KB)
📄
example_rat_test.go
(1.68 KB)
📄
example_test.go
(4.05 KB)
📄
float.go
(44.28 KB)
📄
float_test.go
(51.94 KB)
📄
floatconv.go
(8.34 KB)
📄
floatconv_test.go
(24.27 KB)
📄
floatexample_test.go
(3.63 KB)
📄
floatmarsh.go
(3.53 KB)
📄
floatmarsh_test.go
(3.92 KB)
📄
ftoa.go
(13.55 KB)
📄
gcd_test.go
(2.16 KB)
📄
hilbert_test.go
(2.88 KB)
📄
int.go
(30.26 KB)
📄
int_test.go
(53.14 KB)
📄
intconv.go
(6.69 KB)
📄
intconv_test.go
(10.01 KB)
📄
intmarsh.go
(2.14 KB)
📄
intmarsh_test.go
(3.07 KB)
📄
link_test.go
(1.4 KB)
📄
nat.go
(26.73 KB)
📄
nat_test.go
(23.56 KB)
📄
natconv.go
(14.55 KB)
📄
natconv_test.go
(16.85 KB)
📄
natdiv.go
(34.15 KB)
📄
prime.go
(10.34 KB)
📄
prime_test.go
(7.1 KB)
📄
rat.go
(13.47 KB)
📄
rat_test.go
(18.89 KB)
📄
ratconv.go
(9.78 KB)
📄
ratconv_test.go
(15.75 KB)
📄
ratmarsh.go
(2.1 KB)
📄
ratmarsh_test.go
(3.3 KB)
📄
roundingmode_string.go
(501 B)
📄
sqrt.go
(2.79 KB)
📄
sqrt_test.go
(4.81 KB)
Editing: ratmarsh_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" "encoding/xml" "testing" ) func TestRatGobEncoding(t *testing.T) { var medium bytes.Buffer enc := gob.NewEncoder(&medium) dec := gob.NewDecoder(&medium) for _, test := range encodingTests { medium.Reset() // empty buffer for each test case (in case of failures) var tx Rat tx.SetString(test + ".14159265") if err := enc.Encode(&tx); err != nil { t.Errorf("encoding of %s failed: %s", &tx, err) continue } var rx Rat if err := dec.Decode(&rx); err != nil { t.Errorf("decoding of %s failed: %s", &tx, err) continue } if rx.Cmp(&tx) != 0 { t.Errorf("transmission of %s failed: got %s want %s", &tx, &rx, &tx) } } } // Sending a nil Rat pointer (inside a slice) on a round trip through gob should yield a zero. // TODO: top-level nils. func TestGobEncodingNilRatInSlice(t *testing.T) { buf := new(bytes.Buffer) enc := gob.NewEncoder(buf) dec := gob.NewDecoder(buf) var in = make([]*Rat, 1) err := enc.Encode(&in) if err != nil { t.Errorf("gob encode failed: %q", err) } var out []*Rat err = dec.Decode(&out) if err != nil { t.Fatalf("gob decode failed: %q", err) } if len(out) != 1 { t.Fatalf("wrong len; want 1 got %d", len(out)) } var zero Rat if out[0].Cmp(&zero) != 0 { t.Fatalf("transmission of (*Int)(nil) failed: got %s want 0", out) } } var ratNums = []string{ "-141592653589793238462643383279502884197169399375105820974944592307816406286", "-1415926535897932384626433832795028841971", "-141592653589793", "-1", "0", "1", "141592653589793", "1415926535897932384626433832795028841971", "141592653589793238462643383279502884197169399375105820974944592307816406286", } var ratDenoms = []string{ "1", "718281828459045", "7182818284590452353602874713526624977572", "718281828459045235360287471352662497757247093699959574966967627724076630353", } func TestRatJSONEncoding(t *testing.T) { for _, num := range ratNums { for _, denom := range ratDenoms { var tx Rat tx.SetString(num + "/" + denom) b, err := json.Marshal(&tx) if err != nil { t.Errorf("marshaling of %s failed: %s", &tx, err) continue } var rx Rat if err := json.Unmarshal(b, &rx); err != nil { t.Errorf("unmarshaling of %s failed: %s", &tx, err) continue } if rx.Cmp(&tx) != 0 { t.Errorf("JSON encoding of %s failed: got %s want %s", &tx, &rx, &tx) } } } } func TestRatXMLEncoding(t *testing.T) { for _, num := range ratNums { for _, denom := range ratDenoms { var tx Rat tx.SetString(num + "/" + denom) b, err := xml.Marshal(&tx) if err != nil { t.Errorf("marshaling of %s failed: %s", &tx, err) continue } var rx Rat if err := xml.Unmarshal(b, &rx); err != nil { t.Errorf("unmarshaling of %s failed: %s", &tx, err) continue } if rx.Cmp(&tx) != 0 { t.Errorf("XML encoding of %s failed: got %s want %s", &tx, &rx, &tx) } } } } func TestRatGobDecodeShortBuffer(t *testing.T) { for _, tc := range [][]byte{ []byte{0x2}, []byte{0x2, 0x0, 0x0, 0x0, 0xff}, } { err := NewRat(1, 2).GobDecode(tc) if err == nil { t.Error("expected GobDecode to return error for malformed input") } } }
Upload File
Create Folder