49 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
		
		
			
		
	
	
			49 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
|   | // +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 | ||
|  | 	} | ||
|  | } |