diff options
| author | untodesu <kirill@untode.su> | 2025-03-15 16:22:09 +0500 |
|---|---|---|
| committer | untodesu <kirill@untode.su> | 2025-03-15 16:22:09 +0500 |
| commit | 3bf42c6ff3805a0d42bbc661794a95ff31bedc26 (patch) | |
| tree | 05049955847504808d6bed2bb7b155f8b03807bb /game/shared/chunk.cc | |
| parent | 02294547dcde0d4ad76e229106702261e9f10a51 (diff) | |
| download | voxelius-3bf42c6ff3805a0d42bbc661794a95ff31bedc26.tar.bz2 voxelius-3bf42c6ff3805a0d42bbc661794a95ff31bedc26.zip | |
Add whatever I was working on for the last month
Diffstat (limited to 'game/shared/chunk.cc')
| -rw-r--r-- | game/shared/chunk.cc | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/game/shared/chunk.cc b/game/shared/chunk.cc new file mode 100644 index 0000000..c996973 --- /dev/null +++ b/game/shared/chunk.cc @@ -0,0 +1,55 @@ +#include "shared/pch.hh" +#include "shared/chunk.hh" + +#include "shared/coord.hh" + +Chunk::Chunk(entt::entity entity, Dimension *dimension) +{ + m_entity = entity; + m_dimension = dimension; + m_voxels.fill(NULL_VOXEL_ID); +} + +voxel_id Chunk::get_voxel(const local_pos &lpos) const +{ + return get_voxel(coord::to_index(lpos)); +} + +voxel_id Chunk::get_voxel(const std::size_t index) const +{ + if(index >= CHUNK_VOLUME) + return NULL_VOXEL_ID; + return m_voxels[index]; +} + +void Chunk::set_voxel(voxel_id voxel, const local_pos &lpos) +{ + set_voxel(voxel, coord::to_index(lpos)); +} + +void Chunk::set_voxel(voxel_id voxel, const std::size_t index) +{ + if(index >= CHUNK_VOLUME) + return; + m_voxels[index] = voxel; +} + +const VoxelStorage &Chunk::get_voxels(void) const +{ + return m_voxels; +} + +void Chunk::set_voxels(const VoxelStorage &voxels) +{ + m_voxels = voxels; +} + +entt::entity Chunk::get_entity(void) const +{ + return m_entity; +} + +Dimension *Chunk::get_dimension(void) const +{ + return m_dimension; +} |
