2016-07-05 11:01:22 +08:00
|
|
|
#pragma once
|
|
|
|
|
2016-11-29 11:08:08 +08:00
|
|
|
#include "storage/label/label_collection.hpp"
|
2016-07-05 11:01:22 +08:00
|
|
|
#include "storage/record_accessor.hpp"
|
|
|
|
#include "storage/vertex.hpp"
|
2016-08-29 03:46:30 +08:00
|
|
|
#include "utils/iterator/iterator.hpp"
|
2016-07-05 11:01:22 +08:00
|
|
|
|
|
|
|
class Vertices;
|
2016-08-30 13:16:04 +08:00
|
|
|
class EdgeAccessor;
|
2016-07-05 11:01:22 +08:00
|
|
|
|
2016-08-29 03:46:30 +08:00
|
|
|
// There exists circular dependecy with EdgeAccessor.
|
2016-08-25 22:29:45 +08:00
|
|
|
class VertexAccessor : public RecordAccessor<TypeGroupVertex, VertexAccessor>
|
2016-07-05 11:01:22 +08:00
|
|
|
{
|
2016-08-30 13:16:04 +08:00
|
|
|
friend EdgeAccessor;
|
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
public:
|
|
|
|
using RecordAccessor::RecordAccessor;
|
2016-10-19 08:41:06 +08:00
|
|
|
|
2016-11-29 11:08:08 +08:00
|
|
|
using record_t = Vertex;
|
2016-10-19 08:41:06 +08:00
|
|
|
using record_list_t = VertexRecord;
|
2016-08-18 22:34:36 +08:00
|
|
|
|
2016-08-30 15:53:02 +08:00
|
|
|
// Removes self and all edges connected to it.
|
|
|
|
void remove() const;
|
2016-08-30 13:16:04 +08:00
|
|
|
|
2016-10-19 08:41:06 +08:00
|
|
|
// Returns number of out edges.
|
2016-07-05 11:01:22 +08:00
|
|
|
size_t out_degree() const;
|
|
|
|
|
2016-10-19 08:41:06 +08:00
|
|
|
// Returns number of in edges.
|
2016-07-05 11:01:22 +08:00
|
|
|
size_t in_degree() const;
|
|
|
|
|
2016-10-19 08:41:06 +08:00
|
|
|
// Returns number of all edges.
|
2016-07-05 11:01:22 +08:00
|
|
|
size_t degree() const;
|
|
|
|
|
2016-08-30 13:16:04 +08:00
|
|
|
// True if vertex isn't connected to any other vertex.
|
|
|
|
bool isolated() const;
|
|
|
|
|
2016-10-19 08:41:06 +08:00
|
|
|
// False if it already has the label.
|
2016-08-18 22:34:36 +08:00
|
|
|
bool add_label(const Label &label);
|
|
|
|
|
2016-10-19 08:41:06 +08:00
|
|
|
// False if it doesn't have the label.
|
2016-08-18 22:34:36 +08:00
|
|
|
bool remove_label(const Label &label);
|
2016-07-05 11:01:22 +08:00
|
|
|
|
2016-10-19 08:41:06 +08:00
|
|
|
// Checks if it has the label.
|
2016-07-05 11:01:22 +08:00
|
|
|
bool has_label(const Label &label) const;
|
|
|
|
|
2016-10-19 08:41:06 +08:00
|
|
|
// Returns container with all labels.
|
2016-08-28 22:47:13 +08:00
|
|
|
const std::vector<label_ref_t> &labels() const;
|
2016-08-15 07:09:58 +08:00
|
|
|
|
|
|
|
auto out() const;
|
|
|
|
|
|
|
|
auto in() const;
|
|
|
|
|
2016-10-19 08:41:06 +08:00
|
|
|
// True if there exists edge between other vertex and this vertex.
|
2016-08-25 22:29:45 +08:00
|
|
|
bool in_contains(VertexAccessor const &other) const;
|
2016-11-29 11:08:08 +08:00
|
|
|
|
|
|
|
template <typename Stream>
|
|
|
|
void stream_repr(Stream& stream) const
|
|
|
|
{
|
|
|
|
if (this->record != nullptr)
|
|
|
|
this->record->stream_repr(stream);
|
|
|
|
else
|
|
|
|
std::cout << "TRACE: record is nullptr" << std::endl;
|
|
|
|
|
|
|
|
}
|
2016-07-05 11:01:22 +08:00
|
|
|
};
|