#include "app.hpp" #include "src/world.hpp" #include "loader/loader.hpp" #include "loader/scenery.hpp" #include "src/tile-atlas.hpp" #include "src/anim-atlas.hpp" #include namespace floormat { namespace Path = Corrade::Utility::Path; chunk& test_app::make_test_chunk(chunk_coords ch) { chunk& c = w[ch]; c.mark_modified(); auto metal1 = loader.tile_atlas("metal1", {2, 2}, pass_mode::pass), metal2 = loader.tile_atlas("metal2", {2, 2}, pass_mode::blocked), tiles = loader.tile_atlas("tiles", {8, 5}, pass_mode::pass); constexpr auto N = TILE_MAX_DIM; for (auto [x, k, pt] : c) x.ground() = { tiles, variant_t(k % tiles->num_tiles()) }; auto door = loader.scenery("door1"), table = loader.scenery("table1"), control_panel = loader.scenery("control panel (wall) 1"); control_panel.r = rotation::W; constexpr auto K = N/2; c[{K, K }].wall_north() = { metal1, 0 }; c[{K, K }].wall_west() = { metal2, 0 }; c[{K, K+1}].wall_north() = { metal1, 0 }; c[{K+1, K }].wall_west() = { metal2, 0 }; w.make_entity({ch, {3, 4}}, table); w.make_entity({ch, {K, K+1}}, control_panel); { auto& e = *w.make_entity({ch, {K+3, K+1}}, door); auto i = e.index(); e.activate(i); e.update(i, 1.f/60); fm_assert(e.active); fm_assert(e.frame != 0 && e.frame != e.atlas->info().nframes - 1); } return c; } static bool chunks_equal(const chunk& a, const chunk& b) { if (a.entities().size() != b.entities().size()) return false; for (auto i = 0_uz; i < TILE_COUNT; i++) { const auto &a1 = a[i], &b1 = b[i]; if (a1 != b1) return false; } for (auto i = 0_uz; i < a.entities().size(); i++) { auto &ae = *a.entities()[i], &be = *b.entities()[i]; if (entity_proto(ae) != entity_proto(be)) return false; } return true; } void test_app::test_serializer() { constexpr auto filename = "../test/test-serializer1.dat"; if (Path::exists(filename)) Path::remove(filename); const chunk_coords coord{1, 1}; auto& c = make_test_chunk(coord); w.serialize(filename); auto w2 = world::deserialize(filename); auto& c2 = w2[coord]; fm_assert(chunks_equal(c, c2)); } } // namespace floormat