{-# LANGUAGE PackageImports #-}
module Debian.Extra.Files
( withTemporaryFile
) where
import "mtl" Control.Monad.Trans (MonadIO, liftIO)
import System.Directory (getTemporaryDirectory, removeFile)
import System.IO (hPutStr, hClose, openBinaryTempFile)
withTemporaryFile :: MonadIO m
=> (FilePath -> m a)
-> String
-> m a
withTemporaryFile :: forall (m :: * -> *) a.
MonadIO m =>
(FilePath -> m a) -> FilePath -> m a
withTemporaryFile FilePath -> m a
f FilePath
text =
do path <- IO FilePath -> m FilePath
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO IO FilePath
writeTemporaryFile
result <- f path
liftIO $ removeFile path
return result
where
writeTemporaryFile :: IO FilePath
writeTemporaryFile =
do dir <- IO FilePath
getTemporaryDirectory
(path, h) <- openBinaryTempFile dir "wtf.tmp"
hPutStr h text
hClose h
return path