aboutsummaryrefslogtreecommitdiff
path: root/src/crepe/ScriptSystem.cpp
diff options
context:
space:
mode:
authorjaroWMR <jarorutjes07@gmail.com>2024-10-23 12:32:06 +0200
committerjaroWMR <jarorutjes07@gmail.com>2024-10-23 12:32:06 +0200
commit96da34c1f973525ee57b71ea031d11a966903150 (patch)
treef02d9e743ae852715397bd406b54f5de5fa5d29f /src/crepe/ScriptSystem.cpp
parentcead795b7ff7135e13caf9ad3b76628070391458 (diff)
parent30d84ef9ad4a0010288db18294766fd4d5ed6f4a (diff)
merged with master
Diffstat (limited to 'src/crepe/ScriptSystem.cpp')
-rw-r--r--src/crepe/ScriptSystem.cpp34
1 files changed, 32 insertions, 2 deletions
diff --git a/src/crepe/ScriptSystem.cpp b/src/crepe/ScriptSystem.cpp
index 988bb71..5d882be 100644
--- a/src/crepe/ScriptSystem.cpp
+++ b/src/crepe/ScriptSystem.cpp
@@ -1,8 +1,16 @@
-#include "util/log.h"
+#include <forward_list>
+#include <functional>
+#include <vector>
+#include "ComponentManager.h"
#include "ScriptSystem.h"
+#include "api/BehaviorScript.h"
+#include "api/Script.h"
+#include "util/log.h"
+using namespace std;
using namespace crepe;
+using namespace crepe::api;
ScriptSystem::ScriptSystem() { dbg_trace(); }
ScriptSystem::~ScriptSystem() { dbg_trace(); }
@@ -12,4 +20,26 @@ ScriptSystem & ScriptSystem::get_instance() {
return instance;
}
-void ScriptSystem::update() { dbg_trace(); }
+void ScriptSystem::update() {
+ using namespace std;
+ dbg_trace();
+
+ forward_list<Script *> scripts = this->get_scripts();
+ for (Script * script : scripts) script->update();
+}
+
+forward_list<Script *> ScriptSystem::get_scripts() {
+ forward_list<Script *> scripts = {};
+ ComponentManager & mgr = ComponentManager::get_instance();
+ vector<reference_wrapper<BehaviorScript>> behavior_scripts
+ = mgr.get_components_by_type<BehaviorScript>();
+
+ for (auto behavior_script_ref : behavior_scripts) {
+ BehaviorScript & behavior_script = behavior_script_ref.get();
+ Script * script = behavior_script.script.get();
+ if (script == nullptr) continue;
+ scripts.push_front(script);
+ }
+
+ return scripts;
+}