libcryfs/implementations/testfake/FakeBlockStore.cpp

70 lines
1.8 KiB
C++
Raw Normal View History

#include "FakeBlock.h"
#include "FakeBlockStore.h"
using std::unique_ptr;
using std::make_unique;
using std::make_shared;
using std::string;
using std::mutex;
using std::lock_guard;
using cpputils::Data;
namespace blockstore {
namespace testfake {
FakeBlockStore::FakeBlockStore()
: _blocks(), _used_dataregions_for_blocks() {}
unique_ptr<Block> FakeBlockStore::tryCreate(const Key &key, Data data) {
auto insert_result = _blocks.emplace(key.ToString(), std::move(data));
if (!insert_result.second) {
return nullptr;
}
//Return a copy of the stored data
return load(key);
}
unique_ptr<Block> FakeBlockStore::load(const Key &key) {
//Return a copy of the stored data
string key_string = key.ToString();
try {
2015-04-15 14:51:41 +02:00
return makeFakeBlockFromData(key, _blocks.at(key_string), false);
} catch (const std::out_of_range &e) {
return nullptr;
}
}
void FakeBlockStore::remove(unique_ptr<Block> block) {
Key key = block->key();
block.reset();
2015-02-22 00:29:21 +01:00
int numRemoved = _blocks.erase(key.ToString());
assert(numRemoved == 1);
}
2015-04-15 14:51:41 +02:00
unique_ptr<Block> FakeBlockStore::makeFakeBlockFromData(const Key &key, const Data &data, bool dirty) {
auto newdata = make_shared<Data>(data.copy());
_used_dataregions_for_blocks.push_back(newdata);
2015-04-15 14:51:41 +02:00
return make_unique<FakeBlock>(this, key, newdata, dirty);
}
2015-01-24 22:08:41 +01:00
void FakeBlockStore::updateData(const Key &key, const Data &data) {
2015-04-15 14:51:41 +02:00
auto found = _blocks.find(key.ToString());
if (found == _blocks.end()) {
auto insertResult = _blocks.emplace(key.ToString(), data.copy());
2015-04-15 14:51:41 +02:00
assert(true == insertResult.second);
found = insertResult.first;
}
Data &stored_data = found->second;
assert(data.size() == stored_data.size());
std::memcpy(stored_data.data(), data.data(), data.size());
}
2015-02-23 21:07:07 +01:00
uint64_t FakeBlockStore::numBlocks() const {
return _blocks.size();
}
}
}