From 670fafcd2afd7e7f947f5e2eaa2cae4636610ae9 Mon Sep 17 00:00:00 2001 From: Davide Faconti Date: Thu, 1 Aug 2024 14:32:51 +0200 Subject: [PATCH] fix const accessor --- bonxai_core/include/bonxai/bonxai.hpp | 17 ++++++++++------- examples/visitors.cpp | 3 +++ 2 files changed, 13 insertions(+), 7 deletions(-) diff --git a/bonxai_core/include/bonxai/bonxai.hpp b/bonxai_core/include/bonxai/bonxai.hpp index b507bfe..82a77ca 100644 --- a/bonxai_core/include/bonxai/bonxai.hpp +++ b/bonxai_core/include/bonxai/bonxai.hpp @@ -356,8 +356,8 @@ class VoxelGrid const VoxelGrid& grid_; mutable CoordT prev_root_coord_ = { std::numeric_limits::max(), 0, 0 }; mutable CoordT prev_inner_coord_ = { std::numeric_limits::max(), 0, 0 }; - mutable InnerGrid* prev_inner_ptr_ = nullptr; - mutable LeafGrid* prev_leaf_ptr_ = nullptr; + mutable const InnerGrid* prev_inner_ptr_ = nullptr; + mutable const LeafGrid* prev_leaf_ptr_ = nullptr; }; /** Class to be used to set and get values of a cell of the Grid. @@ -426,7 +426,7 @@ class VoxelGrid Accessor createAccessor() { return Accessor(*this); } - ConstAccessor createConstAccessor() { return Accessor(*this); } + ConstAccessor createConstAccessor() const { return ConstAccessor(*this); } [[nodiscard]] CoordT getRootKey(const CoordT& coord) const; @@ -716,7 +716,8 @@ inline DataT* VoxelGrid::Accessor::value(const CoordT& coord, } template -inline const DataT* VoxelGrid::ConstAccessor::value(const CoordT& coord) const { +inline const DataT* VoxelGrid::ConstAccessor::value(const CoordT& coord) const +{ const CoordT inner_key = grid_.getInnerKey(coord); if (inner_key != prev_inner_coord_) @@ -794,7 +795,9 @@ VoxelGrid::Accessor::getLeafGrid(const CoordT& coord, bool create_if_miss { return nullptr; } - it = mutable_grid_.root_map.insert({ root_key, InnerGrid(mutable_grid_.INNER_BITS) }).first; + it = mutable_grid_.root_map + .insert({ root_key, InnerGrid(mutable_grid_.INNER_BITS) }) + .first; } inner_ptr = &(it->second); // update the cache @@ -827,7 +830,7 @@ template inline const typename VoxelGrid::LeafGrid* VoxelGrid::ConstAccessor::getLeafGrid(const CoordT& coord) const { - InnerGrid* inner_ptr = prev_inner_ptr_; + const InnerGrid* inner_ptr = prev_inner_ptr_; const CoordT root_key = grid_.getRootKey(coord); if (root_key != prev_root_coord_ || !inner_ptr) @@ -844,7 +847,7 @@ VoxelGrid::ConstAccessor::getLeafGrid(const CoordT& coord) const } const uint32_t inner_index = grid_.getInnerIndex(coord); - auto& inner_data = inner_ptr->cell(inner_index); + const auto& inner_data = inner_ptr->cell(inner_index); if (!inner_ptr->mask().isOn(inner_index)) { diff --git a/examples/visitors.cpp b/examples/visitors.cpp index 44fa8dc..409228a 100644 --- a/examples/visitors.cpp +++ b/examples/visitors.cpp @@ -40,6 +40,9 @@ int main() const auto& gridConstRef = grid; gridConstRef.forEachCell(constVisitor); + auto const_accessor = gridConstRef.createConstAccessor(); + std::cout << "value at origing: "<< *(const_accessor.value({0, 0, 0})) << "\n"; + std::cout << "DONE\n"; return 0; }