mirror of
https://github.com/Oarcinae/FactorioScenarioMultiplayerSpawn.git
synced 2025-01-22 03:08:49 +02:00
Fix regrowth and migration issues.
This commit is contained in:
parent
30646f63d7
commit
1421cf029a
@ -148,7 +148,8 @@ end)
|
|||||||
|
|
||||||
script.on_event(defines.events.on_research_finished, function(event)
|
script.on_event(defines.events.on_research_finished, function(event)
|
||||||
local research = event.research
|
local research = event.research
|
||||||
SendBroadcastMsg("Team " .. research.force.name .. " finished research: " .. research.name)
|
-- TODO: Add a non-mod setting to disable this.
|
||||||
|
SendBroadcastMsg({"oarc-research-finished", research.force.name, research.name})
|
||||||
end)
|
end)
|
||||||
|
|
||||||
----------------------------------------
|
----------------------------------------
|
||||||
|
@ -114,14 +114,16 @@ function RegrowthDisableSurface(surface_name)
|
|||||||
storage.rg[surface_name].active = false
|
storage.rg[surface_name].active = false
|
||||||
TableRemoveOneUsingPairs(storage.rg.active_surfaces, surface_name)
|
TableRemoveOneUsingPairs(storage.rg.active_surfaces, surface_name)
|
||||||
|
|
||||||
-- Make sure indices are reset if needed
|
-- Make sure indices are reset and the iterator made invalid too
|
||||||
if (storage.rg.current_surface == surface_name) then
|
if (storage.rg.current_surface == surface_name) then
|
||||||
storage.rg.current_surface = nil
|
storage.rg.current_surface = nil
|
||||||
storage.rg.current_surface_index = 1
|
storage.rg.current_surface_index = 1
|
||||||
|
storage.rg.chunk_iter = nil
|
||||||
end
|
end
|
||||||
if (storage.rg.we_current_surface == surface_name) then
|
if (storage.rg.we_current_surface == surface_name) then
|
||||||
storage.rg.we_current_surface = nil
|
storage.rg.we_current_surface = nil
|
||||||
storage.rg.we_current_surface_index = 1
|
storage.rg.we_current_surface_index = 1
|
||||||
|
storage.rg.we_chunk_iter = nil
|
||||||
end
|
end
|
||||||
if #storage.rg.active_surfaces > 0 then
|
if #storage.rg.active_surfaces > 0 then
|
||||||
storage.rg.current_surface = storage.rg.active_surfaces[1]
|
storage.rg.current_surface = storage.rg.active_surfaces[1]
|
||||||
@ -396,6 +398,7 @@ function GetNextChunkAndUpdateIter()
|
|||||||
|
|
||||||
-- Make sure we have a valid iterator!
|
-- Make sure we have a valid iterator!
|
||||||
if (not storage.rg.chunk_iter or not storage.rg.chunk_iter.valid) then
|
if (not storage.rg.chunk_iter or not storage.rg.chunk_iter.valid) then
|
||||||
|
if game.surfaces[storage.rg.current_surface] == nil then return nil end
|
||||||
storage.rg.chunk_iter = game.surfaces[storage.rg.current_surface].get_chunks()
|
storage.rg.chunk_iter = game.surfaces[storage.rg.current_surface].get_chunks()
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -408,9 +411,13 @@ function GetNextChunkAndUpdateIter()
|
|||||||
local next_surface_info = GetNextActiveSurface(storage.rg.current_surface_index)
|
local next_surface_info = GetNextActiveSurface(storage.rg.current_surface_index)
|
||||||
storage.rg.current_surface = next_surface_info.surface
|
storage.rg.current_surface = next_surface_info.surface
|
||||||
storage.rg.current_surface_index = next_surface_info.index
|
storage.rg.current_surface_index = next_surface_info.index
|
||||||
|
|
||||||
|
-- Surface may not exist
|
||||||
|
if game.surfaces[storage.rg.current_surface] ~= nil then
|
||||||
storage.rg.chunk_iter = game.surfaces[storage.rg.current_surface].get_chunks()
|
storage.rg.chunk_iter = game.surfaces[storage.rg.current_surface].get_chunks()
|
||||||
next_chunk = storage.rg.chunk_iter()
|
next_chunk = storage.rg.chunk_iter()
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
return next_chunk
|
return next_chunk
|
||||||
end
|
end
|
||||||
@ -421,6 +428,7 @@ function GetNextChunkAndUpdateWorldEaterIter()
|
|||||||
|
|
||||||
-- Make sure we have a valid iterator!
|
-- Make sure we have a valid iterator!
|
||||||
if (not storage.rg.we_chunk_iter or not storage.rg.we_chunk_iter.valid) then
|
if (not storage.rg.we_chunk_iter or not storage.rg.we_chunk_iter.valid) then
|
||||||
|
if game.surfaces[storage.rg.we_current_surface] == nil then return nil end
|
||||||
storage.rg.we_chunk_iter = game.surfaces[storage.rg.we_current_surface].get_chunks()
|
storage.rg.we_chunk_iter = game.surfaces[storage.rg.we_current_surface].get_chunks()
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -433,9 +441,13 @@ function GetNextChunkAndUpdateWorldEaterIter()
|
|||||||
local next_surface_info = GetNextActiveSurface(storage.rg.we_current_surface_index)
|
local next_surface_info = GetNextActiveSurface(storage.rg.we_current_surface_index)
|
||||||
storage.rg.we_current_surface = next_surface_info.surface
|
storage.rg.we_current_surface = next_surface_info.surface
|
||||||
storage.rg.we_current_surface_index = next_surface_info.index
|
storage.rg.we_current_surface_index = next_surface_info.index
|
||||||
|
|
||||||
|
-- Surface may not exist
|
||||||
|
if game.surfaces[storage.rg.we_current_surface] ~= nil then
|
||||||
storage.rg.we_chunk_iter = game.surfaces[storage.rg.we_current_surface].get_chunks()
|
storage.rg.we_chunk_iter = game.surfaces[storage.rg.we_current_surface].get_chunks()
|
||||||
next_chunk = storage.rg.we_chunk_iter()
|
next_chunk = storage.rg.we_chunk_iter()
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
return next_chunk
|
return next_chunk
|
||||||
end
|
end
|
||||||
|
@ -393,6 +393,8 @@ oarc-spawn-distance-invalid-msg=Invalid setting! Near spawn min distance is grea
|
|||||||
oarc-world-eater-invalid-msg=Invalid setting! World eater is enabled but regrowth is not! Disabling world eater.
|
oarc-world-eater-invalid-msg=Invalid setting! World eater is enabled but regrowth is not! Disabling world eater.
|
||||||
oarc-default-surface-invalid-msg=Invalid setting! Default surface does not exist! Setting to nauvis.
|
oarc-default-surface-invalid-msg=Invalid setting! Default surface does not exist! Setting to nauvis.
|
||||||
|
|
||||||
|
oarc-research-finished=Team __1__ has finished researching __2__!
|
||||||
|
|
||||||
[entity-name]
|
[entity-name]
|
||||||
oarc-linked-chest=OARC Linked Chest
|
oarc-linked-chest=OARC Linked Chest
|
||||||
oarc-linked-power=OARC Linked Power
|
oarc-linked-power=OARC Linked Power
|
||||||
|
@ -4,7 +4,31 @@ if storage.ocfg.spawn_general.force_tiles == nil then
|
|||||||
log("Updating spawn_general config with new 'force_tiles' setting.")
|
log("Updating spawn_general config with new 'force_tiles' setting.")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- Init OCFG surfaces for other planets if they don't exist.
|
||||||
|
if (storage.ocfg.surfaces_config["fulgora"] == nil) or
|
||||||
|
(storage.ocfg.surfaces_config["fulgora"].spawn_config.fill_tile == nil) then
|
||||||
|
storage.ocfg.surfaces_config["fulgora"] =
|
||||||
|
{
|
||||||
|
spawn_config = FULGORA_SPAWN_CONFIG,
|
||||||
|
starting_items = FULGORA_STARTER_ITEMS
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Refresh the Nauvis config if it is missing the new settings:
|
||||||
|
if storage.ocfg.surfaces_config["nauvis"].spawn_config.fill_tile == nil then
|
||||||
|
storage.ocfg.surfaces_config["nauvis"] = {
|
||||||
|
spawn_config = NAUVIS_SPAWN_CONFIG,
|
||||||
|
starting_items = NAUVIS_STARTER_ITEMS
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
--Make sure new planets get init'd. No harm in running this multiple times.
|
--Make sure new planets get init'd. No harm in running this multiple times.
|
||||||
SeparateSpawnsInitPlanets()
|
SeparateSpawnsInitPlanets()
|
||||||
|
|
||||||
--Migrate surface config changes!
|
-- Block spam. Highhly requested.
|
||||||
|
game.technology_notifications_enabled = false
|
||||||
|
|
||||||
|
-- New global teleport queue for nil characters.
|
||||||
|
if storage.nil_character_teleport_queue == nil then
|
||||||
|
storage.nil_character_teleport_queue = {}
|
||||||
|
end
|
Loading…
x
Reference in New Issue
Block a user