mirror of
https://github.com/veden/Rampant.git
synced 2025-01-16 02:33:53 +02:00
58 lines
1.8 KiB
Lua
Executable File
58 lines
1.8 KiB
Lua
Executable File
local mapProcessor = {}
|
|
|
|
-- imports
|
|
|
|
local mapUtils = require("MapUtils")
|
|
|
|
-- imported functions
|
|
|
|
local getCardinalChunks = mapUtils.getCardinalChunks
|
|
|
|
local mRandom = math.random
|
|
|
|
-- premade tables
|
|
|
|
local processors = {}
|
|
local processorsProbabilityLow = {}
|
|
local processorsProbabilityHigh = {}
|
|
|
|
-- module code
|
|
|
|
-- processing is not consistant as it depends on the number of chunks that have been generated
|
|
-- so 200 chunks is processed 3 times a second and 1200 chunks is processed once a second
|
|
-- In theory, this might be fine as smaller bases have less surface to attack and need to have
|
|
-- pheromone dissipate at a faster rate.
|
|
function mapProcessor.processMap(regionMap, surface, natives, evolution_factor)
|
|
local count = 0
|
|
|
|
if (regionMap.pP == 1) then
|
|
regionMap.pR = mRandom()
|
|
end
|
|
|
|
local roll = regionMap.pR
|
|
|
|
local chunkQueue = regionMap.pQ[regionMap.pP]
|
|
for x=1, #chunkQueue do
|
|
local chunk = chunkQueue[x]
|
|
local cardinalArray = getCardinalChunks(regionMap, chunk.cX, chunk.cY)
|
|
for i=1, #processors do
|
|
if (processorsProbabilityLow[i] <= roll) and (roll <= processorsProbabilityHigh[i]) then
|
|
processors[i](regionMap, surface, natives, chunk, cardinalArray, evolution_factor)
|
|
end
|
|
end
|
|
end
|
|
|
|
regionMap.pP = regionMap.pP + 1
|
|
if (regionMap.pP > regionMap.pI) then
|
|
regionMap.pP = 1
|
|
end
|
|
end
|
|
|
|
|
|
function mapProcessor.install(processor, useProbabilityLow, useProbabilityHigh)
|
|
processors[#processors+1] = processor
|
|
processorsProbabilityLow[#processorsProbabilityLow+1] = useProbabilityLow
|
|
processorsProbabilityHigh[#processorsProbabilityHigh+1] = useProbabilityHigh
|
|
end
|
|
|
|
return mapProcessor |