2021-08-20 08:12:52 +00:00
|
|
|
package bptree
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
)
|
|
|
|
|
|
|
|
/* A BpMap is a B+Tree with support for duplicate keys disabled. This makes it
|
|
|
|
* behave like a regular Map rather than a MultiMap.
|
|
|
|
*/
|
|
|
|
type BpMap BpTree
|
|
|
|
|
|
|
|
func NewBpMap(node_size int) *BpMap {
|
|
|
|
return &BpMap{
|
2021-08-21 22:13:13 +00:00
|
|
|
root: NewLeaf(node_size, true),
|
2021-08-20 08:12:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-08-21 22:54:42 +00:00
|
|
|
func (self *BpMap) Has(key ItemKey) bool {
|
2021-08-20 08:12:52 +00:00
|
|
|
return (*BpTree)(self).Has(key)
|
|
|
|
}
|
|
|
|
|
2021-08-21 22:54:42 +00:00
|
|
|
func (self *BpMap) Put(key ItemKey, value ItemValue) (err error) {
|
2021-08-21 01:34:50 +00:00
|
|
|
new_root, err := self.getRoot().put(key, value)
|
2021-08-20 08:12:52 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2021-08-21 01:34:50 +00:00
|
|
|
self.setRoot(new_root)
|
2021-08-20 08:12:52 +00:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2021-08-21 22:54:42 +00:00
|
|
|
func (self *BpMap) Get(key ItemKey) (value ItemValue, err error) {
|
2021-08-21 01:34:50 +00:00
|
|
|
j, l := self.getRoot().get_start(key)
|
2021-08-20 08:12:52 +00:00
|
|
|
if l.keys[j].Equals(key) {
|
|
|
|
return l.values[j], nil
|
|
|
|
}
|
|
|
|
return nil, fmt.Errorf("key not found: %s", key)
|
|
|
|
}
|
|
|
|
|
2021-08-21 22:54:42 +00:00
|
|
|
func (self *BpMap) Remove(key ItemKey) (value ItemValue, err error) {
|
2021-08-20 08:12:52 +00:00
|
|
|
value, err = self.Get(key)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2021-08-21 01:34:50 +00:00
|
|
|
ns := self.getRoot().NodeSize()
|
2021-08-21 22:52:17 +00:00
|
|
|
new_root, err := self.getRoot().remove(key, func(value ItemValue) bool { return true })
|
2021-08-20 08:12:52 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if new_root == nil {
|
2021-08-23 01:19:26 +00:00
|
|
|
new_root = NewLeaf(ns, false)
|
|
|
|
err = new_root.persist()
|
|
|
|
self.setRoot(new_root)
|
2021-08-20 08:12:52 +00:00
|
|
|
} else {
|
2021-08-21 01:34:50 +00:00
|
|
|
self.setRoot(new_root)
|
2021-08-20 08:12:52 +00:00
|
|
|
}
|
|
|
|
return value, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (self *BpMap) Keys() (ki KIterator) {
|
|
|
|
return (*BpTree)(self).Keys()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (self *BpMap) Values() (vi Iterator) {
|
|
|
|
return (*BpTree)(self).Values()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (self *BpMap) Iterate() (kvi KVIterator) {
|
|
|
|
return (*BpTree)(self).Iterate()
|
|
|
|
}
|