mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-03-30 15:08:33 +00:00

* [NOD-176] Moved daghash from dagconfig to util * [NOD-176] Fixed order of includes with gofmt
41 lines
1.0 KiB
Go
41 lines
1.0 KiB
Go
// Copyright (c) 2015 The Decred developers
|
|
// Copyright (c) 2016-2017 The btcsuite developers
|
|
// Use of this source code is governed by an ISC
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package daghash
|
|
|
|
import "crypto/sha256"
|
|
|
|
// HashB calculates hash(b) and returns the resulting bytes.
|
|
func HashB(b []byte) []byte {
|
|
hash := sha256.Sum256(b)
|
|
return hash[:]
|
|
}
|
|
|
|
// HashH calculates hash(b) and returns the resulting bytes as a Hash.
|
|
func HashH(b []byte) Hash {
|
|
return Hash(sha256.Sum256(b))
|
|
}
|
|
|
|
// DoubleHashB calculates hash(hash(b)) and returns the resulting bytes.
|
|
func DoubleHashB(b []byte) []byte {
|
|
first := sha256.Sum256(b)
|
|
second := sha256.Sum256(first[:])
|
|
return second[:]
|
|
}
|
|
|
|
// DoubleHashH calculates hash(hash(b)) and returns the resulting bytes as a
|
|
// Hash.
|
|
func DoubleHashH(b []byte) Hash {
|
|
first := sha256.Sum256(b)
|
|
return Hash(sha256.Sum256(first[:]))
|
|
}
|
|
|
|
// DoubleHashP calculates hash(hash(b)) and returns the resulting bytes as a
|
|
// pointer to Hash.
|
|
func DoubleHashP(b []byte) *Hash {
|
|
h := DoubleHashH(b)
|
|
return &h
|
|
}
|