File: TestProcess.hs

package info (click to toggle)
haskell-lukko 0.1.2-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 200 kB
  • sloc: haskell: 262; ansic: 15; makefile: 6
file content (75 lines) | stat: -rw-r--r-- 2,051 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
{-# LANGUAGE CPP               #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RankNTypes        #-}
module Main (main) where

import Control.Concurrent (threadDelay)
import Control.Exception  (bracket)
import System.Environment (getArgs)
import System.IO          (Handle, IOMode (ReadWriteMode), hClose, openFile)

import qualified Data.ByteString as BS
import qualified Data.ByteString.Char8 as BS8

import Lukko

#ifdef HAS_OFD_LOCKING
import qualified Lukko.OFD as OFD
#endif

#ifdef HAS_FLOCK
import qualified Lukko.FLock as FLock
#endif

main :: IO ()
main = withArgs $ \withLock -> do
    putStrLn "starting..."
    withLock $ do
        contents <- BS.readFile "test-actual"
        threadDelay 10000 -- 10 ms
        BS.writeFile "test-actual" $ BS.append contents $ BS8.pack "another line\n"

withArgs
    :: ((forall r. IO r -> IO r) -> IO ())
    -> IO ()
withArgs k = do
    args <- getArgs
    case args of
        ["default"] -> k (genWithLock hLock hUnlock "test-lock")
#ifdef HAS_OFD_LOCKING
        ["ofd"]     -> k (genWithLock OFD.hLock OFD.hUnlock "test-lock")
#endif
#ifdef HAS_FLOCK
        ["flock"]   -> k (genWithLock FLock.hLock FLock.hUnlock "test-lock")
#endif
        ["noop"]    -> k (genWithLock noOpLock noOpUnlock "test-lock")
        _           -> putStrLn "Unknown paramters. Doing nothing."

-------------------------------------------------------------------------------
-- copy pasted
-------------------------------------------------------------------------------

noOpLock :: Handle -> LockMode -> IO ()
noOpLock _ _ = return ()

noOpUnlock :: Handle -> IO ()
noOpUnlock _ = return ()

genWithLock
    :: (Handle -> LockMode -> IO ())
    -> (Handle -> IO ())
    -> FilePath
    -> IO a
    -> IO a
genWithLock implLock implUnlock fp action =
    bracket takeLock releaseLock (const action)
  where
    takeLock = do
        h <- openFile fp ReadWriteMode
        implLock h ExclusiveLock
        return h

    releaseLock :: Handle -> IO ()
    releaseLock h = do
        implUnlock h
        hClose h