{-# LINE 1 "System/Posix/Fcntl.hsc" #-}
{-# LANGUAGE CApiFFI #-}
{-# LANGUAGE Safe #-}
module System.Posix.Fcntl (
Advice(..), fileAdvise,
fileAllocate,
fileGetCaching,
fileSetCaching,
) where
import Foreign.C
import System.Posix.Types
{-# LINE 37 "System/Posix/Fcntl.hsc" #-}
{-# LINE 39 "System/Posix/Fcntl.hsc" #-}
import Data.Bits (complement, (.&.), (.|.))
import System.Posix.Internals (c_fcntl_read)
{-# LINE 42 "System/Posix/Fcntl.hsc" #-}
{-# LINE 44 "System/Posix/Fcntl.hsc" #-}
import System.Posix.Internals (c_fcntl_write)
{-# LINE 46 "System/Posix/Fcntl.hsc" #-}
data Advice
= AdviceNormal
| AdviceRandom
| AdviceSequential
| AdviceWillNeed
| AdviceDontNeed
| AdviceNoReuse
deriving Advice -> Advice -> Bool
(Advice -> Advice -> Bool)
-> (Advice -> Advice -> Bool) -> Eq Advice
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: Advice -> Advice -> Bool
== :: Advice -> Advice -> Bool
$c/= :: Advice -> Advice -> Bool
/= :: Advice -> Advice -> Bool
Eq
fileAdvise :: Fd -> FileOffset -> FileOffset -> Advice -> IO ()
{-# LINE 74 "System/Posix/Fcntl.hsc" #-}
fileAdvise fd off len adv = do
throwErrnoIfMinus1_ "fileAdvise" (c_posix_fadvise (fromIntegral fd) (fromIntegral off) (fromIntegral len) (packAdvice adv))
foreign import capi safe "fcntl.h posix_fadvise"
c_posix_fadvise :: CInt -> COff -> COff -> CInt -> IO CInt
packAdvice :: Advice -> CInt
packAdvice :: Advice -> CInt
packAdvice Advice
AdviceNormal = (CInt
0)
{-# LINE 82 "System/Posix/Fcntl.hsc" #-}
packAdvice AdviceRandom = (1)
{-# LINE 83 "System/Posix/Fcntl.hsc" #-}
packAdvice AdviceSequential = (2)
{-# LINE 84 "System/Posix/Fcntl.hsc" #-}
packAdvice AdviceWillNeed = (3)
{-# LINE 85 "System/Posix/Fcntl.hsc" #-}
packAdvice AdviceDontNeed = (4)
{-# LINE 86 "System/Posix/Fcntl.hsc" #-}
packAdvice AdviceNoReuse = (5)
{-# LINE 87 "System/Posix/Fcntl.hsc" #-}
{-# LINE 90 "System/Posix/Fcntl.hsc" #-}
fileAllocate :: Fd -> FileOffset -> FileOffset -> IO ()
{-# LINE 101 "System/Posix/Fcntl.hsc" #-}
fileAllocate fd off len = do
ret <- c_posix_fallocate (fromIntegral fd) (fromIntegral off) (fromIntegral len)
if ret == 0
then pure ()
else ioError (errnoToIOError "fileAllocate" (Errno ret) Nothing Nothing)
foreign import capi safe "fcntl.h posix_fallocate"
c_posix_fallocate :: CInt -> COff -> COff -> IO CInt
{-# LINE 115 "System/Posix/Fcntl.hsc" #-}
fileGetCaching :: Fd -> IO Bool
{-# LINE 137 "System/Posix/Fcntl.hsc" #-}
fileGetCaching (Fd fd) = do
r <- throwErrnoIfMinus1 "fileGetCaching" (c_fcntl_read fd 3)
{-# LINE 139 "System/Posix/Fcntl.hsc" #-}
return ((r .&. opt_val) == 0)
where
opt_val = 16384
{-# LINE 142 "System/Posix/Fcntl.hsc" #-}
{-# LINE 147 "System/Posix/Fcntl.hsc" #-}
fileSetCaching :: Fd -> Bool -> IO ()
{-# LINE 168 "System/Posix/Fcntl.hsc" #-}
fileSetCaching (Fd fd) val = do
r <- throwErrnoIfMinus1 "fileSetCaching" (c_fcntl_read fd 3)
{-# LINE 170 "System/Posix/Fcntl.hsc" #-}
let r' | val = fromIntegral r .&. complement opt_val
| otherwise = fromIntegral r .|. opt_val
throwErrnoIfMinus1_ "fileSetCaching" (c_fcntl_write fd 4 r')
{-# LINE 173 "System/Posix/Fcntl.hsc" #-}
where
opt_val = 16384
{-# LINE 175 "System/Posix/Fcntl.hsc" #-}
{-# LINE 183 "System/Posix/Fcntl.hsc" #-}