2010-12-03 05:34:57 +01:00
|
|
|
// 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.
|
|
|
|
|
2011-05-20 02:18:15 +02:00
|
|
|
// Package hash provides interfaces for hash functions.
|
2010-12-03 05:34:57 +01:00
|
|
|
package hash
|
|
|
|
|
|
|
|
import "io"
|
|
|
|
|
|
|
|
// Hash is the common interface implemented by all hash functions.
|
|
|
|
type Hash interface {
|
|
|
|
// Write adds more data to the running hash.
|
|
|
|
// It never returns an error.
|
|
|
|
io.Writer
|
|
|
|
|
2011-12-14 16:41:54 +01:00
|
|
|
// Sum appends the current hash to b and returns the resulting slice.
|
|
|
|
// It does not change the underlying hash state.
|
|
|
|
Sum(b []byte) []byte
|
2010-12-03 05:34:57 +01:00
|
|
|
|
|
|
|
// Reset resets the hash to one with zero bytes written.
|
|
|
|
Reset()
|
|
|
|
|
|
|
|
// Size returns the number of bytes Sum will return.
|
|
|
|
Size() int
|
2012-01-25 22:54:22 +01:00
|
|
|
|
|
|
|
// BlockSize returns the hash's underlying block size.
|
|
|
|
// The Write method must be able to accept any amount
|
|
|
|
// of data, but it may operate more efficiently if all writes
|
|
|
|
// are a multiple of the block size.
|
|
|
|
BlockSize() int
|
2010-12-03 05:34:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Hash32 is the common interface implemented by all 32-bit hash functions.
|
|
|
|
type Hash32 interface {
|
|
|
|
Hash
|
|
|
|
Sum32() uint32
|
|
|
|
}
|
|
|
|
|
|
|
|
// Hash64 is the common interface implemented by all 64-bit hash functions.
|
|
|
|
type Hash64 interface {
|
|
|
|
Hash
|
|
|
|
Sum64() uint64
|
|
|
|
}
|