diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 18:24:20 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 18:24:20 +0000 |
commit | 483eb2f56657e8e7f419ab1a4fab8dce9ade8609 (patch) | |
tree | e5d88d25d870d5dedacb6bbdbe2a966086a0a5cf /src/boost/libs/graph/example/scc.cpp | |
parent | Initial commit. (diff) | |
download | ceph-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.cpp | 49 |
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; +} |