1
0
mirror of https://github.com/veden/Rampant.git synced 2025-01-03 22:52:20 +02:00
Rampant/libs/ChunkUtils.lua

701 lines
27 KiB
Lua
Raw Normal View History

2019-02-16 06:17:30 +02:00
if chunkUtilsG then
2020-04-28 05:41:18 +02:00
return chunkUtilsG
2019-02-16 06:17:30 +02:00
end
local chunkUtils = {}
-- imports
local baseUtils = require("BaseUtils")
local constants = require("Constants")
2017-11-21 09:27:03 +02:00
local mapUtils = require("MapUtils")
local chunkPropertyUtils = require("ChunkPropertyUtils")
local mathUtils = require("MathUtils")
2017-11-21 09:27:03 +02:00
-- constants
2017-05-12 06:50:06 +02:00
2019-11-30 02:49:22 +02:00
local HIVE_BUILDINGS_TYPES = constants.HIVE_BUILDINGS_TYPES
2017-11-21 09:27:03 +02:00
local DEFINES_WIRE_TYPE_RED = defines.wire_type.red
local DEFINES_WIRE_TYPE_GREEN = defines.wire_type.green
2017-06-08 02:57:24 +02:00
2019-03-09 02:42:20 +02:00
local CHUNK_PASS_THRESHOLD = constants.CHUNK_PASS_THRESHOLD
2019-02-11 08:14:17 +02:00
local AI_STATE_ONSLAUGHT = constants.AI_STATE_ONSLAUGHT
2016-10-15 02:00:18 +02:00
local BASE_PHEROMONE = constants.BASE_PHEROMONE
local PLAYER_PHEROMONE = constants.PLAYER_PHEROMONE
2017-06-08 02:57:24 +02:00
local RESOURCE_PHEROMONE = constants.RESOURCE_PHEROMONE
local BUILDING_PHEROMONES = constants.BUILDING_PHEROMONES
local CHUNK_SIZE = constants.CHUNK_SIZE
local CHUNK_SIZE_DIVIDER = constants.CHUNK_SIZE_DIVIDER
2017-06-10 10:38:20 +02:00
local CHUNK_NORTH_SOUTH = constants.CHUNK_NORTH_SOUTH
local CHUNK_EAST_WEST = constants.CHUNK_EAST_WEST
2017-06-10 10:38:20 +02:00
local CHUNK_ALL_DIRECTIONS = constants.CHUNK_ALL_DIRECTIONS
local CHUNK_IMPASSABLE = constants.CHUNK_IMPASSABLE
local RESOURCE_NORMALIZER = constants.RESOURCE_NORMALIZER
2016-10-15 02:00:18 +02:00
local CHUNK_TICK = constants.CHUNK_TICK
2019-10-19 21:13:48 +02:00
local GENERATOR_PHEROMONE_LEVEL_1 = constants.GENERATOR_PHEROMONE_LEVEL_1
local GENERATOR_PHEROMONE_LEVEL_3 = constants.GENERATOR_PHEROMONE_LEVEL_3
local GENERATOR_PHEROMONE_LEVEL_5 = constants.GENERATOR_PHEROMONE_LEVEL_5
local GENERATOR_PHEROMONE_LEVEL_6 = constants.GENERATOR_PHEROMONE_LEVEL_6
2017-05-12 06:50:06 +02:00
-- imported functions
local setNestCount = chunkPropertyUtils.setNestCount
local setPlayerBaseGenerator = chunkPropertyUtils.setPlayerBaseGenerator
local addPlayerBaseGenerator = chunkPropertyUtils.addPlayerBaseGenerator
local setResourceGenerator = chunkPropertyUtils.setResourceGenerator
local addResourceGenerator = chunkPropertyUtils.addResourceGenerator
2019-11-30 02:49:22 +02:00
local setHiveCount = chunkPropertyUtils.setHiveCount
local setTrapCount = chunkPropertyUtils.setTrapCount
local setTurretCount = chunkPropertyUtils.setTurretCount
local setUtilityCount = chunkPropertyUtils.setUtilityCount
local getPlayerBaseGenerator = chunkPropertyUtils.getPlayerBaseGenerator
local getNestCount = chunkPropertyUtils.getNestCount
2019-11-30 02:49:22 +02:00
local getHiveCount = chunkPropertyUtils.getHiveCount
local getTrapCount = chunkPropertyUtils.getTrapCount
local getUtilityCount = chunkPropertyUtils.getUtilityCount
local getTurretCount = chunkPropertyUtils.getTurretCount
2019-02-20 08:16:43 +02:00
local setRaidNestActiveness = chunkPropertyUtils.setRaidNestActiveness
local setNestActiveness = chunkPropertyUtils.setNestActiveness
2019-12-16 03:16:56 +02:00
local processNestActiveness = chunkPropertyUtils.processNestActiveness
2019-11-30 02:49:22 +02:00
local getEnemyStructureCount = chunkPropertyUtils.getEnemyStructureCount
local findNearbyBase = baseUtils.findNearbyBase
local createBase = baseUtils.createBase
2017-11-21 09:27:03 +02:00
local upgradeEntity = baseUtils.upgradeEntity
local euclideanDistancePoints = mathUtils.euclideanDistancePoints
2021-04-30 07:24:14 +02:00
local getChunkBase = chunkPropertyUtils.getChunkBase
local setChunkBase = chunkPropertyUtils.setChunkBase
2018-09-24 06:56:45 +02:00
local setPassable = chunkPropertyUtils.setPassable
local setPathRating = chunkPropertyUtils.setPathRating
2021-11-26 08:49:28 +02:00
local getChunkByPosition = mapUtils.getChunkByPosition
local getChunkByXY = mapUtils.getChunkByXY
2021-11-26 08:49:28 +02:00
local queueGeneratedChunk = mapUtils.queueGeneratedChunk
2018-01-14 07:48:21 +02:00
2020-05-25 05:25:21 +02:00
local mMin = math.min
local mMax = math.max
2017-11-21 09:27:03 +02:00
local mFloor = math.floor
2017-05-12 06:50:06 +02:00
-- module code
2017-05-06 11:03:28 +02:00
2018-01-14 07:48:21 +02:00
local function getEntityOverlapChunks(map, entity)
2021-11-26 08:49:28 +02:00
local boundingBox = entity.prototype.collision_box or entity.prototype.selection_box
2021-02-20 09:31:36 +02:00
local overlapArray = map.universe.chunkOverlapArray
2020-04-28 05:41:18 +02:00
2020-05-15 22:51:38 +02:00
overlapArray[1] = -1 --LeftTop
overlapArray[2] = -1 --RightTop
overlapArray[3] = -1 --LeftBottom
overlapArray[4] = -1 --RightBottom
2020-04-28 05:41:18 +02:00
if boundingBox then
local center = entity.position
local topXOffset
local topYOffset
local bottomXOffset
local bottomYOffset
topXOffset = boundingBox.left_top.x
topYOffset = boundingBox.left_top.y
bottomXOffset = boundingBox.right_bottom.x
bottomYOffset = boundingBox.right_bottom.y
local leftTopChunkX = mFloor((center.x + topXOffset) * CHUNK_SIZE_DIVIDER) * CHUNK_SIZE
local leftTopChunkY = mFloor((center.y + topYOffset) * CHUNK_SIZE_DIVIDER) * CHUNK_SIZE
local rightTopChunkX = mFloor((center.x + bottomXOffset) * CHUNK_SIZE_DIVIDER) * CHUNK_SIZE
local leftBottomChunkY = mFloor((center.y + bottomYOffset) * CHUNK_SIZE_DIVIDER) * CHUNK_SIZE
overlapArray[1] = getChunkByXY(map, leftTopChunkX, leftTopChunkY) -- LeftTop
if (leftTopChunkX ~= rightTopChunkX) then
overlapArray[2] = getChunkByXY(map, rightTopChunkX, leftTopChunkY) -- RightTop
end
if (leftTopChunkY ~= leftBottomChunkY) then
overlapArray[3] = getChunkByXY(map, leftTopChunkX, leftBottomChunkY) -- LeftBottom
end
if (leftTopChunkX ~= rightTopChunkX) and (leftTopChunkY ~= leftBottomChunkY) then
overlapArray[4] = getChunkByXY(map, rightTopChunkX, leftBottomChunkY) -- RightBottom
end
end
return overlapArray
2017-11-21 09:27:03 +02:00
end
2021-02-20 07:41:30 +02:00
local function scanPaths(chunk, map)
local surface = map.surface
2020-04-28 05:41:18 +02:00
local pass = CHUNK_IMPASSABLE
local x = chunk.x
local y = chunk.y
2021-02-20 09:31:36 +02:00
local universe = map.universe
local filteredEntitiesCliffQuery = universe.filteredEntitiesCliffQuery
local filteredTilesPathQuery = universe.filteredTilesPathQuery
2020-04-28 05:41:18 +02:00
local count_entities_filtered = surface.count_entities_filtered
local count_tiles_filtered = surface.count_tiles_filtered
local passableNorthSouth = false
local passableEastWest = false
local topPosition = filteredEntitiesCliffQuery.area[1]
local bottomPosition = filteredEntitiesCliffQuery.area[2]
topPosition[2] = y
bottomPosition[2] = y + 32
for xi=x, x + 32 do
topPosition[1] = xi
bottomPosition[1] = xi + 1
if (count_entities_filtered(filteredEntitiesCliffQuery) == 0) and
(count_tiles_filtered(filteredTilesPathQuery) == 0)
then
passableNorthSouth = true
break
end
end
topPosition[1] = x
bottomPosition[1] = x + 32
for yi=y, y + 32 do
topPosition[2] = yi
bottomPosition[2] = yi + 1
if (count_entities_filtered(filteredEntitiesCliffQuery) == 0) and
(count_tiles_filtered(filteredTilesPathQuery) == 0)
then
passableEastWest = true
break
end
end
if passableEastWest and passableNorthSouth then
pass = CHUNK_ALL_DIRECTIONS
elseif passableEastWest then
pass = CHUNK_EAST_WEST
elseif passableNorthSouth then
pass = CHUNK_NORTH_SOUTH
end
return pass
end
2021-02-20 07:41:30 +02:00
local function scorePlayerBuildings(map)
local surface = map.surface
2021-02-20 09:31:36 +02:00
local universe = map.universe
if surface.count_entities_filtered(universe.hasPlayerStructuresQuery) > 0 then
return (surface.count_entities_filtered(universe.filteredEntitiesPlayerQueryLowest) * GENERATOR_PHEROMONE_LEVEL_1) +
(surface.count_entities_filtered(universe.filteredEntitiesPlayerQueryLow) * GENERATOR_PHEROMONE_LEVEL_3) +
(surface.count_entities_filtered(universe.filteredEntitiesPlayerQueryHigh) * GENERATOR_PHEROMONE_LEVEL_5) +
(surface.count_entities_filtered(universe.filteredEntitiesPlayerQueryHighest) * GENERATOR_PHEROMONE_LEVEL_6)
end
return 0
end
2021-02-20 07:41:30 +02:00
function chunkUtils.initialScan(chunk, map, tick)
local surface = map.surface
2021-02-20 09:31:36 +02:00
local universe = map.universe
local waterTiles = (1 - (surface.count_tiles_filtered(universe.filteredTilesQuery) * 0.0009765625)) * 0.80
local enemyBuildings = surface.find_entities_filtered(universe.filteredEntitiesEnemyStructureQuery)
2019-02-06 08:25:43 +02:00
2020-05-25 05:25:21 +02:00
if (waterTiles >= CHUNK_PASS_THRESHOLD) or (#enemyBuildings > 0) then
2021-02-14 06:49:54 +02:00
local neutralObjects = mMax(0,
2021-02-20 09:31:36 +02:00
mMin(1 - (surface.count_entities_filtered(universe.filteredEntitiesChunkNeutral) * 0.005),
2021-02-14 06:49:54 +02:00
1) * 0.20)
2021-02-20 07:41:30 +02:00
local pass = scanPaths(chunk, map)
2019-10-19 23:04:38 +02:00
2021-02-20 07:41:30 +02:00
local playerObjects = scorePlayerBuildings(map)
2020-04-28 05:41:18 +02:00
if ((playerObjects > 0) or (#enemyBuildings > 0)) and (pass == CHUNK_IMPASSABLE) then
pass = CHUNK_ALL_DIRECTIONS
end
2020-04-28 05:41:18 +02:00
if (pass ~= CHUNK_IMPASSABLE) then
2021-02-20 09:31:36 +02:00
local resources = surface.count_entities_filtered(universe.countResourcesQuery) * RESOURCE_NORMALIZER
2020-03-16 00:16:00 +02:00
2021-02-20 09:31:36 +02:00
local buildingHiveTypeLookup = universe.buildingHiveTypeLookup
2020-04-28 05:41:18 +02:00
local counts = map.chunkScanCounts
for i=1,#HIVE_BUILDINGS_TYPES do
counts[HIVE_BUILDINGS_TYPES[i]] = 0
2020-03-16 00:16:00 +02:00
end
if (#enemyBuildings > 0) then
if universe.NEW_ENEMIES then
2020-04-28 05:41:18 +02:00
local base = findNearbyBase(map, chunk)
if base then
setChunkBase(map, chunk, base)
else
2021-02-20 09:31:36 +02:00
base = createBase(map, chunk, tick)
2020-04-28 05:41:18 +02:00
end
local alignment = base.alignment
2021-02-20 09:31:36 +02:00
local unitList = surface.find_entities_filtered(universe.filteredEntitiesUnitQuery)
2020-04-28 05:41:18 +02:00
for i=1,#unitList do
local unit = unitList[i]
if (unit.valid) then
unit.destroy()
2019-02-21 08:31:47 +02:00
end
2020-04-28 05:41:18 +02:00
end
for i = 1, #enemyBuildings do
local enemyBuilding = enemyBuildings[i]
if not buildingHiveTypeLookup[enemyBuilding.name] then
local newEntity = upgradeEntity(enemyBuilding, alignment, map, nil, true)
2020-04-28 05:41:18 +02:00
if newEntity then
2021-11-26 08:49:28 +02:00
local hiveType = buildingHiveTypeLookup[newEntity]
2020-04-28 05:41:18 +02:00
counts[hiveType] = counts[hiveType] + 1
end
else
local hiveType = buildingHiveTypeLookup[enemyBuilding.name] or
(((enemyBuilding.type == "turret") and "turret") or "biter-spawner")
counts[hiveType] = counts[hiveType] + 1
end
end
setNestCount(map, chunk, counts["spitter-spawner"] + counts["biter-spawner"])
setUtilityCount(map, chunk, counts["utility"])
setHiveCount(map, chunk, counts["hive"])
setTrapCount(map, chunk, counts["trap"])
setTurretCount(map, chunk, counts["turret"])
else
for i=1,#enemyBuildings do
local building = enemyBuildings[i]
2021-02-14 06:49:54 +02:00
local hiveType = buildingHiveTypeLookup[building.name] or
(((building.type == "turret") and "turret") or "biter-spawner")
2020-03-16 00:16:00 +02:00
counts[hiveType] = counts[hiveType] + 1
2020-04-28 05:41:18 +02:00
end
setNestCount(map, chunk, counts["spitter-spawner"] + counts["biter-spawner"])
setUtilityCount(map, chunk, counts["utility"])
setHiveCount(map, chunk, counts["hive"])
setTrapCount(map, chunk, counts["trap"])
setTurretCount(map, chunk, counts["turret"])
end
2019-02-21 08:31:47 +02:00
end
2019-02-06 08:25:43 +02:00
2020-04-28 05:41:18 +02:00
setPlayerBaseGenerator(map, chunk, playerObjects)
setResourceGenerator(map, chunk, resources)
2019-02-06 08:25:43 +02:00
2020-04-28 05:41:18 +02:00
setPassable(map, chunk, pass)
2020-05-25 05:25:21 +02:00
setPathRating(map, chunk, waterTiles + neutralObjects)
2020-04-28 05:41:18 +02:00
return chunk
end
end
2020-05-15 22:51:38 +02:00
return -1
end
2021-02-20 07:41:30 +02:00
function chunkUtils.chunkPassScan(chunk, map)
local surface = map.surface
2021-02-20 09:31:36 +02:00
local universe = map.universe
local waterTiles = (1 - (surface.count_tiles_filtered(universe.filteredTilesQuery) * 0.0009765625)) * 0.80
2020-05-25 05:25:21 +02:00
if (waterTiles >= CHUNK_PASS_THRESHOLD) then
2021-02-14 06:49:54 +02:00
local neutralObjects = mMax(0,
2021-02-20 09:31:36 +02:00
mMin(1 - (surface.count_entities_filtered(universe.filteredEntitiesChunkNeutral) * 0.005),
2021-02-14 06:49:54 +02:00
1) * 0.20)
2021-02-20 07:41:30 +02:00
local pass = scanPaths(chunk, map)
2019-02-06 08:25:43 +02:00
2020-04-28 05:41:18 +02:00
local playerObjects = getPlayerBaseGenerator(map, chunk)
2020-04-28 05:41:18 +02:00
local nests = getNestCount(map, chunk)
2020-04-28 05:41:18 +02:00
if ((playerObjects > 0) or (nests > 0)) and (pass == CHUNK_IMPASSABLE) then
pass = CHUNK_ALL_DIRECTIONS
end
2020-04-28 05:41:18 +02:00
setPassable(map, chunk, pass)
2020-05-25 05:25:21 +02:00
setPathRating(map, chunk, waterTiles + neutralObjects)
2020-04-28 05:41:18 +02:00
return chunk
end
2020-05-15 22:51:38 +02:00
return -1
end
2021-02-20 07:41:30 +02:00
function chunkUtils.mapScanPlayerChunk(chunk, map)
local playerObjects = scorePlayerBuildings(map)
setPlayerBaseGenerator(map, chunk, playerObjects)
end
2021-02-20 07:41:30 +02:00
function chunkUtils.mapScanResourceChunk(chunk, map)
local surface = map.surface
2021-02-20 09:31:36 +02:00
local universe = map.universe
local resources = surface.count_entities_filtered(universe.countResourcesQuery) * RESOURCE_NORMALIZER
2020-04-28 05:41:18 +02:00
setResourceGenerator(map, chunk, resources)
2021-02-20 09:31:36 +02:00
local waterTiles = (1 - (surface.count_tiles_filtered(universe.filteredTilesQuery) * 0.0009765625)) * 0.80
2021-02-14 06:49:54 +02:00
local neutralObjects = mMax(0,
2021-02-20 09:31:36 +02:00
mMin(1 - (surface.count_entities_filtered(universe.filteredEntitiesChunkNeutral) * 0.005),
2021-02-14 06:49:54 +02:00
1) * 0.20)
2020-05-25 05:25:21 +02:00
setPathRating(map, chunk, waterTiles + neutralObjects)
end
2021-02-20 07:41:30 +02:00
function chunkUtils.mapScanEnemyChunk(chunk, map)
2021-02-20 09:31:36 +02:00
local universe = map.universe
local buildingHiveTypeLookup = universe.buildingHiveTypeLookup
local buildings = map.surface.find_entities_filtered(universe.filteredEntitiesEnemyStructureQuery)
2020-04-28 05:41:18 +02:00
local counts = map.chunkScanCounts
for i=1,#HIVE_BUILDINGS_TYPES do
counts[HIVE_BUILDINGS_TYPES[i]] = 0
end
for i=1,#buildings do
local building = buildings[i]
2021-02-14 06:49:54 +02:00
local hiveType = buildingHiveTypeLookup[building.name] or
(((building.type == "turret") and "turret") or "biter-spawner")
counts[hiveType] = counts[hiveType] + 1
2020-04-28 05:41:18 +02:00
end
setNestCount(map, chunk, counts["spitter-spawner"] + counts["biter-spawner"])
setUtilityCount(map, chunk, counts["utility"])
setHiveCount(map, chunk, counts["hive"])
setTrapCount(map, chunk, counts["trap"])
setTurretCount(map, chunk, counts["turret"])
end
2019-03-10 21:28:43 +02:00
function chunkUtils.entityForPassScan(map, entity)
2020-04-28 05:41:18 +02:00
local overlapArray = getEntityOverlapChunks(map, entity)
for i=1,#overlapArray do
local chunk = overlapArray[i]
2020-05-15 22:51:38 +02:00
if (chunk ~= -1) then
2020-04-28 05:41:18 +02:00
map.chunkToPassScan[chunk] = true
end
end
2019-03-10 21:28:43 +02:00
end
function chunkUtils.createChunk(topX, topY)
2020-04-28 05:41:18 +02:00
local chunk = {
x = topX,
y = topY,
dOrigin = euclideanDistancePoints(topX, topY, 0, 0)
2020-04-28 05:41:18 +02:00
}
chunk[BASE_PHEROMONE] = 0
chunk[PLAYER_PHEROMONE] = 0
chunk[RESOURCE_PHEROMONE] = 0
chunk[CHUNK_TICK] = 0
return chunk
end
2020-05-24 05:47:14 +02:00
function chunkUtils.colorChunk(chunk, surface, color)
local lx = math.floor(chunk.x * CHUNK_SIZE_DIVIDER) * CHUNK_SIZE
local ly = math.floor(chunk.y * CHUNK_SIZE_DIVIDER) * CHUNK_SIZE
2021-02-14 06:49:54 +02:00
rendering.draw_rectangle({
2020-05-24 05:47:14 +02:00
color = color or {0.1, 0.3, 0.1, 0.6},
width = 32 * 32,
filled = true,
left_top = {lx, ly},
right_bottom = {lx+32, ly+32},
surface = surface,
time_to_live = 180,
draw_on_ground = true,
visible = true
})
end
function chunkUtils.colorXY(x, y, surface, color)
2020-04-28 05:41:18 +02:00
local lx = math.floor(x * CHUNK_SIZE_DIVIDER) * CHUNK_SIZE
local ly = math.floor(y * CHUNK_SIZE_DIVIDER) * CHUNK_SIZE
2020-05-24 05:47:14 +02:00
2021-02-14 06:49:54 +02:00
rendering.draw_rectangle({
2020-05-24 05:47:14 +02:00
color = color or {0.1, 0.3, 0.1, 0.6},
width = 32 * 32,
filled = true,
left_top = {lx, ly},
right_bottom = {lx+32, ly+32},
surface = surface,
time_to_live = 180,
draw_on_ground = true,
visible = true
})
2017-12-31 21:36:23 +02:00
end
2021-11-26 08:49:28 +02:00
function chunkUtils.processPendingUpgrades(map, tick)
local pendingUpgrades = map.pendingUpgrades
local entity = map.pendingUpgradeIterator
local entityData
if not entity then
entity, entityData = next(pendingUpgrades, nil)
else
entityData = pendingUpgrades[entity]
end
if entity then
if entity.valid then
map.pendingUpgradeIterator = next(pendingUpgrades, entity)
pendingUpgrades[entity] = nil
local universe = map.universe
local query = universe.upgradeEntityQuery
query.position = entityData.position or entity.position
query.name = entityData.name
local surface = entity.surface
entity.destroy()
if remote.interfaces["kr-creep"] then
remote.call("kr-creep", "spawn_creep_at_position", surface, query.position)
end
local createdEntity = surface.create_entity(query)
if createdEntity and createdEntity.valid and entityData.register then
local chunk = getChunkByPosition(map, createdEntity.position)
if (chunk ~= -1) then
local base = findNearbyBase(map, chunk)
if not base then
base = createBase(map,
chunk,
tick)
end
if base then
chunkUtils.registerEnemyBaseStructure(map, createdEntity, base)
end
else
queueGeneratedChunk(
universe,
{
surface = createdEntity.surface,
area = {
left_top = {
x = createdEntity.position.x,
y = createdEntity.position.y
}
}
}
)
end
end
else
map.pendingUpgradeIterator = next(pendingUpgrades, entity)
pendingUpgrades[entity] = nil
end
end
end
2020-05-24 05:47:14 +02:00
2021-02-20 07:41:30 +02:00
function chunkUtils.registerEnemyBaseStructure(map, entity, base)
2020-04-28 05:41:18 +02:00
local entityType = entity.type
if ((entityType == "unit-spawner") or (entityType == "turret")) and (entity.force.name == "enemy") then
local overlapArray = getEntityOverlapChunks(map, entity)
local getFunc
local setFunc
2021-02-20 09:31:36 +02:00
local universe = map.universe
local hiveTypeLookup = universe.buildingHiveTypeLookup
2020-04-28 05:41:18 +02:00
local hiveType = hiveTypeLookup[entity.name]
if (hiveType == "spitter-spawner") or (hiveType == "biter-spawner") then
2021-02-20 09:31:36 +02:00
map.builtEnemyBuilding = map.builtEnemyBuilding + 1
2020-04-28 05:41:18 +02:00
getFunc = getNestCount
setFunc = setNestCount
elseif (hiveType == "turret") then
2021-02-20 09:31:36 +02:00
map.builtEnemyBuilding = map.builtEnemyBuilding + 1
2019-11-30 02:49:22 +02:00
getFunc = getTurretCount
setFunc = setTurretCount
2020-04-28 05:41:18 +02:00
elseif (hiveType == "trap") then
getFunc = getTrapCount
setFunc = setTrapCount
elseif (hiveType == "utility") then
2021-02-20 09:31:36 +02:00
map.builtEnemyBuilding = map.builtEnemyBuilding + 1
2020-04-28 05:41:18 +02:00
getFunc = getUtilityCount
setFunc = setUtilityCount
elseif (hiveType == "hive") then
2021-02-20 09:31:36 +02:00
map.builtEnemyBuilding = map.builtEnemyBuilding + 1
2020-04-28 05:41:18 +02:00
getFunc = getHiveCount
setFunc = setHiveCount
else
if (entityType == "turret") then
2021-02-20 09:31:36 +02:00
map.builtEnemyBuilding = map.builtEnemyBuilding + 1
2020-04-28 05:41:18 +02:00
getFunc = getTurretCount
setFunc = setTurretCount
elseif (entityType == "unit-spawner") then
2021-02-20 09:31:36 +02:00
map.builtEnemyBuilding = map.builtEnemyBuilding + 1
2020-04-28 05:41:18 +02:00
getFunc = getNestCount
setFunc = setNestCount
end
end
for i=1,#overlapArray do
local chunk = overlapArray[i]
2020-05-15 22:51:38 +02:00
if (chunk ~= -1) then
2020-04-28 05:41:18 +02:00
setFunc(map, chunk, getFunc(map, chunk) + 1)
setChunkBase(map, chunk, base)
2021-02-20 07:41:30 +02:00
processNestActiveness(map, chunk)
2020-04-28 05:41:18 +02:00
end
end
end
return entity
2017-11-21 09:27:03 +02:00
end
2021-04-30 07:24:14 +02:00
function chunkUtils.unregisterEnemyBaseStructure(map, entity, damageType)
2020-04-28 05:41:18 +02:00
local entityType = entity.type
if ((entityType == "unit-spawner") or (entityType == "turret")) and (entity.force.name == "enemy") then
local overlapArray = getEntityOverlapChunks(map, entity)
local getFunc
local setFunc
2021-02-20 09:31:36 +02:00
local hiveTypeLookup = map.universe.buildingHiveTypeLookup
2020-04-28 05:41:18 +02:00
local hiveType = hiveTypeLookup[entity.name]
if (hiveType == "spitter-spawner") or (hiveType == "biter-spawner") then
2021-02-20 09:31:36 +02:00
map.lostEnemyBuilding = map.lostEnemyBuilding + 1
2020-04-28 05:41:18 +02:00
getFunc = getNestCount
setFunc = setNestCount
elseif (hiveType == "turret") then
2021-02-20 09:31:36 +02:00
map.lostEnemyBuilding = map.lostEnemyBuilding + 1
2019-11-30 02:49:22 +02:00
getFunc = getTurretCount
setFunc = setTurretCount
2020-04-28 05:41:18 +02:00
elseif (hiveType == "trap") then
getFunc = getTrapCount
setFunc = setTrapCount
elseif (hiveType == "utility") then
2021-02-20 09:31:36 +02:00
map.lostEnemyBuilding = map.lostEnemyBuilding + 1
2020-04-28 05:41:18 +02:00
getFunc = getUtilityCount
setFunc = setUtilityCount
elseif (hiveType == "hive") then
2021-02-20 09:31:36 +02:00
map.lostEnemyBuilding = map.lostEnemyBuilding + 1
2020-04-28 05:41:18 +02:00
getFunc = getHiveCount
setFunc = setHiveCount
else
if (entityType == "turret") then
2021-02-20 09:31:36 +02:00
map.lostEnemyBuilding = map.lostEnemyBuilding + 1
2020-04-28 05:41:18 +02:00
getFunc = getTurretCount
setFunc = setTurretCount
elseif (entityType == "unit-spawner") then
hiveType = "biter-spawner"
2021-02-20 09:31:36 +02:00
map.lostEnemyBuilding = map.lostEnemyBuilding + 1
2020-04-28 05:41:18 +02:00
getFunc = getNestCount
setFunc = setNestCount
end
end
for i=1,#overlapArray do
local chunk = overlapArray[i]
2020-05-15 22:51:38 +02:00
if (chunk ~= -1) then
2020-04-28 05:41:18 +02:00
local count = getFunc(map, chunk)
if count then
local base = getChunkBase(map, chunk)
2021-07-25 03:20:13 +02:00
if damageType and base then
local damageTypeName = damageType.name
base.damagedBy[damageTypeName] = (base.damagedBy[damageTypeName] or 0) + 3
base.deathEvents = base.deathEvents + 3
end
2020-04-28 05:41:18 +02:00
if (count <= 1) then
if (hiveType == "spitter-spawner") or (hiveType == "biter-spawner") then
setRaidNestActiveness(map, chunk, 0)
setNestActiveness(map, chunk, 0)
end
setFunc(map, chunk, 0)
if (getEnemyStructureCount(map, chunk) == 0) then
setChunkBase(map, chunk, nil)
end
else
setFunc(map, chunk, count - 1)
end
end
end
2020-04-28 05:41:18 +02:00
end
2019-10-19 23:04:38 +02:00
2020-04-28 05:41:18 +02:00
end
2017-11-21 09:27:03 +02:00
end
2021-02-20 09:31:36 +02:00
function chunkUtils.accountPlayerEntity(entity, map, addObject, creditNatives)
2020-04-28 05:41:18 +02:00
if (BUILDING_PHEROMONES[entity.type] ~= nil) and (entity.force.name ~= "enemy") then
local universe = map.universe
2020-04-28 05:41:18 +02:00
local entityValue = BUILDING_PHEROMONES[entity.type]
local overlapArray = getEntityOverlapChunks(map, entity)
if not addObject then
if creditNatives then
2021-02-20 09:31:36 +02:00
map.destroyPlayerBuildings = map.destroyPlayerBuildings + 1
if (map.state == AI_STATE_ONSLAUGHT) then
map.points = map.points + entityValue
if universe.aiPointsPrintGainsToChat then
2021-05-01 19:26:05 +02:00
game.print(map.surface.name .. ": Points: +" .. math.floor(entityValue) .. ". [Structure Kill] Total: " .. string.format("%.2f", map.points))
end
2020-04-28 05:41:18 +02:00
else
2021-02-20 09:31:36 +02:00
map.points = map.points + (entityValue * 0.12)
if universe.aiPointsPrintGainsToChat then
2021-05-01 19:26:05 +02:00
game.print(map.surface.name .. ": Points: +" .. math.floor(entityValue * 0.12) .. ". [Structure Kill] Total: " .. string.format("%.2f", map.points))
end
2020-04-28 05:41:18 +02:00
end
end
entityValue = -entityValue
end
for i=1,#overlapArray do
local chunk = overlapArray[i]
2020-05-15 22:51:38 +02:00
if (chunk ~= -1) then
2020-04-28 05:41:18 +02:00
addPlayerBaseGenerator(map, chunk, entityValue)
end
2020-04-28 05:41:18 +02:00
end
end
return entity
2017-11-21 09:27:03 +02:00
end
2018-01-14 07:48:21 +02:00
function chunkUtils.unregisterResource(entity, map)
2020-04-28 05:41:18 +02:00
if entity.prototype.infinite_resource then
return
end
local overlapArray = getEntityOverlapChunks(map, entity)
for i=1,#overlapArray do
local chunk = overlapArray[i]
2020-05-15 22:51:38 +02:00
if (chunk ~= -1) then
2020-04-28 05:41:18 +02:00
addResourceGenerator(map, chunk, -RESOURCE_NORMALIZER)
end
end
end
2019-05-16 07:11:43 +02:00
function chunkUtils.registerResource(entity, map)
2020-04-28 05:41:18 +02:00
local overlapArray = getEntityOverlapChunks(map, entity)
for i=1,#overlapArray do
local chunk = overlapArray[i]
2020-05-15 22:51:38 +02:00
if (chunk ~= -1) then
2020-04-28 05:41:18 +02:00
addResourceGenerator(map, chunk, RESOURCE_NORMALIZER)
end
end
2019-05-16 07:11:43 +02:00
end
2017-11-21 09:27:03 +02:00
function chunkUtils.makeImmortalEntity(surface, entity)
2020-04-28 05:41:18 +02:00
local repairPosition = entity.position
local repairName = entity.name
local repairForce = entity.force
local repairDirection = entity.direction
local wires
if (entity.type == "electric-pole") then
wires = entity.neighbours
end
entity.destroy()
local newEntity = surface.create_entity({position=repairPosition,
name=repairName,
direction=repairDirection,
force=repairForce})
if wires then
for _,v in pairs(wires.copper) do
if (v.valid) then
newEntity.connect_neighbour(v);
end
end
for _,v in pairs(wires.red) do
if (v.valid) then
newEntity.connect_neighbour({wire = DEFINES_WIRE_TYPE_RED, target_entity = v});
end
end
for _,v in pairs(wires.green) do
if (v.valid) then
newEntity.connect_neighbour({wire = DEFINES_WIRE_TYPE_GREEN, target_entity = v});
end
end
end
newEntity.destructible = false
2017-11-21 09:27:03 +02:00
end
2019-02-16 06:17:30 +02:00
chunkUtilsG = chunkUtils
return chunkUtils