write to tmp file
Writing to a tmp file means no locking is needed, and it fixes a bug introduced by the last commit, which made log files be read lazily, so they could still be open when written, which breaks due to haskell's internal locking.
This commit is contained in:
parent
d5a0c16298
commit
59672d32ed
1 changed files with 5 additions and 9 deletions
|
@ -35,6 +35,7 @@ import qualified Data.Map as Map
|
||||||
import System.IO
|
import System.IO
|
||||||
import System.Directory
|
import System.Directory
|
||||||
import Data.Char
|
import Data.Char
|
||||||
|
import System.Posix.Process
|
||||||
|
|
||||||
import qualified GitRepo as Git
|
import qualified GitRepo as Git
|
||||||
import Utility
|
import Utility
|
||||||
|
@ -111,19 +112,14 @@ readLog file = do
|
||||||
else do
|
else do
|
||||||
return []
|
return []
|
||||||
|
|
||||||
{- Adds a LogLine to a log file -}
|
|
||||||
appendLog :: FilePath -> LogLine -> IO ()
|
|
||||||
appendLog file line = do
|
|
||||||
createDirectoryIfMissing True (parentDir file)
|
|
||||||
withFileLocked file AppendMode $ \h ->
|
|
||||||
hPutStrLn h $ show line
|
|
||||||
|
|
||||||
{- Writes a set of lines to a log file -}
|
{- Writes a set of lines to a log file -}
|
||||||
writeLog :: FilePath -> [LogLine] -> IO ()
|
writeLog :: FilePath -> [LogLine] -> IO ()
|
||||||
writeLog file lines = do
|
writeLog file lines = do
|
||||||
|
pid <- getProcessID
|
||||||
|
let tmpfile = file ++ ".tmp" ++ show pid
|
||||||
createDirectoryIfMissing True (parentDir file)
|
createDirectoryIfMissing True (parentDir file)
|
||||||
withFileLocked file WriteMode $ \h ->
|
writeFile tmpfile $ unlines $ map show lines
|
||||||
hPutStr h $ unlines $ map show lines
|
renameFile tmpfile file
|
||||||
|
|
||||||
{- Generates a new LogLine with the current date. -}
|
{- Generates a new LogLine with the current date. -}
|
||||||
logNow :: LogStatus -> UUID -> IO LogLine
|
logNow :: LogStatus -> UUID -> IO LogLine
|
||||||
|
|
Loading…
Reference in a new issue