tendermint/db/util.go

47 lines
936 B
Go
Raw Normal View History

package db
2017-12-12 18:08:38 -08:00
import (
"bytes"
"strings"
)
2017-12-12 14:00:03 -08:00
func IteratePrefix(db DB, prefix []byte) Iterator {
var start, end []byte
if len(prefix) == 0 {
start = BeginningKey()
end = EndingKey()
} else {
start = cp(prefix)
end = cpIncr(prefix)
}
2017-12-12 14:00:03 -08:00
return db.Iterator(start, end)
}
2017-12-12 14:00:03 -08:00
//----------------------------------------
2017-12-12 14:00:03 -08:00
func cp(bz []byte) (ret []byte) {
ret = make([]byte, len(bz))
copy(ret, bz)
return ret
}
2017-12-12 14:00:03 -08:00
// CONTRACT: len(bz) > 0
func cpIncr(bz []byte) (ret []byte) {
ret = cp(bz)
for i := len(bz) - 1; i >= 0; i-- {
if ret[i] < byte(0xFF) {
ret[i] += 1
return
} else {
ret[i] = byte(0x00)
}
}
2017-12-12 14:00:03 -08:00
return EndingKey()
}
2017-12-12 18:08:38 -08:00
func checkKeyCondition(key string, start, end []byte) bool {
leftCondition := bytes.Equal(start, BeginningKey()) || strings.Compare(key, string(start)) >= 0
rightCondition := bytes.Equal(end, EndingKey()) || strings.Compare(key, string(end)) < 0
return leftCondition && rightCondition
}