mirror of
https://github.com/talent-plan/tinykv.git
synced 2025-01-13 22:00:07 +08:00
Address issues with KeyError and MemStorage (#144)
* Implement `error` for `KeyError` closes #134 Signed-off-by: Nick Cameron <nrc@ncameron.org> * Check for unclosed iterators in memStorage cc #110 Signed-off-by: Nick Cameron <nrc@ncameron.org>
This commit is contained in:
parent
612724328b
commit
9dc51167e8
@ -35,7 +35,7 @@ func (s *MemStorage) Stop() error {
|
||||
}
|
||||
|
||||
func (s *MemStorage) Reader(ctx *kvrpcpb.Context) (StorageReader, error) {
|
||||
return &memReader{s}, nil
|
||||
return &memReader{s, 0}, nil
|
||||
}
|
||||
|
||||
func (s *MemStorage) Write(ctx *kvrpcpb.Context, batch []Modify) error {
|
||||
@ -132,6 +132,7 @@ func (s *MemStorage) Len(cf string) int {
|
||||
// memReader is a StorageReader which reads from a MemStorage.
|
||||
type memReader struct {
|
||||
inner *MemStorage
|
||||
iterCount int
|
||||
}
|
||||
|
||||
func (mr *memReader) GetCF(cf string, key []byte) ([]byte, error) {
|
||||
@ -168,18 +169,24 @@ func (mr *memReader) IterCF(cf string) engine_util.DBIterator {
|
||||
return nil
|
||||
}
|
||||
|
||||
mr.iterCount += 1
|
||||
min := data.Min()
|
||||
if min == nil {
|
||||
return &memIter{data, memItem{}}
|
||||
return &memIter{data, memItem{}, mr}
|
||||
}
|
||||
return &memIter{data, min.(memItem)}
|
||||
return &memIter{data, min.(memItem), mr}
|
||||
}
|
||||
|
||||
func (r *memReader) Close() {}
|
||||
func (r *memReader) Close() {
|
||||
if r.iterCount > 0 {
|
||||
panic("Unclosed iterator")
|
||||
}
|
||||
}
|
||||
|
||||
type memIter struct {
|
||||
data *llrb.LLRB
|
||||
item memItem
|
||||
reader *memReader
|
||||
}
|
||||
|
||||
func (it *memIter) Item() engine_util.DBItem {
|
||||
@ -212,7 +219,9 @@ func (it *memIter) Seek(key []byte) {
|
||||
})
|
||||
}
|
||||
|
||||
func (it *memIter) Close() {}
|
||||
func (it *memIter) Close() {
|
||||
it.reader.iterCount -= 1
|
||||
}
|
||||
|
||||
type memItem struct {
|
||||
key []byte
|
||||
|
Loading…
Reference in New Issue
Block a user