From 81c397538ebfc2086c671dea89623d386835359a Mon Sep 17 00:00:00 2001 From: Jacob Date: Fri, 19 Mar 2021 14:10:15 +0100 Subject: [PATCH] Fix a few unnecessary type conversions (#339) This PR gets rid of a bunch of unneeded type conversions. I was checking out the code and saw a few of these myself, but most of them were fixed using unconvert. --- flate/fast_encoder.go | 2 +- flate/level2.go | 2 +- fse/compress.go | 10 +++++----- fse/decompress.go | 4 ++-- huff0/compress.go | 4 ++-- s2/s2.go | 2 +- snappy/snappy.go | 2 +- zip/reader.go | 4 ++-- zip/reader_test.go | 2 +- zip/zip_test.go | 2 +- zstd/encoder_test.go | 16 ++++++++-------- zstd/fse_encoder.go | 12 ++++++------ zstd/snappy.go | 2 +- 13 files changed, 32 insertions(+), 32 deletions(-) diff --git a/flate/fast_encoder.go b/flate/fast_encoder.go index f2477abfcb..678f081052 100644 --- a/flate/fast_encoder.go +++ b/flate/fast_encoder.go @@ -237,7 +237,7 @@ func matchLen(a, b []byte) int { b = b[:len(a)] for i := range a { if a[i] != b[i] { - return int(i) + checked + return i + checked } } return len(a) + checked diff --git a/flate/level2.go b/flate/level2.go index 5b986a1944..234c4389ab 100644 --- a/flate/level2.go +++ b/flate/level2.go @@ -155,7 +155,7 @@ func (e *fastEncL2) Encode(dst *tokens, src []byte) { // Store every second hash in-between, but offset by 1. for i := s - l + 2; i < s-5; i += 7 { - x := load6432(src, int32(i)) + x := load6432(src, i) nextHash := hash4u(uint32(x), bTableBits) e.table[nextHash] = tableEntry{offset: e.cur + i} // Skip one diff --git a/fse/compress.go b/fse/compress.go index b69237c9b8..0d31f5ebc9 100644 --- a/fse/compress.go +++ b/fse/compress.go @@ -301,7 +301,7 @@ func (s *Scratch) writeCount() error { out[outP+1] = byte(bitStream >> 8) outP += (bitCount + 7) / 8 - if uint16(charnum) > s.symbolLen { + if charnum > s.symbolLen { return errors.New("internal error: charnum > s.symbolLen") } s.Out = out[:outP] @@ -331,7 +331,7 @@ type cTable struct { func (s *Scratch) allocCtable() { tableSize := 1 << s.actualTableLog // get tableSymbol that is big enough. - if cap(s.ct.tableSymbol) < int(tableSize) { + if cap(s.ct.tableSymbol) < tableSize { s.ct.tableSymbol = make([]byte, tableSize) } s.ct.tableSymbol = s.ct.tableSymbol[:tableSize] @@ -565,8 +565,8 @@ func (s *Scratch) normalizeCount2() error { distributed uint32 total = uint32(s.br.remain()) tableLog = s.actualTableLog - lowThreshold = uint32(total >> tableLog) - lowOne = uint32((total * 3) >> (tableLog + 1)) + lowThreshold = total >> tableLog + lowOne = (total * 3) >> (tableLog + 1) ) for i, cnt := range s.count[:s.symbolLen] { if cnt == 0 { @@ -591,7 +591,7 @@ func (s *Scratch) normalizeCount2() error { if (total / toDistribute) > lowOne { // risk of rounding to zero - lowOne = uint32((total * 3) / (toDistribute * 2)) + lowOne = (total * 3) / (toDistribute * 2) for i, cnt := range s.count[:s.symbolLen] { if (s.norm[i] == notYetAssigned) && (cnt <= lowOne) { s.norm[i] = 1 diff --git a/fse/decompress.go b/fse/decompress.go index 413ec3b3cd..926f5f1535 100644 --- a/fse/decompress.go +++ b/fse/decompress.go @@ -172,7 +172,7 @@ type decSymbol struct { // allocDtable will allocate decoding tables if they are not big enough. func (s *Scratch) allocDtable() { tableSize := 1 << s.actualTableLog - if cap(s.decTable) < int(tableSize) { + if cap(s.decTable) < tableSize { s.decTable = make([]decSymbol, tableSize) } s.decTable = s.decTable[:tableSize] @@ -340,7 +340,7 @@ type decoder struct { func (d *decoder) init(in *bitReader, dt []decSymbol, tableLog uint8) { d.dt = dt d.br = in - d.state = uint16(in.getBits(tableLog)) + d.state = in.getBits(tableLog) } // next returns the next symbol and sets the next state. diff --git a/huff0/compress.go b/huff0/compress.go index f9ed5f8306..dea115b334 100644 --- a/huff0/compress.go +++ b/huff0/compress.go @@ -403,7 +403,7 @@ func (s *Scratch) buildCTable() error { var startNode = int16(s.symbolLen) nonNullRank := s.symbolLen - 1 - nodeNb := int16(startNode) + nodeNb := startNode huffNode := s.nodes[1 : huffNodesLen+1] // This overlays the slice above, but allows "-1" index lookups. @@ -580,7 +580,7 @@ func (s *Scratch) setMaxHeight(lastNonNull int) uint8 { // Get pos of last (smallest) symbol per rank { - currentNbBits := uint8(maxNbBits) + currentNbBits := maxNbBits for pos := int(n); pos >= 0; pos-- { if huffNode[pos].nbBits >= currentNbBits { continue diff --git a/s2/s2.go b/s2/s2.go index a3e4abfe4d..46622e117b 100644 --- a/s2/s2.go +++ b/s2/s2.go @@ -106,7 +106,7 @@ var crcTable = crc32.MakeTable(crc32.Castagnoli) // https://github.com/google/snappy/blob/master/framing_format.txt func crc(b []byte) uint32 { c := crc32.Update(0, crcTable, b) - return uint32(c>>15|c<<17) + 0xa282ead8 + return c>>15 | c<<17 + 0xa282ead8 } // literalExtraSize returns the extra size of encoding n literals. diff --git a/snappy/snappy.go b/snappy/snappy.go index 74a36689e8..ea58ced882 100644 --- a/snappy/snappy.go +++ b/snappy/snappy.go @@ -94,5 +94,5 @@ var crcTable = crc32.MakeTable(crc32.Castagnoli) // https://github.com/google/snappy/blob/master/framing_format.txt func crc(b []byte) uint32 { c := crc32.Update(0, crcTable, b) - return uint32(c>>15|c<<17) + 0xa282ead8 + return c>>15 | c<<17 + 0xa282ead8 } diff --git a/zip/reader.go b/zip/reader.go index 9fab6e3878..030b460b2b 100644 --- a/zip/reader.go +++ b/zip/reader.go @@ -374,8 +374,8 @@ parseExtras: const ticksPerSecond = 1e7 // Windows timestamp resolution ts := int64(attrBuf.uint64()) // ModTime since Windows epoch - secs := int64(ts / ticksPerSecond) - nsecs := (1e9 / ticksPerSecond) * int64(ts%ticksPerSecond) + secs := ts / ticksPerSecond + nsecs := (1e9 / ticksPerSecond) * (ts % ticksPerSecond) epoch := time.Date(1601, time.January, 1, 0, 0, 0, 0, time.UTC) modified = time.Unix(epoch.Unix()+secs, nsecs) } diff --git a/zip/reader_test.go b/zip/reader_test.go index 6b3f2f33bb..0275e91b77 100644 --- a/zip/reader_test.go +++ b/zip/reader_test.go @@ -1047,7 +1047,7 @@ func TestIssue12449(t *testing.T) { 0x00, 0x50, 0x00, 0x00, 0x00, 0x00, 0x00, } // Read in the archive. - _, err := NewReader(bytes.NewReader([]byte(data)), int64(len(data))) + _, err := NewReader(bytes.NewReader(data), int64(len(data))) if err != nil { t.Errorf("Error reading the archive: %v", err) } diff --git a/zip/zip_test.go b/zip/zip_test.go index 3a3a4e07f8..a01e1963f7 100644 --- a/zip/zip_test.go +++ b/zip/zip_test.go @@ -597,7 +597,7 @@ func testZip64(t testing.TB, size int64) *rleBuffer { } // read back zip file and check that we get to the end of it - r, err := NewReader(buf, int64(buf.Size())) + r, err := NewReader(buf, buf.Size()) if err != nil { t.Fatal("reader:", err) } diff --git a/zstd/encoder_test.go b/zstd/encoder_test.go index e131753516..918d543a38 100644 --- a/zstd/encoder_test.go +++ b/zstd/encoder_test.go @@ -35,7 +35,7 @@ func TestEncoder_EncodeAllSimple(t *testing.T) { defer dec.Close() in = append(in, in...) - for level := EncoderLevel(speedNotSet + 1); level < speedLast; level++ { + for level := speedNotSet + 1; level < speedLast; level++ { t.Run(level.String(), func(t *testing.T) { e, err := NewWriter(nil, WithEncoderLevel(level), WithEncoderConcurrency(2), WithWindowSize(128<<10), WithZeroFrames(true)) if err != nil { @@ -79,7 +79,7 @@ func TestEncoder_EncodeAllConcurrent(t *testing.T) { t.Fatal(err) } defer dec.Close() - for level := EncoderLevel(speedNotSet + 1); level < speedLast; level++ { + for level := speedNotSet + 1; level < speedLast; level++ { t.Run(level.String(), func(t *testing.T) { rng := rand.New(rand.NewSource(0x1337)) e, err := NewWriter(nil, WithEncoderLevel(level), WithZeroFrames(true)) @@ -131,7 +131,7 @@ func TestEncoder_EncodeAllEncodeXML(t *testing.T) { in = in[:10000] } - for level := EncoderLevel(speedNotSet + 1); level < speedLast; level++ { + for level := speedNotSet + 1; level < speedLast; level++ { t.Run(level.String(), func(t *testing.T) { e, err := NewWriter(nil, WithEncoderLevel(level)) if err != nil { @@ -174,7 +174,7 @@ func TestEncoderRegression(t *testing.T) { if testing.Short() { testWindowSizes = []int{1 << 20} } - for level := EncoderLevel(speedNotSet + 1); level < speedLast; level++ { + for level := speedNotSet + 1; level < speedLast; level++ { t.Run(level.String(), func(t *testing.T) { for _, windowSize := range testWindowSizes { t.Run(fmt.Sprintf("window:%d", windowSize), func(t *testing.T) { @@ -260,7 +260,7 @@ func TestEncoder_EncodeAllTwain(t *testing.T) { } defer dec.Close() - for level := EncoderLevel(speedNotSet + 1); level < speedLast; level++ { + for level := speedNotSet + 1; level < speedLast; level++ { t.Run(level.String(), func(t *testing.T) { for _, windowSize := range testWindowSizes { t.Run(fmt.Sprintf("window:%d", windowSize), func(t *testing.T) { @@ -306,7 +306,7 @@ func TestEncoder_EncodeAllPi(t *testing.T) { } defer dec.Close() - for level := EncoderLevel(speedNotSet + 1); level < speedLast; level++ { + for level := speedNotSet + 1; level < speedLast; level++ { t.Run(level.String(), func(t *testing.T) { for _, windowSize := range testWindowSizes { t.Run(fmt.Sprintf("window:%d", windowSize), func(t *testing.T) { @@ -885,7 +885,7 @@ func BenchmarkEncoder_EncodeAllSimple(b *testing.B) { b.Fatal(err) } - for level := EncoderLevel(speedNotSet + 1); level < speedLast; level++ { + for level := speedNotSet + 1; level < speedLast; level++ { b.Run(level.String(), func(b *testing.B) { enc, err := NewWriter(nil, WithEncoderConcurrency(1), WithEncoderLevel(level)) if err != nil { @@ -918,7 +918,7 @@ func BenchmarkEncoder_EncodeAllSimple4K(b *testing.B) { } in = in[:4096] - for level := EncoderLevel(speedNotSet + 1); level < speedLast; level++ { + for level := speedNotSet + 1; level < speedLast; level++ { b.Run(level.String(), func(b *testing.B) { enc, err := NewWriter(nil, WithEncoderConcurrency(1), WithEncoderLevel(level)) if err != nil { diff --git a/zstd/fse_encoder.go b/zstd/fse_encoder.go index aa9eba88b8..b80709d5ea 100644 --- a/zstd/fse_encoder.go +++ b/zstd/fse_encoder.go @@ -97,7 +97,7 @@ func (s *fseEncoder) prepare() (*fseEncoder, error) { func (s *fseEncoder) allocCtable() { tableSize := 1 << s.actualTableLog // get tableSymbol that is big enough. - if cap(s.ct.tableSymbol) < int(tableSize) { + if cap(s.ct.tableSymbol) < tableSize { s.ct.tableSymbol = make([]byte, tableSize) } s.ct.tableSymbol = s.ct.tableSymbol[:tableSize] @@ -202,13 +202,13 @@ func (s *fseEncoder) buildCTable() error { case 0: case -1, 1: symbolTT[i].deltaNbBits = tl - symbolTT[i].deltaFindState = int16(total - 1) + symbolTT[i].deltaFindState = total - 1 total++ default: maxBitsOut := uint32(tableLog) - highBit(uint32(v-1)) minStatePlus := uint32(v) << maxBitsOut symbolTT[i].deltaNbBits = (maxBitsOut << 16) - minStatePlus - symbolTT[i].deltaFindState = int16(total - v) + symbolTT[i].deltaFindState = total - v total += v } } @@ -353,8 +353,8 @@ func (s *fseEncoder) normalizeCount2(length int) error { distributed uint32 total = uint32(length) tableLog = s.actualTableLog - lowThreshold = uint32(total >> tableLog) - lowOne = uint32((total * 3) >> (tableLog + 1)) + lowThreshold = total >> tableLog + lowOne = (total * 3) >> (tableLog + 1) ) for i, cnt := range s.count[:s.symbolLen] { if cnt == 0 { @@ -379,7 +379,7 @@ func (s *fseEncoder) normalizeCount2(length int) error { if (total / toDistribute) > lowOne { // risk of rounding to zero - lowOne = uint32((total * 3) / (toDistribute * 2)) + lowOne = (total * 3) / (toDistribute * 2) for i, cnt := range s.count[:s.symbolLen] { if (s.norm[i] == notYetAssigned) && (cnt <= lowOne) { s.norm[i] = 1 diff --git a/zstd/snappy.go b/zstd/snappy.go index 841fd95acc..c95fe5111c 100644 --- a/zstd/snappy.go +++ b/zstd/snappy.go @@ -417,7 +417,7 @@ var crcTable = crc32.MakeTable(crc32.Castagnoli) // https://github.com/google/snappy/blob/master/framing_format.txt func snappyCRC(b []byte) uint32 { c := crc32.Update(0, crcTable, b) - return uint32(c>>15|c<<17) + 0xa282ead8 + return c>>15 | c<<17 + 0xa282ead8 } // snappyDecodedLen returns the length of the decoded block and the number of bytes