fs

package
v0.18.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 20, 2024 License: Apache-2.0 Imports: 7 Imported by: 9

Documentation

Overview

Package fs defines virtual filesystem abstractions.

Index

Constants

View Source
const MaxFailedEntriesPerDirectorySummary = 10

MaxFailedEntriesPerDirectorySummary is the maximum number of failed entries per directory summary.

ModBits is a bitmask representing the mode flags supported.

Variables

View Source
var ErrEntryNotFound = errors.New("entry not found")

ErrEntryNotFound is returned when an entry is not found.

View Source
var ErrUnknown = errors.New("unknown or unsupported entry type")

ErrUnknown is returned by ErrorEntry.ErrorInfo() to indicate that type of an entry is unknown.

Functions

func IterateEntries added in v0.15.0

func IterateEntries(ctx context.Context, dir Directory, cb func(context.Context, Entry) error) error

IterateEntries iterates entries the provided directory and invokes given callback for each entry or until the callback returns an error.

func Sort added in v0.11.0

func Sort(entries []Entry)

Sort sorts the entries by name.

Types

type DeviceInfo added in v0.8.0

type DeviceInfo struct {
	Dev  uint64 `json:"dev"`
	Rdev uint64 `json:"rdev"`
}

DeviceInfo describes the device this filesystem entry is on.

type Directory

type Directory interface {
	Entry

	Child(ctx context.Context, name string) (Entry, error)
	Iterate(ctx context.Context) (DirectoryIterator, error)
	// SupportsMultipleIterations returns true if the Directory supports iterating
	// through the entries multiple times. Otherwise it returns false.
	SupportsMultipleIterations() bool
}

Directory represents contents of a directory.

type DirectoryIterator added in v0.15.0

type DirectoryIterator interface {
	Next(ctx context.Context) (Entry, error)
	Close()
}

DirectoryIterator iterates entries in a directory.

The client is expected to call Next() in a loop until it returns a nil entry to signal end of iteration or until an error has occurred.

Valid results:

(nil,nil) - end of iteration, success (entry,nil) - iteration in progress, success (nil,err) - iteration stopped, failure

The behavior of calling Next() after iteration has signaled its end is undefined.

To release any resources associated with iteration the client must call Close().

func StaticIterator added in v0.15.0

func StaticIterator(entries []Entry, err error) DirectoryIterator

StaticIterator returns a DirectoryIterator which returns the provided entries in order followed by a given final error. It is not safe to concurrently access directory iterator.

type DirectorySummary

type DirectorySummary struct {
	TotalFileSize     int64        `json:"size"`
	TotalFileCount    int64        `json:"files"`
	TotalSymlinkCount int64        `json:"symlinks"`
	TotalDirCount     int64        `json:"dirs"`
	MaxModTime        UTCTimestamp `json:"maxTime"`
	IncompleteReason  string       `json:"incomplete,omitempty"`

	// number of failed files
	FatalErrorCount   int `json:"numFailed"`
	IgnoredErrorCount int `json:"numIgnoredErrors,omitempty"`

	// first 10 failed entries
	FailedEntries []*EntryWithError `json:"errors,omitempty"`
}

DirectorySummary represents summary information about a directory.

func (*DirectorySummary) Clone added in v0.7.0

Clone clones given directory summary.

type DirectoryWithSummary added in v0.7.2

type DirectoryWithSummary interface {
	Summary(ctx context.Context) (*DirectorySummary, error)
}

DirectoryWithSummary is optionally implemented by Directory that provide summary.

type Entry

type Entry interface {
	os.FileInfo
	Owner() OwnerInfo
	Device() DeviceInfo
	LocalFilesystemPath() string // returns full local filesystem path or "" if not a local filesystem
	Close()                      // closes or recycles any resources associated with the entry, must be idempotent
}

Entry represents a filesystem entry, which can be Directory, File, or Symlink.

func FindByName added in v0.11.0

func FindByName(entries []Entry, n string) Entry

FindByName returns an entry with a given name, or nil if not found. Assumes the given slice of fs.Entry is sorted.

func GetAllEntries added in v0.11.0

func GetAllEntries(ctx context.Context, d Directory) ([]Entry, error)

GetAllEntries uses Iterate to return all entries in a Directory.

