2015-12-08 04:51:55 +08:00
|
|
|
#pragma once
|
2015-10-08 06:58:29 +08:00
|
|
|
|
|
|
|
#include "data_structures/bitset/dynamic_bitset.hpp"
|
2016-07-05 11:01:22 +08:00
|
|
|
#include "mvcc/id.hpp"
|
2015-10-08 06:58:29 +08:00
|
|
|
|
|
|
|
namespace tx
|
|
|
|
{
|
|
|
|
|
|
|
|
class CommitLog
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
struct Info
|
|
|
|
{
|
|
|
|
enum Status
|
|
|
|
{
|
2016-07-05 11:01:22 +08:00
|
|
|
ACTIVE = 0, // 00
|
2015-10-08 06:58:29 +08:00
|
|
|
COMMITTED = 1, // 01
|
2016-07-05 11:01:22 +08:00
|
|
|
ABORTED = 2, // 10
|
2015-10-08 06:58:29 +08:00
|
|
|
};
|
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
bool is_active() const { return flags & ACTIVE; }
|
2015-10-08 06:58:29 +08:00
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
bool is_committed() const { return flags & COMMITTED; }
|
2015-10-08 06:58:29 +08:00
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
bool is_aborted() const { return flags & ABORTED; }
|
2015-10-08 06:58:29 +08:00
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
operator uint8_t() const { return flags; }
|
2015-10-08 06:58:29 +08:00
|
|
|
|
|
|
|
uint8_t flags;
|
|
|
|
};
|
|
|
|
|
|
|
|
CommitLog() = default;
|
2016-07-05 11:01:22 +08:00
|
|
|
CommitLog(CommitLog &) = delete;
|
|
|
|
CommitLog(CommitLog &&) = delete;
|
2015-10-08 06:58:29 +08:00
|
|
|
|
|
|
|
CommitLog operator=(CommitLog) = delete;
|
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
Info fetch_info(const Id &id) { return Info{log.at(2 * id, 2)}; }
|
2015-10-08 06:58:29 +08:00
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
bool is_active(const Id &id) { return fetch_info(id).is_active(); }
|
2015-10-08 06:58:29 +08:00
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
bool is_committed(const Id &id) { return fetch_info(id).is_committed(); }
|
2015-10-08 06:58:29 +08:00
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
void set_committed(const Id &id) { log.set(2 * id); }
|
2015-10-08 06:58:29 +08:00
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
bool is_aborted(const Id &id) { return fetch_info(id).is_aborted(); }
|
2015-10-08 06:58:29 +08:00
|
|
|
|
2016-07-05 11:01:22 +08:00
|
|
|
void set_aborted(const Id &id) { log.set(2 * id + 1); }
|
2015-10-08 06:58:29 +08:00
|
|
|
|
|
|
|
private:
|
2016-08-25 22:29:45 +08:00
|
|
|
// TODO: Searching the log will take more and more time the more and more
|
|
|
|
// transactoins are done. This could be awerted if DynamicBitset is changed
|
|
|
|
// to point to largest chunk instead of the smallest.
|
2015-10-08 06:58:29 +08:00
|
|
|
DynamicBitset<uint8_t, 32768> log;
|
|
|
|
};
|
|
|
|
}
|