1
0
mirror of https://github.com/veden/Rampant.git synced 2025-01-16 02:33:53 +02:00
Rampant/libs/ChunkProcessor.lua
2017-06-01 18:59:32 -07:00

63 lines
1.6 KiB
Lua

local chunkProcessor = {}
-- imports
local chunkUtils = require("ChunkUtils")
local constants = require("Constants")
-- constants
local CHUNK_SIZE = constants.CHUNK_SIZE
-- imported functions
local createChunk = chunkUtils.createChunk
local checkChunkPassability = chunkUtils.checkChunkPassability
local scoreChunk = chunkUtils.scoreChunk
-- module code
function chunkProcessor.processPendingChunks(natives, regionMap, surface, pendingStack, tick)
local processQueue = regionMap.processQueue
local offset = {0, 0}
local areaBoundingBox = {false, offset}
local query = {area=areaBoundingBox,
force=false}
local count = 0
local start = #pendingStack
for i=start, 1, -1 do
local event = pendingStack[i]
count = count + 1
pendingStack[i] = nil
local x = event.area.left_top.x
local y = event.area.left_top.y
local chunk = createChunk(x, y)
areaBoundingBox[1] = chunk
offset[1] = x + CHUNK_SIZE
offset[2] = y + CHUNK_SIZE
local chunkX = chunk.cX
if regionMap[chunkX] == nil then
regionMap[chunkX] = {}
end
regionMap[chunkX][chunk.cY] = chunk
checkChunkPassability(chunk, surface)
scoreChunk(regionMap, chunk, surface, natives, tick, query)
processQueue[#processQueue+1] = chunk
if (count >= 3500) then
break
end
end
if (count >= 3500) and (start > 0) then
surface.print("Rampant - " .. (start - count) .. " Remaining chunks to process")
end
end
return chunkProcessor