func IterateEntriesAndFindChild added in v0.11.0

func IterateEntriesAndFindChild(ctx context.Context, d Directory, name string) (Entry, error)

IterateEntriesAndFindChild iterates through entries from a directory and returns one by name. This is a convenience function that may be helpful in implementations of Directory.Child().

type EntryWithError added in v0.6.0

type EntryWithError struct {
	EntryPath string `json:"path"`
	Error     string `json:"error"`
}

EntryWithError describes error encountered when processing an entry.

type ErrorEntry added in v0.8.0

type ErrorEntry interface {
	Entry

	ErrorInfo() error
}

ErrorEntry represents entry in a Directory that had encountered an error or is unknown/unsupported (ErrUnknown).

type File

type File interface {
	Entry
	Open(ctx context.Context) (Reader, error)
}

File represents an entry that is a file.

type OwnerInfo

type OwnerInfo struct {
	UserID  uint32 `json:"uid"`
	GroupID uint32 `json:"gid"`
}

OwnerInfo describes owner of a filesystem entry.

type Reader

type Reader interface {
	io.ReadCloser
	io.Seeker

	Entry() (Entry, error)
}

Reader allows reading from a file and retrieving its up-to-date file info.

type StreamingFile added in v0.8.0

type StreamingFile interface {
	Entry
	GetReader(ctx context.Context) (io.ReadCloser, error)
}

StreamingFile represents an entry that is a stream.

type Symlink interface {
	Entry
	Readlink(ctx context.Context) (string, error)
	Resolve(ctx context.Context) (Entry, error)
}

Symlink represents a symbolic link entry.

type UTCTimestamp added in v0.12.0

type UTCTimestamp int64

UTCTimestamp stores the UTC timestamp in nanoseconds and provides JSON serializability.

func UTCTimestampFromTime added in v0.12.0

func UTCTimestampFromTime(t time.Time) UTCTimestamp

UTCTimestampFromTime converts time.Time to UTCTimestamp.

func (UTCTimestamp) Add added in v0.12.0

Add adds the specified duration to UTC time.

func (UTCTimestamp) After added in v0.12.0

func (u UTCTimestamp) After(other UTCTimestamp) bool

After returns true if the timestamp is after another timestamp.

func (UTCTimestamp) Before added in v0.12.0

func (u UTCTimestamp) Before(other UTCTimestamp) bool

Before returns true if the timestamp is before another timestamp.

func (UTCTimestamp) Equal added in v0.12.0

func (u UTCTimestamp) Equal(other UTCTimestamp) bool

Equal returns true if the timestamp is equal to another timestamp.

func (UTCTimestamp) Format added in v0.12.0

func (u UTCTimestamp) Format(layout string) string

Format formats the timestamp according to the provided layout.

func (UTCTimestamp) MarshalJSON added in v0.12.0

func (u UTCTimestamp) MarshalJSON() ([]byte, error)

MarshalJSON implements json.Marshaler.

func (UTCTimestamp) Sub added in v0.12.0

Sub returns the difference between two specified durations.

func (UTCTimestamp) ToTime added in v0.12.0

func (u UTCTimestamp) ToTime() time.Time

ToTime returns time.Time representation of the time.

func (*UTCTimestamp) UnmarshalJSON added in v0.12.0

func (u *UTCTimestamp) UnmarshalJSON(v []byte) error

UnmarshalJSON implements json.Unmarshaler.

Directories

Path Synopsis
Package cachefs implements a wrapper that caches filesystem actions.
Package cachefs implements a wrapper that caches filesystem actions.
Package ignorefs implements a wrapper that hides ignored files listed in '.kopiaignore' and in policies attached to directories.
Package ignorefs implements a wrapper that hides ignored files listed in '.kopiaignore' and in policies attached to directories.
Package localfs implements virtual filesystem abstraction for a local filesystem.
Package localfs implements virtual filesystem abstraction for a local filesystem.
Package loggingfs implements a wrapper that logs all filesystem actions.
Package loggingfs implements a wrapper that logs all filesystem actions.
Package virtualfs implements an in-memory abstraction of fs.Directory and fs.StreamingFile.
Package virtualfs implements an in-memory abstraction of fs.Directory and fs.StreamingFile.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL