-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathkeyset.go
95 lines (86 loc) · 2.4 KB
/
keyset.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
// Copyright 2020 Zhizhesihai (Beijing) Technology Limited.
//
// 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,
// See the License for the specific language governing permissions and
// limitations under the License.
package zetta
import (
tspb "github.com/zhihu/zetta-proto/pkg/tablestore"
)
// KeySet is collection of keys and/or key ranges
// all the keys in the same table or index. and keys needn't be sorted
type KeySet struct {
// true means all rows of a table or under a index.
All bool
// a list of keys covered by KeySet
Keys []Key
// list of key ranges covered by KeySet
Ranges []KeyRange
}
// AllKeys returns a KeySet that represents all Keys of a table or a index.
func AllKeys() KeySet {
return KeySet{All: true}
}
// Keys returns a KeySet for a set of keys.
func Keys(keys ...Key) KeySet {
ks := KeySet{Keys: make([]Key, len(keys))}
copy(ks.Keys, keys)
return ks
}
// Range returns a KeySet for a range of keys.
func Range(r KeyRange) KeySet {
return KeySet{Ranges: []KeyRange{r}}
}
// PrefixRange returns a KeySet for all keys with the given prefix, which is a key itself
func PrefixRange(prefix Key) KeySet {
return KeySet{Ranges: []KeyRange{
{
Start: prefix,
End: prefix,
Kind: ClosedClosed,
},
}}
}
// union key set to one unity
func UnionKeySets(keySets ...KeySet) KeySet {
s := KeySet{}
for _, ks := range keySets {
if ks.All {
return KeySet{All: true}
}
s.Keys = append(s.Keys, ks.Keys...)
s.Ranges = append(s.Ranges, ks.Ranges...)
}
return s
}
// proto converts KeySet into tspb.KeySet, which is the protobuf
// representation of KeySet.
func (keys KeySet) proto() (*tspb.KeySet, error) {
pb := &tspb.KeySet{
Keys: make([]*tspb.ListValue, 0, len(keys.Keys)),
Ranges: make([]*tspb.KeyRange, 0, len(keys.Ranges)),
All: keys.All,
}
for _, key := range keys.Keys {
keyProto, err := key.proto()
if err != nil {
return nil, err
}
pb.Keys = append(pb.Keys, keyProto)
}
for _, r := range keys.Ranges {
rProto, err := r.proto()
if err != nil {
return nil, err
}
pb.Ranges = append(pb.Ranges, rProto)
}
return pb, nil
}