2016-01-23 23:41:55 +01:00
|
|
|
package backend
|
|
|
|
|
2016-08-29 19:18:57 +02:00
|
|
|
import (
|
2017-06-03 17:39:57 +02:00
|
|
|
"context"
|
2016-08-29 19:18:57 +02:00
|
|
|
"io"
|
2017-01-23 16:07:39 +01:00
|
|
|
"io/ioutil"
|
2017-07-23 14:21:03 +02:00
|
|
|
|
2017-07-24 17:42:25 +02:00
|
|
|
"github.com/restic/restic/internal/restic"
|
2016-08-29 19:18:57 +02:00
|
|
|
)
|
2016-02-04 19:37:33 +01:00
|
|
|
|
2017-01-23 16:07:39 +01:00
|
|
|
// LoadAll reads all data stored in the backend for the handle.
|
2017-06-03 17:39:57 +02:00
|
|
|
func LoadAll(ctx context.Context, be restic.Backend, h restic.Handle) (buf []byte, err error) {
|
|
|
|
rd, err := be.Load(ctx, h, 0, 0)
|
2016-01-23 23:41:55 +01:00
|
|
|
if err != nil {
|
2017-01-23 16:07:39 +01:00
|
|
|
return nil, err
|
2016-01-23 23:41:55 +01:00
|
|
|
}
|
|
|
|
|
2017-01-23 16:07:39 +01:00
|
|
|
defer func() {
|
2017-05-01 15:38:01 +02:00
|
|
|
_, e := io.Copy(ioutil.Discard, rd)
|
|
|
|
if err == nil {
|
|
|
|
err = e
|
|
|
|
}
|
|
|
|
|
|
|
|
e = rd.Close()
|
2017-01-23 16:07:39 +01:00
|
|
|
if err == nil {
|
|
|
|
err = e
|
|
|
|
}
|
|
|
|
}()
|
2016-01-23 23:41:55 +01:00
|
|
|
|
2017-01-23 16:07:39 +01:00
|
|
|
return ioutil.ReadAll(rd)
|
2016-01-23 23:41:55 +01:00
|
|
|
}
|
2017-01-22 22:01:12 +01:00
|
|
|
|
|
|
|
// LimitedReadCloser wraps io.LimitedReader and exposes the Close() method.
|
|
|
|
type LimitedReadCloser struct {
|
|
|
|
io.ReadCloser
|
|
|
|
io.Reader
|
|
|
|
}
|
|
|
|
|
|
|
|
// Read reads data from the limited reader.
|
|
|
|
func (l *LimitedReadCloser) Read(p []byte) (int, error) {
|
|
|
|
return l.Reader.Read(p)
|
|
|
|
}
|
|
|
|
|
|
|
|
// LimitReadCloser returns a new reader wraps r in an io.LimitReader, but also
|
|
|
|
// exposes the Close() method.
|
|
|
|
func LimitReadCloser(r io.ReadCloser, n int64) *LimitedReadCloser {
|
|
|
|
return &LimitedReadCloser{ReadCloser: r, Reader: io.LimitReader(r, n)}
|
|
|
|
}
|