30 lines
1.6 KiB
Markdown
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
|