summaryrefslogtreecommitdiff
path: root/Utility/ThreadLock.hs
blob: 548d524e19c9f415c0fa2f676faa7b82f91ea799 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
{- locking between threads
 -
 - Copyright 2012 Joey Hess <joey@kitenet.net>
 -
 - License: BSD-2-clause
 -}

module Utility.ThreadLock where

import Control.Concurrent.MVar

type Lock = MVar ()

newLock :: IO Lock
newLock = newMVar ()

{- Runs an action with a lock held, so only one thread at a time can run it. -}
withLock :: Lock -> IO a -> IO a
withLock lock = withMVar lock . const