2024-10-15 15:56:42 +00:00
|
|
|
{- Opening files
|
|
|
|
-
|
|
|
|
- Copyright 2024 Joey Hess <id@joeyh.name>
|
|
|
|
-
|
|
|
|
- License: BSD-2-clause
|
|
|
|
-}
|
|
|
|
|
2024-10-18 14:17:07 +00:00
|
|
|
{-# LANGUAGE CPP #-}
|
|
|
|
|
2024-10-15 15:56:42 +00:00
|
|
|
module Utility.OpenFile where
|
|
|
|
|
2024-10-18 14:17:07 +00:00
|
|
|
#ifndef mingw32_HOST_OS
|
|
|
|
|
2024-10-15 15:56:42 +00:00
|
|
|
import System.IO
|
|
|
|
import System.Posix.IO
|
|
|
|
import GHC.IO.FD
|
|
|
|
import GHC.IO.Handle.FD
|
|
|
|
import GHC.IO.Device
|
|
|
|
|
|
|
|
import Utility.OpenFd
|
|
|
|
import Utility.RawFilePath
|
|
|
|
import Utility.FileSystemEncoding
|
|
|
|
|
|
|
|
{- Usually, opening a Handle to a file that another thread also has open
|
|
|
|
- for write is prevented, which avoids a lot of concurrency bugs especially
|
|
|
|
- with lazy IO.
|
|
|
|
-
|
|
|
|
- However, sometimes one thread is writing and another thread really wants
|
|
|
|
- to read from the same file. This bypasses the usual locking, by claiming
|
|
|
|
- that an opened FD is a Stream.
|
|
|
|
-}
|
|
|
|
openFileBeingWritten :: RawFilePath -> IO Handle
|
|
|
|
openFileBeingWritten f = do
|
|
|
|
fd <- openFdWithMode f ReadOnly Nothing defaultFileFlags
|
|
|
|
(fd', fdtype) <- mkFD (fromIntegral fd) ReadMode (Just (Stream, 0, 0)) False False
|
|
|
|
mkHandleFromFD fd' fdtype (fromRawFilePath f) ReadMode False Nothing
|
2024-10-18 14:17:07 +00:00
|
|
|
|
|
|
|
#endif
|