2015-11-22 02:16:19 +08:00
|
|
|
#pragma once
|
2015-10-08 06:58:29 +08:00
|
|
|
|
|
|
|
#include <algorithm>
|
2016-08-25 22:29:45 +08:00
|
|
|
#include <vector>
|
2015-10-08 06:58:29 +08:00
|
|
|
|
|
|
|
namespace tx
|
|
|
|
{
|
|
|
|
|
|
|
|
template <class id_t>
|
|
|
|
class Snapshot
|
|
|
|
{
|
|
|
|
public:
|
2015-11-22 02:16:19 +08:00
|
|
|
Snapshot() = default;
|
|
|
|
|
2015-10-08 06:58:29 +08:00
|
|
|
Snapshot(std::vector<id_t> active) : active(std::move(active)) {}
|
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
Snapshot(const Snapshot &other) { active = other.active; }
|
2015-10-08 06:58:29 +08:00
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
Snapshot(Snapshot &&other) { active = std::move(other.active); }
|
2015-10-08 06:58:29 +08:00
|
|
|
|
|
|
|
bool is_active(id_t xid) const
|
|
|
|
{
|
|
|
|
return std::binary_search(active.begin(), active.end(), xid);
|
|
|
|
}
|
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
void insert(const id_t &id) { active.push_back(id); }
|
2015-11-22 02:16:19 +08:00
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
void remove(const id_t &id)
|
2015-11-22 02:16:19 +08:00
|
|
|
{
|
|
|
|
// remove transaction from the active transactions list
|
|
|
|
auto last = std::remove(active.begin(), active.end(), id);
|
|
|
|
active.erase(last, active.end());
|
|
|
|
}
|
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
const id_t &front() { return active.front(); }
|
2015-11-22 02:16:19 +08:00
|
|
|
|
2016-08-25 22:29:45 +08:00
|
|
|
const id_t &back() { return active.back(); }
|
|
|
|
|
|
|
|
size_t size() { return active.size(); }
|
2015-11-22 02:16:19 +08:00
|
|
|
|
2015-10-08 06:58:29 +08:00
|
|
|
private:
|
|
|
|
std::vector<id_t> active;
|
|
|
|
};
|
|
|
|
}
|