From 15e8cebc19bfb484ba46a3589378d52ca769769e Mon Sep 17 00:00:00 2001 From: Stanislaw Halik Date: Fri, 7 Oct 2022 16:45:28 +0200 Subject: a --- src/chunk.hpp | 10 ---------- src/floor-mesh.cpp | 12 ++++++------ src/local-coords.hpp | 14 +++++++------- src/wall-mesh.cpp | 4 ++-- 4 files changed, 15 insertions(+), 25 deletions(-) (limited to 'src') diff --git a/src/chunk.hpp b/src/chunk.hpp index a22dc025..debb5983 100644 --- a/src/chunk.hpp +++ b/src/chunk.hpp @@ -22,16 +22,6 @@ struct chunk final const auto& tiles() const { return _tiles; } auto& tiles() { return _tiles; } - template F> - constexpr inline void foreach_tile(F&& fun) { - foreach_tile_(std::forward(fun)); - } - - template F> - constexpr inline void foreach_const_tile(F&& fun) const { - const_cast(this)->foreach_tile_(std::forward(fun)); - } - using iterator = basic_tile_iterator; using const_iterator = basic_tile_iterator; diff --git a/src/floor-mesh.cpp b/src/floor-mesh.cpp index ce0a3d19..fdace9d8 100644 --- a/src/floor-mesh.cpp +++ b/src/floor-mesh.cpp @@ -33,16 +33,16 @@ void floor_mesh::set_tile(quad_data& data, tile& x) void floor_mesh::draw(tile_shader& shader, chunk& c) { std::array data; - c.foreach_tile([&](tile& x, std::size_t idx, local_coords) { - set_tile(data[idx], x); - }); + for (auto [x, idx, pt] : c) { + set_tile(data[idx], x); + } _vertex_buffer.setSubData(0, data); Magnum::GL::MeshView mesh{_mesh}; mesh.setCount(quad_index_count); const tile_atlas* last_tile_atlas = nullptr; - c.foreach_tile([&](tile& x, std::size_t i, local_coords) { + for (auto [x, i, pt] : c) { if (!x.ground_image) - return; + continue; mesh.setIndexRange((int)(i*quad_index_count), 0, quad_index_count*TILE_COUNT - 1); if (auto* atlas = x.ground_image.atlas.get(); atlas != last_tile_atlas) { @@ -50,7 +50,7 @@ void floor_mesh::draw(tile_shader& shader, chunk& c) last_tile_atlas = atlas; } shader.draw(mesh); - }); + } } std::array, TILE_COUNT> floor_mesh::make_index_array() diff --git a/src/local-coords.hpp b/src/local-coords.hpp index d2520a42..b63f3db8 100644 --- a/src/local-coords.hpp +++ b/src/local-coords.hpp @@ -9,21 +9,21 @@ namespace Magnum::Examples { struct local_coords final { std::uint8_t x = 0, y = 0; - explicit constexpr local_coords(std::size_t idx); - constexpr local_coords() = default; - constexpr local_coords(std::size_t x, std::size_t y); - constexpr local_coords(std::uint8_t x, std::uint8_t y) : x{x}, y{y} {} - constexpr std::size_t to_index() const { return y*TILE_MAX_DIM + x; } + explicit constexpr local_coords(std::size_t idx) noexcept; // NOLINT(bugprone-exception-escape) + constexpr local_coords() noexcept = default; + constexpr local_coords(std::size_t x, std::size_t y) noexcept; // NOLINT(bugprone-exception-escape) + constexpr local_coords(std::uint8_t x, std::uint8_t y) noexcept : x{x}, y{y} {} + constexpr std::size_t to_index() const noexcept { return y*TILE_MAX_DIM + x; } }; -constexpr local_coords::local_coords(std::size_t index) : +constexpr local_coords::local_coords(std::size_t index) noexcept : // NOLINT(bugprone-exception-escape) x{(std::uint8_t)(index % TILE_MAX_DIM)}, y{(std::uint8_t)(index / TILE_MAX_DIM)} { ASSERT(index < TILE_COUNT); } -constexpr local_coords::local_coords(std::size_t x, std::size_t y) +constexpr local_coords::local_coords(std::size_t x, std::size_t y) noexcept // NOLINT(bugprone-exception-escape) : x{(std::uint8_t)x}, y{(std::uint8_t)y} { ASSERT(x <= 0xff && y <= 0xff); diff --git a/src/wall-mesh.cpp b/src/wall-mesh.cpp index 68d8733e..dce86dc1 100644 --- a/src/wall-mesh.cpp +++ b/src/wall-mesh.cpp @@ -42,9 +42,9 @@ void wall_mesh::draw(tile_shader& shader, chunk& c) texture_array textures = {}; { vertex_array data; - c.foreach_tile([&](tile& x, std::size_t idx, local_coords) { + for (auto [x, idx, pt] : c) { maybe_add_tile(data, textures, x, idx); - }); + } _vertex_buffer.setSubData(0, data); } -- cgit v1.2.3