package robustio
import "cmd/internal/robustio"
Package robustio wraps I/O functions that are prone to failure on Windows, transparently retrying errors up to an arbitrary timeout.
Errors are classified heuristically and retries are bounded, so the functions in this package do not completely eliminate spurious errors. However, they do significantly reduce the rate of failure in practice.
If so, the error will likely wrap one of: The functions in this package do not completely eliminate spurious errors, but substantially reduce their rate of occurrence in practice.
Index ¶
- func IsEphemeralError(err error) bool
- func ReadFile(filename string) ([]byte, error)
- func RemoveAll(path string) error
- func Rename(oldpath, newpath string) error
Functions ¶
func IsEphemeralError ¶
IsEphemeralError reports whether err is one of the errors that the functions in this package attempt to mitigate.
Errors considered ephemeral include:
- syscall.ERROR_ACCESS_DENIED
- syscall.ERROR_FILE_NOT_FOUND
- internal/syscall/windows.ERROR_SHARING_VIOLATION
This set may be expanded in the future; programs must not rely on the non-ephemerality of any given error.
func ReadFile ¶
ReadFile is like os.ReadFile, but on Windows retries errors that may occur if the file is concurrently replaced.
(See golang.org/issue/31247 and golang.org/issue/32188.)
func RemoveAll ¶
RemoveAll is like os.RemoveAll, but on Windows retries errors that may occur if an executable file in the directory has recently been executed.
(See golang.org/issue/19491.)
func Rename ¶
Rename is like os.Rename, but on Windows retries errors that may occur if the file is concurrently read or overwritten.
(See golang.org/issue/31247 and golang.org/issue/32188.)
Source Files ¶
- Version
- v1.24.0 (latest)
- Published
- Feb 10, 2025
- Platform
- linux/amd64
- Imports
- 1 packages
- Last checked
- 1 minute ago –
Tools for package owners.