1
0
mirror of https://github.com/nxshock/zkv.git synced 2024-11-27 11:21:02 +05:00
zkv/record.go

81 lines
1.7 KiB
Go
Raw Normal View History

2022-02-16 16:16:29 +05:00
package zkv
2022-02-16 16:08:20 +05:00
import (
"bytes"
"encoding/binary"
2022-02-16 16:38:50 +05:00
"encoding/gob"
2022-02-16 16:08:20 +05:00
"io"
)
type RecordType uint8
const (
RecordTypeSet RecordType = iota + 1
RecordTypeDelete
)
type Record struct {
Type RecordType
KeyHash []byte
ValueBytes []byte
2022-02-16 16:08:20 +05:00
}
func newRecord(recordType RecordType, key, value interface{}) (*Record, error) {
keyBytes, err := encode(key)
if err != nil {
return nil, err
}
valueBytes, err := encode(value)
if err != nil {
return nil, err
}
record := &Record{
Type: recordType,
KeyHash: hashBytes(keyBytes),
ValueBytes: valueBytes}
return record, nil
}
func (r *Record) Marshal() ([]byte, error) {
buf := new(bytes.Buffer)
2022-02-16 16:38:50 +05:00
err := gob.NewEncoder(buf).Encode(r)
2022-02-16 16:08:20 +05:00
if err != nil {
return nil, err
}
buf2 := new(bytes.Buffer)
err = binary.Write(buf2, binary.LittleEndian, int64(buf.Len()))
if err != nil {
return nil, err
}
return append(buf2.Bytes(), buf.Bytes()...), nil
}
func readRecord(r io.Reader) (n int64, record *Record, err error) {
var recordBytesLen int64
err = binary.Read(r, binary.LittleEndian, &recordBytesLen)
if err != nil {
return 0, nil, err // TODO: вместо нуля должно быть реальное кол-во считанных байт
}
recordBytes := make([]byte, int(recordBytesLen))
_, err = io.ReadAtLeast(r, recordBytes, int(recordBytesLen))
if err != nil {
return 0, nil, err // TODO: вместо нуля должно быть реальное кол-во считанных байт
}
2022-02-16 16:38:50 +05:00
err = gob.NewDecoder(bytes.NewReader(recordBytes)).Decode(&record)
2022-02-16 16:08:20 +05:00
if err != nil {
return 0, nil, err // TODO: вместо нуля должно быть реальное кол-во считанных байт
}
return recordBytesLen + 8, record, nil
}