summaryrefslogtreecommitdiff
path: root/Command/Map.hs
diff options
context:
space:
mode:
Diffstat (limited to 'Command/Map.hs')
-rw-r--r--Command/Map.hs52
1 files changed, 10 insertions, 42 deletions
diff --git a/Command/Map.hs b/Command/Map.hs
index b89f8f89b..5b035e283 100644
--- a/Command/Map.hs
+++ b/Command/Map.hs
@@ -21,6 +21,7 @@ import Messages
import Types
import Utility
import UUID
+import qualified Dot
-- a link from the first repository to the second (its remote)
data Link = Link Git.Repo Git.Repo
@@ -50,41 +51,41 @@ start = do
- displayed as a node, and each of its remotes is represented as an edge
- pointing at the node for the remote. -}
drawMap :: [Git.Repo] -> (M.Map UUID String) -> String
-drawMap rs umap = dotGraph $ repos ++ others
+drawMap rs umap = Dot.graph $ repos ++ others
where
repos = map (dotGraphRepo umap rs) rs
others = map uuidnode (M.keys umap)
- uuidnode u = dotGraphNode u $ M.findWithDefault "" u umap
+ uuidnode u = Dot.graphNode u $ M.findWithDefault "" u umap
dotGraphRepo :: (M.Map UUID String) -> [Git.Repo] -> Git.Repo -> String
dotGraphRepo umap fullinfo r = unlines $ node:edges
where
- node = inhost $ dotGraphNode (nodeid r) (repoName umap r)
+ node = inhost $ Dot.graphNode (nodeid r) (repoName umap r)
edges = map edge (Git.remotes r)
inhost a
- | Git.repoIsUrl r = dotSubGraph hostname a
+ | Git.repoIsUrl r = Dot.subGraph (Git.urlHost r) (hostname r) a
| otherwise = a
- hostname = head $ split "." $ Git.urlHost r
+ hostname n = head $ split "." $ Git.urlHost n
edge to =
-- get the full info for the repo since its UUID
-- is in there
let to' = findfullinfo to
- in dotGraphEdge
+ in Dot.graphEdge
(nodeid r)
(nodeid $ makeabs r to')
(edgename to to')
-- Only name an edge if the name is different than the name
- -- that will be used for the destination node. (This
- -- reduces visual clutter.)
+ -- that will be used for the destination node, and is
+ -- different from its hostname. (This reduces visual clutter.)
edgename to to' =
case (Git.repoRemoteName to) of
Nothing -> Nothing
Just n ->
- if (n == repoName umap to')
+ if (n == repoName umap to' || n == hostname to')
then Nothing
else Just n
@@ -108,39 +109,6 @@ repoName umap r
Just n -> n
Nothing -> "unknown"
-dotGraphNode :: String -> String -> String
-dotGraphNode nodeid desc = dotLineLabeled desc $ dotQuote nodeid
-
-dotGraphEdge :: String -> String -> Maybe String -> String
-dotGraphEdge fromid toid d =
- case d of
- Nothing -> dotLine edge
- Just desc -> dotLineLabeled desc edge
- where
- edge = dotQuote fromid ++ " -> " ++ dotQuote toid
-
-dotGraph :: [String] -> String
-dotGraph s = unlines $ [header] ++ s ++ [footer]
- where
- header = "digraph map {"
- footer= "}"
-
-dotQuote :: String -> String
-dotQuote s = "\"" ++ s ++ "\""
-
-dotLine :: String -> String
-dotLine s = "\t" ++ s ++ ";"
-
-dotLineLabeled :: String -> String -> String
-dotLineLabeled label s = dotLine $ s ++ " [ label=" ++ dotQuote label ++ " ]"
-
-dotSubGraph :: String -> String -> String
-dotSubGraph label s = "subgraph " ++ name ++ "{ " ++ setlabel ++ s ++ " }"
- where
- -- the "cluster_" makes dot draw a box
- name = dotQuote ("cluster_ " ++ label)
- setlabel = dotLine $ "label=" ++ dotQuote label
-
{- Recursively searches out remotes starting with the specified repo. -}
spider :: Git.Repo -> Annex [Git.Repo]
spider r = spider' [r] []