2016-07-05 11:01:22 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "data_structures/concurrent/concurrent_map.hpp"
|
|
|
|
#include "storage/common.hpp"
|
|
|
|
#include "storage/indexes/index.hpp"
|
|
|
|
#include "storage/indexes/index_record_collection.hpp"
|
|
|
|
#include "storage/vertex_accessor.hpp"
|
|
|
|
|
|
|
|
class Vertices
|
|
|
|
{
|
|
|
|
public:
|
2016-08-08 16:32:34 +08:00
|
|
|
using vertices_t = ConcurrentMap<uint64_t, VertexRecord>;
|
|
|
|
|
|
|
|
vertices_t::Accessor access();
|
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
const Vertex::Accessor find(tx::Transaction &t, const Id &id);
|
|
|
|
|
2016-08-08 16:32:34 +08:00
|
|
|
const Vertex::Accessor first(tx::Transaction &t);
|
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
Vertex::Accessor insert(tx::Transaction &t);
|
|
|
|
|
|
|
|
void update_label_index(const Label &label,
|
|
|
|
VertexIndexRecord &&index_record);
|
|
|
|
|
|
|
|
VertexIndexRecordCollection& find_label_index(const Label& label);
|
2016-08-08 16:32:34 +08:00
|
|
|
|
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;
|
|
|
|
};
|