| Safe Haskell | Trustworthy | 
|---|---|
| Language | Haskell2010 | 
Lukko
Contents
Description
Open Handle based locking
Synopsis
- data FileLockingNotSupported = FileLockingNotSupported
- fileLockingSupported :: Bool
- type FileLockingSupported = True
- data FileLockingMethod
- fileLockingMethod :: FileLockingMethod
- data LockMode
- type FD = FD
- fdOpen :: FilePath -> IO FD
- fdClose :: FD -> IO ()
- fdLock :: FD -> LockMode -> IO ()
- fdTryLock :: FD -> LockMode -> IO Bool
- fdUnlock :: FD -> IO ()
- handleToFd :: Handle -> IO FD
- hLock :: Handle -> LockMode -> IO ()
- hTryLock :: Handle -> LockMode -> IO Bool
- hUnlock :: Handle -> IO ()
Documentation
data FileLockingNotSupported Source #
Exception thrown by hLock on non-Windows platforms that don't support
 flock.
Constructors
| FileLockingNotSupported | 
Instances
| Show FileLockingNotSupported Source # | |
| Defined in Lukko.Internal.Types Methods showsPrec :: Int -> FileLockingNotSupported -> ShowS # show :: FileLockingNotSupported -> String # showList :: [FileLockingNotSupported] -> ShowS # | |
| Exception FileLockingNotSupported Source # | |
| Defined in Lukko.Internal.Types | |
fileLockingSupported :: Bool Source #
A constants specifying whether file locking is supported.
type FileLockingSupported = True Source #
A type level fileLockingSupported.
data FileLockingMethod Source #
Potentially availble lock methods.
Constructors
| MethodOFD | open file descriptor locking | 
| MethodFLock | BSD  | 
| MethodWindows | Windows locking | 
| MethodNoOp | No-Op (throws  | 
Instances
fileLockingMethod :: FileLockingMethod Source #
A constant specifying this method
Indicates a mode in which a file should be locked.
Constructors
| SharedLock | |
| ExclusiveLock | 
File descriptors
Handles
hLock :: Handle -> LockMode -> IO () Source #
If a Handle references a file descriptor, attempt to lock contents of the
 underlying file in appropriate mode. If the file is already locked in
 incompatible mode, this function blocks until the lock is established. The
 lock is automatically released upon closing a Handle.
Things to be aware of:
1) This function may block inside a C call. If it does, in order to be able to interrupt it with asynchronous exceptions and/or for other threads to continue working, you MUST use threaded version of the runtime system.
2) The implementation uses LockFileEx on Windows,
 open file descriptor locks on Linux, and flock otherwise,
 hence all of their caveats also apply here.
3) On non-Windows plaftorms that don't support flock (e.g. Solaris) this
 function throws FileLockingNotImplemented. We deliberately choose to not
 provide fcntl based locking instead because of its broken semantics.