datatree

package
v0.6.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 3, 2024 License: Apache-2.0 Imports: 19 Imported by: 3

Documentation

Index

Constants

View Source
const (
	MinimumJobsInGoroutine = 20
	MaximumGoroutines      = 16
)
View Source
const (
	BufferSize      = 16 * 1024 * 1024
	SmallBufferSize = 32 * 1024 //For UnitTest
	PreReadBufSize  = 256 * 1024
)
View Source
const (
	FirstLevelAboveTwig int   = 13
	MinPruneCount       int64 = 2

	DeactivedSNListMaxLen = 64
)
View Source
const (
	TwigShift       = 11
	LeafCountInTwig = 1 << TwigShift // 2048
	TwigMask        = LeafCountInTwig - 1
)
View Source
const (
	IgnoredCount     = 2048 - 256
	TwigMtFullLength = 4095
	TwigMtEntryCount = TwigMtFullLength - IgnoredCount
	TwigMtSize       = 12 + TwigMtEntryCount*32
)
View Source
const Debug = false

var Debug bool

View Source
const (
	MSB32 = uint32(1 << 31)
)
View Source
const MaxEntryBytes int = (1 << 24) - 1
View Source
const OtherNodeCount = 1 + 11 + 1 + 3 + 1

Variables

View Source
var MagicBytes = [8]byte{255, 254, 253, 252, 252, 253, 254, 255}
View Source
var NullMT4Twig [4096][32]byte
View Source
var NullNodeInHigherTree [64][32]byte
View Source
var Phase1Time, Phase2Time, Phase3Time uint64 //nolint:unused
View Source
var TotalWriteTime, TotalReadTime, TotalSyncTime uint64

Functions

func CheckHashConsistency

func CheckHashConsistency(tree *Tree)

func CheckProof

func CheckProof(path *ProofPath) ([]byte, error)

func CompareTreeNodes

func CompareTreeNodes(treeA, treeB *Tree)

func CompareTreeTwigs

func CompareTreeTwigs(treeA, treeB *Tree)

func CompareTwig

func CompareTwig(twigID int64, a, b *Twig)

func EdgeNodesToBytes

func EdgeNodesToBytes(edgeNodes []*EdgeNode) []byte

func EntryToBytes

func EntryToBytes(entry Entry, deactivedSerialNumList []int64) []byte

func ExtractKeyFromRawBytes

func ExtractKeyFromRawBytes(b []byte) []byte

func ExtractSerialNum

func ExtractSerialNum(entryBz []byte) int64

func GetUint24

func GetUint24(b []byte) (n uint32)

func ParallelRun

func ParallelRun(workerCount int, fn func(workerID int))

func PutUint24

func PutUint24(b []byte, n uint32)

func SNListToBytes

func SNListToBytes(deactivedSerialNumList []int64) []byte

func UpdateSerialNum

func UpdateSerialNum(entryBz []byte, sn int64)

Types

type EdgeNode

type EdgeNode struct {
	Pos   NodePos
	Value []byte
}

func BytesToEdgeNodes

func BytesToEdgeNodes(bz []byte) []*EdgeNode

type Entry

type Entry = types.Entry

func DummyEntry

func DummyEntry(sn int64) *Entry

func EntryFromBytes

func EntryFromBytes(b []byte, numberOfSN int) (*Entry, []int64)

func EntryFromRawBytes

func EntryFromRawBytes(b []byte) *Entry

func NullEntry

func NullEntry() Entry

type EntryFile

type EntryFile struct {
	*HPFile
}

func NewEntryFile

func NewEntryFile(bufferSize, blockSize int, dirName string) (res EntryFile, err error)

func (*EntryFile) Append

func (ef *EntryFile) Append(b [2][]byte) (pos int64)

func (*EntryFile) Close

func (ef *EntryFile) Close()

func (*EntryFile) Flush

func (ef *EntryFile) Flush()

func (*EntryFile) GetActiveEntriesInTwig

func (ef *EntryFile) GetActiveEntriesInTwig(twig *Twig) chan []byte

func (*EntryFile) PruneHead

func (ef *EntryFile) PruneHead(off int64)

