Documentation ¶
Overview ¶
Package local provides functions to operate local files and local file systems.
For better performance, all functions in this package are unsafe for concurrency unless otherwise specified.
Index ¶
- Variables
- func Checksum(filename string, upper bool, newHashes ...func() hash.Hash) (checksums []string, err error)
- func Read(name string, opts *filesys.ReadOptions) (r filesys.Reader, err error)
- func Tmp(dir, prefix, suffix string, perm fs.FileMode) (f *os.File, err error)
- func TmpDir(dir, prefix, suffix string, perm fs.FileMode) (name string, err error)
- func VerifyChecksum(filename string, hvs ...filesys.HashVerifier) bool
- func WriteAppend(name string, perm fs.FileMode, mkDirs bool, opts *filesys.WriteOptions) (w filesys.Writer, err error)
- func WriteExcl(name string, perm fs.FileMode, mkDirs bool, opts *filesys.WriteOptions) (w filesys.Writer, err error)
- func WriteTrunc(name string, perm fs.FileMode, mkDirs bool, opts *filesys.WriteOptions) (w filesys.Writer, err error)
Constants ¶
This section is empty.
Variables ¶
var ErrContainsPathSeparator = errors.AutoNewCustom( "prefix/suffix contains path separator", errors.PrependFullPkgName, 0, )
ErrContainsPathSeparator is an error indicating that the prefix or the suffix contains a path separator.
The client should use errors.Is to test whether an error is ErrContainsPathSeparator.
Functions ¶
func Checksum ¶ added in v0.6.0
func Checksum(filename string, upper bool, newHashes ...func() hash.Hash) ( checksums []string, err error)
Checksum calculates hash checksums of a local file, and returns the result in hexadecimal representation and any error encountered during opening and reading the file.
If the file is a directory, Checksum reports filesys.ErrIsDir and returns nil checksums. (To test whether err is filesys.ErrIsDir, use function errors.Is.)
upper indicates whether to use uppercase in hexadecimal representation.
newHashes are functions that create new hash functions (e.g., crypto/sha256.New, crypto.SHA256.New).
The length of the returned checksums is the same as that of newHashes. The hash result of newHashes[i] is checksums[i], encoded in hexadecimal. In particular, if newHashes[i] is nil or returns nil, checksums[i] will be an empty string. If len(newHashes) is 0, checksums will be nil.
func Read ¶
Read opens a file with specified name and options opts for reading.
If the file is a directory, Read reports filesys.ErrIsDir and returns a nil Reader. (To test whether err is filesys.ErrIsDir, use function errors.Is.)
If opts are nil, a zero-value filesys.ReadOptions will be used.
The file will be closed when the returned reader is closed.
If the file is a symlink, it will be evaluated by filepath.EvalSymlinks.
The file is opened by os.Open; the associated file descriptor has mode os.O_RDONLY.
func Tmp ¶
Tmp creates and opens a new temporary file in the directory dir, with specified permission perm (before umask), for reading and writing (the associated file descriptor has mode os.O_RDWR).
The filename is generated by concatenating prefix, a random string, and suffix. Both prefix and suffix must not contain a path separator. If prefix or suffix contains a path separator, it returns a nil f and an error ErrContainsPathSeparator. (To test whether err is ErrContainsPathSeparator, use function errors.Is.)
If dir is empty, it will use the default directory for temporary files (as returned by os.TempDir) instead.
Calling this function simultaneously will not choose the same file.
The client can use f.Name() to find the pathname of the file. The client is responsible for removing the file when no longer needed.
func TmpDir ¶
TmpDir creates a new temporary directory in the directory dir, with specified permission perm (before umask), and returns the pathname of the new directory.
The new directory's name is generated by concatenating prefix, a random string, and suffix. Both prefix and suffix must not contain a path separator. If prefix or suffix contains a path separator, it returns an empty name and an error ErrContainsPathSeparator. (To test whether err is ErrContainsPathSeparator, use function errors.Is.)
If dir is empty, it will use the default directory for temporary files (as returned by os.TempDir) instead.
Calling this function simultaneously will not choose the same directory.
The client is responsible for removing the directory when no longer needed.
func VerifyChecksum ¶
func VerifyChecksum(filename string, hvs ...filesys.HashVerifier) bool
VerifyChecksum verifies a local file by hash checksum.
It returns true if the file can be read and matches all filesys.HashVerifier in hvs (nil and duplicate filesys.HashVerifier will be ignored). In particular, it returns true if there is no non-nil filesys.HashVerifier in hvs and the file can be opened for reading. In this case, the file will not be read.
Note that VerifyChecksum will not reset the hash state of anyone in hvs. The client should use new filesys.HashVerifier returned by filesys.NewHashVerifier or call the Reset method of filesys.HashVerifier before calling this function if needed.
func WriteAppend ¶ added in v0.5.0
func WriteAppend( name string, perm fs.FileMode, mkDirs bool, opts *filesys.WriteOptions, ) (w filesys.Writer, err error)
WriteAppend creates (if necessary) and opens a file with specified name and options opts for writing.
If the file exists, new data will be appended to the file. If the file does not exist, it will be created with specified permission perm (before umask).
mkDirs indicates whether to make necessary directories before opening the file.
opts are handled the same as in function github.com/donyori/gogo/filesys.Write.
The file will be closed when the returned writer is closed.
func WriteExcl ¶ added in v0.5.0
func WriteExcl( name string, perm fs.FileMode, mkDirs bool, opts *filesys.WriteOptions, ) (w filesys.Writer, err error)
WriteExcl creates and opens a file with specified name and options opts for writing.
The file will be created with specified permission perm (before umask). If the file exists, it reports an error that satisfies errors.Is(err, fs.ErrExist) is true.
mkDirs indicates whether to make necessary directories before opening the file.
opts are handled the same as in function github.com/donyori/gogo/filesys.Write.
The file will be closed when the returned writer is closed.
func WriteTrunc ¶ added in v0.5.0
func WriteTrunc( name string, perm fs.FileMode, mkDirs bool, opts *filesys.WriteOptions, ) (w filesys.Writer, err error)
WriteTrunc creates (if necessary) and opens a file with specified name and options opts for writing.
If the file exists, it will be truncated. If the file does not exist, it will be created with specified permission perm (before umask).
mkDirs indicates whether to make necessary directories before opening the file.
opts are handled the same as in function github.com/donyori/gogo/filesys.Write.
The file will be closed when the returned writer is closed.
Types ¶
This section is empty.