]> git.localhorst.tv Git - blank.git/blobdiff - src/server/ServerState.cpp
server: notify clients of player joins/parts
[blank.git] / src / server / ServerState.cpp
index 7617b416882785003f8b198f3c3fb69fbd764002..0bec3918c0345bc0e3e836157d3d148ba0ddcac2 100644 (file)
@@ -1,7 +1,6 @@
 #include "ServerState.hpp"
 
 #include "../app/Environment.hpp"
-#include "../app/TextureIndex.hpp"
 #include "../io/WorldSave.hpp"
 #include "../net/io.hpp"
 
@@ -19,22 +18,20 @@ ServerState::ServerState(
        const Config &config
 )
 : env(env)
-, shapes()
-, block_types()
-, world(block_types, wc)
+, res()
+, world(res.block_types, wc)
 , generator(gc)
 , chunk_loader(world.Chunks(), generator, ws)
-, skeletons()
-, spawner(world, skeletons, env.rng)
+, spawner(world, res.models, env.rng)
 , server(config.net, world, wc, ws)
 , loop_timer(16) {
-       TextureIndex tex_index;
-       env.loader.LoadShapes("default", shapes);
-       env.loader.LoadBlockTypes("default", block_types, tex_index, shapes);
-       generator.LoadTypes(block_types);
-       skeletons.LoadHeadless();
-       spawner.LimitSkeletons(1, skeletons.size());
-       server.SetPlayerModel(skeletons[0]);
+       res.Load(env.loader, "default");
+       if (res.models.size() < 2) {
+               throw std::runtime_error("need at least two models to run");
+       }
+       generator.LoadTypes(res.block_types);
+       spawner.LimitModels(1, res.models.size());
+       server.SetPlayerModel(res.models[0]);
 
        loop_timer.Start();