summary refs log tree commit diff
path: root/src/World/World.cpp
diff options
context:
space:
mode:
authorMel <einebeere@gmail.com>2024-02-02 16:16:25 +0100
committerMel <einebeere@gmail.com>2024-02-02 16:16:25 +0100
commita4a61ac2e6389af0968ac4fb305b82c6eb90bf0e (patch)
tree800749ed6a5d503837a6bf0c389c133fcb59143d /src/World/World.cpp
parent250e37c742f3ad46f093f4534098cdf8f68a29a9 (diff)
downloadmeowcraft-a4a61ac2e6389af0968ac4fb305b82c6eb90bf0e.tar.zst
meowcraft-a4a61ac2e6389af0968ac4fb305b82c6eb90bf0e.zip
Placing blocks
Diffstat (limited to 'src/World/World.cpp')
-rw-r--r--src/World/World.cpp11
1 files changed, 7 insertions, 4 deletions
diff --git a/src/World/World.cpp b/src/World/World.cpp
index cc5d91f..2b5848b 100644
--- a/src/World/World.cpp
+++ b/src/World/World.cpp
@@ -47,17 +47,20 @@ Chunk::BlockData World::block_at(Position::BlockWorld pos) {
     return {};
 }
 
-void World::break_block(Position::BlockWorld pos) {
+void World::set_block(Position::BlockWorld pos, BlockType type) {
     auto& chunk_data = m_registry.find(pos);
     if (!chunk_data.chunk.has_value()) return;
 
     auto& block_data = chunk_data.chunk->at(pos.to_local());
-    if (!block_data.type.is_solid()) return;
-
-    block_data.type = {};
+    block_data.type = type;
     chunk_data.damage();
 }
 
+void World::break_block(Position::BlockWorld pos) {
+    if (!block_at(pos).type.is_solid()) return;
+    set_block(pos, BlockType::Air);
+}
+
 std::vector<ChunkIndex> World::get_visible_chunk_indices(const Position::World position) const {
     ChunkIndex center = ChunkIndex::from_position(position.round_to_block());