X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fserver%2FServer.hpp;h=683d36254c76523a6ba5afddd84c2607ae204292;hb=dbd214ac278019c20c883cbb76456b0b0fddc063;hp=cf4fc0433e889f5966bee3806eee1427d57c521c;hpb=b066e776622f96e906600a0c4a08de392bd03676;p=blank.git diff --git a/src/server/Server.hpp b/src/server/Server.hpp index cf4fc04..683d362 100644 --- a/src/server/Server.hpp +++ b/src/server/Server.hpp @@ -2,24 +2,30 @@ #define BLANK_SERVER_SERVER_HPP #include "../app/Config.hpp" +#include "../world/World.hpp" +#include "../world/WorldManipulator.hpp" +#include #include #include namespace blank { -class CompositeModel; -class World; +class ChunkIndex; +class Model; +class Player; +class WorldSave; namespace server { class ClientConnection; -class Server { +class Server +: public WorldManipulator { public: - Server(const Config::Network &, World &); + Server(const Config::Network &, World &, const World::Config &, const WorldSave &); ~Server(); void Handle(); @@ -30,23 +36,35 @@ public: UDPpacket &GetPacket() noexcept { return serv_pack; } World &GetWorld() noexcept { return world; } + const WorldSave &GetWorldSave() noexcept { return save; } - void SetPlayerModel(const CompositeModel &) noexcept; + void SetPlayerModel(const Model &) noexcept; bool HasPlayerModel() const noexcept; - const CompositeModel &GetPlayerModel() const noexcept; + const Model &GetPlayerModel() const noexcept; + + Player *JoinPlayer(const std::string &name); + + void SetBlock(Chunk &, int, const Block &) override; + + /// send message to all connected clients + void DistributeMessage(std::uint8_t type, std::uint32_t ref, const std::string &msg); private: void HandlePacket(const UDPpacket &); ClientConnection &GetClient(const IPaddress &); + void SendAll(); + private: UDPsocket serv_sock; UDPpacket serv_pack; std::list clients; World &world; - const CompositeModel *player_model; + ChunkIndex &spawn_index; + const WorldSave &save; + const Model *player_model; };