diff options
Diffstat (limited to 'src/engine.cpp')
-rw-r--r-- | src/engine.cpp | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/src/engine.cpp b/src/engine.cpp index a2d0e9b..703b45e 100644 --- a/src/engine.cpp +++ b/src/engine.cpp @@ -27,6 +27,7 @@ #include "script.hpp" #include "render.hpp" #include "physics.hpp" +#include "text.hpp" #include "components/EventListener.hpp" #include "components/Script.hpp" @@ -48,10 +49,22 @@ int Engine::init(void) systems.add<RenderSystem>(); systems.add<ScriptSystem>(entities, *(systems.system<WorldSystem>().get())); systems.add<PhysicsSystem>(); + systems.add<TextSystem>(); systems.configure(); // Load game script and entity data - systems.system<ScriptSystem>()->init(); + auto* script = systems.system<ScriptSystem>().get(); + script->addToGameNamespace("loadFont", + [this](std::string name, std::string file, int size) { + systems.system<TextSystem>().get()->loadFont(name, file, size); + }); + script->addToGameNamespace("puts", + [this](std::string name, float x, float y, std::string text) { + systems.system<TextSystem>().get()->put(name, x, y, text); + }); + script->init(); + + if (GameState::load("save.json", entities)) { std::cout << "Loaded from save.json. Delete the file if you don't want " "it." << std::endl; @@ -129,6 +142,7 @@ void Engine::renderLoop(void) { entityx::TimeDelta dt = 0; /**< Elapsed milliseconds since each loop */ while (shouldRun()) { + systems.update<TextSystem>(dt); systems.update<RenderSystem>(dt); } } |