2015-11-22 02:16:19 +08:00
|
|
|
#pragma once
|
2015-09-13 17:34:17 +08:00
|
|
|
|
2015-11-22 02:16:19 +08:00
|
|
|
#include "mvcc/id.hpp"
|
2015-09-13 17:34:17 +08:00
|
|
|
#include "threading/sync/lockable.hpp"
|
2015-10-08 06:58:29 +08:00
|
|
|
#include "transactions/transaction.hpp"
|
2015-09-13 17:34:17 +08:00
|
|
|
#include "version.hpp"
|
|
|
|
|
|
|
|
namespace mvcc
|
|
|
|
{
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
class Atom : public Version<T>,
|
2015-10-08 06:58:29 +08:00
|
|
|
public Lockable<SpinLock>
|
2015-09-13 17:34:17 +08:00
|
|
|
{
|
|
|
|
public:
|
2015-11-22 02:16:19 +08:00
|
|
|
Atom(const Id& id, T* first) : Version<T>(first), id(id)
|
2015-09-13 17:34:17 +08:00
|
|
|
{
|
|
|
|
// it's illegal that the first version is nullptr. there should be at
|
|
|
|
// least one version of a record
|
|
|
|
assert(first != nullptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
T* first()
|
|
|
|
{
|
|
|
|
return this->newer();
|
|
|
|
}
|
|
|
|
|
|
|
|
// inspects the record change history and returns the record version visible
|
|
|
|
// to the current transaction if it exists, otherwise it returns nullptr
|
2015-10-08 06:58:29 +08:00
|
|
|
T* latest_visible(const tx::Transaction& t)
|
2015-09-13 17:34:17 +08:00
|
|
|
{
|
|
|
|
return first()->latest_visible(t);
|
|
|
|
}
|
|
|
|
|
|
|
|
// every record has a unique id. 2^64 = 1.8 x 10^19. that should be enough
|
|
|
|
// for a looong time :) but keep in mind that some vacuuming would be nice
|
|
|
|
// to reuse indices for deleted nodes.
|
2015-11-22 02:16:19 +08:00
|
|
|
Id id;
|
2015-10-08 06:58:29 +08:00
|
|
|
|
|
|
|
std::atomic<Atom<T>*> next;
|
2015-09-13 17:34:17 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|