aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndy Belle-Isle <drumsetmonkey@gmail.com>2019-09-11 01:46:14 -0400
committerAndy Belle-Isle <drumsetmonkey@gmail.com>2019-09-11 01:46:14 -0400
commit8f0db67c5fdbc1e7b8759f44b45ad64caf336cb5 (patch)
tree0333263e39e51eab9fdb83fc1f6046159d91b0e4
parent1d9c67f5719b3c55b1f2f2537e796e2ad95e1ac1 (diff)
World system now has a pointer to the current world, and worlds created in Lua are returned to Lua as pointers
-rw-r--r--src/script.cpp2
-rw-r--r--src/world.cpp6
-rw-r--r--src/world.hpp7
3 files changed, 9 insertions, 6 deletions
diff --git a/src/script.cpp b/src/script.cpp
index e3aca3e..f52391f 100644
--- a/src/script.cpp
+++ b/src/script.cpp
@@ -90,7 +90,7 @@ void ScriptSystem::scriptExport(void)
std::function<sol::table(sol::table)> entitySpawn =
[this](sol::table t){ return spawn(t);};
- std::function<unsigned int(sol::object)> worldRegister =
+ std::function<World* (sol::object)> worldRegister =
[this](sol::object t){ return worldSystem.addWorld(t); };
lua.new_usertype<Position>("Position",
diff --git a/src/world.cpp b/src/world.cpp
index 8b71316..63769a9 100644
--- a/src/world.cpp
+++ b/src/world.cpp
@@ -38,10 +38,12 @@ World::World(sol::object ref)
* WORLD SYSTEM *
******************/
-unsigned int WorldSystem::addWorld(sol::object t)
+World* WorldSystem::addWorld(sol::object t)
{
worlds.push_back(World(t));
- return worlds.size()-1;
+ if (currentWorld == nullptr)
+ currentWorld = &(worlds.back());
+ return &(worlds.back());
}
void WorldSystem::configure([[maybe_unused]]entityx::EntityManager& entities,
diff --git a/src/world.hpp b/src/world.hpp
index 7c66e6b..4ceca94 100644
--- a/src/world.hpp
+++ b/src/world.hpp
@@ -52,13 +52,14 @@ class WorldSystem : public entityx::System<WorldSystem>
{
private:
std::vector<World> worlds;
- //World& currentWorld;
+ World* currentWorld;
public:
- WorldSystem(void) {}
+ WorldSystem(void):
+ currentWorld(nullptr) {}
~WorldSystem(void) {}
- unsigned int addWorld(sol::object);
+ World* addWorld(sol::object);
/**
* Prepares the system for running.