2016-09-08 20:25:52 +08:00
|
|
|
#pragma once
|
|
|
|
|
2016-09-09 23:14:20 +08:00
|
|
|
#include "database/db_accessor.hpp"
|
2016-09-08 20:25:52 +08:00
|
|
|
#include "storage/edge_accessor.hpp"
|
|
|
|
#include "storage/edge_type/edge_type.hpp"
|
|
|
|
#include "storage/label/label.hpp"
|
|
|
|
#include "storage/vertex_accessor.hpp"
|
|
|
|
|
|
|
|
namespace serialization
|
|
|
|
{
|
|
|
|
|
|
|
|
// Serializes Vertex to given writer which implements GraphEncoder.
|
|
|
|
template <class W>
|
|
|
|
void serialize_vertex(VertexAccessor const &v, W &writer)
|
|
|
|
{
|
2016-09-19 06:22:36 +08:00
|
|
|
// Serialize vertex id
|
2016-09-08 20:25:52 +08:00
|
|
|
writer.start_vertex(v.id());
|
|
|
|
|
2016-09-19 06:22:36 +08:00
|
|
|
// Serialize labels
|
2016-09-08 20:25:52 +08:00
|
|
|
auto const &labels = v.labels();
|
|
|
|
writer.label_count(labels.size());
|
|
|
|
for (auto &label : labels) {
|
|
|
|
writer.label(label.get().str());
|
|
|
|
}
|
|
|
|
|
2016-09-19 06:22:36 +08:00
|
|
|
// Serialize propertys
|
2016-09-08 20:25:52 +08:00
|
|
|
auto const &propertys = v.properties();
|
|
|
|
writer.property_count(propertys.size());
|
|
|
|
for (auto &prop : propertys) {
|
|
|
|
writer.property_name(prop.key.family_name());
|
|
|
|
prop.accept_primitive(writer);
|
|
|
|
}
|
|
|
|
|
|
|
|
writer.end_vertex();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Serializes Edge to given writer which implements GraphEncoder.
|
|
|
|
template <class W>
|
|
|
|
void serialize_edge(EdgeAccessor const &e, W &writer)
|
|
|
|
{
|
2016-09-19 06:22:36 +08:00
|
|
|
// Serialize to and from vertices ids.
|
2016-09-09 23:14:20 +08:00
|
|
|
writer.start_edge(e.from().id(), e.to().id());
|
2016-09-08 20:25:52 +08:00
|
|
|
|
2016-09-19 06:22:36 +08:00
|
|
|
// Serialize type
|
2016-09-08 20:25:52 +08:00
|
|
|
writer.edge_type(e.edge_type().str());
|
|
|
|
|
2016-09-19 06:22:36 +08:00
|
|
|
// Serialize propertys
|
2016-09-08 20:25:52 +08:00
|
|
|
auto const &propertys = e.properties();
|
|
|
|
writer.property_count(propertys.size());
|
|
|
|
for (auto &prop : propertys) {
|
|
|
|
writer.property_name(prop.key.family_name());
|
|
|
|
prop.accept_primitive(writer);
|
|
|
|
}
|
|
|
|
|
|
|
|
writer.end_edge();
|
|
|
|
}
|
2016-09-09 23:14:20 +08:00
|
|
|
|
|
|
|
// Deserializes vertex from reader into database db. Returns Id which vertex had
|
|
|
|
// in the reader and VertexAccessor.
|
|
|
|
template <class D>
|
|
|
|
std::pair<Id, VertexAccessor> deserialize_vertex(DbAccessor &db, D &reader)
|
|
|
|
{
|
|
|
|
auto v = db.vertex_insert();
|
|
|
|
auto old_id = reader.vertex_start();
|
|
|
|
|
2016-09-19 06:22:36 +08:00
|
|
|
// Deserialize labels
|
2016-09-09 23:14:20 +08:00
|
|
|
std::string s;
|
|
|
|
for (auto i = reader.label_count(); i > 0; i--) {
|
|
|
|
auto &label_key = db.label_find_or_create(reader.label().c_str());
|
|
|
|
v.add_label(label_key);
|
|
|
|
}
|
|
|
|
|
2016-09-19 06:22:36 +08:00
|
|
|
// Deserialize propertys
|
2016-09-09 23:14:20 +08:00
|
|
|
for (auto i = reader.property_count(); i > 0; i--) {
|
|
|
|
auto &family =
|
|
|
|
db.vertex_property_family_get(reader.property_name().c_str());
|
|
|
|
v.set(StoredProperty<TypeGroupVertex>(
|
|
|
|
family, reader.template property<Property>()));
|
|
|
|
}
|
|
|
|
|
|
|
|
reader.vertex_end();
|
|
|
|
return std::make_pair(old_id, v);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Deserializes edge from reader into database db. Returns loaded EdgeAccessor.
|
|
|
|
// S - is the storage with at() method for accesing VertexAccessor under thers
|
|
|
|
// deserialization local id returnd from deserialize_vertex.
|
|
|
|
template <class D, class S>
|
|
|
|
EdgeAccessor deserialize_edge(DbAccessor &db, D &reader, S &store)
|
|
|
|
{
|
|
|
|
auto ids = reader.edge_start();
|
2016-09-19 06:22:36 +08:00
|
|
|
// Deserialize from and to ids of vertices.
|
2016-09-09 23:14:20 +08:00
|
|
|
VertexAccessor &from = store.at(ids.first);
|
|
|
|
VertexAccessor &to = store.at(ids.second);
|
|
|
|
|
|
|
|
auto e = db.edge_insert(from, to);
|
|
|
|
|
2016-09-19 06:22:36 +08:00
|
|
|
// Deserialize type
|
2016-09-09 23:14:20 +08:00
|
|
|
auto &edge_type_key = db.type_find_or_create(reader.edge_type().c_str());
|
|
|
|
e.edge_type(edge_type_key);
|
|
|
|
|
2016-09-19 06:22:36 +08:00
|
|
|
// Deserialize properties
|
2016-09-09 23:14:20 +08:00
|
|
|
for (auto i = reader.property_count(); i > 0; i--) {
|
|
|
|
auto &family =
|
|
|
|
db.edge_property_family_get(reader.property_name().c_str());
|
|
|
|
e.set(StoredProperty<TypeGroupEdge>(
|
|
|
|
family, reader.template property<Property>()));
|
|
|
|
}
|
|
|
|
|
|
|
|
reader.edge_end();
|
|
|
|
return e;
|
|
|
|
}
|
2016-09-08 20:25:52 +08:00
|
|
|
};
|