Go: cmd/go/internal/renameio Index | Files

package renameio

import "cmd/go/internal/renameio"

Package renameio writes files atomically by renaming temporary files.

Index

Package Files

renameio.go

func Pattern Uses

func Pattern(filename string) string

Pattern returns a glob pattern that matches the unrenamed temporary files created when writing to filename.

func ReadFile Uses

func ReadFile(filename string) ([]byte, error)

ReadFile is like ioutil.ReadFile, but on Windows retries spurious errors that may occur if the file is concurrently replaced.

Errors are classified heuristically and retries are bounded, so even this function may occasionally return a spurious error on Windows. If so, the error will likely wrap one of:

- syscall.ERROR_ACCESS_DENIED
- syscall.ERROR_FILE_NOT_FOUND
- internal/syscall/windows.ERROR_SHARING_VIOLATION

func WriteFile Uses

func WriteFile(filename string, data []byte, perm os.FileMode) (err error)

WriteFile is like ioutil.WriteFile, but first writes data to an arbitrary file in the same directory as filename, then renames it atomically to the final name.

That ensures that the final location, if it exists, is always a complete file.

func WriteToFile Uses

func WriteToFile(filename string, data io.Reader, perm os.FileMode) (err error)

WriteToFile is a variant of WriteFile that accepts the data as an io.Reader instead of a slice.

Package renameio imports 7 packages (graph) and is imported by 6 packages. Updated 2019-09-06. Refresh now. Tools for package owners.