memgraph/include/storage/indexes/index_definition.hpp
2016-09-09 16:14:20 +01:00

80 lines
2.0 KiB
C++

#pragma once
#include "utils/option.hpp"
#include "utils/order.hpp"
#include "utils/underlying_cast.hpp"
enum DbSide : uint8_t
{
EdgeSide = 0,
VertexSide = 1,
};
struct IndexType
{
public:
// Are the records unique
const bool unique;
// Ordering of the records.
const Order order;
};
struct IndexLocation
{
public:
const DbSide side;
const Option<std::string> property_name;
const Option<std::string> label_name;
};
// Fully answers:
// On what index?
// What kind of index?
struct IndexDefinition
{
public:
// Serializes self which can be deserialized
template <class E>
void serialize(E &encoder) const
{
std::string empty;
encoder.write_integer(underlying_cast(loc.side));
encoder.write_string(loc.property_name.get_or(empty));
encoder.write_string(loc.label_name.get_or(empty));
encoder.write_bool(type.unique);
encoder.write_integer(underlying_cast(type.order));
}
// Deserializes self.
template <class D>
static IndexDefinition deserialize(D &decoder)
{
auto side = decoder.integer() == 0 ? EdgeSide : VertexSide;
std::string property_name_s;
decoder.string(property_name_s);
auto property_name =
property_name_s.empty()
? Option<std::string>()
: Option<std::string>(std::move(property_name_s));
std::string label_name_s;
decoder.string(label_name_s);
auto label_name = label_name_s.empty()
? Option<std::string>()
: Option<std::string>(std::move(label_name_s));
bool unique = decoder.read_bool();
auto order_v = decoder.integer();
auto order =
order_v == 0 ? None : (order_v == 1 ? Ascending : Descending);
return IndexDefinition{IndexLocation{side, property_name, label_name},
IndexType{unique, order}};
}
const IndexLocation loc;
const IndexType type;
};