summaryrefslogtreecommitdiff
path: root/Utility
diff options
context:
space:
mode:
authorGravatar Joey Hess <joeyh@joeyh.name>2015-10-08 13:31:55 -0400
committerGravatar Joey Hess <joeyh@joeyh.name>2015-10-08 13:34:49 -0400
commite2693da16db892d002b2993443bcbe38b6c6efa0 (patch)
treea0167a759640569568edd9c0e4fa876b46ac7fcb /Utility
parent7433e26d25a2b8b2e0eef9692d1f9ba741bd370c (diff)
open lock file ReadOnly when taking shared lock
It's only necessary to open a file for write when taking an exclusive lock.
Diffstat (limited to 'Utility')
-rw-r--r--Utility/LockFile/Posix.hs16
1 files changed, 10 insertions, 6 deletions
diff --git a/Utility/LockFile/Posix.hs b/Utility/LockFile/Posix.hs
index 18d9e4fc1..8f06ae69e 100644
--- a/Utility/LockFile/Posix.hs
+++ b/Utility/LockFile/Posix.hs
@@ -39,7 +39,7 @@ lockExclusive = lock WriteLock
-- Tries to take an exclusive lock, but does not block.
tryLockExclusive :: Maybe FileMode -> LockFile -> IO (Maybe LockHandle)
tryLockExclusive mode lockfile = do
- l <- openLockFile mode lockfile
+ l <- openLockFile WriteLock mode lockfile
v <- tryIO $ setLock l (WriteLock, AbsoluteSeek, 0, 0)
case v of
Left _ -> do
@@ -51,16 +51,20 @@ tryLockExclusive mode lockfile = do
-- If it's Nothing then this only succeeds when the lock file already exists.
lock :: LockRequest -> Maybe FileMode -> LockFile -> IO LockHandle
lock lockreq mode lockfile = do
- l <- openLockFile mode lockfile
+ l <- openLockFile lockreq mode lockfile
waitToSetLock l (lockreq, AbsoluteSeek, 0, 0)
return (LockHandle l)
-- Close on exec flag is set so child processes do not inherit the lock.
-openLockFile :: Maybe FileMode -> LockFile -> IO Fd
-openLockFile filemode lockfile = do
- l <- openFd lockfile ReadWrite filemode defaultFileFlags
+openLockFile :: LockRequest -> Maybe FileMode -> LockFile -> IO Fd
+openLockFile lockreq filemode lockfile = do
+ l <- openFd lockfile openfor filemode defaultFileFlags
setFdOption l CloseOnExec True
return l
+ where
+ openfor = case lockreq of
+ ReadLock -> ReadOnly
+ _ -> ReadWrite
-- Returns Nothing when the file doesn't exist, for cases where
-- that is different from it not being locked.
@@ -81,7 +85,7 @@ getLockStatus lockfile = do
getLockStatus' :: LockFile -> IO (Maybe (Maybe ProcessID))
getLockStatus' lockfile = go =<< catchMaybeIO open
where
- open = openFd lockfile ReadOnly Nothing defaultFileFlags
+ open = openLockFile ReadLock Nothing lockfile
go Nothing = return Nothing
go (Just h) = do
v <- getLock h (ReadLock, AbsoluteSeek, 0, 0)