extends Node var world = null var Chunk = preload("res://world/chunk/Chunk.tscn") var chunks = {} var loaded_chunks = {} var chunk_thread = Thread.new() var mtx = Mutex.new() var sgnl = Semaphore.new() var exit = false var chunk_to_load = null func _ready(): chunk_thread.start(self, "chunk_loader") func _exit_tree(): mtx.lock() exit = true sgnl.post() mtx.unlock() chunk_thread.wait_to_finish() func add_chunk(coords:Vector2): chunks[coords] = coords.length() func free_chunk(coords:Vector2): if !loaded_chunks.has(coords): return var c = loaded_chunks[coords].get_ref() if c != null: c.queue_free() loaded_chunks.erase(coords) func chunk_update(): var closest_unloaded_chunk = null var closest_len = 0.0 for chunk in chunks.keys(): if !loaded_chunks.has(chunk): if closest_unloaded_chunk == null || closest_len > chunks[chunk]: closest_unloaded_chunk = chunk closest_len = chunks[chunk] if closest_unloaded_chunk != null: mtx.lock() if chunk_to_load == null: chunk_to_load = closest_unloaded_chunk sgnl.post() mtx.unlock() for chunk in loaded_chunks.keys(): if !chunks.has(chunk): free_chunk(chunk) chunks = {} func chunk_loader(): while true: sgnl.wait() mtx.lock() var x = exit var coords = chunk_to_load chunk_to_load = null mtx.unlock() if x: break var chunk = Chunk.instance() chunk.transform.origin = Vector3(coords.x,0.0,coords.y) ChunkGen.gen_chunk(chunk) self.call_deferred("finish_chunk", chunk) func finish_chunk(chunk): world.get_node("Chunks").add_child(chunk) loaded_chunks[Vector2(chunk.transform.origin.x,chunk.transform.origin.z)] = weakref(chunk)