summaryrefslogtreecommitdiff
path: root/Command
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2011-09-28 16:43:10 -0400
committerGravatar Joey Hess <joey@kitenet.net>2011-09-28 16:43:10 -0400
commit297bc648b9a3c1b950e65f23a0e974b7934dc4dd (patch)
tree829ba7455be689c6e389d06420b24e0fe9c74bc6 /Command
parent5ae270001c978b306419e6799e67e5f14a1765a2 (diff)
make unused check branches and tags too
needs time and space optimisation
Diffstat (limited to 'Command')
-rw-r--r--Command/Unused.hs31
1 files changed, 30 insertions, 1 deletions
diff --git a/Command/Unused.hs b/Command/Unused.hs
index f62e68c30..e629f9fb9 100644
--- a/Command/Unused.hs
+++ b/Command/Unused.hs
@@ -15,6 +15,8 @@ import qualified Data.Set as S
import Data.Maybe
import System.FilePath
import System.Directory
+import Data.List
+import Control.Applicative
import Command
import Types
@@ -22,12 +24,17 @@ import Content
import Messages
import Locations
import Utility
+import Utility.FileMode
+import Utility.SafeCommand
import LocationLog
import qualified Annex
import qualified Git
import qualified Git.LsFiles as LsFiles
+import qualified Git.LsTree as LsTree
import qualified Backend
import qualified Remote
+import qualified Branch
+import CatFile
command :: [Command]
command = [repoCommand "unused" paramNothing seek
@@ -173,7 +180,29 @@ getKeysReferenced = do
g <- Annex.gitRepo
files <- liftIO $ LsFiles.inRepo g [Git.workTree g]
keypairs <- mapM Backend.lookupFile files
- return $ map fst $ catMaybes keypairs
+ ingit <- getKeysReferencedInGit
+ return $ concat [ingit, map fst $ catMaybes keypairs]
+
+{- List of keys referenced by symlinks in all git branches and tags. -}
+getKeysReferencedInGit :: Annex [Key]
+getKeysReferencedInGit = do
+ g <- Annex.gitRepo
+ c <- liftIO $ Git.pipeRead g [Param "show-ref"]
+ -- Skip the git-annex branches, and get all other unique refs.
+ let refs = nub $ map head $ filter ourbranches $ map words $ lines c
+ concat <$> mapM (\r -> findkeys r [] =<< liftIO (LsTree.lsTree g r)) refs
+ where
+ ourbranchend = "/" ++ Branch.name
+ ourbranches ws = not $ ourbranchend `isSuffixOf` last ws
+ findkeys _ c [] = return c
+ findkeys ref c (l:ls) = do
+ if isSymLink (LsTree.mode l)
+ then do
+ content <- catFile ref $ LsTree.file l
+ case fileKey (takeFileName content) of
+ Nothing -> findkeys ref c ls
+ Just k -> findkeys ref (k:c) ls
+ else findkeys ref c ls
{- Looks in the specified directory for bad/tmp keys, and returns a list
- of those that might still have value, or might be stale and removable.