memgraph/include/utils/border.hpp
Kruno Tomola Fabro 8a89f6601d EdgeType indexes added.
Implemented untested UniqueOrderedIndex.

Introduced TypeGroupEdge/Vertex into database.

Added Index capabilityes to PropertyFamily.
Added method for adding index.
Added method for removing index.
2016-08-25 15:29:45 +01:00

92 lines
2.4 KiB
C++

#pragma once
#include "utils/option.hpp"
#include "utils/total_ordering.hpp"
// Defines Including as [ and Excluding < for ranges.
enum BorderType
{
Including = 0,
Excluding = 1,
};
// If key is not present he is both the largest and the smallest of the keys.
template <class T>
class Border
{
public:
Border() : key(Option<T>()), type(Including) {}
Border(T Tey, BorderType type) : key(Option<T>(std::move(key))), type(type)
{
}
// Border(Border &other) = default;
Border(Border &other) = default;
Border(Border &&other) = default;
Border &operator=(Border &&other) = default;
Border &operator=(Border &other) = default;
friend bool operator<(const Border<T> &a, const T &other)
{
return !a.key.is_present() ||
(a.type == Excluding && a.key.get() <= other) ||
(a.type == Including && a.key.get() < other);
}
friend bool operator==(const Border<T> &a, const T &other)
{
return a.type == Including && a.key.is_present() &&
a.key.get() == other;
}
friend bool operator>(const Border<T> &a, const T &other)
{
return !a.key.is_present() ||
(a.type == Excluding && a.key.get() >= other) ||
(a.type == Including && a.key.get() > other);
}
friend bool operator!=(const Border<T> &a, const T &b) { return !(a == b); }
friend bool operator<=(const Border<T> &a, const T &b)
{
return a < b || a == b;
}
friend bool operator>=(const Border<T> &a, const T &b)
{
return a > b || a == b;
}
// // true if no border or this > key or this >= key depends on border type.
// bool operator>(const T &other) const
// {
// return !key.is_present() || key.get() > other ||
// (type == Including && key.get() == other);
// }
//
// // true if this border is inclusive and key is present and key == other.
// bool operator==(const T &other) const
// {
// return type == Including && key.is_present() && key.get() == other;
// }
//
// // true if no border or this < key or this <= key depends on border type.
// bool operator<(const T &other) const
// {
// return !key.is_present() || key.get() < other ||
// (type == Including && key.get() == other);
// }
Option<T> key;
BorderType type;
};
template <class T>
auto make_inf_border()
{
return Border<T>();
}