From abc736df1d25f9cbde87bde42df525cab4c60fa7 Mon Sep 17 00:00:00 2001 From: Nick Craig-Wood Date: Mon, 19 Feb 2018 16:12:43 +0000 Subject: [PATCH] cat: Use RangeOption for limited fetches to make more efficient #1825 --- fs/operations/operations.go | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/fs/operations/operations.go b/fs/operations/operations.go index 19a01dd51..6a2f48734 100644 --- a/fs/operations/operations.go +++ b/fs/operations/operations.go @@ -1340,16 +1340,17 @@ func Cat(f fs.Fs, w io.Writer, offset, count int64) error { defer func() { accounting.Stats.DoneTransferring(o.Remote(), err == nil) }() + opt := fs.RangeOption{Start: offset, End: -1} size := o.Size() - thisOffset := offset - if thisOffset < 0 { - thisOffset += size + if opt.Start < 0 { + opt.Start += size + } + if count >= 0 { + opt.End = opt.Start + count - 1 } - // size remaining is now reduced by thisOffset - size -= thisOffset var options []fs.OpenOption - if thisOffset > 0 { - options = append(options, &fs.SeekOption{Offset: thisOffset}) + if opt.Start > 0 || opt.End >= 0 { + options = append(options, &opt) } in, err := o.Open(options...) if err != nil {