lukko: File locking

[ concurrency, library, system ] [ Propose Tags ]

This package provides access to platform dependent file locking APIs:

There are alternative file locking packages:

  • GHC.IO.Handle.Lock in base >= 4.10 is good enough for most use cases. However, uses only Handles 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.


Manual Flags


Enable open file descriptor locking. Available on Linux (kernel 3.15, released Jun 8, 2014).


Use -f <flag> to enable a flag, or -f -<flag> to disable that flag. More info


Maintainer's Corner

Package maintainers

For package maintainers and hackage trustees


Versions [RSS] 0.1, 0.1.1,,,, 0.1.2
Change log
Dependencies base (>= && <4.21) [details]
License GPL-2.0-or-later AND BSD-3-Clause[multiple license files]
Maintainer Oleg Grenrus <>
Category System, Concurrency
Source repo head: git clone
Uploaded by phadej at 2024-06-05T12:42:08Z
Distributions Arch:, Fedora:, LTSHaskell:, NixOS:, Stackage:0.1.2, openSUSE:
Reverse Dependencies 5 direct, 13 indirect [details]
Downloads 21416 total (202 in the last 30 days)
Rating (no votes yet) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Docs uploaded by user
Build status unknown [no reports yet]