dev-haskell/atomic-write (haskell)

Search

Package Information

Description:
Atomically write to a file on POSIX-compliant systems while preserving permissions. On most Unix systems, `mv` is an atomic operation. This makes it simple to write to a file atomically just by using the mv operation. However, this will destroy the permissions on the original file. This library does the following to preserve permissions while atomically writing to a file: * If an original file exists, take those permissions and apply them to the temp file before `mv`ing the file into place. * If the original file does not exist, create a following with default permissions (based on the currently-active umask). This way, when the file is `mv`'ed into place, the permissions will be the ones held by the original file. This library is based on similar implementations found in common libraries in Ruby and Python: * <http://apidock.com/rails/File/atomic_write/class Ruby on Rails includes a similar method called atomic_write> * <https://github.com/chef/chef/blob/c4631816132fcfefaba3d123a1d0dfe8bc2866bb/lib/chef/file_content_management/deploy/mv_unix.rb#L23:L71 Chef includes atomic update functionality> * <https://github.com/sashka/atomicfile There is a python library for atomically updating a file> To use `atomic-write`, import the module corresponding to the type you wish to write atomically, e.g., to write a (strict) ByteString atomically: > import System.AtomicWrite.Writer.ByteString Then you can use the atomicWriteFile function that accepts a `FilePath` and a `ByteString`, e.g.: > atomicWriteFile myFilePath myByteString
Homepage:
https://github.com/stackbuilders/atomic-write
License:
MIT

Versions

Version EAPI Keywords Slot
0.2.0.7 8 ~amd64 0/0.2.0.7

Metadata

Description

Maintainers

Raw Metadata XML
<pkgmetadata>
	<maintainer type="project">
		<email>haskell@gentoo.org</email>
		<name>Gentoo Haskell</name>
	</maintainer>
	<longdescription>
		
		Atomically write to a file on POSIX-compliant systems while preserving
		permissions.
		
		On most Unix systems, `mv` is an atomic operation. This makes it simple to write
		to a file atomically just by using the mv operation. However, this will
		destroy the permissions on the original file. This library does the following
		to preserve permissions while atomically writing to a file:
		
		* If an original file exists, take those permissions and apply them to the
		temp file before `mv`ing the file into place.
		
		* If the original file does not exist, create a following with default
		permissions (based on the currently-active umask).
		
		This way, when the file is `mv`&#39;ed into place, the permissions will be the ones
		held by the original file.
		
		This library is based on similar implementations found in common libraries in
		Ruby and Python:
		
		* &lt;http://apidock.com/rails/File/atomic_write/class Ruby on Rails includes a similar method called atomic_write&gt;
		
		* &lt;https://github.com/chef/chef/blob/c4631816132fcfefaba3d123a1d0dfe8bc2866bb/lib/chef/file_content_management/deploy/mv_unix.rb#L23:L71 Chef includes atomic update functionality&gt;
		
		* &lt;https://github.com/sashka/atomicfile There is a python library for atomically updating a file&gt;
		
		To use `atomic-write`, import the module corresponding to the type you wish to
		write atomically, e.g., to write a (strict) ByteString atomically:
		
		&gt; import System.AtomicWrite.Writer.ByteString
		
		Then you can use the atomicWriteFile function that accepts a `FilePath` and a
		`ByteString`, e.g.:
		
		&gt; atomicWriteFile myFilePath myByteString
	</longdescription>
</pkgmetadata>

Lint Warnings

Manifest

Type File Size Versions
DIST atomic-write-0.2.0.7.tar.gz 7199 bytes 0.2.0.7
Unmatched Entries
Type File Size