3 Copyright (C) 2013 celeron55, Perttu Ahola <celeron55@gmail.com>
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU Lesser General Public License as published by
7 the Free Software Foundation; either version 2.1 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public License along
16 with this program; if not, write to the Free Software Foundation, Inc.,
17 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
24 #include "database-dummy.h"
25 #include "remoteplayer.h"
28 bool Database_Dummy::saveBlock(const v3s16 &pos, const std::string &data)
30 m_database[getBlockAsInteger(pos)] = data;
34 void Database_Dummy::loadBlock(const v3s16 &pos, std::string *block)
36 s64 i = getBlockAsInteger(pos);
37 auto it = m_database.find(i);
38 if (it == m_database.end()) {
46 bool Database_Dummy::deleteBlock(const v3s16 &pos)
48 m_database.erase(getBlockAsInteger(pos));
52 void Database_Dummy::listAllLoadableBlocks(std::vector<v3s16> &dst)
54 dst.reserve(m_database.size());
55 for (std::map<s64, std::string>::const_iterator x = m_database.begin();
56 x != m_database.end(); ++x) {
57 dst.push_back(getIntegerAsBlock(x->first));
61 void Database_Dummy::savePlayer(RemotePlayer *player)
63 m_player_database.insert(player->getName());
66 bool Database_Dummy::loadPlayer(RemotePlayer *player, PlayerSAO *sao)
68 return m_player_database.find(player->getName()) != m_player_database.end();
71 bool Database_Dummy::removePlayer(const std::string &name)
73 m_player_database.erase(name);
77 void Database_Dummy::listPlayers(std::vector<std::string> &res)
79 for (const auto &player : m_player_database) {
80 res.emplace_back(player);
84 bool Database_Dummy::getModEntries(const std::string &modname, StringMap *storage)
86 const auto mod_pair = m_mod_meta_database.find(modname);
87 if (mod_pair != m_mod_meta_database.cend()) {
88 for (const auto &pair : mod_pair->second) {
89 (*storage)[pair.first] = pair.second;
95 bool Database_Dummy::setModEntry(const std::string &modname,
96 const std::string &key, const std::string &value)
98 auto mod_pair = m_mod_meta_database.find(modname);
99 if (mod_pair == m_mod_meta_database.end()) {
100 m_mod_meta_database[modname] = StringMap({{key, value}});
102 mod_pair->second[key] = value;
107 bool Database_Dummy::removeModEntry(const std::string &modname, const std::string &key)
109 auto mod_pair = m_mod_meta_database.find(modname);
110 if (mod_pair != m_mod_meta_database.end())
111 return mod_pair->second.erase(key) > 0;
115 void Database_Dummy::listMods(std::vector<std::string> *res)
117 for (const auto &pair : m_mod_meta_database) {
118 res->push_back(pair.first);