This commit implements a massive refactor of the repository, and moves the build system over to use Mage (magefile.org) which should allow seamless building across multiple platforms.
46 lines
1.1 KiB
Go
46 lines
1.1 KiB
Go
// Copyright 2014-2017 Ulrich Kunitz. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package lzma
|
|
|
|
/* Naming conventions follows the CodeReviewComments in the Go Wiki. */
|
|
|
|
// ntz32Const is used by the functions NTZ and NLZ.
|
|
const ntz32Const = 0x04d7651f
|
|
|
|
// ntz32Table is a helper table for de Bruijn algorithm by Danny Dubé.
|
|
// See Henry S. Warren, Jr. "Hacker's Delight" section 5-1 figure 5-26.
|
|
var ntz32Table = [32]int8{
|
|
0, 1, 2, 24, 3, 19, 6, 25,
|
|
22, 4, 20, 10, 16, 7, 12, 26,
|
|
31, 23, 18, 5, 21, 9, 15, 11,
|
|
30, 17, 8, 14, 29, 13, 28, 27,
|
|
}
|
|
|
|
// ntz32 computes the number of trailing zeros for an unsigned 32-bit integer.
|
|
func ntz32(x uint32) int {
|
|
if x == 0 {
|
|
return 32
|
|
}
|
|
x = (x & -x) * ntz32Const
|
|
return int(ntz32Table[x>>27])
|
|
}
|
|
|
|
// nlz32 computes the number of leading zeros for an unsigned 32-bit integer.
|
|
func nlz32(x uint32) int {
|
|
// Smear left most bit to the right
|
|
x |= x >> 1
|
|
x |= x >> 2
|
|
x |= x >> 4
|
|
x |= x >> 8
|
|
x |= x >> 16
|
|
// Use ntz mechanism to calculate nlz.
|
|
x++
|
|
if x == 0 {
|
|
return 0
|
|
}
|
|
x *= ntz32Const
|
|
return 32 - int(ntz32Table[x>>27])
|
|
}
|