fs: define ListP interface for paged listing #4788

This commit is contained in:
Nick Craig-Wood 2024-11-22 17:55:15 +00:00
parent d48cf0ade1
commit 182fce9914
2 changed files with 40 additions and 0 deletions

View File

@ -158,6 +158,21 @@ type Features struct {
// of listing recursively that doing a directory traversal. // of listing recursively that doing a directory traversal.
ListR ListRFn ListR ListRFn
// ListP lists the objects and directories of the Fs starting
// from dir non recursively to out.
//
// dir should be "" to start from the root, and should not
// have trailing slashes.
//
// This should return ErrDirNotFound if the directory isn't
// found.
//
// It should call callback for each tranche of entries read.
// These need not be returned in any particular order. If
// callback returns an error then the listing will stop
// immediately.
ListP func(ctx context.Context, dir string, callback ListRCallback) error
// About gets quota information from the Fs // About gets quota information from the Fs
About func(ctx context.Context) (*Usage, error) About func(ctx context.Context) (*Usage, error)
@ -326,6 +341,9 @@ func (ft *Features) Fill(ctx context.Context, f Fs) *Features {
if do, ok := f.(ListRer); ok { if do, ok := f.(ListRer); ok {
ft.ListR = do.ListR ft.ListR = do.ListR
} }
if do, ok := f.(ListPer); ok {
ft.ListP = do.ListP
}
if do, ok := f.(Abouter); ok { if do, ok := f.(Abouter); ok {
ft.About = do.About ft.About = do.About
} }
@ -432,6 +450,9 @@ func (ft *Features) Mask(ctx context.Context, f Fs) *Features {
if mask.ListR == nil { if mask.ListR == nil {
ft.ListR = nil ft.ListR = nil
} }
if mask.ListP == nil {
ft.ListP = nil
}
if mask.About == nil { if mask.About == nil {
ft.About = nil ft.About = nil
} }
@ -660,6 +681,24 @@ type ListRer interface {
ListR(ctx context.Context, dir string, callback ListRCallback) error ListR(ctx context.Context, dir string, callback ListRCallback) error
} }
// ListPer is an optional interfaces for Fs
type ListPer interface {
// ListP lists the objects and directories of the Fs starting
// from dir non recursively into out.
//
// dir should be "" to start from the root, and should not
// have trailing slashes.
//
// This should return ErrDirNotFound if the directory isn't
// found.
//
// It should call callback for each tranche of entries read.
// These need not be returned in any particular order. If
// callback returns an error then the listing will stop
// immediately.
ListP(ctx context.Context, dir string, callback ListRCallback) error
}
// RangeSeeker is the interface that wraps the RangeSeek method. // RangeSeeker is the interface that wraps the RangeSeek method.
// //
// Some of the returns from Object.Open() may optionally implement // Some of the returns from Object.Open() may optionally implement

View File

@ -311,6 +311,7 @@ func DirectoryOptionalInterfaces(d Directory) (supported, unsupported []string)
type ListRCallback func(entries DirEntries) error type ListRCallback func(entries DirEntries) error
// ListRFn is defines the call used to recursively list a directory // ListRFn is defines the call used to recursively list a directory
// with ListR or page through a directory with ListP
type ListRFn func(ctx context.Context, dir string, callback ListRCallback) error type ListRFn func(ctx context.Context, dir string, callback ListRCallback) error
// Flagger describes the interface rclone config types flags must satisfy // Flagger describes the interface rclone config types flags must satisfy