From 49edf2de852e08f6c32c6f5ef8da48412819f862 Mon Sep 17 00:00:00 2001 From: EmaMaker Date: Sun, 1 Oct 2023 11:00:00 +0200 Subject: [PATCH] move chunk update back to secondary thread --- src/chunkmanager.cpp | 11 ++++++++--- src/main.cpp | 2 +- 2 files changed, 9 insertions(+), 4 deletions(-) diff --git a/src/chunkmanager.cpp b/src/chunkmanager.cpp index fa93d84..a13fc35 100644 --- a/src/chunkmanager.cpp +++ b/src/chunkmanager.cpp @@ -68,7 +68,7 @@ namespace chunkmanager chunkmesher::getMeshDataQueue().push(new chunkmesher::MeshData()); should_run = true; - //update_thread = std::thread(update); + update_thread = std::thread(update); gen_thread = std::thread(generate); mesh_thread = std::thread(mesh); @@ -108,8 +108,10 @@ namespace chunkmanager int nUnloaded{0}; std::queue chunks_todelete; - void primary_thread_update(){ - int nExplored{0}, nMeshed{0}, nGenerated{0}; + void update(){ + while(should_run) { + + int nExplored{0}, nMeshed{0}, nGenerated{0}; int chunkX=static_cast(theCamera.getAtomicPosX() / CHUNK_SIZE); int chunkY=static_cast(theCamera.getAtomicPosY() / CHUNK_SIZE); int chunkZ=static_cast(theCamera.getAtomicPosZ() / CHUNK_SIZE); @@ -211,6 +213,7 @@ namespace chunkmanager debug::window::set_parameter("update_chunks_generated", nGenerated); debug::window::set_parameter("update_chunks_meshed", nMeshed); debug::window::set_parameter("update_chunks_explored", nExplored); + } } // uint32_t is fine, since i'm limiting the coordinate to only use up to ten bits (1023). There's actually two spare bits @@ -224,6 +227,8 @@ namespace chunkmanager should_run=false; std::cout << "waiting for secondary threads to finish\n"; + update_thread.join(); + std::cout << "update thread terminated\n"; gen_thread.join(); std::cout << "generation thread terminated\n"; mesh_thread.join(); diff --git a/src/main.cpp b/src/main.cpp index fd7ed51..42c0f33 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -103,7 +103,7 @@ int main() // Reset blockping timeout if 200ms have passed if(glfwGetTime() - lastBlockPick > 0.1) blockpick = false; - chunkmanager::primary_thread_update(); + //chunkmanager::primary_thread_update(); // Render pass renderer::render();