1
0
mirror of https://github.com/ComfyFactory/ComfyFactorio.git synced 2024-12-30 23:17:53 +02:00

code cleanup

This commit is contained in:
danielmartin0 2024-09-27 17:44:33 +01:00 committed by Gerkiz
parent 9bbfe2ffb3
commit baf267732c
18 changed files with 305 additions and 401 deletions

View File

@ -47,7 +47,7 @@ local side_attack_target_names = {
--=== Tick Actions --=== Tick Actions
function Public.Tick_actions(tickinterval) function Public.Tick_actions(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local destination = Common.current_destination() local destination = Common.current_destination()
@ -56,8 +56,8 @@ function Public.Tick_actions(tickinterval)
if (memory.game_lost) or (destination.dynamic_data.timeratlandingtime and destination.dynamic_data.timer < destination.dynamic_data.timeratlandingtime + Balance.grace_period_on_arriving_at_island_seconds) then return end if (memory.game_lost) or (destination.dynamic_data.timeratlandingtime and destination.dynamic_data.timer < destination.dynamic_data.timeratlandingtime + Balance.grace_period_on_arriving_at_island_seconds) then return end
if game.tick % (tickinterval * 2) == 0 and memory.boat.state == Boats.enum_state.LANDED then if game.tick % (tick_interval * 2) == 0 and memory.boat.state == Boats.enum_state.LANDED then
local extra_evo = 2 * tickinterval / 60 * Balance.evolution_per_second() local extra_evo = 2 * tick_interval / 60 * Balance.evolution_per_second()
Common.increment_evo(extra_evo) Common.increment_evo(extra_evo)
destination.dynamic_data.evolution_accrued_time = destination.dynamic_data.evolution_accrued_time + extra_evo destination.dynamic_data.evolution_accrued_time = destination.dynamic_data.evolution_accrued_time + extra_evo
end end
@ -411,9 +411,9 @@ function Public.try_spawner_spend_fraction_of_available_pollution_on_biters(spaw
local initial_spawner_count = destination.dynamic_data.initial_spawner_count local initial_spawner_count = destination.dynamic_data.initial_spawner_count
if initial_spawner_count > 0 then if initial_spawner_count > 0 then
local spawnerscount = Common.spawner_count(surface) local spawners_count = Common.spawner_count(surface)
if spawnerscount > 0 then if spawners_count > 0 then
map_pollution_cost_multiplier = Math.max(initial_spawner_count / spawnerscount, 1) map_pollution_cost_multiplier = Math.max(initial_spawner_count / spawners_count, 1)
else else
map_pollution_cost_multiplier = 1000000 map_pollution_cost_multiplier = 1000000
end end
@ -502,8 +502,8 @@ function Public.generate_main_attack_target()
local destination = Common.current_destination() local destination = Common.current_destination()
local target local target
local fractioncharged = 0 local fractioncharged = 0
if (not destination.dynamic_data.rocketlaunched) and destination.dynamic_data.rocketsilos and destination.dynamic_data.rocketsilos[1] and destination.dynamic_data.rocketsilos[1].valid and destination.dynamic_data.rocketsilos[1].destructible and destination.dynamic_data.rocketsiloenergyconsumed and destination.dynamic_data.rocketsiloenergyneeded and destination.dynamic_data.rocketsiloenergyneeded > 0 then if (not destination.dynamic_data.rocket_launched) and destination.dynamic_data.rocketsilos and destination.dynamic_data.rocketsilos[1] and destination.dynamic_data.rocketsilos[1].valid and destination.dynamic_data.rocketsilos[1].destructible and destination.dynamic_data.rocket_silo_energy_consumed and destination.dynamic_data.rocket_silo_energy_needed and destination.dynamic_data.rocket_silo_energy_needed > 0 then
fractioncharged = destination.dynamic_data.rocketsiloenergyconsumed / destination.dynamic_data.rocketsiloenergyneeded fractioncharged = destination.dynamic_data.rocket_silo_energy_consumed / destination.dynamic_data.rocket_silo_energy_needed
if memory.overworldx > 40 * 22 then --chance of biters going directly to silo if memory.overworldx > 40 * 22 then --chance of biters going directly to silo
fractioncharged = fractioncharged + 0.03 fractioncharged = fractioncharged + 0.03

View File

@ -56,7 +56,7 @@ function Public.silo_die()
if CoreData.rocket_silo_death_causes_loss then if CoreData.rocket_silo_death_causes_loss then
-- Crew.lose_life() -- Crew.lose_life()
Crew.try_lose({ 'pirates.loss_silo_destroyed' }) Crew.try_lose({ 'pirates.loss_silo_destroyed' })
elseif (not destination.dynamic_data.rocketlaunched) then elseif (not destination.dynamic_data.rocket_launched) then
if destination.static_params and destination.static_params.base_cost_to_undock and destination.static_params.base_cost_to_undock['launch_rocket'] == true then if destination.static_params and destination.static_params.base_cost_to_undock and destination.static_params.base_cost_to_undock['launch_rocket'] == true then
Crew.try_lose({ 'pirates.loss_silo_destroyed_before_necessary_launch' }) Crew.try_lose({ 'pirates.loss_silo_destroyed_before_necessary_launch' })
else else
@ -1510,31 +1510,9 @@ local function event_on_player_joined_game(event)
-- end -- end
end end
global_memory.last_players_health[event.player_index] = player.character.health if player.character and player.character.valid then
global_memory.last_players_health[event.player_index] = player.character.health
-- player.teleport(surface.find_non_colliding_position('character', spawnpoint, 32, 0.5), surface) end
-- -- for item, amount in pairs(Balance.starting_items_player) do
-- -- player.insert({name = item, count = amount})
-- -- end
-- end
-- if player.surface.name ~= Common.current_destination().surface_name and string.sub(player.surface.name, 1, 10) ~= 'crowsnest-' then -- add other adventuring surfaces here
-- player.character = nil
-- player.set_controller({type=defines.controllers.god})
-- player.create_character()
-- player.teleport(surface.find_non_colliding_position('character', memory.force.get_spawn_position(surface), 32, 0.5), surface)
-- for item, amount in pairs(starting_items_player) do
-- player.insert({name = item, count = amount})
-- end
-- end
-- local tile = surface.get_tile(player.position)
-- if tile.valid then
-- if tile.name == 'out-of-map' then
-- player.teleport(surface.find_non_colliding_position('character', memory.force.get_spawn_position(surface), 32, 0.5), surface)
-- end
-- end
end end
@ -1959,7 +1937,7 @@ local function event_on_rocket_launched(event)
local rocket_launch_coal_reward = Balance.rocket_launch_fuel_reward() local rocket_launch_coal_reward = Balance.rocket_launch_fuel_reward()
local rocket_launch_coin_reward = Balance.rocket_launch_coin_reward() local rocket_launch_coin_reward = Balance.rocket_launch_coin_reward()
destination.dynamic_data.rocketlaunched = true destination.dynamic_data.rocket_launched = true
if memory.stored_fuel then if memory.stored_fuel then
memory.stored_fuel = memory.stored_fuel + rocket_launch_coal_reward memory.stored_fuel = memory.stored_fuel + rocket_launch_coal_reward
Common.give_items_to_crew({ { name = 'coin', count = rocket_launch_coin_reward } }) Common.give_items_to_crew({ { name = 'coin', count = rocket_launch_coin_reward } })
@ -2041,40 +2019,32 @@ local function event_on_built_entity(event)
end end
local function event_on_console_chat(event) local function event_on_console_chat(event)
if not (event.message and event.player_index and game.players[event.player_index]) then return end if not (event.message and event.player_index) then return end
local global_memory = Memory.get_global_memory()
local player = game.players[event.player_index] local player = game.players[event.player_index]
if not (player and player.valid) then return end
local global_memory = Memory.get_global_memory()
local tag = player.tag or '' local tag = player.tag or ''
local color = player.chat_color local color = player.chat_color
-- if global.tournament_mode then
-- return
-- end
local crew_id = Common.get_id_from_force_name(player.force.name) local crew_id = Common.get_id_from_force_name(player.force.name)
Memory.set_working_id(crew_id) Memory.set_working_id(crew_id)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
-- NOTE: This check to see if player is in a crew is not reliable and can sometimes cause errors! local message_prefix = player.name .. tag
if player.force.name == Common.lobby_force_name then local full_message = message_prefix .. ': ' .. event.message
local other_force_indices = global_memory.crew_active_ids
for _, index in pairs(other_force_indices) do if player.force.name == Common.lobby_force_name then
for _, index in pairs(global_memory.crew_active_ids) do
local recipient_force_name = global_memory.crew_memories[index].force_name local recipient_force_name = global_memory.crew_memories[index].force_name
game.forces[recipient_force_name].print(player.name .. tag .. ' [LOBBY]: ' .. event.message, color) game.forces[recipient_force_name].print(message_prefix .. ' [LOBBY]: ' .. event.message, color)
end end
else else
-- NOTE: For some reason memory.name(or player.name?) can be nil so need this check. It was observed it happened after crew died and resetted, then I said something in lobby before launching new run. That's the only recorded occurence so far. if memory.name then
if memory.name and player.name then full_message = message_prefix .. ' [' .. memory.name .. ']: ' .. event.message
game.forces.player.print(player.name .. tag .. ' [' .. memory.name .. ']: ' .. event.message, color)
elseif player.name then
game.forces.player.print(player.name .. tag .. ': ' .. event.message, color)
log('Error (non-critical): memory.name is nil')
else
log('Error (non-critical): player.name is nil')
end end
game.forces.player.print(full_message, color)
end end
end end
@ -2082,8 +2052,6 @@ local function event_on_market_item_purchased(event)
Shop.event_on_market_item_purchased(event) Shop.event_on_market_item_purchased(event)
end end
local remove_boost_movement_speed_on_respawn = local remove_boost_movement_speed_on_respawn =
Token.register( Token.register(
function (data) function (data)

View File

@ -1,7 +1,7 @@
-- This file is part of thesixthroc's Pirate Ship softmod, licensed under GPLv3 and stored at https://github.com/ComfyFactory/ComfyFactorio and https://github.com/danielmartin0/ComfyFactorio-Pirates. -- This file is part of thesixthroc's Pirate Ship softmod, licensed under GPLv3 and stored at https://github.com/ComfyFactory/ComfyFactorio and https://github.com/danielmartin0/ComfyFactorio-Pirates.
--luacheck: ignore --luacheck: ignore
--luacheck ignores because tickinterval arguments are a code templating choice... --luacheck ignores because tick_interval arguments are a code templating choice...
local Memory = require 'maps.pirates.memory' local Memory = require 'maps.pirates.memory'
local Gui = require 'maps.pirates.gui.gui' local Gui = require 'maps.pirates.gui.gui'
@ -36,7 +36,7 @@ local QuestStructures = require 'maps.pirates.structures.quest_structures.quest_
local Public = {} local Public = {}
function Public.strobe_player_colors(tickinterval) function Public.strobe_player_colors(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local strobing_players = memory.speed_boost_characters local strobing_players = memory.speed_boost_characters
@ -54,7 +54,7 @@ function Public.strobe_player_colors(tickinterval)
end end
end end
function Public.prevent_unbarreling_off_ship(tickinterval) function Public.prevent_unbarreling_off_ship(tick_interval)
if Common.allow_barreling_off_ship then return end if Common.allow_barreling_off_ship then return end
if Common.activecrewcount() == 0 then return end if Common.activecrewcount() == 0 then return end
@ -80,7 +80,7 @@ function Public.prevent_unbarreling_off_ship(tickinterval)
end end
end end
function Public.apply_restrictions_to_machines(tickinterval) function Public.apply_restrictions_to_machines(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local boat = memory.boat local boat = memory.boat
@ -172,7 +172,7 @@ function Public.apply_restrictions_to_machines(tickinterval)
end end
end end
function Public.prevent_disembark(tickinterval) function Public.prevent_disembark(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if Common.activecrewcount() == 0 then return end if Common.activecrewcount() == 0 then return end
@ -223,7 +223,7 @@ function Public.prevent_disembark(tickinterval)
end end
end end
function Public.check_all_spawners_dead(tickinterval) function Public.check_all_spawners_dead(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local destination = Common.current_destination() local destination = Common.current_destination()
local boat = memory.boat local boat = memory.boat
@ -233,8 +233,8 @@ function Public.check_all_spawners_dead(tickinterval)
local surface = game.surfaces[destination.surface_name] local surface = game.surfaces[destination.surface_name]
if not (surface and surface.valid) then return end if not (surface and surface.valid) then return end
local spawnerscount = Common.spawner_count(surface) local spawners_count = Common.spawner_count(surface)
if spawnerscount == 0 then if spawners_count == 0 then
destination.static_params.base_cost_to_undock = nil destination.static_params.base_cost_to_undock = nil
Common.notify_force(memory.force, { 'pirates.destroyed_all_nests' }) Common.notify_force(memory.force, { 'pirates.destroyed_all_nests' })
end end
@ -242,7 +242,7 @@ function Public.check_all_spawners_dead(tickinterval)
end end
end end
function Public.raft_raids(tickinterval) function Public.raft_raids(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if memory.game_lost then return end if memory.game_lost then return end
local destination = Common.current_destination() local destination = Common.current_destination()
@ -268,7 +268,7 @@ function Public.raft_raids(tickinterval)
end end
end end
function Public.ship_deplete_fuel(tickinterval) function Public.ship_deplete_fuel(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if memory.game_lost then return end if memory.game_lost then return end
if not (memory.stored_fuel and memory.boat.input_chests and memory.boat.input_chests[1]) then return end if not (memory.stored_fuel and memory.boat.input_chests and memory.boat.input_chests[1]) then return end
@ -294,7 +294,7 @@ function Public.ship_deplete_fuel(tickinterval)
inv.remove { name = 'coal', count = count } inv.remove { name = 'coal', count = count }
end end
memory.stored_fuel = memory.stored_fuel + count + rate * tickinterval / 60 memory.stored_fuel = memory.stored_fuel + count + rate * tick_interval / 60
if rate < 0 and memory.stored_fuel < 1000 and (not (memory.parrot_fuel_most_recent_warning and memory.parrot_fuel_most_recent_warning >= game.tick - 60 * 60 * 12)) then --12 minutes if rate < 0 and memory.stored_fuel < 1000 and (not (memory.parrot_fuel_most_recent_warning and memory.parrot_fuel_most_recent_warning >= game.tick - 60 * 60 * 12)) then --12 minutes
memory.parrot_fuel_most_recent_warning = game.tick memory.parrot_fuel_most_recent_warning = game.tick
@ -317,7 +317,7 @@ function Public.victory_continue_reminder()
end end
end end
function Public.transfer_pollution(tickinterval) function Public.transfer_pollution(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local p = 0 local p = 0
@ -333,20 +333,20 @@ function Public.transfer_pollution(tickinterval)
memory.floating_pollution = memory.floating_pollution + p memory.floating_pollution = memory.floating_pollution + p
end end
function Public.shop_ratelimit_tick(tickinterval) function Public.shop_ratelimit_tick(tick_interval)
-- if memory.mainshop_rate_limit_ticker and memory.mainshop_rate_limit_ticker > 0 then -- if memory.mainshop_rate_limit_ticker and memory.mainshop_rate_limit_ticker > 0 then
-- memory.mainshop_rate_limit_ticker = memory.mainshop_rate_limit_ticker - tickinterval -- memory.mainshop_rate_limit_ticker = memory.mainshop_rate_limit_ticker - tick_interval
-- end -- end
end end
function Public.captain_warn_afk(tickinterval) function Public.captain_warn_afk(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if memory.game_lost then return end if memory.game_lost then return end
if memory.run_is_protected then return end if memory.run_is_protected then return end
if memory.playerindex_captain then if memory.playerindex_captain then
for _, player in pairs(game.connected_players) do for _, player in pairs(game.connected_players) do
if Common.is_captain(player) and #Common.crew_get_nonafk_crew_members() > 1 and player.afk_time >= Common.afk_time - 20 * 60 - 60 - tickinterval and player.afk_time < Common.afk_time - 20 * 60 then if Common.is_captain(player) and #Common.crew_get_nonafk_crew_members() > 1 and player.afk_time >= Common.afk_time - 20 * 60 - 60 - tick_interval and player.afk_time < Common.afk_time - 20 * 60 then
Common.notify_player_announce(player, { 'pirates.warn_nearly_afk_captain' }) Common.notify_player_announce(player, { 'pirates.warn_nearly_afk_captain' })
player.play_sound { path = 'utility/scenario_message' } player.play_sound { path = 'utility/scenario_message' }
end end
@ -354,7 +354,7 @@ function Public.captain_warn_afk(tickinterval)
end end
end end
function Public.prune_offline_characters_list(tickinterval) function Public.prune_offline_characters_list(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if memory.game_lost then return end if memory.game_lost then return end
@ -399,7 +399,7 @@ function Public.prune_offline_characters_list(tickinterval)
end end
end end
function Public.periodic_free_resources(tickinterval) function Public.periodic_free_resources(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if memory.game_lost then return end if memory.game_lost then return end
local destination = Common.current_destination() local destination = Common.current_destination()
@ -418,7 +418,7 @@ function Public.periodic_free_resources(tickinterval)
end end
end end
function Public.pick_up_tick(tickinterval) function Public.pick_up_tick(tick_interval)
if Common.activecrewcount() == 0 then return end if Common.activecrewcount() == 0 then return end
local destination = Common.current_destination() local destination = Common.current_destination()
@ -552,7 +552,7 @@ function Public.interpret_shorthanded_force_name(shorthanded_name)
return ret return ret
end end
function Public.place_cached_structures(tickinterval) function Public.place_cached_structures(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local destination = Common.current_destination() local destination = Common.current_destination()
local surface_name = destination.surface_name local surface_name = destination.surface_name
@ -777,13 +777,13 @@ function Public.place_cached_structures(tickinterval)
end end
end end
function Public.update_boat_stored_resources(tickinterval) function Public.update_boat_stored_resources(tick_interval)
if Common.activecrewcount() == 0 then return end if Common.activecrewcount() == 0 then return end
Common.update_boat_stored_resources() Common.update_boat_stored_resources()
end end
function Public.buried_treasure_check(tickinterval) function Public.buried_treasure_check(tick_interval)
if Common.activecrewcount() == 0 then return end if Common.activecrewcount() == 0 then return end
-- local memory = Memory.get_crew_memory() -- local memory = Memory.get_crew_memory()
@ -881,14 +881,14 @@ function Public.buried_treasure_check(tickinterval)
end end
end end
function Public.boat_movement_tick(tickinterval) function Public.boat_movement_tick(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local destination = Common.current_destination() local destination = Common.current_destination()
local enemy_force_name = memory.enemy_force_name local enemy_force_name = memory.enemy_force_name
local boat = memory.boat local boat = memory.boat
if boat and boat.surface_name and game.surfaces[boat.surface_name] and game.surfaces[boat.surface_name].valid and boat.speed and boat.speed > 0 and memory.game_lost == false then if boat and boat.surface_name and game.surfaces[boat.surface_name] and game.surfaces[boat.surface_name].valid and boat.speed and boat.speed > 0 and memory.game_lost == false then
local ticker_increase = boat.speed / 60 * tickinterval local ticker_increase = boat.speed / 60 * tick_interval
boat.speedticker1 = boat.speedticker1 + ticker_increase boat.speedticker1 = boat.speedticker1 + ticker_increase
boat.speedticker2 = boat.speedticker2 + ticker_increase boat.speedticker2 = boat.speedticker2 + ticker_increase
boat.speedticker3 = boat.speedticker3 + ticker_increase boat.speedticker3 = boat.speedticker3 + ticker_increase
@ -911,7 +911,7 @@ function Public.boat_movement_tick(tickinterval)
local eboat = destination.dynamic_data.enemyboats[i] local eboat = destination.dynamic_data.enemyboats[i]
if eboat and eboat.surface_name and game.surfaces[eboat.surface_name] and game.surfaces[eboat.surface_name].valid then if eboat and eboat.surface_name and game.surfaces[eboat.surface_name] and game.surfaces[eboat.surface_name].valid then
if eboat.state == Boats.enum_state.APPROACHING and eboat.speed and eboat.speed > 0 and memory.game_lost == false then if eboat.state == Boats.enum_state.APPROACHING and eboat.speed and eboat.speed > 0 and memory.game_lost == false then
local ticker_increase = eboat.speed / 60 * tickinterval local ticker_increase = eboat.speed / 60 * tick_interval
eboat.speedticker1 = eboat.speedticker1 + ticker_increase eboat.speedticker1 = eboat.speedticker1 + ticker_increase
if eboat.speedticker1 >= 1 then if eboat.speedticker1 >= 1 then
eboat.speedticker1 = 0 eboat.speedticker1 = 0
@ -940,229 +940,168 @@ function Public.boat_movement_tick(tickinterval)
end end
end end
function Public.crowsnest_natural_move(tickinterval) function Public.crowsnest_natural_move(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if not (memory.boat and memory.boat.state == Structures.Boats.enum_state.ATSEA_SAILING) then return end if not (memory.boat and memory.boat.state == Structures.Boats.enum_state.ATSEA_SAILING) then return end
if memory.loadingticks then return end if memory.loading_ticks then return end
if Public.overworld_check_collisions() then return end if Public.overworld_check_collisions() then return end
Overworld.try_overworld_move_v2 { x = 1, y = 0 } Overworld.try_overworld_move_v2 { x = 1, y = 0 }
end end
function Public.overworld_check_collisions(tickinterval) function Public.overworld_check_collisions(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if not memory.loadingticks then if not memory.loading_ticks then
Overworld.check_for_kraken_collisions() Overworld.check_for_kraken_collisions()
return Overworld.check_for_destination_collisions() return Overworld.check_for_destination_collisions()
end end
return false return false
end end
function Public.loading_update(tickinterval) function Public.loading_update(tick_interval)
local global_memory = Memory.get_global_memory()
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if not memory.loading_ticks or memory.game_lost then return end
local boat = memory.boat local boat = memory.boat
if not boat or not boat.state then return end
if not memory.loadingticks then return end local destination_index = memory.map_being_loaded_destination_index
if not destination_index then
if memory.game_lost then return end memory.loading_ticks = nil
return
end
local currentdestination = Common.current_destination() local currentdestination = Common.current_destination()
if not currentdestination then return end
local destination_index = memory.mapbeingloadeddestination_index if currentdestination.type == Surfaces.enum.LOBBY then
if not destination_index then Public.loading_update_lobby(tick_interval, memory, boat, destination_index, currentdestination)
memory.loadingticks = nil elseif boat.state == Boats.enum_state.ATSEA_LOADING_MAP then
return Public.loading_update_atsea(tick_interval, memory, boat, destination_index, currentdestination)
elseif boat.state == Boats.enum_state.LANDED then
Public.loading_update_landed(tick_interval, memory, boat, destination_index, currentdestination)
end end
end
if not boat.state then return end function Public.loading_update_lobby(tick_interval, memory, boat, destination_index, currentdestination)
memory.loading_ticks = memory.loading_ticks + tick_interval
local map_loads = false if memory.loading_ticks >= 350 - Common.loading_interval then
if boat.state == Boats.enum_state.LANDED then map_loads = true end if Boats.players_on_boat_count(boat) > 0 then
if boat.state == Boats.enum_state.ATSEA_LOADING_MAP then map_loads = true end if memory.loading_ticks < 350 then
if boat.state == Boats.enum_state.LEAVING_DOCK then map_loads = true end Common.notify_game({ '', '[' .. memory.name .. '] ', { 'pirates.loading_new_game' } })
if boat.state == Boats.enum_state.APPROACHING and destination_index == 1 then map_loads = true end elseif memory.loading_ticks > 410 then
if not Crowsnest.get_crowsnest_surface() then
Crew.initialise_crowsnest_1()
elseif memory.loading_ticks >= 470 then
Crew.initialise_crowsnest_2()
Overworld.ensure_lane_generated_up_to(0, Crowsnest.Data.visibilitywidth)
Overworld.ensure_lane_generated_up_to(24, Crowsnest.Data.visibilitywidth)
Overworld.ensure_lane_generated_up_to(-24, Crowsnest.Data.visibilitywidth)
if not map_loads then return end for i = 1, #memory.destinations do
if memory.destinations[i].overworld_position.x == 0 then
-- if memory.loadingticks % 100 == 0 then game.print(memory.loadingticks) end memory.map_being_loaded_destination_index = i
break
local destination_data = memory.destinations[destination_index]
if boat.state == Boats.enum_state.ATSEA_LOADING_MAP or boat.state == Boats.enum_state.LEAVING_DOCK then
local other_crew_loading = nil
local crew_fighting_kraken = nil
for id, crew_memory in pairs(global_memory.crew_memories) do
local is_loading = crew_memory.loadingticks and crew_memory.boat and crew_memory.boat.state and crew_memory.boat.state == Boats.enum_state.ATSEA_LOADING_MAP
if is_loading and (crew_memory.loadingticks > memory.loadingticks or (crew_memory.loadingticks == memory.loadingticks and crew_memory.age and memory.age and crew_memory.age < memory.age)) then
other_crew_loading = id
end
if Kraken.get_active_kraken_count(crew_memory.id) > 0 then
crew_fighting_kraken = id
end
end
if crew_fighting_kraken and crew_fighting_kraken == memory.id then
memory.halted_due_to_crew_loading = nil
memory.halted_due_to_crew_fighting_kraken = memory.id
return
end
-- When other crews are loading, we halt loading if we're ATSEA_LOADING_MAP:
if other_crew_loading and boat.state == Boats.enum_state.ATSEA_LOADING_MAP then
if (not memory.halted_due_to_crew_loading) or memory.halted_due_to_crew_loading ~= other_crew_loading then
memory.halted_due_to_crew_loading = other_crew_loading
memory.halted_due_to_crew_fighting_kraken = nil
local waiting_crew_name = global_memory.crew_memories[other_crew_loading].name or "Unknown crew"
Common.notify_force(memory.force, { 'pirates.wait_for_crew_to_finish_loading', waiting_crew_name })
end
return
end
if crew_fighting_kraken then
if (not memory.halted_due_to_crew_fighting_kraken) or memory.halted_due_to_crew_fighting_kraken ~= crew_fighting_kraken then
memory.halted_due_to_crew_loading = nil
memory.halted_due_to_crew_fighting_kraken = crew_fighting_kraken
local fighting_crew_name = global_memory.crew_memories[crew_fighting_kraken].name or "Unknown crew"
Common.notify_force(memory.force, { 'pirates.wait_for_crew_to_finish_fighting_kraken', fighting_crew_name })
end
if (boat.state == Boats.enum_state.LEAVING_DOCK) then
boat.speed = 0 -- This line depends on the fact it executes after the tick event that sets the boat speed to a positive value.
end
return
end
end
memory.halted_due_to_crew_loading = nil
memory.halted_due_to_crew_fighting_kraken = nil
memory.loadingticks = memory.loadingticks + tickinterval
if (not destination_data) then
if boat and currentdestination.type == Surfaces.enum.LOBBY then
if memory.loadingticks >= 350 - Common.loading_interval then
if Boats.players_on_boat_count(boat) > 0 then
if memory.loadingticks < 350 then
Common.notify_game({ '', '[' .. memory.name .. '] ', { 'pirates.loading_new_game' } })
elseif memory.loadingticks > 410 then
if not Crowsnest.get_crowsnest_surface() then
Crew.initialise_crowsnest_1()
elseif memory.loadingticks >= 470 then
Crew.initialise_crowsnest_2()
Overworld.ensure_lane_generated_up_to(0, Crowsnest.Data.visibilitywidth)
Overworld.ensure_lane_generated_up_to(24, Crowsnest.Data.visibilitywidth)
Overworld.ensure_lane_generated_up_to(-24, Crowsnest.Data.visibilitywidth)
for i = 1, #memory.destinations do
if memory.destinations[i].overworld_position.x == 0 then
memory.mapbeingloadeddestination_index = i
break
end
end
Surfaces.create_surface(memory.destinations[memory.mapbeingloadeddestination_index])
end end
end end
else
if memory.loadingticks >= 1100 then Surfaces.create_surface(memory.destinations[memory.map_being_loaded_destination_index])
Boats.destroy_boat(boat)
Crew.disband_crew()
return
end
end end
end end
else
if memory.loading_ticks >= 1100 then
Boats.destroy_boat(boat)
Crew.disband_crew()
return
end
end
end
if memory.loading_ticks > 500 then
local d = (Crowsnest.Data.visibilitywidth / 3) * (memory.loading_ticks - 500) / 500
Overworld.ensure_lane_generated_up_to(0, d + 26)
Overworld.ensure_lane_generated_up_to(24, d + 13)
Overworld.ensure_lane_generated_up_to(-24, d)
end
if memory.loading_ticks > 860 then
if Boats.players_on_boat_count(boat) > 0 then
local fraction = 0.07 + 0.7 * (memory.loading_ticks - 860) / 400
PiratesApiEvents.load_some_map_chunks(destination_index, fraction)
else
Boats.destroy_boat(boat)
Crew.disband_crew()
return
end
end
if memory.loading_ticks > 1230 then
if boat then
boat.speed = 0
end
end
if memory.loading_ticks >= 1260 then
if boat and boat.rendering_crewname_text and boat.rendering_crewname_text.valid then
boat.rendering_crewname_text.destroy()
boat.rendering_crewname_text = nil
end
Progression.go_from_starting_dock_to_first_destination()
log("starting game for crew " .. memory.name)
end
end
function Public.loading_update_atsea(tick_interval, memory, boat, destination_index, currentdestination)
memory.loading_ticks = memory.loading_ticks + tick_interval
local total = Common.map_loading_ticks_atsea
if currentdestination.type == Surfaces.enum.DOCK then
total = Common.map_loading_ticks_atsea_dock
elseif currentdestination.type == Surfaces.enum.ISLAND and currentdestination.subtype == IslandEnum.enum.MAZE then
total = Common.map_loading_ticks_atsea_maze
end
local fraction = memory.loading_ticks / (total + (memory.extra_time_at_sea or 0))
if fraction > Common.fraction_of_map_loaded_at_sea then
if currentdestination.type == Surfaces.enum.DOCK then
Progression.progress_to_destination(destination_index)
else
boat.state = Boats.enum_state.ATSEA_WAITING_TO_SAIL
memory.at_sea_waiting_game_tick = game.tick
end end
return
else else
local surface_name = destination_data.surface_name local surface = game.surfaces[currentdestination.surface_name]
if not surface_name then return end if surface and surface.valid then
local surface = game.surfaces[surface_name] PiratesApiEvents.load_some_map_chunks_random_order(surface, currentdestination, fraction)
if not surface then return end if currentdestination.subtype == IslandEnum.enum.CAVE then
local cave_surface = currentdestination.dynamic_data.cave_miner.cave_surface
if cave_surface and cave_surface.valid then
if currentdestination.type == Surfaces.enum.LOBBY then PiratesApiEvents.load_some_map_chunks_random_order(cave_surface, currentdestination, fraction)
if memory.loadingticks >= 1260 then
if boat and boat.rendering_crewname_text and boat.rendering_crewname_text.valid then
boat.rendering_crewname_text.destroy()
boat.rendering_crewname_text = nil
end end
Progression.go_from_starting_dock_to_first_destination()
log("starting game for crew " .. memory.name)
elseif memory.loadingticks > 1230 then
if boat then
boat.speed = 0
end
elseif memory.loadingticks > 860 then
if Boats.players_on_boat_count(boat) > 0 then
local fraction = 0.07 + 0.7 * (memory.loadingticks - 860) / 400
PiratesApiEvents.load_some_map_chunks(destination_index, fraction)
else
Boats.destroy_boat(boat)
Crew.disband_crew()
return
end
elseif memory.loadingticks > 500 then
local d = (Crowsnest.Data.visibilitywidth / 3) * (memory.loadingticks - 500) / 500
Overworld.ensure_lane_generated_up_to(0, d + 26)
Overworld.ensure_lane_generated_up_to(24, d + 13)
Overworld.ensure_lane_generated_up_to(-24, d)
-- elseif memory.loadingticks <= 500 and memory.loadingticks >= 100 then
-- local fraction = 0.02 + 0.05 * (memory.loadingticks - 100) / 400
-- PiratesApiEvents.load_some_map_chunks(destination_index, fraction)
end
elseif boat.state == Boats.enum_state.ATSEA_LOADING_MAP then
local total = Common.map_loading_ticks_atsea
if currentdestination.type == Surfaces.enum.DOCK then
total = Common.map_loading_ticks_atsea_dock
elseif currentdestination.type == Surfaces.enum.ISLAND and currentdestination.subtype == IslandEnum.enum.MAZE then
total = Common.map_loading_ticks_atsea_maze
end
-- local eta_ticks = total - (memory.loadingticks - (memory.extra_time_at_sea or 0))
local fraction = memory.loadingticks / (total + (memory.extra_time_at_sea or 0))
if fraction > Common.fraction_of_map_loaded_at_sea then
if currentdestination.type == Surfaces.enum.DOCK then
Progression.progress_to_destination(destination_index)
else
boat.state = Boats.enum_state.ATSEA_WAITING_TO_SAIL
memory.at_sea_waiting_game_tick = game.tick
end
else
PiratesApiEvents.load_some_map_chunks_random_order(surface, currentdestination, fraction) --random order is good for maze world
if currentdestination.subtype == IslandEnum.enum.CAVE then
PiratesApiEvents.load_some_map_chunks_random_order(currentdestination.dynamic_data.cave_miner.cave_surface, currentdestination, fraction)
end
end
elseif boat.state == Boats.enum_state.LANDED then
local fraction = Common.fraction_of_map_loaded_at_sea + (1 - Common.fraction_of_map_loaded_at_sea) * memory.loadingticks / Common.map_loading_ticks_onisland
if fraction > 1 then
memory.loadingticks = nil
else
PiratesApiEvents.load_some_map_chunks(destination_index, fraction)
end end
end end
end end
end end
function Public.crowsnest_steer(tickinterval) function Public.loading_update_landed(tick_interval, memory, boat, destination_index, currentdestination)
memory.loading_ticks = memory.loading_ticks + tick_interval
local fraction = Common.fraction_of_map_loaded_at_sea + (1 - Common.fraction_of_map_loaded_at_sea) * memory.loading_ticks / Common.map_loading_ticks_onisland
if fraction > 1 then
memory.loading_ticks = nil
else
PiratesApiEvents.load_some_map_chunks(destination_index, fraction)
end
end
function Public.crowsnest_steer(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local boat = memory.boat local boat = memory.boat
@ -1174,18 +1113,18 @@ function Public.crowsnest_steer(tickinterval)
boat.state and boat.state and
boat.state == Structures.Boats.enum_state.ATSEA_SAILING and boat.state == Structures.Boats.enum_state.ATSEA_SAILING and
memory.game_lost == false and memory.game_lost == false and
boat.crowsneststeeringchests boat.crows_nest_steering_chests
) )
then then
return return
end end
local leftchest = boat.crowsneststeeringchests.left local left_chest = boat.crows_nest_steering_chests.left
local rightchest = boat.crowsneststeeringchests.right local right_chest = boat.crows_nest_steering_chests.right
if not (leftchest and leftchest.valid and rightchest and rightchest.valid) then return end if not (left_chest and left_chest.valid and right_chest and right_chest.valid) then return end
local inv_left = leftchest.get_inventory(defines.inventory.chest) local inv_left = left_chest.get_inventory(defines.inventory.chest)
local inv_right = rightchest.get_inventory(defines.inventory.chest) local inv_right = right_chest.get_inventory(defines.inventory.chest)
local count_left = inv_left.get_item_count("rail-signal") local count_left = inv_left.get_item_count("rail-signal")
local count_right = inv_right.get_item_count("rail-signal") local count_right = inv_right.get_item_count("rail-signal")
@ -1206,68 +1145,65 @@ function Public.crowsnest_steer(tickinterval)
end end
end end
function Public.silo_update(tickinterval) function Public.silo_update(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local destination = Common.current_destination() local destination = Common.current_destination()
if destination.type == Surfaces.enum.ISLAND then if not (destination and destination.type == Surfaces.enum.ISLAND) then return end
local dynamic_data = destination.dynamic_data
local silos = dynamic_data.rocketsilos
if silos then local dynamic_data = destination.dynamic_data
local silo = silos[1] if not dynamic_data then return end
if silo and silo.valid then
if dynamic_data.silocharged then local silos = dynamic_data.rocketsilos
if not dynamic_data.rocketlaunched then if not silos then return end
silo.launch_rocket()
local silo = silos[1]
if not (silo and silo.valid) then return end
if dynamic_data.silo_is_charged then
if not dynamic_data.rocket_launched then
silo.launch_rocket()
end
else
local p = silo.position
local e = dynamic_data.energy_charged_in_silo_since_last_check or 0
dynamic_data.energy_charged_in_silo_since_last_check = 0
dynamic_data.rocket_silo_energy_consumed = (dynamic_data.rocket_silo_energy_consumed or 0) + e
dynamic_data.rocket_silo_energy_consumed_within_last_half_second = e
if memory.enemy_force_name then
local ef = memory.enemy_force
if ef and ef.valid then
local extra_evo = Balance.evolution_per_full_silo_charge() * e / dynamic_data.rocket_silo_energy_needed
Common.increment_evo(extra_evo)
dynamic_data.evolution_accrued_silo = (dynamic_data.evolution_accrued_silo or 0) + extra_evo
end
end
local pollution = e / 1000000 * Balance.silo_total_pollution() / Balance.silo_energy_needed_MJ()
if p and pollution then
local surface = game.surfaces[destination.surface_name]
if surface and surface.valid then
game.get_pollution_statistics(surface).on_flow('rocket-silo', pollution)
memory.floating_pollution = (memory.floating_pollution or 0) + 3 * pollution / 4
surface.pollute(p, pollution / 4)
if memory.overworldx >= 0 and dynamic_data.rocket_silo_energy_consumed >= 0.25 * dynamic_data.rocket_silo_energy_needed and (not dynamic_data.parrot_silo_warned) then
dynamic_data.parrot_silo_warned = true
local spawners_count = Common.spawner_count(surface)
if spawners_count > 0 then
Common.parrot_speak(memory.force, { 'pirates.parrot_silo_warning' })
end end
else elseif dynamic_data.rocket_silo_energy_consumed >= dynamic_data.rocket_silo_energy_needed and (not (silo.rocket_parts == 100)) and (dynamic_data.silo_is_charged == false) and (not memory.game_lost) then
local p = silo.position silo.rocket_parts = 100
dynamic_data.silo_is_charged = true
local e = dynamic_data.energychargedinsilosincelastcheck or 0 if CoreData.rocket_silo_death_causes_loss then
dynamic_data.energychargedinsilosincelastcheck = 0 silo.destructible = false
dynamic_data.rocketsiloenergyconsumed = dynamic_data.rocketsiloenergyconsumed + e
dynamic_data.rocketsiloenergyconsumedwithinlasthalfsecond = e
if memory.enemy_force_name then
local ef = memory.enemy_force
if ef and ef.valid then
local extra_evo = Balance.evolution_per_full_silo_charge() * e / dynamic_data.rocketsiloenergyneeded
Common.increment_evo(extra_evo)
dynamic_data.evolution_accrued_silo = dynamic_data.evolution_accrued_silo + extra_evo
end
end
local pollution = e / 1000000 * Balance.silo_total_pollution() / Balance.silo_energy_needed_MJ()
if p and pollution then
local surface = game.surfaces[destination.surface_name]
game.get_pollution_statistics(surface).on_flow('rocket-silo', pollution)
if not memory.floating_pollution then memory.floating_pollution = 0 end
-- Eventually I want to reformulate pollution not to pull from the map directly, but to pull from pollution_statistics. Previously all the silo pollution went to the map, but this causes a lag ~1-2 minutes. So as a compromise, let's send some to floating_pollution directly, and some to the map:
memory.floating_pollution = memory.floating_pollution + 3 * pollution / 4
surface.pollute(p, pollution / 4)
if memory.overworldx >= 0 and dynamic_data.rocketsiloenergyconsumed >= 0.25 * dynamic_data.rocketsiloenergyneeded and (not dynamic_data.parrot_silo_warned) then
dynamic_data.parrot_silo_warned = true
local spawnerscount = Common.spawner_count(surface)
if spawnerscount > 0 then
Common.parrot_speak(memory.force, { 'pirates.parrot_silo_warning' })
end
elseif dynamic_data.rocketsiloenergyconsumed >= dynamic_data.rocketsiloenergyneeded and (not (silo.rocket_parts == 100)) and (dynamic_data.silocharged == false) and (not memory.game_lost) then
-- silo.energy = 0
silo.rocket_parts = 100
dynamic_data.silocharged = true
if CoreData.rocket_silo_death_causes_loss then
-- become immune after launching
silo.destructible = false
end
end
end end
end end
end end
@ -1275,18 +1211,18 @@ function Public.silo_update(tickinterval)
end end
end end
function Public.slower_boat_tick(tickinterval) function Public.slower_boat_tick(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if memory.game_lost then return end if memory.game_lost then return end
local destination = Common.current_destination() local destination = Common.current_destination()
if memory.boat.state == Boats.enum_state.LEAVING_DOCK then if memory.boat.state == Boats.enum_state.LEAVING_DOCK then
memory.boat.speed = Math.min(memory.boat.speed + 40 / tickinterval, 12) memory.boat.speed = Math.min(memory.boat.speed + 40 / tick_interval, 12)
end end
local p = memory.boat.position local p = memory.boat.position
if p and destination.subtype ~= IslandEnum.enum.RADIOACTIVE and destination.surface_name then --no locomotive pollute on radioactive islands if p and destination.subtype ~= IslandEnum.enum.RADIOACTIVE and destination.surface_name then --no locomotive pollute on radioactive islands
local pollution = Balance.boat_passive_pollution_per_minute(destination.dynamic_data.timer) / 3600 * tickinterval local pollution = Balance.boat_passive_pollution_per_minute(destination.dynamic_data.timer) / 3600 * tick_interval
local surface = game.surfaces[destination.surface_name] local surface = game.surfaces[destination.surface_name]
if surface and surface.valid then if surface and surface.valid then
@ -1308,7 +1244,7 @@ function Public.slower_boat_tick(tickinterval)
-- end -- end
end end
function Public.LOS_tick(tickinterval) function Public.LOS_tick(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local boat = memory.boat local boat = memory.boat
local destination = Common.current_destination() local destination = Common.current_destination()
@ -1332,7 +1268,7 @@ function Public.LOS_tick(tickinterval)
end end
end end
function Public.minimap_jam(tickinterval) function Public.minimap_jam(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local boat = memory.boat local boat = memory.boat
@ -1347,7 +1283,7 @@ function Public.minimap_jam(tickinterval)
end end
end end
-- function Public.crewtick_handle_delayed_tasks(tickinterval) -- function Public.crewtick_handle_delayed_tasks(tick_interval)
-- local memory = Memory.get_crew_memory() -- local memory = Memory.get_crew_memory()
-- for _, task in pairs(memory.buffered_tasks) do -- for _, task in pairs(memory.buffered_tasks) do
@ -1367,7 +1303,7 @@ end
-- Delay.move_tasks_to_buffer() -- Delay.move_tasks_to_buffer()
-- end -- end
function Public.Kraken_Destroyed_Backup_check(tickinterval) -- a server became stuck when the kraken spawner entity disappeared but the kraken_die had not fired, and I'm not sure why, so this is a backup checker for that case function Public.Kraken_Destroyed_Backup_check(tick_interval) -- a server became stuck when the kraken spawner entity disappeared but the kraken_die had not fired, and I'm not sure why, so this is a backup checker for that case
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local boat = memory.boat local boat = memory.boat
@ -1397,7 +1333,7 @@ function Public.Kraken_Destroyed_Backup_check(tickinterval) -- a server became s
end end
end end
function Public.quest_progress_tick(tickinterval) function Public.quest_progress_tick(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if memory.game_lost then return end if memory.game_lost then return end
local destination = Common.current_destination() local destination = Common.current_destination()
@ -1408,7 +1344,7 @@ function Public.quest_progress_tick(tickinterval)
if dynamic_data.quest_type then if dynamic_data.quest_type then
if dynamic_data.quest_type == Quest.enum.TIME and (not dynamic_data.quest_complete) and dynamic_data.quest_progress > 0 and dynamic_data.quest_progressneeded ~= 1 then if dynamic_data.quest_type == Quest.enum.TIME and (not dynamic_data.quest_complete) and dynamic_data.quest_progress > 0 and dynamic_data.quest_progressneeded ~= 1 then
dynamic_data.quest_progress = dynamic_data.quest_progress - tickinterval / 60 dynamic_data.quest_progress = dynamic_data.quest_progress - tick_interval / 60
end end
if dynamic_data.quest_type == Quest.enum.RESOURCEFLOW and (not dynamic_data.quest_complete) then if dynamic_data.quest_type == Quest.enum.RESOURCEFLOW and (not dynamic_data.quest_complete) then
@ -1465,7 +1401,7 @@ function Public.silo_insta_update()
local silos = dynamic_data.rocketsilos local silos = dynamic_data.rocketsilos
if silos and silos[1] and silos[1].valid then --need the first silo to be alive in order to charge any others if silos and silos[1] and silos[1].valid then --need the first silo to be alive in order to charge any others
if dynamic_data.silocharged then if dynamic_data.silo_is_charged then
for i, silo in ipairs(silos) do for i, silo in ipairs(silos) do
if silo and silo.valid then --sometimes theyre overwritten by other structures e.g. market if silo and silo.valid then --sometimes theyre overwritten by other structures e.g. market
silo.energy = silo.electric_buffer_size silo.energy = silo.electric_buffer_size
@ -1475,14 +1411,14 @@ function Public.silo_insta_update()
for i, silo in ipairs(silos) do for i, silo in ipairs(silos) do
if silo and silo.valid then --sometimes theyre overwritten by other structures e.g. market if silo and silo.valid then --sometimes theyre overwritten by other structures e.g. market
local e = silo.energy - 1 local e = silo.energy - 1
local e2 = dynamic_data.rocketsiloenergyneeded - dynamic_data.rocketsiloenergyconsumed local e2 = dynamic_data.rocket_silo_energy_needed - dynamic_data.rocket_silo_energy_consumed
if e > 0 and e2 > 0 then if e > 0 and e2 > 0 then
local absorb = Math.min(e, e2) local absorb = Math.min(e, e2)
dynamic_data.energychargedinsilosincelastcheck = dynamic_data.energychargedinsilosincelastcheck + absorb dynamic_data.energy_charged_in_silo_since_last_check = dynamic_data.energy_charged_in_silo_since_last_check + absorb
silo.energy = silo.energy - absorb silo.energy = silo.energy - absorb
if dynamic_data.rocketsilochargedbools and (not dynamic_data.rocketsilochargedbools[i]) then if dynamic_data.rocket_silo_charged_bools and (not dynamic_data.rocket_silo_charged_bools[i]) then
dynamic_data.rocketsilochargedbools[i] = true dynamic_data.rocket_silo_charged_bools[i] = true
local inv = silo.get_inventory(defines.inventory.assembling_machine_input) local inv = silo.get_inventory(defines.inventory.assembling_machine_input)
inv.insert { name = 'processing-unit', count = 10 } inv.insert { name = 'processing-unit', count = 10 }
inv.insert { name = 'low-density-structure', count = 10 } inv.insert { name = 'low-density-structure', count = 10 }
@ -1497,13 +1433,13 @@ function Public.silo_insta_update()
end end
end end
-- function Public.parrot_tick(tickinterval) -- function Public.parrot_tick(tick_interval)
-- Parrot.parrot_tick() -- Parrot.parrot_tick()
-- end -- end
function Public.update_player_guis(tickinterval) function Public.update_player_guis(tick_interval)
-- local global_memory = Memory.get_global_memory() -- local global_memory = Memory.get_global_memory()
local players = game.connected_players local players = game.connected_players
@ -1742,12 +1678,12 @@ function Public.revealed_buried_treasure_distance_check()
end end
end end
function Public.update_pet_biter_lifetime(tickinterval) function Public.update_pet_biter_lifetime(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if memory.pet_biters then if memory.pet_biters then
for id, pet_biter in pairs(memory.pet_biters) do for id, pet_biter in pairs(memory.pet_biters) do
if pet_biter.pet and pet_biter.pet.valid then if pet_biter.pet and pet_biter.pet.valid then
pet_biter.time_to_live = pet_biter.time_to_live - tickinterval pet_biter.time_to_live = pet_biter.time_to_live - tick_interval
if pet_biter.time_to_live <= 0 then if pet_biter.time_to_live <= 0 then
memory.pet_biters[id].pet.die() memory.pet_biters[id].pet.die()
memory.pet_biters[id] = nil memory.pet_biters[id] = nil

View File

@ -592,7 +592,7 @@ if _DEBUG then
Memory.set_working_id(data.id) Memory.set_working_id(data.id)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
memory.loadingticks = 0 memory.loading_ticks = 0
-- local surface = game.surfaces[Common.current_destination().surface_name] -- local surface = game.surfaces[Common.current_destination().surface_name]
-- surface.request_to_generate_chunks({x = 0, y = 0}, 10) -- surface.request_to_generate_chunks({x = 0, y = 0}, 10)
@ -610,12 +610,12 @@ if _DEBUG then
for i = 1, #memory.destinations do for i = 1, #memory.destinations do
if memory.destinations[i].overworld_position.x == 0 then if memory.destinations[i].overworld_position.x == 0 then
memory.mapbeingloadeddestination_index = i memory.map_being_loaded_destination_index = i
break break
end end
end end
memory.currentdestination_index = memory.mapbeingloadeddestination_index memory.currentdestination_index = memory.map_being_loaded_destination_index
Surfaces.create_surface(Common.current_destination()) Surfaces.create_surface(Common.current_destination())
Task.set_timeout_in_ticks(60, go_2, { id = data.id }) Task.set_timeout_in_ticks(60, go_2, { id = data.id })
end end
@ -699,7 +699,7 @@ if _DEBUG then
-- memory.boat = boat -- memory.boat = boat
-- boat.dockedposition = boat.position -- boat.dockedposition = boat.position
-- boat.decksteeringchests = {} -- boat.decksteeringchests = {}
-- boat.crowsneststeeringchests = {} -- boat.crows_nest_steering_chests = {}
Task.set_timeout_in_ticks(120, go_1, { id = memory.id }) Task.set_timeout_in_ticks(120, go_1, { id = memory.id })
else else

View File

@ -582,7 +582,7 @@ function Public.query_can_pay_cost_to_leave()
local can_leave = true local can_leave = true
for name, count in pairs(adjusted_cost) do for name, count in pairs(adjusted_cost) do
if name == 'launch_rocket' and count == true then if name == 'launch_rocket' and count == true then
if not destination.dynamic_data.rocketlaunched then if not destination.dynamic_data.rocket_launched then
can_leave = false can_leave = false
end end
else else

View File

@ -315,9 +315,9 @@ function Public.player_and_crew_state_bools(player)
atsea_victorious_bool = boat and boat.state == Boats.enum_state.ATSEA_VICTORIOUS atsea_victorious_bool = boat and boat.state == Boats.enum_state.ATSEA_VICTORIOUS
landed_bool = boat and boat.state == Boats.enum_state.LANDED landed_bool = boat and boat.state == Boats.enum_state.LANDED
quest_bool = (dynamic_data.quest_type ~= nil) and onmap_bool quest_bool = (dynamic_data.quest_type ~= nil) and onmap_bool
charged_bool = dynamic_data.silocharged charged_bool = dynamic_data.silo_is_charged
silo_bool = dynamic_data.rocketsilos and onmap_bool and ((dynamic_data.rocketsilos[1] and dynamic_data.rocketsilos[1].valid) or charged_bool) silo_bool = dynamic_data.rocketsilos and onmap_bool and ((dynamic_data.rocketsilos[1] and dynamic_data.rocketsilos[1].valid) or charged_bool)
launched_bool = dynamic_data.rocketlaunched launched_bool = dynamic_data.rocket_launched
cost_bool = destination.static_params.base_cost_to_undock and (not atsea_sailing_bool) and (not atsea_waiting_bool) and (not atsea_victorious_bool) and (not retreating_bool) cost_bool = destination.static_params.base_cost_to_undock and (not atsea_sailing_bool) and (not atsea_waiting_bool) and (not atsea_victorious_bool) and (not retreating_bool)
cost_includes_rocket_launch_bool = cost_bool and destination.static_params.base_cost_to_undock['launch_rocket'] cost_includes_rocket_launch_bool = cost_bool and destination.static_params.base_cost_to_undock['launch_rocket']
@ -326,7 +326,7 @@ function Public.player_and_crew_state_bools(player)
end end
if boat then if boat then
atsea_loading_bool = boat.state == Boats.enum_state.ATSEA_LOADING_MAP and memory.loadingticks atsea_loading_bool = boat.state == Boats.enum_state.ATSEA_LOADING_MAP and memory.loading_ticks
character_on_deck_bool = player.character and player.character.position and player.surface.name and player.surface.name == boat.surface_name character_on_deck_bool = player.character and player.character.position and player.surface.name and player.surface.name == boat.surface_name

View File

@ -542,7 +542,7 @@ function Public.process_etaframe_update(player, flow1, bools)
total = Common.map_loading_ticks_atsea_maze total = Common.map_loading_ticks_atsea_maze
end end
local eta_ticks = total + (memory.extra_time_at_sea or 0) - memory.loadingticks local eta_ticks = total + (memory.extra_time_at_sea or 0) - memory.loading_ticks
flow2.etaframe_label_1.caption = { 'pirates.gui_etaframe_loading' } flow2.etaframe_label_1.caption = { 'pirates.gui_etaframe_loading' }
flow2.etaframe_label_2.caption = 'for ' .. Utils.standard_string_form_of_time_in_seconds(eta_ticks / 60) flow2.etaframe_label_2.caption = 'for ' .. Utils.standard_string_form_of_time_in_seconds(eta_ticks / 60)
@ -662,7 +662,7 @@ function Public.process_etaframe_update(player, flow1, bools)
end end
if adjusted_costs['launch_rocket'] and cost_table['cost_launch_rocket'] then if adjusted_costs['launch_rocket'] and cost_table['cost_launch_rocket'] then
if bools.atsea_loading_bool or (not dynamic_data.rocketlaunched) then if bools.atsea_loading_bool or (not dynamic_data.rocket_launched) then
cost_table['cost_launch_rocket'].number = 1 cost_table['cost_launch_rocket'].number = 1
else else
cost_table['cost_launch_rocket'].number = 0 cost_table['cost_launch_rocket'].number = 0
@ -747,9 +747,9 @@ function Public.process_siloframe_and_questframe_updates(flowsilo, flowquest, bo
flow1.silo_progressbar.visible = true flow1.silo_progressbar.visible = true
flow1.silo_label_3.visible = false flow1.silo_label_3.visible = false
local consumed = dynamic_data.rocketsiloenergyconsumed local consumed = dynamic_data.rocket_silo_energy_consumed
local needed = dynamic_data.rocketsiloenergyneeded local needed = dynamic_data.rocket_silo_energy_needed
local recent = (dynamic_data.rocketsiloenergyconsumedwithinlasthalfsecond * 2) local recent = (dynamic_data.rocket_silo_energy_consumed_within_last_half_second * 2)
flow1.silo_progressbar.value = consumed / needed flow1.silo_progressbar.value = consumed / needed
@ -1199,7 +1199,7 @@ local function on_gui_click(event)
end end
elseif memory.boat.state == Boats.enum_state.ATSEA_WAITING_TO_SAIL then elseif memory.boat.state == Boats.enum_state.ATSEA_WAITING_TO_SAIL then
if Permissions.player_privilege_level(player) >= Permissions.privilege_levels.CAPTAIN then if Permissions.player_privilege_level(player) >= Permissions.privilege_levels.CAPTAIN then
local destination_index = memory.mapbeingloadeddestination_index local destination_index = memory.map_being_loaded_destination_index
Progression.progress_to_destination(destination_index) Progression.progress_to_destination(destination_index)
end end

View File

@ -60,7 +60,7 @@ function Public.fallthrough_crew_memory() --could make this a metatable, but met
stored_resources = {}, stored_resources = {},
position = nil, --the far right edge of the boat position = nil, --the far right edge of the boat
decksteeringchests = nil, decksteeringchests = nil,
crowsneststeeringchests = nil, crows_nest_steering_chests = nil,
cannons = nil, cannons = nil,
EEI = nil, EEI = nil,
EEIpower_production = nil, EEIpower_production = nil,

View File

@ -586,8 +586,8 @@ function Public.check_for_destination_collisions()
Surfaces.create_surface(destination_data) Surfaces.create_surface(destination_data)
local index = destination_data.destination_index local index = destination_data.destination_index
memory.loadingticks = 0 memory.loading_ticks = 0
memory.mapbeingloadeddestination_index = index memory.map_being_loaded_destination_index = index
memory.currentdestination_index = index memory.currentdestination_index = index
memory.boat.state = Boats.enum_state.ATSEA_LOADING_MAP memory.boat.state = Boats.enum_state.ATSEA_LOADING_MAP

View File

@ -87,8 +87,8 @@ Public.framecounts = {
-- destination.dynamic_data.parrot_gave_overstay_tip = true -- destination.dynamic_data.parrot_gave_overstay_tip = true
-- local spawners = surface.find_entities_filtered({type = 'unit-spawner', force = memory.enemy_force_name}) -- local spawners = surface.find_entities_filtered({type = 'unit-spawner', force = memory.enemy_force_name})
-- local spawnerscount = #spawners or 0 -- local spawners_count = #spawners or 0
-- if spawnerscount > 0 then --check biter bases actually exist -- if spawners_count > 0 then --check biter bases actually exist
-- Public.parrot_overstay_tip() -- Public.parrot_overstay_tip()
-- end -- end
-- end -- end

View File

@ -74,8 +74,8 @@ function Public.set_off_from_starting_dock()
Common.current_destination().type = Surfaces.enum.LOBBY Common.current_destination().type = Surfaces.enum.LOBBY
memory.mapbeingloadeddestination_index = 0 --This is a dummy value, overwritten later memory.map_being_loaded_destination_index = 0 --This is a dummy value, overwritten later
memory.loadingticks = 0 memory.loading_ticks = 0
local surface = game.surfaces[CoreData.lobby_surface_name] local surface = game.surfaces[CoreData.lobby_surface_name]
local p = Utils.psum { memory.boat.position, Boats.get_scope(memory.boat).Data.crewname_rendering_position } local p = Utils.psum { memory.boat.position, Boats.get_scope(memory.boat).Data.crewname_rendering_position }
@ -166,7 +166,7 @@ function Public.go_from_starting_dock_to_first_destination()
Crowsnest.move_crowsnest(0, -24) Crowsnest.move_crowsnest(0, -24)
Public.progress_to_destination(memory.mapbeingloadeddestination_index) Public.progress_to_destination(memory.map_being_loaded_destination_index)
-- local scope = Boats.get_scope(boat) -- local scope = Boats.get_scope(boat)
-- local boatwidth, boatheight = scope.Data.width, scope.Data.height -- local boatwidth, boatheight = scope.Data.width, scope.Data.height
@ -257,7 +257,7 @@ function Public.progress_to_destination(destination_index)
Crowsnest.paint_around_destination(destination_index, CoreData.overworld_presence_tile) Crowsnest.paint_around_destination(destination_index, CoreData.overworld_presence_tile)
if memory.loadingticks then memory.loadingticks = -120 end if memory.loading_ticks then memory.loading_ticks = -120 end
if old_type == Surfaces.enum.SEA then if old_type == Surfaces.enum.SEA then
game.delete_surface(oldsurface) game.delete_surface(oldsurface)
@ -513,8 +513,8 @@ function Public.go_from_currentdestination_to_sea()
Common.set_evo(base_evo) Common.set_evo(base_evo)
memory.dynamic_kraken_evo = 0 memory.dynamic_kraken_evo = 0
memory.loadingticks = nil memory.loading_ticks = nil
memory.mapbeingloadeddestination_index = nil memory.map_being_loaded_destination_index = nil
local d = destination.iconized_map_width + Crowsnest.platformwidth local d = destination.iconized_map_width + Crowsnest.platformwidth

View File

@ -1,5 +1,5 @@
--luacheck: ignore --luacheck: ignore
--luacheck ignores because tickinterval arguments are a code templating choice... --luacheck ignores because tick_interval arguments are a code templating choice...
local Memory = require 'maps.pirates.memory' local Memory = require 'maps.pirates.memory'
local Structures = require 'maps.pirates.structures.structures' local Structures = require 'maps.pirates.structures.structures'
@ -39,7 +39,7 @@ local function discharge_accumulators(surface, position, force, power_needs)
end end
-- NOTE: You can currently switch between classes shaman -> iron leg -> shaman, without losing your shaman charge, but I'm too lazy to fix. -- NOTE: You can currently switch between classes shaman -> iron leg -> shaman, without losing your shaman charge, but I'm too lazy to fix.
function Public.class_update_auxiliary_data(tickinterval) function Public.class_update_auxiliary_data(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if not memory.classes_table then return end if not memory.classes_table then return end
@ -89,7 +89,7 @@ function Public.class_update_auxiliary_data(tickinterval)
data.shaman_charge = data.shaman_charge + energy data.shaman_charge = data.shaman_charge + energy
-- charge from sun pasively -- charge from sun pasively
data.shaman_charge = data.shaman_charge + (1 - player.surface.daytime) * Balance.shaman_passive_charge * (tickinterval / 60) data.shaman_charge = data.shaman_charge + (1 - player.surface.daytime) * Balance.shaman_passive_charge * (tick_interval / 60)
data.shaman_charge = Math.min(data.shaman_charge, Balance.shaman_max_charge) data.shaman_charge = Math.min(data.shaman_charge, Balance.shaman_max_charge)
end end
end end
@ -102,7 +102,7 @@ function Public.class_update_auxiliary_data(tickinterval)
end end
end end
function Public.class_renderings(tickinterval) function Public.class_renderings(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if not memory.classes_table then return end if not memory.classes_table then return end
@ -255,7 +255,7 @@ function Public.class_renderings(tickinterval)
end end
end end
function Public.update_character_properties(tickinterval) function Public.update_character_properties(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local crew = Common.crew_get_crew_members() local crew = Common.crew_get_crew_members()
@ -352,15 +352,15 @@ function Public.update_character_properties(tickinterval)
end end
end end
function Public.class_rewards_tick(tickinterval) function Public.class_rewards_tick(tick_interval)
--assuming tickinterval = 7 seconds for now --assuming tick_interval = 7 seconds for now
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local crew = Common.crew_get_crew_members() local crew = Common.crew_get_crew_members()
for _, player in pairs(crew) do for _, player in pairs(crew) do
local class = Classes.get_class(player.index) local class = Classes.get_class(player.index)
if Common.validate_player_and_character(player) and if Common.validate_player_and_character(player) and
game.tick % tickinterval == 0 and game.tick % tick_interval == 0 and
class and class and
not Boats.is_boat_at_sea() and --it is possible to spend infinite time here, so don't give out freebies not Boats.is_boat_at_sea() and --it is possible to spend infinite time here, so don't give out freebies
( (
@ -392,7 +392,7 @@ function Public.class_rewards_tick(tickinterval)
-- Smoldering class is disabled -- Smoldering class is disabled
-- if memory.classes_table and memory.classes_table[player.index] then -- if memory.classes_table and memory.classes_table[player.index] then
-- if game.tick % tickinterval == 0 and Common.validate_player_and_character(player) then -- if game.tick % tick_interval == 0 and Common.validate_player_and_character(player) then
-- if memory.classes_table[player.index] == Classes.enum.SMOLDERING then -- if memory.classes_table[player.index] == Classes.enum.SMOLDERING then
-- local inv = player.get_inventory(defines.inventory.character_main) -- local inv = player.get_inventory(defines.inventory.character_main)
-- if not (inv and inv.valid) then return end -- if not (inv and inv.valid) then return end

View File

@ -85,10 +85,10 @@ function Public.currentdestination_try_move_boat_steered()
if (destination and destination.dynamic_data and destination.dynamic_data.timer) and (destination.dynamic_data.timer < 1) then return end if (destination and destination.dynamic_data and destination.dynamic_data.timer) and (destination.dynamic_data.timer < 1) then return end
if boat and boat.decksteeringchests then if boat and boat.decksteeringchests then
local leftchest, rightchest = boat.decksteeringchests.left, boat.decksteeringchests.right local left_chest, right_chest = boat.decksteeringchests.left, boat.decksteeringchests.right
if leftchest and leftchest.valid and rightchest and rightchest.valid then if left_chest and left_chest.valid and right_chest and right_chest.valid then
local inv_left = leftchest.get_inventory(defines.inventory.chest) local inv_left = left_chest.get_inventory(defines.inventory.chest)
local inv_right = rightchest.get_inventory(defines.inventory.chest) local inv_right = right_chest.get_inventory(defines.inventory.chest)
local count_left = inv_left.get_item_count("rail-signal") local count_left = inv_left.get_item_count("rail-signal")
local count_right = inv_right.get_item_count("rail-signal") local count_right = inv_right.get_item_count("rail-signal")

View File

@ -216,7 +216,7 @@ end
function Public.tick_quest_structure_entry_price_check() function Public.tick_quest_structure_entry_price_check()
if Common.activecrewcount() == 0 then return end if Common.activecrewcount() == 0 then return end
-- function Public.tick_quest_structure_entry_price_check(tickinterval) -- function Public.tick_quest_structure_entry_price_check(tick_interval)
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
if memory.game_lost then return end if memory.game_lost then return end
local destination = Common.current_destination() local destination = Common.current_destination()

View File

@ -360,13 +360,13 @@ function Public.crowsnest_surface_delayed_init()
e.destructible = false e.destructible = false
e.minable = false e.minable = false
e.rotatable = false e.rotatable = false
if not memory.boat.crowsneststeeringchests then if not memory.boat.crows_nest_steering_chests then
memory.boat.crowsneststeeringchests = {} memory.boat.crows_nest_steering_chests = {}
end end
if p.y < 0 then if p.y < 0 then
memory.boat.crowsneststeeringchests.left = e memory.boat.crows_nest_steering_chests.left = e
else else
memory.boat.crowsneststeeringchests.right = e memory.boat.crows_nest_steering_chests.right = e
end end
end end
end end

View File

@ -101,7 +101,7 @@ function Public.place_dock_jetty_and_boats()
-- boat2.hold_input_belts = boat.hold_input_belts -- boat2.hold_input_belts = boat.hold_input_belts
-- boat2.hold_output_belts = boat.hold_output_belts -- boat2.hold_output_belts = boat.hold_output_belts
-- boat2.crowsneststeeringchests = boat.crowsneststeeringchests -- boat2.crows_nest_steering_chests = boat.crows_nest_steering_chests
-- boat2.cannons = {} -- boat2.cannons = {}
-- boat2.speedticker1 = 0 -- boat2.speedticker1 = 0
-- boat2.speedticker2 = 1/3 * Common.boat_steps_at_a_time -- boat2.speedticker2 = 1/3 * Common.boat_steps_at_a_time

View File

@ -251,14 +251,14 @@ local function radioactive_tick()
local memory = Memory.get_crew_memory() local memory = Memory.get_crew_memory()
local destination = Common.current_destination() local destination = Common.current_destination()
local tickinterval = 60 local tick_interval = 60
if destination.subtype == IslandEnum.enum.RADIOACTIVE then if destination.subtype == IslandEnum.enum.RADIOACTIVE then
-- Stop increasing evo when boat left the island -- Stop increasing evo when boat left the island
local surface_name = memory.boat and memory.boat.surface_name local surface_name = memory.boat and memory.boat.surface_name
if surface_name ~= memory.sea_name then if surface_name ~= memory.sea_name then
-- faster evo (doesn't need difficulty scaling as higher difficulties have higher base evo): -- faster evo (doesn't need difficulty scaling as higher difficulties have higher base evo):
local extra_evo = 0.22 * tickinterval / 60 / Balance.expected_time_on_island() local extra_evo = 0.22 * tick_interval / 60 / Balance.expected_time_on_island()
Common.increment_evo(extra_evo) Common.increment_evo(extra_evo)
if (not destination.dynamic_data.evolution_accrued_time) then if (not destination.dynamic_data.evolution_accrued_time) then
destination.dynamic_data.evolution_accrued_time = 0 destination.dynamic_data.evolution_accrued_time = 0
@ -271,7 +271,7 @@ local function radioactive_tick()
local pollution = 0 local pollution = 0
local timer = destination.dynamic_data.timer local timer = destination.dynamic_data.timer
if timer and timer > 15 then if timer and timer > 15 then
pollution = 6 * (Common.difficulty_scale() ^ (1.1) * (memory.overworldx / 40) ^ (18 / 10) * (Balance.crew_scale()) ^ (1 / 5)) / 3600 * tickinterval * (1 + (Common.difficulty_scale() - 1) * 0.2 + 0.001 * timer) pollution = 6 * (Common.difficulty_scale() ^ (1.1) * (memory.overworldx / 40) ^ (18 / 10) * (Balance.crew_scale()) ^ (1 / 5)) / 3600 * tick_interval * (1 + (Common.difficulty_scale() - 1) * 0.2 + 0.001 * timer)
end end
local surface = game.surfaces[destination.surface_name] local surface = game.surfaces[destination.surface_name]

View File

@ -100,12 +100,12 @@ function Public.on_surface_generation(destination)
destination.dynamic_data.rocketsilomaxhp = Balance.silo_max_hp destination.dynamic_data.rocketsilomaxhp = Balance.silo_max_hp
destination.dynamic_data.rocketsilohp = Balance.silo_max_hp destination.dynamic_data.rocketsilohp = Balance.silo_max_hp
destination.dynamic_data.rocketsilochargedbools = {} destination.dynamic_data.rocket_silo_charged_bools = {}
destination.dynamic_data.rocketsiloenergyconsumed = 0 destination.dynamic_data.rocket_silo_energy_consumed = 0
destination.dynamic_data.rocketsiloenergyconsumedwithinlasthalfsecond = 0 destination.dynamic_data.rocket_silo_energy_consumed_within_last_half_second = 0
destination.dynamic_data.energychargedinsilosincelastcheck = 0 destination.dynamic_data.energy_charged_in_silo_since_last_check = 0
destination.dynamic_data.silocharged = false destination.dynamic_data.silo_is_charged = false
destination.dynamic_data.rocketlaunched = false destination.dynamic_data.rocket_launched = false
if subtype ~= IslandEnum.enum.STANDARD and subtype ~= IslandEnum.enum.STANDARD_VARIANT and subtype ~= IslandEnum.enum.RADIOACTIVE and subtype ~= IslandEnum.enum.RED_DESERT then if subtype ~= IslandEnum.enum.STANDARD and subtype ~= IslandEnum.enum.STANDARD_VARIANT and subtype ~= IslandEnum.enum.RADIOACTIVE and subtype ~= IslandEnum.enum.RED_DESERT then
destination.dynamic_data.hidden_ore_remaining_abstract = Utils.deepcopy(destination.static_params.abstract_ore_amounts) destination.dynamic_data.hidden_ore_remaining_abstract = Utils.deepcopy(destination.static_params.abstract_ore_amounts)
@ -265,7 +265,7 @@ function Public.destination_on_arrival(destination)
memory.active_sea_enemies.krakens = {} memory.active_sea_enemies.krakens = {}
if destination.type == enum.ISLAND then if destination.type == enum.ISLAND then
destination.dynamic_data.rocketsiloenergyneeded = Balance.silo_energy_needed_MJ() * 1000000 destination.dynamic_data.rocket_silo_energy_needed = Balance.silo_energy_needed_MJ() * 1000000
destination.dynamic_data.time_remaining = Balance.max_time_on_island_seconds(destination.subtype) destination.dynamic_data.time_remaining = Balance.max_time_on_island_seconds(destination.subtype)