-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathiteration.go
150 lines (133 loc) · 3.41 KB
/
iteration.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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
package jsonvalue
import "sort"
// Deprecated: ObjectIter is a deprecated type.
type ObjectIter struct {
K string
V *V
}
// Deprecated: ArrayIter is a deprecated type.
type ArrayIter struct {
I int
V *V
}
// RangeObjects goes through each children when this is an object value
//
// Return true in callback to continue range iteration, while false to break.
//
// 若当前 JSON 值是一个 object 类型时,RangeObjects 遍历所有的键值对。
//
// 在回调函数中返回 true 表示继续迭代,返回 false 表示退出迭代
func (v *V) RangeObjects(callback func(k string, v *V) bool) {
if !v.IsObject() {
return
}
if nil == callback {
return
}
for k, c := range v.children.object {
ok := callback(k, c.v)
if !ok {
break
}
}
}
// RangeObjectsBySetSequence acts just like RangeObjects, but the key sequence
// is arranged by when a key is set to the given object.
//
// RangeObjectsBySetSequence 类似于 RangeObjects 函数, 但是 key 的顺序会依照其被 set
// 进这个 object 的顺序传递。
func (v *V) RangeObjectsBySetSequence(callback func(k string, v *V) bool) {
if !v.IsObject() {
return
}
if nil == callback {
return
}
type keysAndID struct {
k string
id uint32
v *V
}
kvs := make([]keysAndID, 0, len(v.children.object))
for k, child := range v.children.object {
kvs = append(kvs, keysAndID{
k: k,
id: child.id,
v: child.v,
})
}
sort.Slice(kvs, func(i, j int) bool {
return kvs[i].id <= kvs[j].id
})
for _, kv := range kvs {
ok := callback(kv.k, kv.v)
if !ok {
break
}
}
}
// Deprecated: IterObjects is deprecated, please Use ForRangeObj() instead.
func (v *V) IterObjects() <-chan *ObjectIter {
ch := make(chan *ObjectIter, len(v.children.object))
go func() {
for k, c := range v.children.object {
ch <- &ObjectIter{
K: k,
V: c.v,
}
}
close(ch)
}()
return ch
}
// ForRangeObj returns a map which can be used in for - range block to iteration KVs in a JSON object value.
//
// ForRangeObj 返回一个 map 类型,用于使用 for - range 块迭代 JSON 对象类型的子成员。
func (v *V) ForRangeObj() map[string]*V {
res := make(map[string]*V, len(v.children.object))
for k, c := range v.children.object {
res[k] = c.v
}
return res
}
// RangeArray goes through each children when this is an array value
//
// Return true in callback to continue range iteration, while false to break.
//
// 若当前 JSON 值是一个 array 类型时,RangeArray 遍历所有的数组成员。
//
// 在回调函数中返回 true 表示继续迭代,返回 false 表示退出迭代
func (v *V) RangeArray(callback func(i int, v *V) bool) {
if !v.IsArray() {
return
}
if nil == callback {
return
}
for i, child := range v.children.arr {
if ok := callback(i, child); !ok {
break
}
}
}
// Deprecated: IterArray is deprecated, please Use ForRangeArr() instead.
func (v *V) IterArray() <-chan *ArrayIter {
c := make(chan *ArrayIter, len(v.children.arr))
go func() {
for i, child := range v.children.arr {
c <- &ArrayIter{
I: i,
V: child,
}
}
close(c)
}()
return c
}
// ForRangeArr returns a slice which can be used in for - range block to iteration KVs in a JSON array value.
//
// ForRangeObj 返回一个切片,用于使用 for - range 块迭代 JSON 数组类型的子成员。
func (v *V) ForRangeArr() []*V {
res := make([]*V, 0, len(v.children.arr))
return append(res, v.children.arr...)
}