CurryInfo: icurry-3.2.0 / TermGraph.SVG.treeSvg

definition:
treeSvg :: Int -> Maybe Dimensions -> (Graph, [ChoiceMapping], NodeID) -> XmlExp
treeSvg maxDepth dims (graph, chMap, root) =
  let (drawGraph, depth) = constructDGraph maxDepth graph root
      calcX      = toFloat ((width drawGraph) * 140)
      calcY      = max (toFloat depth * 80) 400.0
      dimX       = fromMaybe (max calcX calcY) (fst <$> dims)
      dimY       = fromMaybe dimX (snd <$> dims)
  in XElem "svg" [("viewbox", "0 0 " ++ show dimX ++ " " ++ show dimY),
                  ("xmlns", "http://www.w3.org/2000/svg")]
           (treeSvgRek
              maxDepth
              0
              (dimY / (toFloat depth))
              (dimX / (toFloat $ width drawGraph))
              0
              drawGraph
              chMap)
demand:
argument 3
deterministic:
deterministic operation
documentation:
-- Draw a svg-tree of a given graph
failfree:
<FAILING>
indeterministic:
referentially transparent operation
infix:
no fixity defined
iotype:
{(_,_,{(,,)}) |-> {XElem}}
name:
treeSvg
precedence:
no precedence defined
result-values:
{XElem}
signature:
Prelude.Int -> Prelude.Maybe (Prelude.Float, Prelude.Float)
-> ([Node], [(Prelude.Int, Prelude.Int)], Prelude.Int) -> XML.XmlExp
solution-complete:
operation might suspend on free variables
terminating:
possibly non-terminating
totally-defined:
possibly non-reducible on same data term