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