mirror of
				https://github.com/kaspanet/kaspad.git
				synced 2025-10-14 00:59:33 +00:00 
			
		
		
		
	 7609c50641
			
		
	
	
		7609c50641
		
			
		
	
	
	
	
		
			
			* [NOD-885] Create database.Key type * [NOD-885] Rename FullKey()->FullKeyBytes() and Key()->KeyBytes() * [NOD-885] Make Key.String return a hex string * [NOD-885] Rename key parts * [NOD-885] Rename separator->bucketSeparator * [NOD-885] Rename SuffixBytes->Suffix and PrefixBytes->Prefix * [NOD-885] Change comments * [NOD-885] Change key prefix to bucket * [NOD-885] Don't use database.NewKey inside dbaccess * [NOD-885] Fix nil bug in Bucket.Path() * [NOD-885] Rename helpers.go -> keys.go * [NOD-885] Unexport database.NewKey * [NOD-885] Remove redundant code in Bucket.Path()
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package database
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"encoding/hex"
 | |
| )
 | |
| 
 | |
| var bucketSeparator = []byte("/")
 | |
| 
 | |
| // Key is a helper type meant to combine prefix
 | |
| // and suffix into a single database key.
 | |
| type Key struct {
 | |
| 	bucket *Bucket
 | |
| 	suffix []byte
 | |
| }
 | |
| 
 | |
| // Bytes returns the full key bytes that are consisted
 | |
| // from the bucket path concatenated to the suffix.
 | |
| func (k *Key) Bytes() []byte {
 | |
| 	bucketPath := k.bucket.Path()
 | |
| 	keyBytes := make([]byte, len(bucketPath)+len(k.suffix))
 | |
| 	copy(keyBytes, bucketPath)
 | |
| 	copy(keyBytes[len(bucketPath):], k.suffix)
 | |
| 	return keyBytes
 | |
| }
 | |
| 
 | |
| func (k *Key) String() string {
 | |
| 	return hex.EncodeToString(k.Bytes())
 | |
| }
 | |
| 
 | |
| // Bucket returns the key bucket.
 | |
| func (k *Key) Bucket() *Bucket {
 | |
| 	return k.bucket
 | |
| }
 | |
| 
 | |
| // Suffix returns the key suffix.
 | |
| func (k *Key) Suffix() []byte {
 | |
| 	return k.suffix
 | |
| }
 | |
| 
 | |
| // newKey returns a new key composed
 | |
| // of the given bucket and suffix
 | |
| func newKey(bucket *Bucket, suffix []byte) *Key {
 | |
| 	return &Key{bucket: bucket, suffix: suffix}
 | |
| }
 | |
| 
 | |
| // Bucket is a helper type meant to combine buckets
 | |
| // and sub-buckets that can be used to create database
 | |
| // keys and prefix-based cursors.
 | |
| type Bucket struct {
 | |
| 	path [][]byte
 | |
| }
 | |
| 
 | |
| // MakeBucket creates a new Bucket using the given path
 | |
| // of buckets.
 | |
| func MakeBucket(path ...[]byte) *Bucket {
 | |
| 	return &Bucket{path: path}
 | |
| }
 | |
| 
 | |
| // Bucket returns the sub-bucket of the current bucket
 | |
| // defined by bucketBytes.
 | |
| func (b *Bucket) Bucket(bucketBytes []byte) *Bucket {
 | |
| 	newPath := make([][]byte, len(b.path)+1)
 | |
| 	copy(newPath, b.path)
 | |
| 	copy(newPath[len(b.path):], [][]byte{bucketBytes})
 | |
| 
 | |
| 	return MakeBucket(newPath...)
 | |
| }
 | |
| 
 | |
| // Key returns a key in the current bucket with the
 | |
| // given suffix.
 | |
| func (b *Bucket) Key(suffix []byte) *Key {
 | |
| 	return newKey(b, suffix)
 | |
| }
 | |
| 
 | |
| // Path returns the full path of the current bucket.
 | |
| func (b *Bucket) Path() []byte {
 | |
| 	bucketPath := bytes.Join(b.path, bucketSeparator)
 | |
| 
 | |
| 	bucketPathWithFinalSeparator := make([]byte, len(bucketPath)+len(bucketSeparator))
 | |
| 	copy(bucketPathWithFinalSeparator, bucketPath)
 | |
| 	copy(bucketPathWithFinalSeparator[len(bucketPath):], bucketSeparator)
 | |
| 
 | |
| 	return bucketPathWithFinalSeparator
 | |
| }
 |