aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Scripts/init.lua13
-rw-r--r--src/components/Script.hpp (renamed from src/components/IdleFunc.hpp)37
-rw-r--r--src/engine.cpp11
-rw-r--r--src/script.cpp47
4 files changed, 63 insertions, 45 deletions
diff --git a/Scripts/init.lua b/Scripts/init.lua
index 851c180..807ef9a 100644
--- a/Scripts/init.lua
+++ b/Scripts/init.lua
@@ -4,7 +4,7 @@ bird = {
y = 3.4
},
Name = "bord",
- init = function(self)
+ Init = function(self)
print(self.Position.x .. "," .. self.Position.y)
end
}
@@ -18,8 +18,11 @@ dog = {
texture = "assets/tex.png",
visible = true
},
- init = function(self)
+ Init = function(self)
print(self.Position.x .. "," .. self.Position.y)
+ end,
+ Idle = function(self)
+ self.Position.x = self.Position.x + 0.01;
end
}
@@ -31,12 +34,10 @@ animal = {
}
birdSpawn = game.spawn(bird);
-birdSpawn:init()
-print(birdSpawn.Name.value)
+birdSpawn:Init()
dogSpawn = game.spawn(dog);
-dogSpawn:init()
+dogSpawn:Init()
dogSpawn.Position.x = 37.5
animalSpawn = game.spawn(animal);
-animalSpawn.Render.texture = "assets/newText.png"
diff --git a/src/components/IdleFunc.hpp b/src/components/Script.hpp
index 29bcd7b..0e7c9db 100644
--- a/src/components/IdleFunc.hpp
+++ b/src/components/Script.hpp
@@ -16,24 +16,41 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
-#ifndef IDLEFUNC_HPP_
-#define IDLEFUNC_HPP_
+#ifndef SCRIPT_COMPONENT_HPP_
+#define SCRIPT_COMPONENT_HPP_
#include <components/Component.hpp>
-struct IdleFunc : Component<IdleFunc>, entityx::Component<IdleFunc>
+struct Scripted : Component<Scripted>, entityx::Component<Scripted>
{
- sol::function luafunc;
public:
- IdleFunc() {}
+ sol::table caller;
+ Scripted() {}
+ Scripted(sol::table call): caller(call) {}
- IdleFunc FromLua(sol::object ref)
+
+ ~Scripted()
+ {}
+
+ void cleanup()
{
- if (ref.get_type() == sol::type::function) {
- this->luafunc = ref;
- }
+ caller = sol::nil;
+ }
+
+ Scripted FromLua(sol::object)
+ {
+ //if (ref.get_type() == sol::type::function) {
+ // this->luafunc = ref;
+ //}
+ //init = true;
return *this;
}
+
+ void exec() {
+ if (caller["Idle"] == sol::type::function)
+ caller["Idle"](caller); // Call idle function and pass itself
+ // in or to fulfill the 'self' param
+ }
};
-#endif//IDLEFUNC_HPP_
+#endif//SCRIPT_COMPONENT_HPP_
diff --git a/src/engine.cpp b/src/engine.cpp
index 4803c64..317e116 100644
--- a/src/engine.cpp
+++ b/src/engine.cpp
@@ -25,6 +25,9 @@
#include "window.hpp"
#include "script.hpp"
+#include "components/Script.hpp"
+#include "components/Position.hpp"
+
int Engine::init(void)
{
systems.add<GameRunSystem>();
@@ -44,8 +47,16 @@ void Engine::logicLoop(void)
while (shouldRun()) {
systems.update<InputSystem>(dt);
+
+ // All entities with an idle function should be run here
+ entities.each<Scripted>([](entityx::Entity, Scripted &f){
+ f.exec();
+ });
std::this_thread::sleep_for(100ms);
}
+
+ // Remove all Lua references from entities
+ entities.each<Scripted>([](entityx::Entity, Scripted &f){ f.cleanup(); });
}
void Engine::renderLoop(void)
diff --git a/src/script.cpp b/src/script.cpp
index bb413fe..4dc3a2a 100644
--- a/src/script.cpp
+++ b/src/script.cpp
@@ -62,36 +62,23 @@ int ScriptSystem::init(void)
return 0;
}
-// TODO move all of these below once the test printouts are gone
-#include <components/Position.hpp>
-#include <components/Name.hpp>
-#include <components/Render.hpp>
-#include <components/IdleFunc.hpp>
-
void ScriptSystem::doFile(void)
{
+
auto result = lua.script_file("Scripts/init.lua");
+
if (!result.valid()) {
std::cout << "Lua error: " << std::endl;
}
-
- manager->each<Position>(
- [&](entityx::Entity, Position& p)
- {std::cout << p.x << "," << p.y << std::endl;});
-
- manager->each<Name>(
- [&](entityx::Entity, Name& n)
- {std::cout << n.name << std::endl;});
-
- manager->each<Render>(
- [&](entityx::Entity, Render& r)
- {std::cout << r.texture << ": " << r.visible << std::endl;});
}
/********************
* SCRIPT PARSING *
********************/
-// TODO here
+#include <components/Position.hpp>
+#include <components/Name.hpp>
+#include <components/Render.hpp>
+#include <components/Script.hpp>
void ScriptSystem::scriptExport()
{
@@ -119,29 +106,31 @@ void ScriptSystem::scriptExport()
sol::table ScriptSystem::spawn(sol::object param)
{
- sol::table toRet = lua.create_table_with();
-
+ sol::table* toRet;
if (param.get_type() == sol::type::table) {
sol::table tab = param;
entityx::Entity e = manager->create();
+ auto d = e.assign<Scripted>().get();
+ d->caller = lua.create_table();
+ toRet = &(d->caller);
+
+ *toRet = tab; // Copy table to our new entity to preserve functions
+ // this reduces the amount of work done in this function
+ // as well
if (tab["Position"] != nullptr) {
- toRet["Position"] =
+ (*toRet)["Position"] =
e.assign<Position>(Position().FromLua(tab["Position"])).get();
}
- if (tab["init"] != nullptr) {
- toRet["init"] = tab["init"];
- }
-
if (tab["Name"] != nullptr) {
- toRet["Name"] =
+ (*toRet)["Name"] =
e.assign<Name>(Name().FromLua(tab["Name"])).get();
}
if (tab["Render"] != nullptr) {
- toRet["Render"] =
+ (*toRet)["Render"] =
e.assign<Render>(Render().FromLua(tab["Render"])).get();
}
@@ -149,5 +138,5 @@ sol::table ScriptSystem::spawn(sol::object param)
std::cerr << "Parameter to spawn() must be a table!" << std::endl;
}
- return toRet;
+ return *toRet;
}