memgraph/src/storage/edge_accessor.cpp

36 lines
1.0 KiB
C++
Raw Normal View History

#include "storage/edge_accessor.hpp"
#include "database/graph_db_accessor.hpp"
#include "storage/vertex_accessor.hpp"
#include "utils/algorithm.hpp"
storage::EdgeType EdgeAccessor::EdgeType() const { return edge_type_; }
VertexAccessor EdgeAccessor::from() const {
return VertexAccessor(from_, db_accessor());
}
2016-08-29 21:51:31 +08:00
bool EdgeAccessor::from_is(const VertexAccessor &v) const {
return v.address() == from_;
}
VertexAccessor EdgeAccessor::to() const {
return VertexAccessor(to_, db_accessor());
2016-08-29 21:51:31 +08:00
}
bool EdgeAccessor::to_is(const VertexAccessor &v) const {
return v.address() == to_;
}
bool EdgeAccessor::is_cycle() const { return to_ == from_; }
std::ostream &operator<<(std::ostream &os, const EdgeAccessor &ea) {
os << "E[" << ea.db_accessor().EdgeTypeName(ea.EdgeType());
os << " {";
utils::PrintIterable(os, ea.Properties(), ", ", [&](auto &stream,
const auto &pair) {
stream << ea.db_accessor().PropertyName(pair.first) << ": " << pair.second;
});
return os << "}]";
}