summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Command/Unused.hs58
1 files changed, 29 insertions, 29 deletions
diff --git a/Command/Unused.hs b/Command/Unused.hs
index 1d14b837c..71cbfd470 100644
--- a/Command/Unused.hs
+++ b/Command/Unused.hs
@@ -54,14 +54,11 @@ start = do
next action
checkUnused :: CommandPerform
-checkUnused = do
- unused <- findunused =<< Annex.getState Annex.fast
- stalebad <- staleKeysPrune gitAnnexBadDir
- staletmp <- staleKeysPrune gitAnnexTmpDir
- _ <- list "" unusedMsg unused 0 >>=
- list "bad" staleBadMsg stalebad >>=
- list "tmp" staleTmpMsg staletmp
- next $ return True
+checkUnused = chain 0
+ [ check "" unusedMsg $ findunused =<< Annex.getState Annex.fast
+ , check "bad" staleBadMsg $ staleKeysPrune gitAnnexBadDir
+ , check "tmp" staleTmpMsg $ staleKeysPrune gitAnnexTmpDir
+ ]
where
findunused True = do
showNote "fast mode enabled; only finding stale files"
@@ -69,25 +66,32 @@ checkUnused = do
findunused False = do
showAction "checking for unused data"
excludeReferenced =<< getKeysPresent
- list file msg l c = do
- let unusedlist = number c l
- unless (null l) $ showLongNote $ msg unusedlist
- writeUnusedFile file unusedlist
- return $ c + length l
+ chain _ [] = next $ return True
+ chain v (a:as) = do
+ v' <- a v
+ chain v' as
checkRemoteUnused :: String -> CommandPerform
-checkRemoteUnused name = do
- checkRemoteUnused' =<< fromJust <$> Remote.byName (Just name)
- next $ return True
-
-checkRemoteUnused' :: Remote -> Annex ()
-checkRemoteUnused' r = do
- showAction "checking for unused data"
- remotehas <- loggedKeysFor (Remote.uuid r)
- remoteunused <- excludeReferenced remotehas
- let list = number 0 remoteunused
- writeUnusedFile "" list
- unless (null remoteunused) $ showLongNote $ remoteUnusedMsg r list
+checkRemoteUnused name = go =<< fromJust <$> Remote.byName (Just name)
+ where
+ go r = do
+ showAction "checking for unused data"
+ _ <- check "" (remoteUnusedMsg r) (remoteunused r) 0
+ next $ return True
+ remoteunused r =
+ excludeReferenced =<< loggedKeysFor (Remote.uuid r)
+
+check :: FilePath -> ([(Int, Key)] -> String) -> Annex [Key] -> Int -> Annex Int
+check file msg a c = do
+ l <- a
+ let unusedlist = number c l
+ unless (null l) $ showLongNote $ msg unusedlist
+ writeUnusedFile file unusedlist
+ return $ c + length l
+
+number :: Int -> [a] -> [(Int, a)]
+number _ [] = []
+number n (x:xs) = (n+1, x) : number (n+1) xs
writeUnusedFile :: FilePath -> [(Int, Key)] -> Annex ()
writeUnusedFile prefix l = do
@@ -101,10 +105,6 @@ table l = " NUMBER KEY" : map cols l
cols (n,k) = " " ++ pad 6 (show n) ++ " " ++ show k
pad n s = s ++ replicate (n - length s) ' '
-number :: Int -> [a] -> [(Int, a)]
-number _ [] = []
-number n (x:xs) = (n+1, x) : number (n+1) xs
-
staleTmpMsg :: [(Int, Key)] -> String
staleTmpMsg t = unlines $
["Some partially transferred data exists in temporary files:"]