Skip to content

Commit

Permalink
Merge pull request #55 from Ritchie6/memo7
Browse files Browse the repository at this point in the history
Added Inverse func for the PathTransform func
  • Loading branch information
rtb-12 authored Jan 14, 2025
2 parents f13e4ec + 0a63d73 commit 5f812b6
Showing 1 changed file with 24 additions and 6 deletions.
30 changes: 24 additions & 6 deletions memoria.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,14 @@ const (
)

var (
defaultTransform = func(s string) *PathKey { return &PathKey{Path: []string{}, FileName: s} }
defaultTransform = func(s string) *PathKey {
return &PathKey{Path: []string{}, FileName: s}
}
)
var defaultInverseTransform = func(pathKey *PathKey) string {
// Rebuild the key by joining the path parts and appending the filename
return fmt.Sprintf("%s/%s", filepath.Join(pathKey.Path...), pathKey.FileName)
}

type PathKey struct {
Path []string
Expand All @@ -32,15 +38,19 @@ type PathKey struct {
// so the final location of the data file will be <basedir>/ab/cde/f/abcdef
type PathTransform func(key string) *PathKey

// inv transform func takes file path as input and returns the original key
type InversePathTransform func(pathKey *PathKey) string

type Options struct {
MaxCacheSize uint64
Basedir string
// Tempdir string solve for issues
pathPerm os.FileMode
filePerm os.FileMode
PathTransform PathTransform
cachePolicy CachePolicy
bufferSize int // the reading and writing is bufferd in memria so this feild represents the size of that buffer
pathPerm os.FileMode
filePerm os.FileMode
PathTransform PathTransform
InversePathTransform InversePathTransform
cachePolicy CachePolicy
bufferSize int // the reading and writing is bufferd in memria so this feild represents the size of that buffer
// compression Compression this field represents a compression mechanism for the store
// index Indexer this field is for the stores that have some sort of ordering

Expand All @@ -63,6 +73,10 @@ func New(o Options) *Memoria {
o.PathTransform = defaultTransform
}

if o.InversePathTransform == nil {
o.InversePathTransform = defaultInverseTransform
}

if o.cachePolicy == nil {
o.cachePolicy = &defaultCachePolicy{}
}
Expand Down Expand Up @@ -96,6 +110,10 @@ func (m *Memoria) transform(key string) (pathkey *PathKey) {
return pathkey
}

func (m *Memoria) InverseTransform(pathKey *PathKey) string {
return m.InversePathTransform(pathKey)
}

// Write synchronously the key-value pair to the disk making it immedialtely avaialble for
// reads. If you need stronger sync gaurantess see WriteStream
func (m *Memoria) Write(key string, val []byte) error {
Expand Down

0 comments on commit 5f812b6

Please sign in to comment.