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/test/serialize.cpp | |
parent | Initial commit. (diff) | |
download | ceph-upstream.tar.xz ceph-upstream.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/test/serialize.cpp')
-rw-r--r-- | src/boost/libs/graph/test/serialize.cpp | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/src/boost/libs/graph/test/serialize.cpp b/src/boost/libs/graph/test/serialize.cpp new file mode 100644 index 00000000..5f5a6712 --- /dev/null +++ b/src/boost/libs/graph/test/serialize.cpp @@ -0,0 +1,83 @@ +// Copyright (C) 2006 Trustees of Indiana University +// +// 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) + +#include <boost/config.hpp> +#include <iostream> +#include <fstream> +#include <string> +#include <boost/tuple/tuple.hpp> +#include <boost/graph/adjacency_list.hpp> +#include <boost/graph/visitors.hpp> +#include <boost/graph/breadth_first_search.hpp> +#include <map> +#include <boost/graph/adj_list_serialize.hpp> +#include <boost/archive/xml_iarchive.hpp> +#include <boost/archive/xml_oarchive.hpp> + +struct vertex_properties { + std::string name; + + template<class Archive> + void serialize(Archive & ar, const unsigned int /*version*/) { + ar & BOOST_SERIALIZATION_NVP(name); + } +}; + +struct edge_properties { + std::string name; + + template<class Archive> + void serialize(Archive & ar, const unsigned int /*version*/) { + ar & BOOST_SERIALIZATION_NVP(name); + } +}; + +using namespace boost; + +typedef adjacency_list<vecS, vecS, undirectedS, + vertex_properties, edge_properties> Graph; + +typedef graph_traits<Graph>::vertex_descriptor vd_type; + + +typedef adjacency_list<vecS, vecS, undirectedS, + vertex_properties> Graph_no_edge_property; + +int main() +{ + { + std::ofstream ofs("./kevin-bacon2.dat"); + archive::xml_oarchive oa(ofs); + Graph g; + vertex_properties vp; + vp.name = "A"; + vd_type A = add_vertex( vp, g ); + vp.name = "B"; + vd_type B = add_vertex( vp, g ); + + edge_properties ep; + ep.name = "a"; + add_edge( A, B, ep, g); + + oa << BOOST_SERIALIZATION_NVP(g); + + Graph_no_edge_property g_n; + oa << BOOST_SERIALIZATION_NVP(g_n); + } + + { + std::ifstream ifs("./kevin-bacon2.dat"); + archive::xml_iarchive ia(ifs); + Graph g; + ia >> BOOST_SERIALIZATION_NVP(g); + + if (!( g[*(vertices( g ).first)].name == "A" )) return -1; + + Graph_no_edge_property g_n; + ia >> BOOST_SERIALIZATION_NVP(g_n); + } + return 0; +} |