2015-03-12 14:27:51 +01:00
|
|
|
#include "OnDiskBlock.h"
|
|
|
|
#include "OnDiskBlockStore.h"
|
2014-12-09 17:19:59 +01:00
|
|
|
|
|
|
|
using std::string;
|
2015-04-25 02:48:41 +02:00
|
|
|
using cpputils::Data;
|
2015-07-20 18:57:48 +02:00
|
|
|
using cpputils::unique_ref;
|
|
|
|
using boost::optional;
|
|
|
|
using boost::none;
|
2014-12-09 17:19:59 +01:00
|
|
|
|
|
|
|
namespace bf = boost::filesystem;
|
|
|
|
|
|
|
|
namespace blockstore {
|
|
|
|
namespace ondisk {
|
|
|
|
|
|
|
|
OnDiskBlockStore::OnDiskBlockStore(const boost::filesystem::path &rootdir)
|
2015-10-29 15:49:59 +01:00
|
|
|
: _rootdir(rootdir) {
|
|
|
|
if (!bf::exists(rootdir)) {
|
|
|
|
throw std::runtime_error("Base directory not found");
|
|
|
|
}
|
2015-10-30 18:10:24 +01:00
|
|
|
if (!bf::is_directory(rootdir)) {
|
|
|
|
throw std::runtime_error("Base directory is not a directory");
|
|
|
|
}
|
2015-10-29 15:49:59 +01:00
|
|
|
//TODO Test for read access, write access, enter (x) access, and throw runtime_error in case
|
|
|
|
}
|
2014-12-09 17:19:59 +01:00
|
|
|
|
2015-10-15 04:49:31 +02:00
|
|
|
//TODO Do I have to lock tryCreate/remove and/or load? Or does ParallelAccessBlockStore take care of that?
|
|
|
|
|
2015-07-20 18:57:48 +02:00
|
|
|
optional<unique_ref<Block>> OnDiskBlockStore::tryCreate(const Key &key, Data data) {
|
|
|
|
//TODO Easier implementation? This is only so complicated because of the cast OnDiskBlock -> Block
|
|
|
|
auto result = std::move(OnDiskBlock::CreateOnDisk(_rootdir, key, std::move(data)));
|
|
|
|
if (result == boost::none) {
|
|
|
|
return boost::none;
|
2014-12-09 17:19:59 +01:00
|
|
|
}
|
2015-07-20 18:57:48 +02:00
|
|
|
return unique_ref<Block>(std::move(*result));
|
2014-12-09 17:19:59 +01:00
|
|
|
}
|
|
|
|
|
2015-07-21 14:50:52 +02:00
|
|
|
optional<unique_ref<Block>> OnDiskBlockStore::load(const Key &key) {
|
|
|
|
return optional<unique_ref<Block>>(OnDiskBlock::LoadFromDisk(_rootdir, key));
|
2014-12-09 17:19:59 +01:00
|
|
|
}
|
|
|
|
|
2015-07-21 14:50:52 +02:00
|
|
|
void OnDiskBlockStore::remove(unique_ref<Block> block) {
|
2015-02-22 16:53:49 +01:00
|
|
|
Key key = block->key();
|
2015-07-21 18:19:34 +02:00
|
|
|
cpputils::destruct(std::move(block));
|
2015-02-22 00:29:21 +01:00
|
|
|
OnDiskBlock::RemoveFromDisk(_rootdir, key);
|
|
|
|
}
|
|
|
|
|
2015-02-23 21:07:07 +01:00
|
|
|
uint64_t OnDiskBlockStore::numBlocks() const {
|
|
|
|
return std::distance(bf::directory_iterator(_rootdir), bf::directory_iterator());
|
|
|
|
}
|
|
|
|
|
2014-12-09 17:19:59 +01:00
|
|
|
}
|
|
|
|
}
|