Implement IterKVStore/Iterator with TODO
This commit is contained in:
parent
dc3aa6d92a
commit
e6f1737a62
|
@ -100,7 +100,7 @@ type IAVLStore struct {
|
||||||
|
|
||||||
// CacheWrap returns a wrapper around the current writable state
|
// CacheWrap returns a wrapper around the current writable state
|
||||||
func (i IAVLStore) CacheWrap() interface{} {
|
func (i IAVLStore) CacheWrap() interface{} {
|
||||||
// TODO: something here for sure
|
// TODO: add CacheWrap to IAVLTree using new db stuff
|
||||||
return i
|
return i
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -127,8 +127,88 @@ func (i IAVLStore) Remove(key []byte) (prev []byte, removed bool) {
|
||||||
return i.tree.Remove(key)
|
return i.tree.Remove(key)
|
||||||
}
|
}
|
||||||
|
|
||||||
// var _ IterKVStore = IAVLStore{}
|
// Iterator implements IterKVStore
|
||||||
var _ KVStore = IAVLStore{}
|
func (i IAVLStore) Iterator(start, end []byte) Iterator {
|
||||||
|
// TODO: this needs changes to IAVL tree
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// ReverseIterator implements IterKVStore
|
||||||
|
func (i IAVLStore) ReverseIterator(start, end []byte) Iterator {
|
||||||
|
// TODO
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// First implements IterKVStore
|
||||||
|
func (i IAVLStore) First(start, end []byte) (kv KVPair, ok bool) {
|
||||||
|
// TODO
|
||||||
|
return KVPair{}, false
|
||||||
|
}
|
||||||
|
|
||||||
|
// Last implements IterKVStore
|
||||||
|
func (i IAVLStore) Last(start, end []byte) (kv KVPair, ok bool) {
|
||||||
|
// TODO
|
||||||
|
return KVPair{}, false
|
||||||
|
}
|
||||||
|
|
||||||
|
var _ IterKVStore = IAVLStore{}
|
||||||
|
|
||||||
|
type iavlIterator struct {
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
|
var _ Iterator = (*iavlIterator)(nil)
|
||||||
|
|
||||||
|
// Domain implements Iterator
|
||||||
|
//
|
||||||
|
// The start & end (exclusive) limits to iterate over.
|
||||||
|
// If end < start, then the Iterator goes in reverse order.
|
||||||
|
func (i *iavlIterator) Domain() (start, end []byte) {
|
||||||
|
// TODO
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Valid implements Iterator
|
||||||
|
//
|
||||||
|
// Returns if the current position is valid.
|
||||||
|
func (i *iavlIterator) Valid() bool {
|
||||||
|
// TODO
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
// Next implements Iterator
|
||||||
|
//
|
||||||
|
// Next moves the iterator to the next key/value pair.
|
||||||
|
func (i *iavlIterator) Next() {
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
|
// Key implements Iterator
|
||||||
|
//
|
||||||
|
// Key returns the key of the current key/value pair, or nil if done.
|
||||||
|
// The caller should not modify the contents of the returned slice, and
|
||||||
|
// its contents may change after calling Next().
|
||||||
|
func (i *iavlIterator) Key() []byte {
|
||||||
|
// TODO
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Value implements Iterator
|
||||||
|
//
|
||||||
|
// Value returns the key of the current key/value pair, or nil if done.
|
||||||
|
// The caller should not modify the contents of the returned slice, and
|
||||||
|
// its contents may change after calling Next().
|
||||||
|
func (i *iavlIterator) Value() []byte {
|
||||||
|
// TODO
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Release implements Iterator
|
||||||
|
//
|
||||||
|
// Releases any resources and iteration-locks
|
||||||
|
func (i *iavlIterator) Release() {
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
// iavlLoader contains info on what store we want to load from
|
// iavlLoader contains info on what store we want to load from
|
||||||
type iavlLoader struct {
|
type iavlLoader struct {
|
||||||
|
|
Loading…
Reference in New Issue