// Copyright 2009 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 adler32 implements the Adler-32 checksum.//// It is defined in RFC 1950://// Adler-32 is composed of two sums accumulated per byte: s1 is// the sum of all bytes, s2 is the sum of all s1 values. Both sums// are done modulo 65521. s1 is initialized to 1, s2 to zero. The// Adler-32 checksum is stored as s2*65536 + s1 in most-// significant-byte first (network) order.
package adler32import ()const (// mod is the largest prime that is less than 65536. mod = 65521// nmax is the largest n such that // 255 * n * (n+1) / 2 + (n+1) * (mod-1) <= 2^32-1. // It is mentioned in RFC 1950 (search for "5552"). nmax = 5552)// The size of an Adler-32 checksum in bytes.constSize = 4// digest represents the partial evaluation of a checksum.// The low 16 bits are s1, the high 16 bits are s2.type digest uint32func ( *digest) () { * = 1 }// New returns a new hash.Hash32 computing the Adler-32 checksum. Its// Sum method will lay the value out in big-endian byte order. The// returned Hash32 also implements [encoding.BinaryMarshaler] and// [encoding.BinaryUnmarshaler] to marshal and unmarshal the internal// state of the hash.func () hash.Hash32 { := new(digest) .Reset()return}func ( *digest) () int { returnSize }func ( *digest) () int { return4 }const ( magic = "adl\x01" marshaledSize = len(magic) + 4)func ( *digest) ( []byte) ([]byte, error) { = append(, magic...) = byteorder.BEAppendUint32(, uint32(*))return , nil}func ( *digest) () ([]byte, error) {return .AppendBinary(make([]byte, 0, marshaledSize))}func ( *digest) ( []byte) error {iflen() < len(magic) || string([:len(magic)]) != magic {returnerrors.New("hash/adler32: invalid hash state identifier") }iflen() != marshaledSize {returnerrors.New("hash/adler32: invalid hash state size") } * = digest(byteorder.BEUint32([len(magic):]))returnnil}// Add p to the running checksum d.func update( digest, []byte) digest { , := uint32(&0xffff), uint32(>>16)forlen() > 0 {var []byteiflen() > nmax { , = [:nmax], [nmax:] }forlen() >= 4 { += uint32([0]) += += uint32([1]) += += uint32([2]) += += uint32([3]) += = [4:] }for , := range { += uint32() += } %= mod %= mod = }returndigest(<<16 | )}func ( *digest) ( []byte) ( int, error) { * = update(*, )returnlen(), nil}func ( *digest) () uint32 { returnuint32(*) }func ( *digest) ( []byte) []byte { := uint32(*)returnappend(, byte(>>24), byte(>>16), byte(>>8), byte())}// Checksum returns the Adler-32 checksum of data.func ( []byte) uint32 { returnuint32(update(1, )) }
The pages are generated with Goldsv0.7.3. (GOOS=linux GOARCH=amd64)
Golds is a Go 101 project developed by Tapir Liu.
PR and bug reports are welcome and can be submitted to the issue list.
Please follow @zigo_101 (reachable from the left QR code) to get the latest news of Golds.