summaryrefslogtreecommitdiffstats
path: root/src/boost/libs/graph/test/serialize.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/test/serialize.cpp
parentInitial commit. (diff)
downloadceph-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.cpp83
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;
+}