2010-10-12 17:10:07 +00:00
|
|
|
{- git-annex uuids
|
|
|
|
-
|
|
|
|
- Each git repository used by git-annex has an annex.uuid setting that
|
|
|
|
- uniquely identifies that repository.
|
|
|
|
-
|
2011-03-27 20:55:43 +00:00
|
|
|
- UUIDs of remotes are cached in git config, using keys named
|
|
|
|
- remote.<name>.annex-uuid
|
|
|
|
-
|
2011-10-06 19:31:25 +00:00
|
|
|
- uuid.log stores a list of known uuids, and their descriptions.
|
|
|
|
-
|
|
|
|
- Copyright 2010-2011 Joey Hess <joey@kitenet.net>
|
2010-10-27 20:53:54 +00:00
|
|
|
-
|
|
|
|
- Licensed under the GNU GPL version 3 or higher.
|
2010-10-12 17:10:07 +00:00
|
|
|
-}
|
|
|
|
|
2011-10-15 20:21:08 +00:00
|
|
|
module Logs.UUID (
|
2010-10-16 20:15:31 +00:00
|
|
|
describeUUID,
|
2011-11-02 18:18:21 +00:00
|
|
|
recordUUID,
|
2011-10-06 19:31:25 +00:00
|
|
|
uuidMap
|
2010-10-12 17:10:07 +00:00
|
|
|
) where
|
|
|
|
|
2010-10-16 00:20:16 +00:00
|
|
|
import qualified Data.Map as M
|
2011-10-06 19:31:25 +00:00
|
|
|
import Data.Time.Clock.POSIX
|
2010-10-16 20:20:49 +00:00
|
|
|
|
2011-10-05 20:02:51 +00:00
|
|
|
import Common.Annex
|
2011-10-04 04:40:47 +00:00
|
|
|
import qualified Annex.Branch
|
2011-10-15 20:21:08 +00:00
|
|
|
import Logs.UUIDBased
|
2011-10-28 23:49:01 +00:00
|
|
|
import qualified Annex.UUID
|
2010-10-12 19:48:00 +00:00
|
|
|
|
2011-06-22 21:08:51 +00:00
|
|
|
{- Filename of uuid.log. -}
|
2011-10-06 19:31:25 +00:00
|
|
|
logfile :: FilePath
|
|
|
|
logfile = "uuid.log"
|
2011-06-22 21:08:51 +00:00
|
|
|
|
2011-10-06 19:31:25 +00:00
|
|
|
{- Records a description for a uuid in the log. -}
|
2010-10-16 00:20:16 +00:00
|
|
|
describeUUID :: UUID -> String -> Annex ()
|
2011-10-06 19:31:25 +00:00
|
|
|
describeUUID uuid desc = do
|
|
|
|
ts <- liftIO $ getPOSIXTime
|
|
|
|
Annex.Branch.change logfile $
|
|
|
|
showLog id . changeLog ts uuid desc . parseLog Just
|
2010-10-14 03:18:58 +00:00
|
|
|
|
2011-11-02 18:18:21 +00:00
|
|
|
{- Records the uuid in the log, if it's not already there. -}
|
|
|
|
recordUUID :: UUID -> Annex ()
|
|
|
|
recordUUID u = go . M.lookup u =<< uuidMap
|
|
|
|
where
|
|
|
|
go (Just "") = set
|
|
|
|
go Nothing = set
|
|
|
|
go _ = return ()
|
|
|
|
set = describeUUID u ""
|
|
|
|
|
2011-10-28 23:49:01 +00:00
|
|
|
{- Read the uuidLog into a simple Map.
|
|
|
|
-
|
|
|
|
- The UUID of the current repository is included explicitly, since
|
|
|
|
- it may not have been described and so otherwise would not appear. -}
|
2010-10-16 00:20:16 +00:00
|
|
|
uuidMap :: Annex (M.Map UUID String)
|
2011-10-28 23:49:01 +00:00
|
|
|
uuidMap = do
|
|
|
|
m <- (simpleMap . parseLog Just) <$> Annex.Branch.get logfile
|
|
|
|
u <- Annex.UUID.getUUID
|
|
|
|
return $ M.insertWith' preferold u "" m
|
|
|
|
where
|
|
|
|
preferold = flip const
|