From 871a882833364cf3a2b1de13fc25f610ef5d7da5 Mon Sep 17 00:00:00 2001 From: Andy Belle-Isle Date: Sat, 31 Aug 2019 01:22:14 -0400 Subject: Added velocity component, and force add component dependencies when they don't exist --- src/components/Position.hpp | 2 +- src/components/Script.hpp | 8 ++------ src/components/Velocity.hpp | 47 +++++++++++++++++++++++++++++++++++++++++++++ src/script.cpp | 10 ++++++++++ 4 files changed, 60 insertions(+), 7 deletions(-) create mode 100644 src/components/Velocity.hpp (limited to 'src') diff --git a/src/components/Position.hpp b/src/components/Position.hpp index 0d69393..0462d1a 100644 --- a/src/components/Position.hpp +++ b/src/components/Position.hpp @@ -24,7 +24,7 @@ struct Position : Component, entityx::Component { public: - float x,y; + float x, y; Position(float _x, float _y): x(_x), y(_y) {} Position(void): x(0), y(0) {} diff --git a/src/components/Script.hpp b/src/components/Script.hpp index 0e7c9db..7570802 100644 --- a/src/components/Script.hpp +++ b/src/components/Script.hpp @@ -1,6 +1,6 @@ -/* +/** + * @file Script.hpp * Copyright (C) 2019 Belle-Isle, Andrew - * Author: Belle-Isle, Andrew * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -39,10 +39,6 @@ struct Scripted : Component, entityx::Component Scripted FromLua(sol::object) { - //if (ref.get_type() == sol::type::function) { - // this->luafunc = ref; - //} - //init = true; return *this; } diff --git a/src/components/Velocity.hpp b/src/components/Velocity.hpp new file mode 100644 index 0000000..eacadf2 --- /dev/null +++ b/src/components/Velocity.hpp @@ -0,0 +1,47 @@ +/** + * @file Velocity.hpp + * + * Copyright (C) 2019 Belle-Isle, Andrew + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +#ifndef VELOCITY_HPP_ +#define VELOCITY_HPP_ + +#include + +struct Velocity : Component, entityx::Component +{ + public: + float x, y; + Velocity(): x(0), y(0) {} + Velocity(float _x, float _y): x(_x), y(_y) {} + + Velocity FromLua(sol::object ref) + { + if (ref.get_type() == sol::type::table) { + sol::table tab = ref; + if (tab["x"] != nullptr) + this->x = tab["x"]; + if (tab["y"] != nullptr) + this->y = tab["y"]; + } else { + throw std::string("Velocity table not formatted properly"); + } + return *this; + } +}; + +#endif//VELOCITY_HPP_ diff --git a/src/script.cpp b/src/script.cpp index 4dc3a2a..1a6bda8 100644 --- a/src/script.cpp +++ b/src/script.cpp @@ -79,6 +79,7 @@ void ScriptSystem::doFile(void) #include #include #include +#include void ScriptSystem::scriptExport() { @@ -130,10 +131,19 @@ sol::table ScriptSystem::spawn(sol::object param) } if (tab["Render"] != nullptr) { + if (!e.has_component()) + e.assign(); (*toRet)["Render"] = e.assign(Render().FromLua(tab["Render"])).get(); } + if (tab["Velocity"] != nullptr) { + if (!e.has_component()) + e.assign(); + (*toRet)["Velocity"] = + e.assign(Velocity().FromLua(tab["Velocity"])).get(); + } + } else { std::cerr << "Parameter to spawn() must be a table!" << std::endl; } -- cgit v1.2.3