{- Utilities for git remotes. - - Copyright 2011-2014 Joey Hess - - Licensed under the GNU AGPL version 3 or higher. -} module Remote.Helper.Git where import Annex.Common import qualified Git import Types.Availability import qualified Types.Remote as Remote import qualified Utility.RawFilePath as R import Data.Time.Clock.POSIX import System.PosixCompat.Files (modificationTime) repoCheap :: Git.Repo -> Bool repoCheap = not . Git.repoIsUrl localpathCalc :: Git.Repo -> Maybe FilePath localpathCalc r | availabilityCalc r == GloballyAvailable = Nothing | otherwise = Just $ fromRawFilePath $ Git.repoPath r availabilityCalc :: Git.Repo -> Availability availabilityCalc r | (Git.repoIsLocal r || Git.repoIsLocalUnknown r) = LocallyAvailable | otherwise = GloballyAvailable {- Avoids performing an action on a local repository that's not usable. - Does not check that the repository is still available on disk. -} guardUsable :: Git.Repo -> Annex a -> Annex a -> Annex a guardUsable r fallback a | Git.repoIsLocalUnknown r = fallback | otherwise = a gitRepoInfo :: Remote -> Annex [(String, String)] gitRepoInfo r = do d <- fromRawFilePath <$> fromRepo Git.localGitDir mtimes <- liftIO $ mapM (\p -> modificationTime <$> R.getFileStatus (toRawFilePath p)) =<< emptyWhenDoesNotExist (dirContentsRecursive (d "refs" "remotes" Remote.name r)) let lastsynctime = case mtimes of [] -> "never" _ -> show $ posixSecondsToUTCTime $ realToFrac $ maximum mtimes repo <- Remote.getRepo r return [ ("repository location", Git.repoLocation repo) , ("last synced", lastsynctime) ]