GPL-2.0-or-later AND BSD-3-Clause licensed
Maintained by
Oleg Grenrus This version can be pinned in stack with:lukko-0.1.2@sha256:8334a8d810e385e1dc1423dc02945daaa1f1a9ba058e5227f1a3211e4882ca28,4473
Module documentation for 0.1.2
This package provides access to platform dependent file locking APIs:
Open file descriptor locking on Linux (Lukko.OFD
)
BSD-style flock(2)
locks on UNIX platforms (Lukko.FLock
)
Windows locking via LockFileEx (Lukko.Windows
)
No-op locking, which throws exceptions (Lukko.NoOp
)
Lukko
module exports the best option for the target platform with uniform API.
There are alternative file locking packages:
GHC.IO.Handle.Lock
in base >= 4.10
is good enough for most use cases.
However, uses only Handle
s so these locks cannot be used for intra-process locking.
(You should use e.g. MVar
in addition).
filelock doesn't support OFD locking.
Lukko means lock in Finnish.
Submodules Lukko.OFD
, Lukko.Windows
etc are available based on following conditions.
if os(windows)
cpp-options: -DHAS_WINDOWS_LOCK
elif (os(linux) && flag(ofd-locking))
cpp-options: -DHAS_OFD_LOCKING
cpp-options: -DHAS_FLOCK
elif !(os(solaris) || os(aix))
cpp-options: -DHAS_FLOCK
Lukko.FLock
is available on not (Windows or Solaris or AIX).
Lukko.NoOp
is always available.
0.1.2
0.1.1.3
Use CApiFFI
to call varargs C functions.
Define let alignment
only when needed.
0.1.1.2
Make Win32 code more idiomatic
0.1.1.1
0.1.1
Add Setup.hs
to sdist
Add type-level FileLockingSupported
Stackage is a service provided by the
Haskell Foundation
│ Originally developed by
FP Complete