surrealpatch/util/keys/index.go
Tobie Morgan Hitchcock 07139fdc5b Add database keys package
The keys package is used to encode and decode keys. Keys are used for storage in the key:value store.
2016-03-15 21:30:47 +00:00

51 lines
1.3 KiB
Go

// Copyright © 2016 Abcum Ltd
//
// 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 keys
import (
"strings"
)
// Index ...
type Index struct {
KV string // Base
NS string // Namespace
DB string // Database
TB string // Table
TK string // ¤
What []string // What
}
// init initialises the key
func (k *Index) init() *Index {
k.TK = "¤"
return k
}
// Encode encodes the key into binary
func (k *Index) Encode() []byte {
return output(k.init())
}
// Decode decodes the key from binary
func (k *Index) Decode(data []byte) {
injest(k, data)
}
// String returns a string representation of the key
func (k *Index) String() string {
k.init()
return "/" + strings.Join([]string{k.KV, k.NS, k.DB, k.TB, k.TK, "[" + strings.Join(k.What, ",") + "]"}, "/")
}