1
0
mirror of https://github.com/veden/Rampant.git synced 2025-01-14 02:23:01 +02:00

FACTO-248: Fixed pheromone process inner and outer chunks

This commit is contained in:
Aaron Veden 2023-03-11 11:10:15 -08:00
parent 4d17d4e1f0
commit 749f6cbb90
No known key found for this signature in database
GPG Key ID: FF5990B1C6DD3F84
2 changed files with 33 additions and 65 deletions

View File

@ -119,77 +119,39 @@ local next = next
pheromone dissipate at a faster rate.
--]]
function mapProcessor.processMap(map, tick)
local outgoingWave = map.outgoingScanWave
local processQueue = map.processQueue
local processQueueLength = #processQueue
local index = mMin(map.processIndex, processQueueLength)
local step
local endIndex
if outgoingWave then
step = 1
endIndex = mMin(index + PROCESS_QUEUE_SIZE, processQueueLength)
else
step = -1
endIndex = mMax(index - PROCESS_QUEUE_SIZE, 1)
end
if (processQueueLength == 0) then
return
end
for x=index,endIndex,step do
local chunk = processQueue[x]
if chunk[CHUNK_TICK] ~= tick then
chunk[CHUNK_TICK] = tick
processPheromone(map, chunk)
end
end
local startIndex = mMin(map.processIndex, processQueueLength)
local step
local endIndex
if map.outgoingScanWave then
step = 1
endIndex = mMin(startIndex + PROCESS_QUEUE_SIZE, processQueueLength)
if (endIndex == processQueueLength) then
map.outgoingScanWave = false
elseif (endIndex == 1) then
map.outgoingScanWave = true
elseif outgoingWave then
map.processIndex = processQueueLength
else
map.processIndex = endIndex + 1
end
else
step = -1
endIndex = mMax(startIndex - PROCESS_QUEUE_SIZE, 1)
if (endIndex == 1) then
map.outgoingScanWave = true
map.processIndex = 1
else
map.processIndex = endIndex - 1
end
map.universe.processedChunks = map.universe.processedChunks + PROCESS_QUEUE_SIZE
end
map.universe.processedChunks = map.universe.processedChunks + ((startIndex - endIndex) * step)
function mapProcessor.processStaticMap(map)
local outgoingWave = map.outgoingStaticScanWave
local processQueue = map.processQueue
local processQueueLength = #processQueue
local index = mMin(map.processStaticIndex, processQueueLength)
local step
local endIndex
if outgoingWave then
step = 1
endIndex = mMin(index + PROCESS_STATIC_QUEUE_SIZE, processQueueLength)
else
step = -1
endIndex = mMax(index - PROCESS_STATIC_QUEUE_SIZE, 1)
end
if (processQueueLength == 0) then
return
end
for x=index,endIndex,step do
processStaticPheromone(map, processQueue[x])
end
if (endIndex == processQueueLength) then
map.outgoingStaticScanWave = false
elseif (endIndex == 1) then
map.outgoingStaticScanWave = true
elseif outgoingWave then
map.processStaticIndex = endIndex + 1
else
map.processStaticIndex = endIndex - 1
for x=startIndex,endIndex,step do
processPheromone(map, processQueue[x], tick)
end
end
@ -258,9 +220,8 @@ function mapProcessor.processPlayers(players, universe, tick)
for y=playerChunk.y - PROCESS_PLAYER_BOUND, playerChunk.y + PROCESS_PLAYER_BOUND, 32 do
local chunk = getChunkByXY(map, x, y)
if (chunk ~= -1) and (chunk[CHUNK_TICK] ~= tick) then
chunk[CHUNK_TICK] = tick
processPheromone(map, chunk, true)
if (chunk ~= -1) then
processPheromone(map, chunk, tick, true)
if (getNestCount(map, chunk) > 0) then
processNestActiveness(map, chunk)

View File

@ -27,6 +27,8 @@ local chunkPropertyUtils = require("ChunkPropertyUtils")
-- constants
local CHUNK_TICK = constants.CHUNK_TICK
local ENEMY_PHEROMONE_MULTIPLER = constants.ENEMY_PHEROMONE_MULTIPLER
local VICTORY_SCENT_MULTIPLER = constants.VICTORY_SCENT_MULTIPLER
local VICTORY_SCENT_BOUND = constants.VICTORY_SCENT_BOUND
@ -128,7 +130,12 @@ function pheromoneUtils.deathScent(map, chunk, structure)
addPermanentDeathGenerator(map, chunk, amount)
end
function pheromoneUtils.processPheromone(map, chunk, player)
function pheromoneUtils.processPheromone(map, chunk, tick, player)
if chunk[CHUNK_TICK] > tick then
return
end
chunk[CHUNK_TICK] = tick
local chunkPlayer = chunk[PLAYER_PHEROMONE]
local chunkBase = -MAGIC_MAXIMUM_NUMBER
local chunkDeath = getCombinedDeathGenerator(map, chunk)