summaryrefslogtreecommitdiffstats
path: root/src/lib
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/eina_graph.c25
-rw-r--r--src/lib/eina_graph.h10
2 files changed, 35 insertions, 0 deletions
diff --git a/src/lib/eina_graph.c b/src/lib/eina_graph.c
index 4cea67f..e3bf209 100644
--- a/src/lib/eina_graph.c
+++ b/src/lib/eina_graph.c
@@ -159,3 +159,28 @@ eina_graph_edge_add(Eina_Graph *g, unsigned int v, unsigned int w)
return EINA_TRUE;
}
+
+EAPI void
+eina_graph_dot_write(Eina_Graph *g, FILE *f)
+{
+ int r;
+ char buf[32];
+ unsigned int i, j, n;
+ Eina_Array *ar;
+ _Eina_Graph * _g = (_Eina_Graph *) g;
+
+ fwrite("digraph {\n", 10, 1, f);
+
+ for (i = 0; i< _g->vertices; i++)
+ {
+ ar = _g->adjs[i];
+ n = eina_array_count_get(ar);
+ for (j = 0; j < n; j++)
+ {
+ r = snprintf(buf, 32, "%u -> %u;\n", i, eina_array_uint_nth_get(ar, j));
+ fwrite(buf, r, 1, f);
+ }
+ }
+
+ fwrite("}\n", 2, 1, f);
+}
diff --git a/src/lib/eina_graph.h b/src/lib/eina_graph.h
index c748ede..3297a22 100644
--- a/src/lib/eina_graph.h
+++ b/src/lib/eina_graph.h
@@ -29,6 +29,7 @@
#ifndef _EINA_GRAPH_H
#define _EINA_GRAPH_H
+#include <stdio.h>
#include <eina_types.h>
/**
@@ -130,4 +131,13 @@ eina_graph_self_loops(const Eina_Graph *g);
EAPI Eina_Bool
eina_graph_edge_add(Eina_Graph *g, unsigned int v, unsigned int w);
+/**
+ * generate dot file from the graph.
+ *
+ * @param g the graph to add to edje to.
+ * @param f the output stream to write to.
+ */
+EAPI void
+eina_graph_dot_write(Eina_Graph *g, FILE *f);
+
#endif /* _EINA_GRAPH_H */