package catala

  1. Overview
  2. Docs
Compiler and library for the literate programming language for tax code specification

Install

dune-project
 Dependency

Authors

Maintainers

Sources

1.0.0-alpha.tar.gz
md5=2615968670ac21b1d00386a9b04b3843
sha512=eff292fdd75012f26ce7b17020f5a8374eef37cd4dd6ba60338dfbe89fbcad3443d1b409e44c182b740da9f58dff7e76dcb8ddefe47f9b2b160666d1c6930143

doc/src/catala.catala_utils/graphs.ml.html

Source file graphs.ml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
module JSON_Graph
    (V : sig
      include Graph.Sig.COMPARABLE

      val format : Format.formatter -> t -> unit
    end)
    (G : Graph.Sig.G with type V.t = V.t) =
struct
  let graph_to_json g =
    let nodes =
      G.fold_vertex
        (fun v acc ->
          (string_of_int (G.V.hash v), `String (Format.asprintf "%a" V.format v))
          :: acc)
        g []
    in
    let nodes = `Assoc nodes in
    let edges =
      G.fold_edges
        (fun v1 v2 acc ->
          `Assoc ["from", `Int (V.hash v1); "to", `Int (V.hash v2)] :: acc)
        g []
    in
    let edges = `List edges in
    `Assoc ["nodes", nodes; "edges", edges]
end