aboutsummaryrefslogtreecommitdiff
path: root/lib/gmp
diff options
context:
space:
mode:
authorKornelijus Tvarijanavičius <kornelitvari@protonmail.com>2021-02-21 11:29:02 +0000
committersfan5 <sfan5@live.de>2021-02-23 18:27:54 +0100
commit0e75f85c41c987185af1224019d6f46bf6608edc (patch)
tree93c2f323d6fb429b2f44c4dc0dc532d1437c1a79 /lib/gmp
parentd77a8a980f122f61a5b7ff2060160a741b18acf7 (diff)
downloadminetest-0e75f85c41c987185af1224019d6f46bf6608edc.tar.gz
minetest-0e75f85c41c987185af1224019d6f46bf6608edc.tar.bz2
minetest-0e75f85c41c987185af1224019d6f46bf6608edc.zip
Translated using Weblate (Lithuanian)
Currently translated at 16.0% (217 of 1353 strings)
Diffstat (limited to 'lib/gmp')
0 files changed, 0 insertions, 0 deletions
the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ #include "config.h" #if USE_LEVELDB #include "database-leveldb.h" #include "log.h" #include "filesys.h" #include "exceptions.h" #include "util/string.h" #include "leveldb/db.h" #define ENSURE_STATUS_OK(s) \ if (!(s).ok()) { \ throw FileNotGoodException(std::string("LevelDB error: ") + \ (s).ToString()); \ } Database_LevelDB::Database_LevelDB(const std::string &savedir) { leveldb::Options options; options.create_if_missing = true; leveldb::Status status = leveldb::DB::Open(options, savedir + DIR_DELIM + "map.db", &m_database); ENSURE_STATUS_OK(status); } Database_LevelDB::~Database_LevelDB() { delete m_database; } bool Database_LevelDB::saveBlock(const v3s16 &pos, const std::string &data) { leveldb::Status status = m_database->Put(leveldb::WriteOptions(), i64tos(getBlockAsInteger(pos)), data); if (!status.ok()) { warningstream << "saveBlock: LevelDB error saving block " << PP(pos) << ": " << status.ToString() << std::endl; return false; } return true; } std::string Database_LevelDB::loadBlock(const v3s16 &pos) { std::string datastr; leveldb::Status status = m_database->Get(leveldb::ReadOptions(), i64tos(getBlockAsInteger(pos)), &datastr); if(status.ok()) return datastr; else return ""; } bool Database_LevelDB::deleteBlock(const v3s16 &pos) { leveldb::Status status = m_database->Delete(leveldb::WriteOptions(), i64tos(getBlockAsInteger(pos))); if (!status.ok()) { warningstream << "deleteBlock: LevelDB error deleting block " << PP(pos) << ": " << status.ToString() << std::endl; return false; } return true; } void Database_LevelDB::listAllLoadableBlocks(std::vector<v3s16> &dst) { leveldb::Iterator* it = m_database->NewIterator(leveldb::ReadOptions()); for (it->SeekToFirst(); it->Valid(); it->Next()) { dst.push_back(getIntegerAsBlock(stoi64(it->key().ToString()))); } ENSURE_STATUS_OK(it->status()); // Check for any errors found during the scan delete it; } #endif // USE_LEVELDB