Involved Source Files
Package fs defines basic interfaces to a file system.
A file system can be provided by the host operating system
but also by other packages.
glob.goreaddir.goreadfile.gostat.gosub.gowalk.go
Package-Level Type Names (total 15, in which 13 are exported)
/* sort exporteds by: | */
A DirEntry is an entry read from a directory
(using the ReadDir function or a ReadDirFile's ReadDir method).
Info returns the FileInfo for the file or subdirectory described by the entry.
The returned FileInfo may be from the time of the original directory read
or from the time of the call to Info. If the file has been removed or renamed
since the directory read, Info may return an error satisfying errors.Is(err, ErrNotExist).
If the entry denotes a symbolic link, Info reports the information about the link itself,
not the link's target.
IsDir reports whether the entry describes a directory.
Name returns the name of the file (or subdirectory) described by the entry.
This name is only the final element of the path (the base name), not the entire path.
For example, Name would return "hello.go" not "/home/gopher/hello.go".
Type returns the type bits for the entry.
The type bits are a subset of the usual FileMode bits, those returned by the FileMode.Type method.
*statDirEntry
*embed.file
github.com/spf13/afero.dirEntry
*os.unixDirent
*path/filepath.statDirEntry
func ReadDir(fsys FS, name string) ([]DirEntry, error)
func ReadDirFile.ReadDir(n int) ([]DirEntry, error)
func ReadDirFS.ReadDir(name string) ([]DirEntry, error)
func embed.FS.ReadDir(name string) ([]DirEntry, error)
func github.com/spf13/afero.IOFS.ReadDir(name string) ([]DirEntry, error)
func os.ReadDir(name string) ([]os.DirEntry, error)
func os.(*File).ReadDir(n int) ([]os.DirEntry, error)
func crypto/x509.readUniqueDirectoryEntries(dir string) ([]DirEntry, error)
func os.newUnixDirent(parent, name string, typ os.FileMode) (os.DirEntry, error)
func os.(*File).readdir(n int, mode os.readdirMode) (names []string, dirents []os.DirEntry, infos []os.FileInfo, err error)
func path/filepath.readDir(dirname string) ([]DirEntry, error)
func walkDir(fsys FS, name string, d DirEntry, walkDirFn WalkDirFunc) error
func crypto/x509.isSameDirSymlink(f DirEntry, dir string) bool
func path/filepath.walkDir(path string, d DirEntry, walkDirFn WalkDirFunc) error
A GlobFS is a file system with a Glob method.
Glob returns the names of all files matching pattern,
providing an implementation of the top-level
Glob function.
Open opens the named file.
When Open returns an error, it should be of type *PathError
with the Op field set to "open", the Path field set to name,
and the Err field describing the problem.
Open should reject attempts to open names that do not satisfy
ValidPath(name), returning a *PathError with Err set to
ErrInvalid or ErrNotExist.
github.com/spf13/afero.IOFS
*subFS
T : FS
A ReadDirFile is a directory file whose entries can be read with the ReadDir method.
Every directory file should implement this interface.
(It is permissible for any file to implement this interface,
but if so ReadDir should return an error for non-directories.)
( T) Close() error( T) Read([]byte) (int, error)
ReadDir reads the contents of the directory and returns
a slice of up to n DirEntry values in directory order.
Subsequent calls on the same file will yield further DirEntry values.
If n > 0, ReadDir returns at most n DirEntry structures.
In this case, if ReadDir returns an empty slice, it will return
a non-nil error explaining why.
At the end of a directory, the error is io.EOF.
If n <= 0, ReadDir returns all the DirEntry values from the directory
in a single slice. In this case, if ReadDir succeeds (reads all the way
to the end of the directory), it returns the slice and a nil error.
If it encounters an error before the end of the directory,
ReadDir returns the DirEntry list read until that point and a non-nil error.
( T) Stat() (FileInfo, error)
*os.File
*embed.openDir
github.com/spf13/afero.readDirFile
net/http.ioFile
T : File
T : io.Closer
T : io.ReadCloser
T : io.Reader
ReadDirFS is the interface implemented by a file system
that provides an optimized implementation of ReadDir.
Open opens the named file.
When Open returns an error, it should be of type *PathError
with the Op field set to "open", the Path field set to name,
and the Err field describing the problem.
Open should reject attempts to open names that do not satisfy
ValidPath(name), returning a *PathError with Err set to
ErrInvalid or ErrNotExist.
ReadDir reads the named directory
and returns a list of directory entries sorted by filename.
embed.FS
github.com/spf13/afero.IOFS
*subFS
T : FS
ReadFileFS is the interface implemented by a file system
that provides an optimized implementation of ReadFile.
Open opens the named file.
When Open returns an error, it should be of type *PathError
with the Op field set to "open", the Path field set to name,
and the Err field describing the problem.
Open should reject attempts to open names that do not satisfy
ValidPath(name), returning a *PathError with Err set to
ErrInvalid or ErrNotExist.
ReadFile reads the named file and returns its contents.
A successful call returns a nil error, not io.EOF.
(Because ReadFile reads the whole file, the expected EOF
from the final Read is not treated as an error to be reported.)
embed.FS
github.com/spf13/afero.IOFS
*subFS
T : FS
A StatFS is a file system with a Stat method.
Open opens the named file.
When Open returns an error, it should be of type *PathError
with the Op field set to "open", the Path field set to name,
and the Err field describing the problem.
Open should reject attempts to open names that do not satisfy
ValidPath(name), returning a *PathError with Err set to
ErrInvalid or ErrNotExist.
Stat returns a FileInfo describing the file.
If there is an error, it should be of type *PathError.
github.com/spf13/afero.IOFS
T : FS
A SubFS is a file system with a Sub method.
Open opens the named file.
When Open returns an error, it should be of type *PathError
with the Op field set to "open", the Path field set to name,
and the Err field describing the problem.
Open should reject attempts to open names that do not satisfy
ValidPath(name), returning a *PathError with Err set to
ErrInvalid or ErrNotExist.
Sub returns an FS corresponding to the subtree rooted at dir.
github.com/spf13/afero.IOFS
T : FS
WalkDirFunc is the type of the function called by WalkDir to visit
each file or directory.
The path argument contains the argument to WalkDir as a prefix.
That is, if WalkDir is called with root argument "dir" and finds a file
named "a" in that directory, the walk function will be called with
argument "dir/a".
The d argument is the fs.DirEntry for the named path.
The error result returned by the function controls how WalkDir
continues. If the function returns the special value SkipDir, WalkDir
skips the current directory (path if d.IsDir() is true, otherwise
path's parent directory). Otherwise, if the function returns a non-nil
error, WalkDir stops entirely and returns that error.
The err argument reports an error related to path, signaling that
WalkDir will not walk into that directory. The function can decide how
to handle that error; as described earlier, returning the error will
cause WalkDir to stop walking the entire tree.
WalkDir calls the function with a non-nil err argument in two cases.
First, if the initial fs.Stat on the root directory fails, WalkDir
calls the function with path set to root, d set to nil, and err set to
the error from fs.Stat.
Second, if a directory's ReadDir method fails, WalkDir calls the
function with path set to the directory's path, d set to an
fs.DirEntry describing the directory, and err set to the error from
ReadDir. In this second case, the function is called twice with the
path of the directory: the first call is before the directory read is
attempted and has err set to nil, giving the function a chance to
return SkipDir and avoid the ReadDir entirely. The second call is
after a failed ReadDir and reports the error from ReadDir.
(If ReadDir succeeds, there is no second call.)
The differences between WalkDirFunc compared to filepath.WalkFunc are:
- The second argument has type fs.DirEntry instead of fs.FileInfo.
- The function is called before reading a directory, to allow SkipDir
to bypass the directory read entirely.
- If a directory read fails, the function is called a second time
for that directory to report the error.
func WalkDir(fsys FS, root string, fn WalkDirFunc) error
func path/filepath.WalkDir(root string, fn WalkDirFunc) error
func walkDir(fsys FS, name string, d DirEntry, walkDirFn WalkDirFunc) error
func path/filepath.walkDir(path string, d DirEntry, walkDirFn WalkDirFunc) error
Package-Level Functions (total 16, in which 7 are exported)
Glob returns the names of all files matching pattern or nil
if there is no matching file. The syntax of patterns is the same
as in path.Match. The pattern may describe hierarchical names such as
usr/*/bin/ed.
Glob ignores file system errors such as I/O errors reading directories.
The only possible returned error is path.ErrBadPattern, reporting that
the pattern is malformed.
If fs implements GlobFS, Glob calls fs.Glob.
Otherwise, Glob uses ReadDir to traverse the directory tree
and look for matches for the pattern.
ReadDir reads the named directory
and returns a list of directory entries sorted by filename.
If fs implements ReadDirFS, ReadDir calls fs.ReadDir.
Otherwise ReadDir calls fs.Open and uses ReadDir and Close
on the returned file.
ReadFile reads the named file from the file system fs and returns its contents.
A successful call returns a nil error, not io.EOF.
(Because ReadFile reads the whole file, the expected EOF
from the final Read is not treated as an error to be reported.)
If fs implements ReadFileFS, ReadFile calls fs.ReadFile.
Otherwise ReadFile calls fs.Open and uses Read and Close
on the returned file.
Stat returns a FileInfo describing the named file from the file system.
If fs implements StatFS, Stat calls fs.Stat.
Otherwise, Stat opens the file to stat it.
Sub returns an FS corresponding to the subtree rooted at fsys's dir.
If fs implements SubFS, Sub calls returns fsys.Sub(dir).
Otherwise, if dir is ".", Sub returns fsys unchanged.
Otherwise, Sub returns a new FS implementation sub that,
in effect, implements sub.Open(dir) as fsys.Open(path.Join(dir, name)).
The implementation also translates calls to ReadDir, ReadFile, and Glob appropriately.
Note that Sub(os.DirFS("/"), "prefix") is equivalent to os.DirFS("/prefix")
and that neither of them guarantees to avoid operating system
accesses outside "/prefix", because the implementation of os.DirFS
does not check for symbolic links inside "/prefix" that point to
other directories. That is, os.DirFS is not a general substitute for a
chroot-style security mechanism, and Sub does not change that fact.
ValidPath reports whether the given path name
is valid for use in a call to Open.
Path names passed to open are UTF-8-encoded,
unrooted, slash-separated sequences of path elements, like “x/y/z”.
Path names must not contain an element that is “.” or “..” or the empty string,
except for the special case that the root directory is named “.”.
Paths must not start or end with a slash: “/x” and “x/” are invalid.
Note that paths are slash-separated on all systems, even Windows.
Paths containing other characters such as backslash and colon
are accepted as valid, but those characters must never be
interpreted by an FS implementation as path element separators.
WalkDir walks the file tree rooted at root, calling fn for each file or
directory in the tree, including root.
All errors that arise visiting files and directories are filtered by fn:
see the fs.WalkDirFunc documentation for details.
The files are walked in lexical order, which makes the output deterministic
but requires WalkDir to read an entire directory into memory before proceeding
to walk that directory.
WalkDir does not follow symbolic links found in directories,
but if root itself is a symbolic link, its target will be walked.
glob searches for files matching pattern in the directory dir
and appends them to matches, returning the updated slice.
If the directory cannot be opened, glob returns the existing matches.
New matches are added in lexicographical order.
hasMeta reports whether path contains any of the magic characters
recognized by path.Match.
Package-Level Variables (total 6, all are exported)
Generic file system errors.
Errors returned by file systems can be tested against these errors
using errors.Is.
Generic file system errors.
Errors returned by file systems can be tested against these errors
using errors.Is.
Generic file system errors.
Errors returned by file systems can be tested against these errors
using errors.Is.
Generic file system errors.
Errors returned by file systems can be tested against these errors
using errors.Is.
Generic file system errors.
Errors returned by file systems can be tested against these errors
using errors.Is.
SkipDir is used as a return value from WalkDirFuncs to indicate that
the directory named in the call is to be skipped. It is not returned
as an error by any function.
Package-Level Constants (total 15, all are exported)
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
The single letters are the abbreviations
used by the String method's formatting.
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
The defined file mode bits are the most significant bits of the FileMode.
The nine least-significant bits are the standard Unix rwxrwxrwx permissions.
The values of these bits should be considered part of the public API and
may be used in wire protocols or disk representations: they must not be
changed, although new bits might be added.
Mask for the type bits. For regular files, none will be set.
The pages are generated with Goldsv0.3.2. (GOOS=linux GOARCH=amd64)
Golds is a Go 101 project developed by Tapir Liu.
PR and bug reports are welcome and can be submitted to the issue list.
Please follow @Go100and1 (reachable from the left QR code) to get the latest news of Golds.