From 37215facfcecb3a4133a740d7fda57c0ef564395 Mon Sep 17 00:00:00 2001 From: Stanislaw Halik Date: Tue, 28 May 2024 03:44:47 +0200 Subject: w --- editor/vobj-editor.cpp | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) (limited to 'editor/vobj-editor.cpp') diff --git a/editor/vobj-editor.cpp b/editor/vobj-editor.cpp index e82c6d27..9eb36e39 100644 --- a/editor/vobj-editor.cpp +++ b/editor/vobj-editor.cpp @@ -1,6 +1,7 @@ #include "vobj-editor.hpp" #include "src/world.hpp" #include "src/light.hpp" +#include "src/hole.hpp" #include "loader/loader.hpp" #include "loader/vobj-cell.hpp" #include "app.hpp" @@ -74,6 +75,8 @@ start: while (auto id = a.get_object_colliding_with_cursor()) #pragma clang diagnostic ignored "-Wweak-vtables" #endif +namespace { + struct light_factory final : vobj_factory { object_type type() const override; @@ -98,6 +101,32 @@ std::shared_ptr light_factory::make(world& w, object_id id, global_coord return ret; } +struct hole_factory final : vobj_factory +{ + object_type type() const override; + const vobj_cell& info() const override; + std::shared_ptr make(world& w, object_id id, global_coords pos) const override; +}; + +object_type hole_factory::type() const { return object_type::hole; } + +const vobj_cell& hole_factory::info() const +{ + constexpr auto NAME = "hole"_s; + static const vobj_cell& ret = loader.vobj(NAME); + fm_debug_assert(ret.name == NAME); + fm_debug_assert(ret.atlas != nullptr); + return ret; +} + +std::shared_ptr hole_factory::make(world& w, object_id id, global_coords pos) const +{ + auto ret = w.make_object(id, pos, hole_proto{}); + return ret; +} + +} // namespace + auto vobj_editor::make_vobj_type_map() -> std::map { constexpr auto add = [](auto& m, std::unique_ptr&& x) { @@ -106,6 +135,7 @@ auto vobj_editor::make_vobj_type_map() -> std::map }; std::map map; add(map, std::make_unique()); + add(map, std::make_unique()); return map; } -- cgit v1.2.3