git-annex/Annex/Wanted.hs
Joey Hess fee40dd374 generalized Annex.Wanted
this should make it easy to use from inside the assistant, where
everything is an AssociatedFile.
2012-10-08 17:14:01 -04:00

40 lines
1.2 KiB
Haskell

{- git-annex control over whether content is wanted
-
- Copyright 2012 Joey Hess <joey@kitenet.net>
-
- Licensed under the GNU GPL version 3 or higher.
-}
module Annex.Wanted where
import Common.Annex
import Logs.PreferredContent
import Git.FilePath
import qualified Annex
import Annex.UUID
import Types.Remote
import qualified Data.Set as S
{- Check if a file is preferred content for the local repository. -}
wantGet :: AssociatedFile -> Annex Bool
wantGet Nothing = return True
wantGet (Just file) = do
fp <- inRepo $ toTopFilePath file
isPreferredContent Nothing S.empty fp
{- Check if a file is preferred content for a remote. -}
wantSend :: UUID -> AssociatedFile -> Annex Bool
wantSend _ Nothing = return True
wantSend to (Just file) = do
fp <- inRepo $ toTopFilePath file
isPreferredContent (Just to) S.empty fp
{- Check if a file can be dropped, maybe from a remote.
- Don't drop files that are preferred content. -}
wantDrop :: Maybe UUID -> AssociatedFile -> Annex Bool
wantDrop _ Nothing = return True
wantDrop from (Just file) = do
fp <- inRepo $ toTopFilePath file
u <- maybe getUUID (return . id) from
not <$> isPreferredContent (Just u) (S.singleton u) fp