2016-07-05 11:01:22 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "data_structures/concurrent/concurrent_map.hpp"
|
2016-08-15 07:09:58 +08:00
|
|
|
#include "database/db_transaction.hpp"
|
2016-07-05 11:01:22 +08:00
|
|
|
#include "storage/common.hpp"
|
|
|
|
#include "storage/indexes/index.hpp"
|
|
|
|
#include "storage/indexes/index_record_collection.hpp"
|
|
|
|
#include "storage/vertex_accessor.hpp"
|
2016-08-15 07:09:58 +08:00
|
|
|
#include "utils/option.hpp"
|
2016-07-05 11:01:22 +08:00
|
|
|
|
|
|
|
class Vertices
|
|
|
|
{
|
|
|
|
public:
|
2016-08-08 16:32:34 +08:00
|
|
|
using vertices_t = ConcurrentMap<uint64_t, VertexRecord>;
|
|
|
|
|
|
|
|
vertices_t::Accessor access();
|
|
|
|
|
2016-08-15 07:09:58 +08:00
|
|
|
Option<const Vertex::Accessor> find(DbTransaction &t, const Id &id);
|
2016-07-05 11:01:22 +08:00
|
|
|
|
2016-08-15 07:09:58 +08:00
|
|
|
// Creates new Vertex and returns filled Vertex::Accessor.
|
|
|
|
Vertex::Accessor insert(DbTransaction &t);
|
2016-07-05 11:01:22 +08:00
|
|
|
|
|
|
|
void update_label_index(const Label &label,
|
|
|
|
VertexIndexRecord &&index_record);
|
|
|
|
|
2016-08-15 07:09:58 +08:00
|
|
|
VertexIndexRecordCollection &find_label_index(const Label &label);
|
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
private:
|
2016-08-08 16:32:34 +08:00
|
|
|
vertices_t vertices;
|
2016-07-05 11:01:22 +08:00
|
|
|
Index<label_ref_t, VertexIndexRecordCollection> label_index;
|
|
|
|
AtomicCounter<uint64_t> counter;
|
|
|
|
};
|