summaryrefslogtreecommitdiff
path: root/Remote.hs
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2012-01-07 18:13:12 -0400
committerGravatar Joey Hess <joey@kitenet.net>2012-01-07 18:18:09 -0400
commita35278430ae2dd3ae2f0c5be291e49077bcac534 (patch)
tree193e1eb496b64625dd0f4269cd8341075c4e7c61 /Remote.hs
parent2f0c3befbd3c04fab474a8cec30f830e08828006 (diff)
log: Add --gource mode, which generates output usable by gource.
As part of this, I fixed up how log was getting the descriptions of remotes.
Diffstat (limited to 'Remote.hs')
-rw-r--r--Remote.hs27
1 files changed, 18 insertions, 9 deletions
diff --git a/Remote.hs b/Remote.hs
index 3f60ca3ac..63d32f429 100644
--- a/Remote.hs
+++ b/Remote.hs
@@ -19,6 +19,7 @@ module Remote (
remoteList,
enabledRemoteList,
remoteMap,
+ uuidDescriptions,
byName,
prettyPrintUUIDs,
remotesWithUUID,
@@ -94,6 +95,18 @@ enabledRemoteList = filterM (repoNotIgnored . repo) =<< remoteList
remoteMap :: Annex (M.Map UUID String)
remoteMap = M.fromList . map (\r -> (uuid r, name r)) <$> remoteList
+{- Map of UUIDs and their descriptions.
+ - The names of Remotes are added to suppliment any description that has
+ - been set for a repository. -}
+uuidDescriptions :: Annex (M.Map UUID String)
+uuidDescriptions = M.unionWith addName <$> uuidMap <*> remoteMap
+
+addName :: String -> String -> String
+addName desc n
+ | desc == n = desc
+ | null desc = n
+ | otherwise = n ++ " (" ++ desc ++ ")"
+
{- When a name is specified, looks up the remote matching that name.
- (Or it can be a UUID.) Only finds currently configured git remotes. -}
byName :: Maybe String -> Annex (Maybe Remote)
@@ -143,28 +156,24 @@ nameToUUID n = byName' n >>= go
prettyPrintUUIDs :: String -> [UUID] -> Annex String
prettyPrintUUIDs desc uuids = do
hereu <- getUUID
- m <- M.unionWith addname <$> uuidMap <*> remoteMap
+ m <- uuidDescriptions
maybeShowJSON [(desc, map (jsonify m hereu) uuids)]
return $ unwords $ map (\u -> "\t" ++ prettify m hereu u ++ "\n") uuids
where
- addname d n
- | d == n = d
- | null d = n
- | otherwise = n ++ " (" ++ d ++ ")"
- findlog m u = M.findWithDefault "" u m
+ finddescription m u = M.findWithDefault "" u m
prettify m hereu u
| not (null d) = fromUUID u ++ " -- " ++ d
| otherwise = fromUUID u
where
ishere = hereu == u
- n = findlog m u
+ n = finddescription m u
d
| null n && ishere = "here"
- | ishere = addname n "here"
+ | ishere = addName n "here"
| otherwise = n
jsonify m hereu u = toJSObject
[ ("uuid", toJSON $ fromUUID u)
- , ("description", toJSON $ findlog m u)
+ , ("description", toJSON $ finddescription m u)
, ("here", toJSON $ hereu == u)
]