// 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

// FT ...
type FT struct {
	KV string
	NS string
	DB string
	TB string
	FT string
}

// init initialises the key
func (k *FT) init() *FT {
	return k
}

func (k *FT) Copy() *FT {
	return &FT{
		KV: k.KV,
		NS: k.NS,
		DB: k.DB,
		TB: k.TB,
		FT: k.FT,
	}
}

// Encode encodes the key into binary
func (k *FT) Encode() []byte {
	k.init()
	return encode(k.KV, k.NS, "*", k.DB, "*", k.TB, "!", "t", k.FT)
}

// Decode decodes the key from binary
func (k *FT) Decode(data []byte) {
	k.init()
	var __ string
	decode(data, &k.KV, &k.NS, &__, &k.DB, &__, &k.TB, &__, &__, &k.FT)
}

// String returns a string representation of the key
func (k *FT) String() string {
	k.init()
	return output(k.KV, k.NS, "*", k.DB, "*", k.TB, "!", "t", k.FT)
}