forked from TrueCloudLab/restic
Add Load() to MemBackend
This commit is contained in:
parent
3aafa21887
commit
e966df3fed
1 changed files with 42 additions and 0 deletions
|
@ -45,6 +45,10 @@ func NewMemoryBackend() *MemoryBackend {
|
||||||
return memGetReader(be, t, name, offset, length)
|
return memGetReader(be, t, name, offset, length)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
be.MockBackend.LoadFn = func(h Handle, p []byte, off int64) (int, error) {
|
||||||
|
return memLoad(be, h, p, off)
|
||||||
|
}
|
||||||
|
|
||||||
be.MockBackend.RemoveFn = func(t Type, name string) error {
|
be.MockBackend.RemoveFn = func(t Type, name string) error {
|
||||||
return memRemove(be, t, name)
|
return memRemove(be, t, name)
|
||||||
}
|
}
|
||||||
|
@ -61,6 +65,10 @@ func NewMemoryBackend() *MemoryBackend {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
be.MockBackend.LocationFn = func() string {
|
||||||
|
return "Memory Backend"
|
||||||
|
}
|
||||||
|
|
||||||
debug.Log("MemoryBackend.New", "created new memory backend")
|
debug.Log("MemoryBackend.New", "created new memory backend")
|
||||||
|
|
||||||
return be
|
return be
|
||||||
|
@ -171,6 +179,40 @@ func memGetReader(be *MemoryBackend, t Type, name string, offset, length uint) (
|
||||||
return readCloser{bytes.NewReader(buf)}, nil
|
return readCloser{bytes.NewReader(buf)}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func memLoad(be *MemoryBackend, h Handle, p []byte, off int64) (int, error) {
|
||||||
|
be.m.Lock()
|
||||||
|
defer be.m.Unlock()
|
||||||
|
|
||||||
|
if err := h.Valid(); err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if h.Type == Config {
|
||||||
|
h.Name = ""
|
||||||
|
}
|
||||||
|
|
||||||
|
debug.Log("MemoryBackend.Load", "get %v offset %v len %v", h, off, len(p))
|
||||||
|
|
||||||
|
if _, ok := be.data[entry{h.Type, h.Name}]; !ok {
|
||||||
|
return 0, errors.New("no such data")
|
||||||
|
}
|
||||||
|
|
||||||
|
buf := be.data[entry{h.Type, h.Name}]
|
||||||
|
if off > int64(len(buf)) {
|
||||||
|
return 0, errors.New("offset beyond end of file")
|
||||||
|
}
|
||||||
|
|
||||||
|
buf = buf[off:]
|
||||||
|
|
||||||
|
n := copy(p, buf)
|
||||||
|
|
||||||
|
if len(p) > len(buf) {
|
||||||
|
return n, io.ErrUnexpectedEOF
|
||||||
|
}
|
||||||
|
|
||||||
|
return n, nil
|
||||||
|
}
|
||||||
|
|
||||||
func memRemove(be *MemoryBackend, t Type, name string) error {
|
func memRemove(be *MemoryBackend, t Type, name string) error {
|
||||||
be.m.Lock()
|
be.m.Lock()
|
||||||
defer be.m.Unlock()
|
defer be.m.Unlock()
|
||||||
|
|
Loading…
Reference in a new issue