X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/3a7b90da8ac9b920d87eaf3a783b72c4bb94db14..8d6c35e4dd68baec1b58d566d32d89feb651deac:/sdk/go/arvados/fs_filehandle.go diff --git a/sdk/go/arvados/fs_filehandle.go b/sdk/go/arvados/fs_filehandle.go index 9af8d0ad40..f50dd4612b 100644 --- a/sdk/go/arvados/fs_filehandle.go +++ b/sdk/go/arvados/fs_filehandle.go @@ -6,6 +6,7 @@ package arvados import ( "io" + "io/fs" "os" ) @@ -73,6 +74,31 @@ func (f *filehandle) Write(p []byte) (n int, err error) { return } +// dirEntry implements fs.DirEntry, see (*filehandle)ReadDir(). +type dirEntry struct { + os.FileInfo +} + +func (ent dirEntry) Type() fs.FileMode { + return ent.Mode().Type() +} +func (ent dirEntry) Info() (fs.FileInfo, error) { + return ent, nil +} + +// ReadDir implements fs.ReadDirFile. +func (f *filehandle) ReadDir(count int) ([]fs.DirEntry, error) { + fis, err := f.Readdir(count) + if len(fis) == 0 { + return nil, err + } + ents := make([]fs.DirEntry, len(fis)) + for i, fi := range fis { + ents[i] = dirEntry{fi} + } + return ents, err +} + func (f *filehandle) Readdir(count int) ([]os.FileInfo, error) { if !f.inode.IsDir() { return nil, ErrInvalidOperation @@ -110,3 +136,18 @@ func (f *filehandle) Sync() error { // Sync the containing filesystem. return f.FS().Sync() } + +func (f *filehandle) Snapshot() (*Subtree, error) { + if !f.readable { + return nil, ErrInvalidOperation + } + node, err := f.inode.Snapshot() + return &Subtree{inode: node}, err +} + +func (f *filehandle) Splice(r *Subtree) error { + if !f.writable { + return ErrReadOnlyFile + } + return f.inode.Splice(r.inode) +}