futriix/src/storage/teststorageprovider.cpp

106 lines
2.5 KiB
C++
Raw Normal View History

#include "teststorageprovider.h"
#include "../server.h"
IStorage *TestStorageFactory::create(int, key_load_iterator, void *)
{
return new (MALLOC_LOCAL) TestStorageProvider();
}
IStorage *TestStorageFactory::createMetadataDb()
{
IStorage *metadataDb = new (MALLOC_LOCAL) TestStorageProvider();
metadataDb->insert("KEYDB_METADATA_ID", strlen("KEYDB_METADATA_ID"), (void*)METADATA_DB_IDENTIFIER, strlen(METADATA_DB_IDENTIFIER), false);
return metadataDb;
}
const char *TestStorageFactory::name() const
{
return "TEST Storage Provider";
}
TestStorageProvider::TestStorageProvider()
{
}
TestStorageProvider::~TestStorageProvider()
{
}
void TestStorageProvider::insert(const char *key, size_t cchKey, void *data, size_t cb, bool fOverwrite)
{
auto strkey = std::string(key, cchKey);
bool fActuallyExists = m_map.find(strkey) != m_map.end();
serverAssert(fActuallyExists == fOverwrite);
m_map.insert(std::make_pair(strkey, std::string((char*)data, cb)));
}
bool TestStorageProvider::erase(const char *key, size_t cchKey)
{
auto itr = m_map.find(std::string(key, cchKey));
if (itr != m_map.end())
{
m_map.erase(itr);
return true;
}
return false;
}
void TestStorageProvider::retrieve(const char *key, size_t cchKey, callbackSingle fn) const
{
auto itr = m_map.find(std::string(key, cchKey));
if (itr != m_map.end())
fn(key, cchKey, itr->second.data(), itr->second.size());
}
size_t TestStorageProvider::clear()
{
size_t size = m_map.size();
m_map.clear();
return size;
}
bool TestStorageProvider::enumerate(callback fn) const
{
bool fAll = true;
for (auto &pair : m_map)
{
if (!fn(pair.first.data(), pair.first.size(), pair.second.data(), pair.second.size()))
{
fAll = false;
break;
}
}
return fAll;
}
bool TestStorageProvider::enumerate_hashslot(callback fn, unsigned int hashslot) const
{
bool fAll = true;
for (auto &pair : m_map)
{
if (keyHashSlot(pair.first.data(), pair.first.size()) == hashslot)
if (!fn(pair.first.data(), pair.first.size(), pair.second.data(), pair.second.size()))
{
fAll = false;
break;
}
}
return fAll;
}
size_t TestStorageProvider::count() const
{
return m_map.size();
}
void TestStorageProvider::flush()
{
/* NOP */
}
/* This is permitted to be a shallow clone */
const IStorage *TestStorageProvider::clone() const
{
return new (MALLOC_LOCAL) TestStorageProvider(*this);
}