{-# LINE 1 "System/Posix/Fcntl.hsc" #-}
{-# LANGUAGE CApiFFI #-}
{-# LINE 3 "System/Posix/Fcntl.hsc" #-}
{-# LANGUAGE Safe #-}
{-# LINE 7 "System/Posix/Fcntl.hsc" #-}
module System.Posix.Fcntl (
Advice(..), fileAdvise,
fileAllocate,
) where
{-# LINE 31 "System/Posix/Fcntl.hsc" #-}
import Foreign.C
{-# LINE 33 "System/Posix/Fcntl.hsc" #-}
import System.Posix.Types
{-# LINE 39 "System/Posix/Fcntl.hsc" #-}
data Advice
= AdviceNormal
| AdviceRandom
| AdviceSequential
| AdviceWillNeed
| AdviceDontNeed
| AdviceNoReuse
deriving Eq
fileAdvise :: Fd -> FileOffset -> FileOffset -> Advice -> IO ()
{-# LINE 67 "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 AdviceNormal = (0)
{-# LINE 75 "System/Posix/Fcntl.hsc" #-}
packAdvice AdviceRandom = (1)
{-# LINE 76 "System/Posix/Fcntl.hsc" #-}
packAdvice AdviceSequential = (2)
{-# LINE 77 "System/Posix/Fcntl.hsc" #-}
packAdvice AdviceWillNeed = (3)
{-# LINE 78 "System/Posix/Fcntl.hsc" #-}
packAdvice AdviceDontNeed = (4)
{-# LINE 79 "System/Posix/Fcntl.hsc" #-}
packAdvice AdviceNoReuse = (5)
{-# LINE 80 "System/Posix/Fcntl.hsc" #-}
{-# LINE 83 "System/Posix/Fcntl.hsc" #-}
fileAllocate :: Fd -> FileOffset -> FileOffset -> IO ()
{-# LINE 94 "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 108 "System/Posix/Fcntl.hsc" #-}