1
mirror of https://github.com/rclone/rclone synced 2025-01-09 11:46:24 +01:00
rclone/lib/readers/limited.go

37 lines
924 B
Go
Raw Normal View History

2018-01-22 20:44:55 +01:00
package readers
import (
"io"
"github.com/rclone/rclone/fs"
)
2018-01-22 20:44:55 +01:00
// LimitedReadCloser adds io.Closer to io.LimitedReader. Create one with NewLimitedReadCloser
type LimitedReadCloser struct {
*io.LimitedReader
io.Closer
}
// Close closes the underlying io.Closer. The error, if any, will be ignored if data is read completely
func (lrc *LimitedReadCloser) Close() error {
err := lrc.Closer.Close()
if err != nil && lrc.N == 0 {
fs.Debugf(nil, "ignoring close error because we already got all the data")
err = nil
}
return err
}
2018-01-22 20:44:55 +01:00
// NewLimitedReadCloser returns a LimitedReadCloser wrapping rc to
// limit it to reading limit bytes. If limit < 0 then it does not
2018-01-22 20:44:55 +01:00
// wrap rc, it just returns it.
func NewLimitedReadCloser(rc io.ReadCloser, limit int64) (lrc io.ReadCloser) {
if limit < 0 {
2018-01-22 20:44:55 +01:00
return rc
}
return &LimitedReadCloser{
LimitedReader: &io.LimitedReader{R: rc, N: limit},
Closer: rc,
}
}