forked from h2oai/wave
-
Notifications
You must be signed in to change notification settings - Fork 0
/
listbuf.go
86 lines (76 loc) · 1.82 KB
/
listbuf.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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
// Copyright 2020 H2O.ai, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package wave
import "strconv"
// ListBuf represents a list (dynamic array) buffer.
type ListBuf struct {
b *FixBuf
i int
}
func (b *ListBuf) put(ixs any) {
if xs, ok := ixs.([]any); ok {
for _, x := range xs {
b.set("", x)
}
}
}
func (b *ListBuf) set(key string, v any) {
fb := b.b
// Check if key is a valid index.
if i, err := strconv.Atoi(key); err == nil {
// Support negative indices.
if i < 0 {
i += b.i
}
if i >= 0 && i < len(fb.tups) {
fb.seti(i, v)
return
}
}
// Otherwise, append to the current end.
if b.i >= len(fb.tups) {
xs := make([][]interface{}, len(fb.tups)*2)
tups := fb.tups
fb.tups = xs
for i, t := range tups {
fb.seti(i, t)
}
}
fb.seti(b.i, v)
b.i++
}
func (b *ListBuf) get(key string) (Cur, bool) {
// Check if key is a valid index.
if i, err := strconv.Atoi(key); err == nil {
if i < 0 {
i += len(b.b.tups)
}
return b.b.geti(i)
}
return b.b.geti(b.i)
}
func (b *ListBuf) dump() BufD {
return BufD{L: &ListBufD{b.b.t.f, b.b.tups, len(b.b.tups)}}
}
func loadListBuf(ns *Namespace, b *ListBufD) *ListBuf {
t := ns.make(b.F)
if len(b.D) == 0 {
n := b.N
if n <= 0 {
n = 10
}
return &ListBuf{newFixBuf(t, n), n - 1}
}
return &ListBuf{&FixBuf{t, b.D}, len(b.D)}
}