rclone/vendor/github.com/calebcase/tmpfile/README.md
2020-05-12 15:56:50 +00:00

30 lines
1.6 KiB
Markdown

[![Documentation][godoc.badge]][godoc]
[![Test Status][workflow.tests.badge]][workflow.tests]
# Cross Platform Temporary Files
This library attempts to bridge the gap between the what is provided in
[ioutil.TempFile][ioutil.tempfile] and the best practice of ensuring temporary
files are ***always*** deleted when the application exits.
The normal way to do this on a POSIX system is to use the behavior of
[unlink][posix.unlink] to immediately remove the directory entry for the
temporary file. The OS then ensures that when all open file handles on the file
are close that the file resources are removed. Unfortunately, despite Go having
[os.Remove][os.remove] this does not work on Windows because on Windows it is
necessary to open the files with special flags
([FILE_SHARE_DELETE][windows.flags.share],
[FILE_FLAG_DELETE_ON_CLOSE][windows.flags.on_close]) to enable removing a file
that is open (and ioutil does not do this).
---
[godoc.badge]: https://godoc.org/github.com/calebcase/tmpfile?status.svg
[godoc]: https://godoc.org/github.com/calebcase/tmpfile
[ioutil.tempfile]: https://golang.org/pkg/io/ioutil/#TempFile
[os.remove]: https://golang.org/pkg/os/#Remove
[posix.unlink]: https://pubs.opengroup.org/onlinepubs/9699919799/functions/unlink.html
[windows.flags.on_close]: https://github.com/golang/sys/blob/master/windows/types_windows.go#L108
[windows.flags.share]: https://github.com/golang/sys/blob/master/windows/types_windows.go#L71
[workflow.tests.badge]: https://github.com/calebcase/tmpfile/workflows/tests/badge.svg
[workflow.tests]: https://github.com/calebcase/tmpfile/actions?query=workflow%3Atests