1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
|
package hashring
import (
"encoding/binary"
"fmt"
)
type Int64PairHashKey struct {
High int64
Low int64
}
func (k *Int64PairHashKey) Less(other HashKey) bool {
o := other.(*Int64PairHashKey)
if k.High < o.High {
return true
}
return k.High == o.High && k.Low < o.Low
}
func NewInt64PairHashKey(bytes []byte) (HashKey, error) {
const expected = 16
if len(bytes) != expected {
return nil, fmt.Errorf(
"expected %d bytes, got %d bytes",
expected, len(bytes),
)
}
return &Int64PairHashKey{
High: int64(binary.LittleEndian.Uint64(bytes[:8])),
Low: int64(binary.LittleEndian.Uint64(bytes[8:])),
}, nil
}
|