1
0
mirror of https://github.com/Oarcinae/FactorioScenarioMultiplayerSpawn.git synced 2025-01-24 03:16:22 +02:00

Trying to fix the weird bug with player name being a number. Changes to use player index in a LOT of places, probably introduced some new bugs. Changed gui tab to have text at the start. Change enemy bases to visibly die if being removed inside the player's spawn radius.

This commit is contained in:
Oarcinae 2019-08-16 11:30:19 -05:00
parent d08e149dfa
commit 6ba7fd8899
7 changed files with 110 additions and 92 deletions

View File

@ -212,6 +212,10 @@ script.on_event(defines.events.on_player_created, function(event)
InitOarcGuiTabs(player)
end)
script.on_event(defines.events.on_player_removed, function(event)
OarcEnemiesPlayerRemovedEvent(event)
end)
script.on_event(defines.events.on_player_respawned, function(event)
SeparateSpawnsPlayerRespawned(event)

View File

@ -53,11 +53,12 @@ end
function CreateOarcGuiButton(player)
if (mod_gui.get_button_flow(player).oarc_button == nil) then
local b = mod_gui.get_button_flow(player).add{name="oarc_button",
caption="CLICK ME FOR MORE INFO",
type="sprite-button",
sprite="utility/expand_dots",
-- sprite="utility/expand_dots",
style=mod_gui.button_style}
b.style.padding=2
b.style.width=20
-- b.style.width=20
end
end
@ -86,6 +87,13 @@ function ClickOarcGuiButton(event)
local name = event.element.name
if (name ~= "oarc_button") then return end
if (event.element.caption ~= "") then
event.element.caption = ""
event.element.style.width = 20
event.element.sprite="utility/expand_dots"
end
if (not DoesOarcGuiExist(player)) then
CreateOarcGuiTabsPane(player)
else

View File

@ -289,7 +289,11 @@ function ModifyEnemySpawnsNearPlayerStartingAreas(event)
-- No enemies inside safe radius!
if (getDistance(enemy_pos, closest_spawn.pos) < global.ocfg.spawn_config.safe_area.safe_radius) then
event.entity.destroy()
if (event.entity.type == "unit-spawner") then
event.entity.die(game.forces["neutral"])
else
event.entity.destroy()
end
-- Warn distance is all SMALL only.
elseif (getDistance(enemy_pos, closest_spawn.pos) < global.ocfg.spawn_config.safe_area.warn_radius) then

View File

@ -5,7 +5,7 @@
-- This is what an attack request should look like:
-- attack_request_example = {
-- target_player=player_name, -- REQUIRED (Player Name)
-- target_player=player_index, -- REQUIRED (Player index)
-- target_type=TYPE, -- REQUIRED (OE_ATTACK_TYPE)
-- attempts=3, -- REQUIRED (Must be at least 1! Otherwise it won't do anything.)
-- process_stg=TYPE, -- REQUIRED (Normally starts with OE_PROCESS_STG_FIND_TARGET)
@ -81,7 +81,7 @@ function OarcEnemiesSectorScanned(event)
-- 1 in a X chance of triggering an attack on radars?
if (math.random(1,global.oe_params.radar_scan_attack_chance) == 1) then
OarcEnemiesBuildingAttack(player.name, "radar")
OarcEnemiesBuildingAttack(player.index, "radar")
end
end
@ -100,7 +100,7 @@ function OarcEnemiesRocketLaunched(event)
surface=silo.surface,
target_pos=silo.position}
local rocket_launch_attack = {target_player = player_name,
local rocket_launch_attack = {target_player = player.index,
target_type = OE_TARGET_TYPE_ENTITY,
attempts=1,
process_stg=OE_PROCESS_STG_FIND_SPAWN,
@ -114,7 +114,7 @@ end
function OarcEnemiesForceCreated(event)
if (not event.force) then return end
global.oe.tech_levels[event.force.name] = 0
global.oe.tech_levels[event.force.index] = 0
end
function CountForceTechCompleted(force)
@ -210,32 +210,30 @@ end
function OarcEnemiesResearchFinishedEvent(event)
if not (event.research and event.research.force) then return end
local force_name = event.research.force.name
if (global.oe.tech_levels[force_name] == nil) then
global.oe.tech_levels[force_name] = CountForceTechCompleted(game.forces[force_name])
local force = event.research.force
if (global.oe.tech_levels[force.index] == nil) then
global.oe.tech_levels[force.index] = CountForceTechCompleted(force)
else
global.oe.tech_levels[force_name] = global.oe.tech_levels[force_name] + 1
global.oe.tech_levels[force.index] = global.oe.tech_levels[force.index] + 1
end
-- Trigger an attack on science!
OarcEnemiesScienceLabAttack(event.research.force.name)
OarcEnemiesScienceLabAttack(force.index)
end
-- Attack science labs of a given force!
function OarcEnemiesScienceLabAttack(force_name)
function OarcEnemiesScienceLabAttack(force_index)
-- For each player (connected only), find a random science lab,
for _,player in pairs(game.connected_players) do
if (player.force.name == force_name) then
OarcEnemiesBuildingAttack(player.name, "lab")
end
for _,player in pairs(game.forces[force_index].connected_players) do
OarcEnemiesBuildingAttack(player.index, "lab")
end
end
-- Request an attack on a given player's building type.
function OarcEnemiesBuildingAttack(player_name, entity_type)
function OarcEnemiesBuildingAttack(player_index, entity_type)
-- Make sure player exists and is connected.
if (not game.players[player_name] or
not game.players[player_name].connected) then return end
if (not game.players[player_index] or
not game.players[player_index].connected) then return end
-- Check we don't have too many ongoing attacks.
if (#global.oe.attacks >= OE_ATTACKS_MAX) then
@ -243,7 +241,7 @@ function OarcEnemiesBuildingAttack(player_name, entity_type)
return
end
local building_attack = {target_player = player_name,
local building_attack = {target_player = player_index,
target_type = OE_TARGET_TYPE_BUILDING,
attempts=3,
process_stg=OE_PROCESS_STG_FIND_TARGET,
@ -253,13 +251,13 @@ function OarcEnemiesBuildingAttack(player_name, entity_type)
end
-- Attack a player's character
function OarcEnemiesPlayerAttackCharacter(player_name)
function OarcEnemiesPlayerAttackCharacter(player_index)
-- Validation checks.
if (not game.players[player_name] or
not game.players[player_name].connected or
not game.players[player_name].character or
not game.players[player_name].character.valid) then
if (not game.players[player_index] or
not game.players[player_index].connected or
not game.players[player_index].character or
not game.players[player_index].character.valid) then
log("OarcEnemiesPlayerAttackCharacter - player not connected or is dead?")
return
end
@ -271,7 +269,7 @@ function OarcEnemiesPlayerAttackCharacter(player_name)
end
-- Create the attack request
local player_attack = {target_player = player_name,
local player_attack = {target_player = player_index,
target_type = OE_TARGET_TYPE_PLAYER,
attempts=3,
process_stg=OE_PROCESS_STG_FIND_TARGET}
@ -282,29 +280,37 @@ end
-- First time player init stuff
function OarcEnemiesPlayerCreatedEvent(event)
if (game.players[event.player_index] == nil) then return end
local p_name = game.players[event.player_index].name
if (global.oe.player_timers[p_name] == nil) then
global.oe.player_timers[p_name] = {character=GetRandomizedPlayerTimer(0, 60*10),
if (global.oe.player_timers[event.player_index] == nil) then
global.oe.player_timers[event.player_index] = {character=GetRandomizedPlayerTimer(0, 60*10),
generic=GetRandomizedPlayerTimer(0, 0)}
end
if (global.oe.buildings[p_name] == nil) then
global.oe.buildings[p_name] = {}
if (global.oe.buildings[event.player_index] == nil) then
global.oe.buildings[event.player_index] = {}
end
local force = game.players[event.player_index].force
if (global.oe.tech_levels[force.name] == nil) then
global.oe.tech_levels[force.name] = CountForceTechCompleted(force)
if (global.oe.tech_levels[force.index] == nil) then
global.oe.tech_levels[force.index] = CountForceTechCompleted(force)
end
-- Setup tracking of first time chat bubble displays
if (global.oe.player_sbubbles[p_name] == nil) then
global.oe.player_sbubbles[p_name] = {uh_oh=false,
if (global.oe.player_sbubbles[event.player_index] == nil) then
global.oe.player_sbubbles[event.player_index] = {uh_oh=false,
rocket=false}
end
end
function OarcEnemiesPlayerRemovedEvent(event)
if (game.players[event.player_index] == nil) then return end
global.oe.player_timers[event.player_index] = nil
global.oe.buildings[event.player_index] = nil
global.oe.player_sbubbles[event.player_index] = nil
end
function OarcEnemiesChunkGenerated(event)
if (not event.area or not event.area.left_top) then
log("ERROR - OarcEnemiesChunkGenerated")
@ -491,19 +497,25 @@ function OarcEnemiesEntityDiedEvent(event)
-- If there is just a force, then just attack the area.
if (not event.cause) then
if (event.force.name == "neutral") then return end -- Catch non-player destruction.
death_attack.process_stg = OE_PROCESS_STG_CREATE_GROUP
death_attack.spawn_pos = event.entity.position
death_attack.target_type = OE_TARGET_TYPE_AREA
death_attack.target_chunk = GetChunkPosFromTilePos(event.entity.position)
death_attack.evo,death_attack.size = GetEnemyGroup{player=nil,
force_name=event.force.name,
force_index=event.force.index,
surface=game.surfaces[GAME_SURFACE_NAME],
target_pos=event.entity.position,
min_size=8,min_evo=0.25}
-- If we have a cause, go attack that cause.
else
if (event.cause.force.name == "neutral") then return end -- Catch non-player destruction.
local player = nil
if (event.cause.type == "character") then
player = event.cause.player
@ -515,13 +527,13 @@ function OarcEnemiesEntityDiedEvent(event)
-- if (not player or not player.connected) then return end
death_attack.process_stg = OE_PROCESS_STG_SPAWN_PATH_REQ
death_attack.target_player = player.name
death_attack.target_player = player.index
death_attack.target_type = OE_TARGET_TYPE_ENTITY
death_attack.target_entity = event.cause
death_attack.target_chunk = GetChunkPosFromTilePos(player.character.position)
death_attack.evo,death_attack.size = GetEnemyGroup{player=player,
force_name=event.force.name,
force_index=event.force.index,
surface=game.surfaces[GAME_SURFACE_NAME],
target_pos=event.entity.position,
min_size=8,min_evo=0.25}
@ -562,31 +574,31 @@ function OarcEnemiesTrackBuildings(e)
return
end
if (global.oe.buildings[e.last_user.name] == nil) then
global.oe.buildings[e.last_user.name] = {}
if (global.oe.buildings[e.last_user.index] == nil) then
global.oe.buildings[e.last_user.index] = {}
end
if (global.oe.buildings[e.last_user.name][e.type] == nil) then
global.oe.buildings[e.last_user.name][e.type] = {}
if (global.oe.buildings[e.last_user.index][e.type] == nil) then
global.oe.buildings[e.last_user.index][e.type] = {}
end
table.insert(global.oe.buildings[e.last_user.name][e.type], e)
table.insert(global.oe.buildings[e.last_user.index][e.type], e)
end
end
function GetRandomBuildingAny(player_name, entity_type_or_types)
function GetRandomBuildingAny(player_index, entity_type_or_types)
if (type(entity_type_or_types) == "table") then
return GetRandomBuildingMultipleTypes(player_name, entity_type_or_types)
return GetRandomBuildingMultipleTypes(player_index, entity_type_or_types)
else
return GetRandomBuildingSingleType(player_name, entity_type_or_types)
return GetRandomBuildingSingleType(player_index, entity_type_or_types)
end
end
function GetRandomBuildingMultipleTypes(player_name, entity_types)
function GetRandomBuildingMultipleTypes(player_index, entity_types)
local rand_list = {}
for _,e_type in pairs(entity_types) do
local rand_building = GetRandomBuildingSingleType(player_name, e_type)
local rand_building = GetRandomBuildingSingleType(player_index, e_type)
if (rand_building) then
table.insert(rand_list, rand_building)
end
@ -598,7 +610,7 @@ function GetRandomBuildingMultipleTypes(player_name, entity_types)
end
end
function GetRandomBuildingSingleType(player_name, entity_type, count)
function GetRandomBuildingSingleType(player_index, entity_type, count)
-- We only use this if there are lots of invalid entries, likely from destroyed buildings
local count_internal = 0
@ -613,18 +625,18 @@ function GetRandomBuildingSingleType(player_name, entity_type, count)
return nil
end
if (not global.oe.buildings[player_name][entity_type] or
(#global.oe.buildings[player_name][entity_type] == 0)) then
if (not global.oe.buildings[player_index][entity_type] or
(#global.oe.buildings[player_index][entity_type] == 0)) then
-- log("GetRandomBuildingSingleType - none found " .. entity_type)
return nil
end
local rand_key = GetRandomKeyFromTable(global.oe.buildings[player_name][entity_type])
local random_building = global.oe.buildings[player_name][entity_type][rand_key]
local rand_key = GetRandomKeyFromTable(global.oe.buildings[player_index][entity_type])
local random_building = global.oe.buildings[player_index][entity_type][rand_key]
if (not random_building or not random_building.valid) then
table.remove(global.oe.buildings[player_name][entity_type], rand_key)
return GetRandomBuildingSingleType(player_name, entity_type, count_internal-1)
table.remove(global.oe.buildings[player_index][entity_type], rand_key)
return GetRandomBuildingSingleType(player_index, entity_type, count_internal-1)
else
return random_building
end

View File

@ -148,7 +148,7 @@ function GetTechLevelEvoSize(tech_level)
end
-- Get the evo and size given optional params
-- args = {player, force_name, surface, target_pos, min_evo, max_eevo, min_size, max_size}
-- args = {player, force_index, surface, target_pos, min_evo, max_eevo, min_size, max_size}
function GetEnemyGroup(args)
-- Default values
@ -162,7 +162,7 @@ function GetEnemyGroup(args)
-- Given a player, use that for time played AND for player force.
if (args.player and args.player.connected) then
local ticks_online = args.player.online_time
local tech_levels = global.oe.tech_levels[args.player.force.name]
local tech_levels = global.oe.tech_levels[args.player.force.index]
e,s = GetPlayerTimeEvoSize(ticks_online)
evo = evo + e
@ -173,8 +173,8 @@ function GetEnemyGroup(args)
size = size + s
-- Support only force given, no player (should be RARE)
elseif (args.force_name) then
local tech_levels = global.oe.tech_levels[args.force_name]
elseif (args.force_index) then
local tech_levels = global.oe.tech_levels[args.force_index]
e,s = GetTechLevelEvoSize(tech_levels)
evo = evo + e

View File

@ -28,12 +28,10 @@ local function ExpandOarcEnemiesGui(player)
frame.add{type="button", caption="Turret Attack", name="oe_attack_turret"}
local oe_info="General Info:" .. "\n" ..
-- "Units: " .. #global.oe.units .. "\n" ..
"Attacks: " .. #global.oe.attacks .. "\n" ..
-- "Labs: " .. #global.oe.science_labs[player.name] .. "\n" ..
"Tech levels: " .. global.oe.tech_levels[player.force.name] .. "\n" ..
"Next Player Attack: " .. global.oe.player_timers[player.name]["character"] .. "\n" ..
"Next Building Attack: " .. global.oe.player_timers[player.name]["generic"] ..
"Tech levels: " .. global.oe.tech_levels[player.force.index] .. "\n" ..
"Next Player Attack: " .. global.oe.player_timers[player.index]["character"] .. "\n" ..
"Next Building Attack: " .. global.oe.player_timers[player.index]["generic"] ..
" "
AddLabel(frame, "oe_info", oe_info, my_longer_label_style)
end
@ -49,35 +47,27 @@ function OarcEnemiesGuiClick(event)
end
if (name == "oe_attack_player") then
OarcEnemiesPlayerAttackCharacter(player.name)
OarcEnemiesPlayerAttackCharacter(player.index)
end
if (name == "oe_attack_any") then
OarcEnemiesBuildingAttack(player.name, {"ammo-turret",
"electric-turret",
"fluid-turret",
"artillery-turret",
"mining-drill",
"furnace",
"reactor",
"assembling-machine",
"generator"})
OarcEnemiesBuildingAttack(player.index, OE_GENERIC_TARGETS)
end
if (name == "oe_attack_labs") then
OarcEnemiesScienceLabAttack(player.force.name)
OarcEnemiesScienceLabAttack(player.force.index)
end
if (name == "oe_attack_furnace") then
OarcEnemiesBuildingAttack(player.name, "furnace")
OarcEnemiesBuildingAttack(player.index, "furnace")
end
if (name == "oe_attack_mining") then
OarcEnemiesBuildingAttack(player.name, "mining-drill")
OarcEnemiesBuildingAttack(player.index, "mining-drill")
end
if (name == "oe_attack_turret") then
OarcEnemiesBuildingAttack(player.name, {"ammo-turret",
OarcEnemiesBuildingAttack(player.index, {"ammo-turret",
"electric-turret",
"fluid-turret",
"artillery-turret"})

View File

@ -122,22 +122,22 @@ function ProcessAttackCleanupInvalidGroups(key, attack)
end
function ProcessPlayerTimersEverySecond()
for name,timer_table in pairs(global.oe.player_timers) do
if (game.players[name] and game.players[name].connected) then
for p_index,timer_table in pairs(global.oe.player_timers) do
if (game.players[p_index] and game.players[p_index].connected) then
for timer_name,timer in pairs(timer_table) do
if (timer > 0) then
global.oe.player_timers[name][timer_name] = timer-1
for timer_name,timer_val in pairs(timer_table) do
if (timer_val > 0) then
global.oe.player_timers[p_index][timer_name] = timer_val-1
else
if (timer_name == "character") then
OarcEnemiesPlayerAttackCharacter(name)
global.oe.player_timers[name][timer_name] =
GetRandomizedPlayerTimer(game.players[name].online_time/TICKS_PER_SECOND, 0)
OarcEnemiesPlayerAttackCharacter(p_index)
global.oe.player_timers[p_index][timer_name] =
GetRandomizedPlayerTimer(game.players[p_index].online_time/TICKS_PER_SECOND, 0)
elseif (timer_name == "generic") then
OarcEnemiesBuildingAttack(name, OE_GENERIC_TARGETS)
global.oe.player_timers[name][timer_name] =
GetRandomizedPlayerTimer(game.players[name].online_time/TICKS_PER_SECOND, 0)
OarcEnemiesBuildingAttack(p_index, OE_GENERIC_TARGETS)
global.oe.player_timers[p_index][timer_name] =
GetRandomizedPlayerTimer(game.players[p_index].online_time/TICKS_PER_SECOND, 0)
end
end
end
@ -171,7 +171,7 @@ function ProcessAttackFindTarget(key, attack)
global.oe.attacks[key].target_entity = random_building
local e,s = GetEnemyGroup{player=player,
force_name=player.force.name,
force_index=player.force.index,
surface=game.surfaces[GAME_SURFACE_NAME],
target_pos=random_building.position}
@ -190,7 +190,7 @@ function ProcessAttackFindTarget(key, attack)
global.oe.attacks[key].target_entity = player.character
local e,s = GetEnemyGroup{player=player,
force_name=player.force.name,
force_index=player.force.index,
surface=game.surfaces[GAME_SURFACE_NAME],
target_pos=player.character.position}