From f74a674dd773be1fbcfdd5967a64df9641412a1b Mon Sep 17 00:00:00 2001 From: Joey Hess Date: Fri, 13 Nov 2015 14:49:30 -0400 Subject: use /tmp for sidelock file when no /dev/shm --- Utility/LockFile/PidLock.hs | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) (limited to 'Utility/LockFile') diff --git a/Utility/LockFile/PidLock.hs b/Utility/LockFile/PidLock.hs index fb6b0792b..090250f89 100644 --- a/Utility/LockFile/PidLock.hs +++ b/Utility/LockFile/PidLock.hs @@ -35,6 +35,7 @@ import Control.Applicative import Network.BSD import System.FilePath import Data.Hash.MD5 +import System.Directory type LockFile = FilePath @@ -68,10 +69,11 @@ trySideLock lockfile a = do Posix.tryLockExclusive (Just mode) sidelock a mlck where - -- Let all users write to the lock file in /dev/shm, + -- Let all users write to the lock file in /dev/shm or /tmp, -- so that other users can reuse it to take the lock. - -- Since /dev/shm is sticky, a user cannot delete another user's - -- lock file there, so could not delete a stale lock. + -- Since /dev/shm and /tmp are sticky dirs, a user cannot + -- delete another user's lock file there, so could not + -- delete a stale lock. mode = combineModes (readModes ++ writeModes) sideLockFile :: LockFile -> IO LockFile @@ -79,8 +81,12 @@ sideLockFile lockfile = do f <- absPath lockfile let base = intercalate "_" (splitDirectories (makeRelative "/" f)) let shortbase = reverse $ take 32 $ reverse base - let md5 = if base == shortbase then "" else md5s (Str base) - return $ "/dev/shm" md5 ++ shortbase ++ ".lck" + let md5sum = if base == shortbase then "" else md5s (Str base) + dir <- ifM (doesDirectoryExist "/dev/shm") + ( return "/dev/shm" + , return "/tmp" + ) + return $ dir md5sum ++ shortbase ++ ".lck" -- | Tries to take a lock; does not block when the lock is already held. -- -- cgit v1.2.3