X-Git-Url: https://git.lizzy.rs/?a=blobdiff_plain;f=src%2Fdatabase.h;h=5a2b844fde740fe49930d7e7f97e422f72ccfab8;hb=605599b6f150b89ba6539c4d088231b326adcb48;hp=45978930691013f27b25158e85e67aa916ef0236;hpb=4d4b8bb8a46b6472d86fa848954dbc26b4fadb50;p=dragonfireclient.git diff --git a/src/database.h b/src/database.h index 459789306..5a2b844fd 100644 --- a/src/database.h +++ b/src/database.h @@ -20,8 +20,8 @@ with this program; if not, write to the Free Software Foundation, Inc., #ifndef DATABASE_HEADER #define DATABASE_HEADER -#include #include +#include #include "irr_v3d.h" #include "irrlichttypes.h" #include "util/basic_macros.h" @@ -29,10 +29,15 @@ with this program; if not, write to the Free Software Foundation, Inc., class Database { public: - virtual ~Database() {} + virtual void beginSave() = 0; + virtual void endSave() = 0; + virtual bool initialized() const { return true; } +}; - virtual void beginSave() {} - virtual void endSave() {} +class MapDatabase : public Database +{ +public: + virtual ~MapDatabase() {} virtual bool saveBlock(const v3s16 &pos, const std::string &data) = 0; virtual void loadBlock(const v3s16 &pos, std::string *block) = 0; @@ -42,9 +47,19 @@ class Database static v3s16 getIntegerAsBlock(s64 i); virtual void listAllLoadableBlocks(std::vector &dst) = 0; +}; - virtual bool initialized() const { return true; } +class PlayerSAO; +class RemotePlayer; + +class PlayerDatabase +{ +public: + virtual ~PlayerDatabase() {} + virtual void savePlayer(RemotePlayer *player) = 0; + virtual bool loadPlayer(RemotePlayer *player, PlayerSAO *sao) = 0; + virtual bool removePlayer(const std::string &name) = 0; + virtual void listPlayers(std::vector &res) = 0; }; #endif -