summaryrefslogtreecommitdiffstats
path: root/src/boost/libs/graph/example/scc.cpp
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 18:24:20 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 18:24:20 +0000
commit483eb2f56657e8e7f419ab1a4fab8dce9ade8609 (patch)
treee5d88d25d870d5dedacb6bbdbe2a966086a0a5cf /src/boost/libs/graph/example/scc.cpp
parentInitial commit. (diff)
downloadceph-483eb2f56657e8e7f419ab1a4fab8dce9ade8609.tar.xz
ceph-483eb2f56657e8e7f419ab1a4fab8dce9ade8609.zip
Adding upstream version 14.2.21.upstream/14.2.21upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/boost/libs/graph/example/scc.cpp')
-rw-r--r--src/boost/libs/graph/example/scc.cpp49
1 files changed, 49 insertions, 0 deletions
diff --git a/src/boost/libs/graph/example/scc.cpp b/src/boost/libs/graph/example/scc.cpp
new file mode 100644
index 00000000..d66382bf
--- /dev/null
+++ b/src/boost/libs/graph/example/scc.cpp
@@ -0,0 +1,49 @@
+//=======================================================================
+// Copyright 2001 Jeremy G. Siek, Andrew Lumsdaine, Lie-Quan Lee,
+//
+// Distributed under the Boost Software License, Version 1.0. (See
+// accompanying file LICENSE_1_0.txt or copy at
+// http://www.boost.org/LICENSE_1_0.txt)
+//=======================================================================
+
+/*
+ IMPORTANT!!!
+ ~~~~~~~~~~~~
+ This example uses interfaces that have been deprecated and removed from Boost.Grpah.
+ Someone needs to update it, as it does NOT compile.
+*/
+
+#include <boost/config.hpp>
+#include <fstream>
+#include <map>
+#include <string>
+#include <boost/graph/strong_components.hpp>
+#include <boost/graph/graphviz.hpp>
+
+int
+main()
+{
+ using namespace boost;
+ GraphvizDigraph g;
+ read_graphviz("figs/scc.dot", g);
+
+ typedef graph_traits < GraphvizDigraph >::vertex_descriptor vertex_t;
+ std::map < vertex_t, int >component;
+
+ strong_components(g, make_assoc_property_map(component));
+
+ property_map < GraphvizDigraph, vertex_attribute_t >::type
+ vertex_attr_map = get(vertex_attribute, g);
+ std::string color[] = {
+ "white", "gray", "black", "lightgray"};
+ graph_traits < GraphvizDigraph >::vertex_iterator vi, vi_end;
+ for (boost::tie(vi, vi_end) = vertices(g); vi != vi_end; ++vi) {
+ vertex_attr_map[*vi]["color"] = color[component[*vi]];
+ vertex_attr_map[*vi]["style"] = "filled";
+ if (vertex_attr_map[*vi]["color"] == "black")
+ vertex_attr_map[*vi]["fontcolor"] = "white";
+ }
+ write_graphviz("figs/scc-out.dot", g);
+
+ return EXIT_SUCCESS;
+}