summaryrefslogtreecommitdiff
path: root/Logs/FsckResults.hs
diff options
context:
space:
mode:
Diffstat (limited to 'Logs/FsckResults.hs')
-rw-r--r--Logs/FsckResults.hs43
1 files changed, 43 insertions, 0 deletions
diff --git a/Logs/FsckResults.hs b/Logs/FsckResults.hs
new file mode 100644
index 000000000..75ed7389c
--- /dev/null
+++ b/Logs/FsckResults.hs
@@ -0,0 +1,43 @@
+{- git-annex fsck results log files
+ -
+ - Copyright 2013 Joey Hess <joey@kitenet.net>
+ -
+ - Licensed under the GNU GPL version 3 or higher.
+ -}
+
+module Logs.FsckResults (
+ writeFsckResults,
+ readFsckResults
+) where
+
+import Common.Annex
+import Utility.Tmp
+import Git.Fsck
+import Git.Types
+
+import qualified Data.Set as S
+
+writeFsckResults :: UUID -> FsckResults -> Annex ()
+writeFsckResults u fsckresults = do
+ logfile <- fromRepo $ gitAnnexFsckResultsLog u
+ liftIO $
+ case fsckresults of
+ Nothing -> store S.empty logfile
+ Just s
+ | S.null s -> nukeFile logfile
+ | otherwise -> store s logfile
+ where
+ store s logfile = do
+ createDirectoryIfMissing True (parentDir logfile)
+ liftIO $ viaTmp writeFile logfile $ serialize s
+ serialize = unlines . map show . S.toList
+
+readFsckResults :: UUID -> Annex FsckResults
+readFsckResults u = do
+ logfile <- fromRepo $ gitAnnexFsckResultsLog u
+ liftIO $ catchDefaultIO (Just S.empty) $
+ deserialize <$> readFile logfile
+ where
+ deserialize l =
+ let s = S.fromList $ map Ref $ lines l
+ in if S.null s then Nothing else Just s