From 5e8e31b7ee5cf91202a50b15b99031768fe7270c Mon Sep 17 00:00:00 2001 From: Rodrigo Delduca Date: Tue, 31 Dec 2024 12:39:57 -0300 Subject: [PATCH] Work in progress --- src/eventmanager.cpp | 4 +- src/scriptengine.cpp | 105 ++++++++++++++++++++++++++++--------------- 2 files changed, 70 insertions(+), 39 deletions(-) diff --git a/src/eventmanager.cpp b/src/eventmanager.cpp index 2517864..9e163fc 100644 --- a/src/eventmanager.cpp +++ b/src/eventmanager.cpp @@ -98,11 +98,11 @@ void eventmanager::update(float_t delta) { switch (axis) { case SDL_CONTROLLER_AXIS_LEFTY: - process(SDLK_w, SDLK_s); + process(SDLK_UP, SDLK_DOWN); break; case SDL_CONTROLLER_AXIS_LEFTX: - process(SDLK_a, SDLK_d); + process(SDLK_LEFT, SDLK_RIGHT); break; default: diff --git a/src/scriptengine.cpp b/src/scriptengine.cpp index 15f8851..2cde2d3 100644 --- a/src/scriptengine.cpp +++ b/src/scriptengine.cpp @@ -251,34 +251,34 @@ void framework::scriptengine::run() { "subscribe", [](memory::kv &self, const std::string &key, const sol::function &callback, sol::this_state state) { self.subscribe(key, callback, state); } ); - lua.new_usertype( + lua.new_usertype( "Entity", - "id", sol::property(&entity::id), - "x", sol::property(&entity::x), - "y", sol::property(&entity::y), - "visible", sol::property(&entity::visible), - "size", sol::property(&entity::size), - "move", &entity::move, - "on_update", &entity::set_onupdate, - "on_animationfinished", &entity::set_onanimationfinished, - "on_mail", &entity::set_onmail, - "on_collision", &entity::set_oncollision, - "reflection", sol::property([](entity &e) -> reflectionproxy { return reflectionproxy{e}; }), - "action", sol::property([](entity &e) -> actionproxy { return actionproxy{e}; }), - "placement", sol::property([](entity &e) -> placementproxy { return placementproxy{e}; }), - "velocity", sol::property([](entity &e) -> velocityproxy { return velocityproxy{e}; }), - "kv", sol::property([](entity &e) -> memory::kv & { return e.kv(); }) - ); - - lua.new_usertype( + "id", sol::property(&framework::entity::id), + "x", sol::property(&framework::entity::x), + "y", sol::property(&framework::entity::y), + "visible", sol::property(&framework::entity::visible), + "size", sol::property(&framework::entity::size), + "move", &framework::entity::move, + "on_update", &framework::entity::set_onupdate, + "on_animationfinished", &framework::entity::set_onanimationfinished, + "on_mail", &framework::entity::set_onmail, + "on_collision", &framework::entity::set_oncollision, + "reflection", sol::property([](framework::entity &e) -> reflectionproxy { return reflectionproxy{e}; }), + "action", sol::property([](framework::entity &e) -> actionproxy { return actionproxy{e}; }), + "placement", sol::property([](framework::entity &e) -> placementproxy { return placementproxy{e}; }), + "velocity", sol::property([](framework::entity &e) -> velocityproxy { return velocityproxy{e}; }), + "kv", sol::property([](framework::entity &e) -> memory::kv & { return e.kv(); }) + ); + + lua.new_usertype( "EntityManager", - "spawn", &entitymanager::spawn, - "destroy", &entitymanager::destroy + "spawn", &framework::entitymanager::spawn, + "destroy", &framework::entitymanager::destroy ); - lua.new_usertype( + lua.new_usertype( "ResourceManager", - "flush", &resourcemanager::flush, + "flush", &framework::resourcemanager::flush, "prefetch", [](std::shared_ptr manager, sol::table table) { std::vector filenames(table.size()); std::ranges::transform( @@ -292,8 +292,39 @@ void framework::scriptengine::run() { } ); + struct playerproxy { + framework::statemanager &e; + + int8_t at(int8_t val) noexcept { + return val; + } + }; + + struct playereventproxy { + framework::statemanager &e; + uint8_t index; + + void event() noexcept { + std::cout << "Event called for index: " << static_cast(index) << std::endl; + } + }; + + lua.new_usertype( + "PlayerEventProxy", + "event", &playereventproxy::event + ); + + lua.new_usertype( + "PlayerProxy", + sol::meta_function::index, [](playerproxy &proxy, uint8_t index) -> playereventproxy { + // return proxy.at(static_cast(index)); + return playereventproxy{proxy.e, index}; + } + ); + lua.new_usertype( "StateManager", + "player", sol::property([](framework::statemanager &e) -> playerproxy { return playerproxy{e}; }), "is_keydown", &framework::statemanager::is_keydown ); @@ -365,22 +396,22 @@ void framework::scriptengine::run() { sol::constructors(), "connect", &network::socket::connect, "emit", [](network::socket &sio, const std::string &event, sol::table data, sol::this_state state) { - sol::state_view lua(state); - const auto j = _to_json(data); - sio.emit(event, j.dump()); }, + sol::state_view lua(state); + const auto j = _to_json(data); + sio.emit(event, j.dump()); }, "on", [](network::socket &sio, const std::string &event, sol::function callback, sol::this_state state) { - sol::state_view lua(state); - sio.on(event, [callback, lua](const std::string &data) { - const auto j = nlohmann::json::parse(data); - callback(_to_lua(j, lua)); - }); }, + sol::state_view lua(state); + sio.on(event, [callback, lua](const std::string &data) { + const auto j = nlohmann::json::parse(data); + callback(_to_lua(j, lua)); + }); }, "rpc", [](network::socket &sio, const std::string &method, sol::table arguments, sol::function callback, sol::this_state state) { - sol::state_view lua(state); - const auto args_json = _to_json(arguments); - sio.rpc(method, args_json.dump(), [callback, lua](const std::string &response) { - const auto j = nlohmann::json::parse(response); - callback(_to_lua(j, lua)); - }); } + sol::state_view lua(state); + const auto args_json = _to_json(arguments); + sio.rpc(method, args_json.dump(), [callback, lua](const std::string &response) { + const auto j = nlohmann::json::parse(response); + callback(_to_lua(j, lua)); + }); } ); lua.new_usertype(