func (*EntryFile) ReadEntry

func (ef *EntryFile) ReadEntry(off int64) (entry *Entry)

func (*EntryFile) ReadEntryAndSNList

func (ef *EntryFile) ReadEntryAndSNList(off int64) (entry *Entry, deactivedSerialNumList []int64, nextPos int64)

func (*EntryFile) ReadEntryBytesForProof

func (ef *EntryFile) ReadEntryBytesForProof(off int64) (entryBz []byte)

func (*EntryFile) ReadEntryRawBytes

func (ef *EntryFile) ReadEntryRawBytes(off int64) (entryBz []byte, nextPos int64)

func (*EntryFile) Size

func (ef *EntryFile) Size() int64

func (*EntryFile) StartFlushing

func (ef *EntryFile) StartFlushing()

func (*EntryFile) Truncate

func (ef *EntryFile) Truncate(size int64)

func (*EntryFile) WaitForFlushing

func (ef *EntryFile) WaitForFlushing()

type HPFile

type HPFile struct {
	// contains filtered or unexported fields
}

Head prune-able file

func NewHPFile

func NewHPFile(bufferSize, blockSize int, dirName string) (*HPFile, error)

func (*HPFile) Append

func (hpf *HPFile) Append(bufList [][]byte) (int64, error)

func (*HPFile) Close

func (hpf *HPFile) Close() error

func (*HPFile) Flush

func (hpf *HPFile) Flush()

func (*HPFile) InitPreReader

func (hpf *HPFile) InitPreReader()

func (*HPFile) PruneHead

func (hpf *HPFile) PruneHead(off int64) error

func (*HPFile) ReadAt

func (hpf *HPFile) ReadAt(buf []byte, off int64, withBuf bool) (err error)

func (*HPFile) Size

func (hpf *HPFile) Size() int64

func (*HPFile) StartFlushing

func (hpf *HPFile) StartFlushing()

func (*HPFile) Truncate

func (hpf *HPFile) Truncate(size int64) error

func (*HPFile) WaitForFlushing

func (hpf *HPFile) WaitForFlushing()

type Hasher

type Hasher struct {
	// contains filtered or unexported fields
}

func (*Hasher) Add

func (h *Hasher) Add(level byte, target, srcA, srcB []byte)

func (*Hasher) Run

func (h *Hasher) Run()

type MockDataTree

type MockDataTree struct {
	// contains filtered or unexported fields
}

func NewMockDataTree

func NewMockDataTree() *MockDataTree

func (*MockDataTree) AppendEntry

func (dt *MockDataTree) AppendEntry(entry *Entry) int64

func (*MockDataTree) AppendEntryRawBytes

func (dt *MockDataTree) AppendEntryRawBytes(entryBz []byte, sn int64) int64

func (*MockDataTree) Close

func (dt *MockDataTree) Close()

func (*MockDataTree) DeactivateEntry added in v0.6.2

func (dt *MockDataTree) DeactivateEntry(sn int64) int

func (*MockDataTree) DeactivedSNListSize

func (dt *MockDataTree) DeactivedSNListSize() int

func (*MockDataTree) EndBlock

func (dt *MockDataTree) EndBlock() (rootHash [32]byte)

func (*MockDataTree) EvictTwig

func (dt *MockDataTree) EvictTwig(twigID int64)

func (*MockDataTree) GetActiveBit

func (dt *MockDataTree) GetActiveBit(sn int64) bool

func (*MockDataTree) GetActiveEntriesInTwig

func (dt *MockDataTree) GetActiveEntriesInTwig(twigID int64) chan []byte

func (*MockDataTree) GetFileSizes

func (dt *MockDataTree) GetFileSizes() (int64, int64)

func (*MockDataTree) GetProofBytesAndCheck

func (dt *MockDataTree) GetProofBytesAndCheck(sn int64, entryBz []byte) ([]byte, error)

func (*MockDataTree) PrintTree

func (dt *MockDataTree) PrintTree()

func (*MockDataTree) PruneTwigs

func (dt *MockDataTree) PruneTwigs(startID, endID int64) []byte

func (*MockDataTree) ReadEntry

