Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
[xbt] Add unit test got xbt_dict with arbitrary (not a NULL temrinated string) key
[simgrid.git] / src / xbt / graph_private.h
index 991147503e359c3ef32bd476ddf85f48669f827d..819a11fc3907fb372cc7a59e7550170d2fcf18a1 100644 (file)
@@ -1,32 +1,21 @@
-#include "xbt/misc.h"
-#include "xbt/sysdep.h"
-#include "xbt/dynar.h"
+/* Copyright (c) 2006, 2009-2010, 2012-2014. The SimGrid Team.
+ * All rights reserved.                                                     */
+
+/* This program is free software; you can redistribute it and/or modify it
+ * under the terms of the license (GNU LGPL) which comes with this package. */
 
-/* Node structure */
-/* typedef struct xbt_node *xbt_node_t; */
-typedef struct xbt_node 
-{
-  xbt_dynar_t out;
-  xbt_dynar_t in;
-  void *data;
-} s_xbt_node_t;
+#ifndef _XBT_GRAPH_PRIVATE_H
+#define _XBT_GRAPH_PRIVATE_H
+#include "xbt/dynar.h"
+#include "xbt/graph.h"
 
-/* edge structure */
-/* typedef struct xbt_edge *xbt_edge_t; */
-typedef struct xbt_edge 
-{
-  xbt_node_t src;
-  xbt_node_t dst;
-  void *data;
-} s_xbt_edge_t;
+#define NOT_EXPLORED 0
+#define CURRENTLY_EXPLORING 1
+#define ALREADY_EXPLORED 2
 
-/* Graph structure */
-/* typedef struct xbt_graph *xbt_graph_t; */
-typedef struct xbt_graph 
-{
-  xbt_dynar_t nodes;
-  xbt_dynar_t edges;
-  unsigned short int directed;
-  void *data;
-} s_xbt_graph_t;
+void xbt_floyd_algorithm(xbt_graph_t g, double *adj, double *d,
+                         xbt_node_t * p);
+void xbt_graph_depth_visit(xbt_graph_t g, xbt_node_t n,
+                           xbt_node_t * sorted, int *idx);
 
+#endif                          /* _XBT_GRAPH_PRIVATE_H */