prep template for fixed size hashes
This commit is contained in:
parent
0a1eeca41e
commit
48dd601de0
48
common/types_template.go
Normal file
48
common/types_template.go
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
// +build none
|
||||||
|
//sed -e 's/_N_/Hash/g' -e 's/_S_/32/g' -e '1d' types_template.go | gofmt -w hash.go
|
||||||
|
|
||||||
|
package common
|
||||||
|
|
||||||
|
import "math/big"
|
||||||
|
|
||||||
|
type _N_ [_S_]byte
|
||||||
|
|
||||||
|
func BytesTo_N_(b []byte) _N_ {
|
||||||
|
var h _N_
|
||||||
|
h.SetBytes(b)
|
||||||
|
return h
|
||||||
|
}
|
||||||
|
func StringTo_N_(s string) _N_ { return BytesTo_N_([]byte(s)) }
|
||||||
|
func BigTo_N_(b *big.Int) _N_ { return BytesTo_N_(b.Bytes()) }
|
||||||
|
func HexTo_N_(s string) _N_ { return BytesTo_N_(FromHex(s)) }
|
||||||
|
|
||||||
|
// Don't use the default 'String' method in case we want to overwrite
|
||||||
|
|
||||||
|
// Get the string representation of the underlying hash
|
||||||
|
func (h _N_) Str() string { return string(h[:]) }
|
||||||
|
func (h _N_) Bytes() []byte { return h[:] }
|
||||||
|
func (h _N_) Big() *big.Int { return Bytes2Big(h[:]) }
|
||||||
|
func (h _N_) Hex() string { return "0x" + Bytes2Hex(h[:]) }
|
||||||
|
|
||||||
|
// Sets the hash to the value of b. If b is larger than len(h) it will panic
|
||||||
|
func (h *_N_) SetBytes(b []byte) {
|
||||||
|
// Use the right most bytes
|
||||||
|
if len(b) > len(h) {
|
||||||
|
b = b[len(b)-_S_:]
|
||||||
|
}
|
||||||
|
|
||||||
|
// Reverse the loop
|
||||||
|
for i := len(b) - 1; i >= 0; i-- {
|
||||||
|
h[_S_-len(b)+i] = b[i]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set string `s` to h. If s is larger than len(h) it will panic
|
||||||
|
func (h *_N_) SetString(s string) { h.SetBytes([]byte(s)) }
|
||||||
|
|
||||||
|
// Sets h to other
|
||||||
|
func (h *_N_) Set(other _N_) {
|
||||||
|
for i, v := range other {
|
||||||
|
h[i] = v
|
||||||
|
}
|
||||||
|
}
|
@ -37,8 +37,8 @@ func CalcDifficulty(block, parent *types.Header) *big.Int {
|
|||||||
diff.Sub(parent.Difficulty, adjust)
|
diff.Sub(parent.Difficulty, adjust)
|
||||||
}
|
}
|
||||||
|
|
||||||
if diff.Cmp(GenesisDiff) < 0 {
|
if diff.Cmp(min) < 0 {
|
||||||
return GenesisDiff
|
return min
|
||||||
}
|
}
|
||||||
|
|
||||||
return diff
|
return diff
|
||||||
|
Loading…
Reference in New Issue
Block a user