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