func (dt *MockDataTree) ReadEntry(pos int64) *Entry

func (*MockDataTree) ReadEntryBytesForProof

func (dt *MockDataTree) ReadEntryBytesForProof(pos int64) []byte

func (*MockDataTree) SaveMemToDisk

func (dt *MockDataTree) SaveMemToDisk()

func (*MockDataTree) ScanEntries

func (dt *MockDataTree) ScanEntries(oldestActiveTwigID int64, outChan chan types.EntryX)

func (*MockDataTree) ScanEntriesLite

func (dt *MockDataTree) ScanEntriesLite(oldestActiveTwigID int64, outChan chan types.KeyAndPos)

func (*MockDataTree) TwigCanBePruned

func (dt *MockDataTree) TwigCanBePruned(twigID int64) bool

func (*MockDataTree) WaitForFlushing

func (dt *MockDataTree) WaitForFlushing()

type MockTwig

type MockTwig struct {
	// contains filtered or unexported fields
}

type NodePos

type NodePos int64

func Pos

func Pos(level int, n int64) NodePos

func (NodePos) Level

func (np NodePos) Level() int64

func (NodePos) Nth

func (np NodePos) Nth() int64

type PreReader

type PreReader struct {
	// contains filtered or unexported fields
}

func (*PreReader) GetToFill

func (pr *PreReader) GetToFill(fileID, start, end int64) []byte

func (*PreReader) Init

func (pr *PreReader) Init()

func (*PreReader) TryRead

func (pr *PreReader) TryRead(fileID, start int64, buf []byte) bool

type ProofNode

type ProofNode struct {
	SelfHash   [32]byte
	PeerHash   [32]byte
	PeerAtLeft bool
}

type ProofPath

type ProofPath struct {
	LeftOfTwig  [11]ProofNode
	RightOfTwig [3]ProofNode
	UpperPath   []ProofNode
	SerialNum   int64
	Root        [32]byte
}

func BytesToProofPath

func BytesToProofPath(bz []byte) (*ProofPath, error)

func (*ProofPath) Check

func (pp *ProofPath) Check(complete bool) error

func (*ProofPath) ToBytes

func (pp *ProofPath) ToBytes() []byte

type Tree

type Tree struct {
	// contains filtered or unexported fields
}

func LoadTree

func LoadTree(bufferSize, blockSize int, dirName string) *Tree

func NewEmptyTree

func NewEmptyTree(bufferSize, blockSize int, dirName string, suffix string) *Tree

func RecoverTree

func RecoverTree(bufferSize, blockSize int, dirName, suffix string, edgeNodes []*EdgeNode, lastPrunedTwigID, oldestActiveTwigID, youngestTwigID int64, fileSizes []int64) (tree *Tree, rootHash [32]byte)

func (*Tree) ActivateEntry added in v0.6.2

func (tree *Tree) ActivateEntry(sn int64)

func (*Tree) AppendEntry

func (tree *Tree) AppendEntry(entry *Entry) int64

func (*Tree) AppendEntryRawBytes

func (tree *Tree) AppendEntryRawBytes(entryBz []byte, sn int64) int64

func (*Tree) Close

func (tree *Tree) Close()

func (*Tree) DeactivateEntry added in v0.6.2

func (tree *Tree) DeactivateEntry(sn int64) int

func (*Tree) DeactivedSNListSize

func (tree *Tree) DeactivedSNListSize() int

func (*Tree) DumpMtree4YT

func (tree *Tree) DumpMtree4YT(outfile io.Writer) error

func (*Tree) DumpNodes

func (tree *Tree) DumpNodes(outfile io.Writer) error

func (*Tree) EndBlock

func (tree *Tree) EndBlock() (rootHash [32]byte)

func (*Tree) EvictTwig

func (tree *Tree) EvictTwig(twigID int64)

func (*Tree) GetActiveBit

func (tree *Tree) GetActiveBit(sn int64) bool

func (*Tree) GetActiveEntriesInTwig

func (tree *Tree) GetActiveEntriesInTwig(twigID int64) chan []byte

func (*Tree) GetFileSizes

func (tree *Tree) GetFileSizes() (int64, int64)

func (*Tree) GetProof

