-
Notifications
You must be signed in to change notification settings - Fork 0
/
mem.go
49 lines (43 loc) · 935 Bytes
/
mem.go
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
package mem
import (
"github.com/deepfabric/thinkbase/pkg/vm/container/hash"
"github.com/deepfabric/thinkbase/pkg/vm/container/vector"
"github.com/deepfabric/thinkbase/pkg/vm/util/encoding"
"github.com/deepfabric/thinkbase/pkg/vm/value"
)
func New(n int, gen func() (vector.Vector, error)) *mem {
var vs []vector.Vector
for i := 0; i < n; i++ {
v, err := gen()
if err != nil {
for _, v := range vs {
v.Destroy()
}
return nil
}
vs = append(vs, v)
}
return &mem{vs: vs}
}
func (m *mem) Destroy() error {
m.Lock()
defer m.Unlock()
for _, v := range m.vs {
v.Destroy()
}
return nil
}
func (m *mem) Pop(idx int) (vector.Vector, error) {
m.RLock()
defer m.RUnlock()
return m.vs[idx], nil
}
func (m *mem) Set(v value.Value) error {
m.Lock()
defer m.Unlock()
key, err := encoding.EncodeValue(v)
if err != nil {
return err
}
return m.vs[hash.GenHash(key)%len(m.vs)].Append(value.Array{v})
}