func (tree *Tree) GetProof(sn int64) *ProofPath

func (*Tree) GetProofBytesAndCheck

func (tree *Tree) GetProofBytesAndCheck(sn int64, entryBz []byte) ([]byte, error)

func (*Tree) LoadMtree4YT

func (tree *Tree) LoadMtree4YT(infile io.Reader) error

func (*Tree) LoadNodes

func (tree *Tree) LoadNodes(infile io.Reader) error

func (*Tree) PrintTree

func (tree *Tree) PrintTree()

func (*Tree) PruneTwigs

func (tree *Tree) PruneTwigs(startID, endID int64) []byte

Prune the twigs between startID and endID

func (*Tree) ReadEntry

func (tree *Tree) ReadEntry(pos int64) (entry *Entry)

func (*Tree) ReadEntryBytesForProof

func (tree *Tree) ReadEntryBytesForProof(pos int64) (entryBz []byte)

func (*Tree) ReapNodes

func (tree *Tree) ReapNodes(start, end int64) []byte

func (*Tree) RecoverActiveTwigs

func (tree *Tree) RecoverActiveTwigs(oldestActiveTwigID int64) []int64

func (*Tree) RecoverEntry

func (tree *Tree) RecoverEntry(pos int64, entry *Entry, deactivedSNList []int64, oldestActiveTwigID int64)

func (*Tree) RecoverInactiveTwigRoots

func (tree *Tree) RecoverInactiveTwigRoots(lastPrunedTwigID, oldestActiveTwigID int64)

func (*Tree) RecoverUpperNodes

func (tree *Tree) RecoverUpperNodes(edgeNodes []*EdgeNode, nList []int64) [32]byte

func (*Tree) SaveMemToDisk

func (tree *Tree) SaveMemToDisk()

func (*Tree) ScanEntries

func (tree *Tree) ScanEntries(oldestActiveTwigID int64, outChan chan types.EntryX)

func (*Tree) ScanEntriesLite

func (tree *Tree) ScanEntriesLite(oldestActiveTwigID int64, outChan chan types.KeyAndPos)

func (*Tree) TruncateFiles

func (tree *Tree) TruncateFiles(entryFileSize, twigMtFileSize int64)

func (*Tree) TwigCanBePruned

func (tree *Tree) TwigCanBePruned(twigID int64) bool

func (*Tree) WaitForFlushing

func (tree *Tree) WaitForFlushing()

type Twig

type Twig struct {
	FirstEntryPos int64
	// contains filtered or unexported fields
}
var NullTwig Twig

func CopyNullTwig

func CopyNullTwig() *Twig

func LoadTwigFromFile

func LoadTwigFromFile(infile io.Reader) (twigID int64, twig Twig, err error)

func (*Twig) Dump

func (twig *Twig) Dump(twigID int64, outfile io.Writer) error

type TwigMtFile

type TwigMtFile struct {
	*HPFile
}

func NewTwigMtFile

func NewTwigMtFile(bufferSize, blockSize int, dirName string) (res TwigMtFile, err error)

func (*TwigMtFile) AppendTwig

func (tf *TwigMtFile) AppendTwig(mtree [][32]byte, firstEntryPos int64)

func (*TwigMtFile) Close

func (tf *TwigMtFile) Close()

func (*TwigMtFile) Flush

func (tf *TwigMtFile) Flush()

func (*TwigMtFile) GetFirstEntryPos

func (tf *TwigMtFile) GetFirstEntryPos(twigID int64) int64

func (*TwigMtFile) GetHashNode

func (tf *TwigMtFile) GetHashNode(twigID int64, hashID int, cache map[int][]byte) []byte

func (*TwigMtFile) PruneHead

func (tf *TwigMtFile) PruneHead(off int64)

func (*TwigMtFile) Size

func (tf *TwigMtFile) Size() int64

func (*TwigMtFile) StartFlushing

func (tf *TwigMtFile) StartFlushing()

func (*TwigMtFile) Truncate

func (tf *TwigMtFile) Truncate(size int64)

func (*TwigMtFile) WaitForFlushing

func (tf *TwigMtFile) WaitForFlushing()

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL