mirror of
https://github.com/ComfyFactory/ComfyFactorio.git
synced 2024-12-30 23:17:53 +02:00
move wait to after destination load, halt loading for krakens
This commit is contained in:
parent
552a6abc51
commit
64ff90782b
@ -101,7 +101,6 @@ ship_undocked_1=[font=heading-1]Ship undocked[/font] by captain.
|
||||
ship_undocked_2=[font=heading-1]Ship auto-undocked[/font]. Return to ship.
|
||||
ship_undocked_3=[font=heading-1]Ship auto-undocked[/font].
|
||||
|
||||
ship_set_off_to_next_island=[font=heading-1]Ship set sail[/font] for the next destination.
|
||||
crew_continue_on_freeplay=The run now continues on 'Freeplay'.
|
||||
victory_continue_reminder=If you wish to continue the game, click up top.
|
||||
|
||||
@ -145,7 +144,8 @@ granted_3=__1__ __2__, __3__, __4__.
|
||||
|
||||
approaching_destination=Approaching destination __1__, __2__.
|
||||
loading_destination=Loading destination __1__, __2__.
|
||||
wait_for_crew_to_finish_loading=Ship held at signal: Waiting for crew __1__ to finish loading.
|
||||
wait_for_crew_to_finish_loading=Ship held at signal: Waiting for crew '__1__' to finish loading.
|
||||
wait_for_crew_to_finish_fighting_kraken=Ship held at signal: Waiting for crew '__1__' to finish fighting kraken.
|
||||
|
||||
steer_left=Steering portside...
|
||||
steer_right=Steering starboard...
|
||||
@ -561,9 +561,9 @@ gui_minimap_main_tooltip=View the outside world.
|
||||
gui_etaframe_board_warning=RETURN TO SHIP
|
||||
gui_etaframe_board_warning_tooltip=Probably time to board...
|
||||
gui_etaframe_autoundock=Auto-undock:
|
||||
gui_etaframe_arriving_in=Arriving in
|
||||
gui_etaframe_loading_for=Loading for
|
||||
gui_etaframe_defeat_krakens=Defeat the krakens!
|
||||
gui_etaframe_atsea_waiting=Captain — Click here to Sail
|
||||
gui_etaframe_atsea_waiting=Captain — Click here to Approach
|
||||
gui_etaframe_undock=Undock:
|
||||
gui_etaframe_anytime=Anytime
|
||||
gui_etaframe_next_escape_cost=Next escape cost:
|
||||
|
@ -242,7 +242,7 @@ function Public.tell_biters_near_silo_to_attack_it()
|
||||
local enemy_force_name = memory.enemy_force_name
|
||||
|
||||
-- don't do this too early
|
||||
if destination.dynamic_data.timer < destination.dynamic_data.timeratlandingtime + Common.seconds_after_landing_to_enable_AI * 4 then return end
|
||||
if destination.dynamic_data.timeratlandingtime and destination.dynamic_data.timer < destination.dynamic_data.timeratlandingtime + Common.seconds_after_landing_to_enable_AI * 4 then return end
|
||||
if not (destination.dynamic_data.rocketsilos and destination.dynamic_data.rocketsilos[1] and destination.dynamic_data.rocketsilos[1].valid and destination.dynamic_data.rocketsilos[1].destructible) then return end
|
||||
|
||||
local attackcommand = Public.attack_target_entity(destination.dynamic_data.rocketsilos[1])
|
||||
|
@ -27,6 +27,7 @@ local Crew = require 'maps.pirates.crew'
|
||||
local Math = require 'maps.pirates.math'
|
||||
local _inspect = require 'utils.inspect'.inspect
|
||||
local Kraken = require 'maps.pirates.surfaces.sea.kraken'
|
||||
local CustomEvents = require 'maps.pirates.custom_events'
|
||||
|
||||
local Quest = require 'maps.pirates.quest'
|
||||
-- local ShopDock = require 'maps.pirates.shop.dock'
|
||||
@ -975,8 +976,6 @@ function Public.loading_update(tickinterval)
|
||||
local destination_index = memory.mapbeingloadeddestination_index
|
||||
if not destination_index then memory.loadingticks = nil return end
|
||||
|
||||
-- if (not memory.boat.state) or (not (memory.boat.state == Boats.enum_state.LANDED or memory.boat.state == Boats.enum_state.ATSEA_LOADING_MAP or memory.boat.state == Boats.enum_state.LEAVING_DOCK or (memory.boat.state == Boats.enum_state.APPROACHING and destination_index == 1))) then return end
|
||||
|
||||
if not memory.boat.state then return end
|
||||
|
||||
local map_loads = false
|
||||
@ -987,36 +986,65 @@ function Public.loading_update(tickinterval)
|
||||
|
||||
if not map_loads then return end
|
||||
|
||||
|
||||
local crew_to_wait_for = nil
|
||||
if memory.boat.state == Boats.enum_state.ATSEA_LOADING_MAP then
|
||||
for id, crew_memory in pairs(global_memory.crew_memories) do
|
||||
if crew_memory.loadingticks and (crew_memory.loadingticks > memory.loadingticks or (crew_memory.loadingticks == memory.loadingticks and id < memory.id)) then
|
||||
crew_to_wait_for = id
|
||||
break
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
if crew_to_wait_for then
|
||||
if not memory.waiting_for_other_crew or memory.waiting_for_other_crew ~= crew_to_wait_for then
|
||||
memory.waiting_for_other_crew = crew_to_wait_for
|
||||
local waiting_crew_name = global_memory.crew_memories[crew_to_wait_for].name or "Unknown crew"
|
||||
|
||||
Common.notify_force(memory.force, {'pirates.wait_for_crew_to_finish_loading', waiting_crew_name})
|
||||
end
|
||||
|
||||
return
|
||||
else
|
||||
memory.waiting_for_other_crew = nil
|
||||
end
|
||||
|
||||
|
||||
memory.loadingticks = memory.loadingticks + tickinterval
|
||||
|
||||
-- if memory.loadingticks % 100 == 0 then game.print(memory.loadingticks) end
|
||||
|
||||
local destination_data = memory.destinations[destination_index]
|
||||
|
||||
if memory.boat.state == Boats.enum_state.ATSEA_LOADING_MAP or memory.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
|
||||
if crew_memory.loadingticks and (crew_memory.loadingticks > memory.loadingticks or (crew_memory.loadingticks == memory.loadingticks and id < memory.id)) 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 memory.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 (memory.boat.state == Boats.enum_state.LEAVING_DOCK) then
|
||||
memory.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 memory.boat and currentdestination.type == Surfaces.enum.LOBBY then
|
||||
if memory.loadingticks >= 350 - Common.loading_interval then
|
||||
@ -1106,19 +1134,22 @@ function Public.loading_update(tickinterval)
|
||||
|
||||
-- local eta_ticks = total - (memory.loadingticks - (memory.extra_time_at_sea or 0))
|
||||
|
||||
if Kraken.get_active_kraken_count() > 0 then
|
||||
memory.loadingticks = memory.loadingticks - tickinterval --reverse the change to avoid causing lag from map loading during fight
|
||||
else
|
||||
local fraction = memory.loadingticks / (total + (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
|
||||
Progression.progress_to_destination(destination_index)
|
||||
memory.loadingticks = 0
|
||||
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
|
||||
if fraction > Common.fraction_of_map_loaded_at_sea then
|
||||
memory.boat.state = Boats.enum_state.ATSEA_WAITING_TO_SAIL
|
||||
|
||||
memory.force_toggle_machine_states = true
|
||||
Boats.update_EEIs(memory.boat)
|
||||
|
||||
local force = memory.force
|
||||
if not (force and force.valid) then return end
|
||||
|
||||
script.raise_event(CustomEvents.enum['update_crew_fuel_gui'], {})
|
||||
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
|
||||
|
||||
@ -1338,7 +1369,7 @@ function Public.Kraken_Destroyed_Backup_check(tickinterval) -- a server became s
|
||||
local boat = memory.boat
|
||||
|
||||
if boat and boat.surface_name and boat.state and boat.state == Boats.enum_state.ATSEA_LOADING_MAP then
|
||||
if Kraken.get_active_kraken_count() > 0 then
|
||||
if Kraken.get_active_kraken_count(memory.id) > 0 then
|
||||
|
||||
local surface = game.surfaces[boat.surface_name]
|
||||
|
||||
|
@ -148,25 +148,6 @@ function(cmd)
|
||||
end
|
||||
end)
|
||||
|
||||
commands.add_command(
|
||||
'sail',
|
||||
{'pirates.cmd_explain_sail'},
|
||||
function(cmd)
|
||||
cmd_set_memory(cmd)
|
||||
|
||||
local memory = Memory.get_crew_memory()
|
||||
if not Common.is_id_valid(memory.id) then return end
|
||||
|
||||
--local param = tostring(cmd.parameter)
|
||||
if check_admin(cmd) then
|
||||
--local player = game.players[cmd.player_index]
|
||||
Crew.summon_crew()
|
||||
if memory.boat.state == Boats.enum_state.ATSEA_WAITING_TO_SAIL then
|
||||
Progression.at_sea_begin_to_set_sail()
|
||||
end
|
||||
end
|
||||
end)
|
||||
|
||||
commands.add_command(
|
||||
'setcaptain',
|
||||
{'pirates.cmd_explain_setcaptain'},
|
||||
|
@ -562,7 +562,7 @@ function Public.process_etaframe_update(player, flow1, bools)
|
||||
flow2.etaframe_label_2.caption = Utils.standard_string_form_of_time_in_seconds(passive_eta)
|
||||
|
||||
elseif bools.atsea_loading_bool then
|
||||
if Kraken.get_active_kraken_count() > 0 then
|
||||
if Kraken.get_active_kraken_count(memory.id) > 0 then
|
||||
flow2.etaframe_label_1.visible = true
|
||||
flow2.etaframe_label_2.visible = false
|
||||
|
||||
@ -584,7 +584,7 @@ function Public.process_etaframe_update(player, flow1, bools)
|
||||
|
||||
local eta_ticks = total + (memory.extra_time_at_sea or 0) - memory.loadingticks
|
||||
|
||||
flow2.etaframe_label_1.caption = {'pirates.gui_etaframe_arriving_in'}
|
||||
flow2.etaframe_label_1.caption = {'pirates.gui_etaframe_loading_for'}
|
||||
flow2.etaframe_label_2.caption = Utils.standard_string_form_of_time_in_seconds(eta_ticks / 60)
|
||||
end
|
||||
|
||||
@ -606,7 +606,7 @@ function Public.process_etaframe_update(player, flow1, bools)
|
||||
flow2.etaframe_label_2.caption = {'pirates.gui_etaframe_anytime'}
|
||||
end
|
||||
|
||||
if bools.cost_bool and Kraken.get_active_kraken_count() == 0 then
|
||||
if bools.cost_bool and Kraken.get_active_kraken_count(memory.id) == 0 then
|
||||
local costs = destination.static_params.base_cost_to_undock
|
||||
local adjusted_costs = Common.time_adjusted_departure_cost(costs)
|
||||
|
||||
@ -1253,7 +1253,10 @@ local function on_gui_click(event)
|
||||
|
||||
elseif memory.boat.state == Boats.enum_state.ATSEA_WAITING_TO_SAIL then
|
||||
if Roles.player_privilege_level(player) >= Roles.privilege_levels.CAPTAIN then
|
||||
Progression.at_sea_begin_to_set_sail()
|
||||
local destination_index = memory.mapbeingloadeddestination_index
|
||||
|
||||
Progression.progress_to_destination(destination_index)
|
||||
memory.loadingticks = 0
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -537,29 +537,6 @@ function Public.undock_from_dock(manual)
|
||||
end
|
||||
|
||||
|
||||
function Public.at_sea_begin_to_set_sail()
|
||||
local memory = Memory.get_crew_memory()
|
||||
local boat = memory.boat
|
||||
|
||||
boat.state = Boats.enum_state.ATSEA_SAILING
|
||||
|
||||
memory.force_toggle_machine_states = true
|
||||
Boats.update_EEIs(memory.boat)
|
||||
|
||||
script.raise_event(CustomEvents.enum['update_crew_fuel_gui'], {})
|
||||
|
||||
local force = memory.force
|
||||
if not (force and force.valid) then return end
|
||||
|
||||
if memory.victory_continue_message then
|
||||
memory.victory_continue_message = false
|
||||
Common.notify_force(force, {'pirates.crew_continue_on_freeplay'}, CoreData.colors.notify_victory)
|
||||
else
|
||||
Common.notify_force(force, {'pirates.ship_set_off_to_next_island'})
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
||||
|
||||
local parrot_set_sail_advice =
|
||||
@ -587,14 +564,11 @@ function Public.go_from_currentdestination_to_sea()
|
||||
local destination = Common.current_destination()
|
||||
if memory.game_lost then return end
|
||||
|
||||
local oldsurface = game.surfaces[destination.surface_name]
|
||||
|
||||
Sea.ensure_sea_surface()
|
||||
local seaname = memory.sea_name
|
||||
|
||||
local boat = memory.boat
|
||||
|
||||
local old_boatposition = memory.boat.position
|
||||
local new_boatposition = Utils.snap_coordinates_for_rails({x = Boats.get_scope(memory.boat).Data.width / 2, y = 0})
|
||||
|
||||
Boats.teleport_boat(boat, seaname, new_boatposition, CoreData.static_boat_floor, 'water')
|
||||
@ -619,15 +593,19 @@ function Public.go_from_currentdestination_to_sea()
|
||||
end
|
||||
end
|
||||
|
||||
memory.boat.state = Boats.enum_state.ATSEA_WAITING_TO_SAIL
|
||||
boat.state = Boats.enum_state.ATSEA_SAILING
|
||||
|
||||
memory.force_toggle_machine_states = true
|
||||
Boats.update_EEIs(memory.boat)
|
||||
boat.speed = 0
|
||||
boat.position = new_boatposition
|
||||
boat.surface_name = seaname
|
||||
boat.fish_caught_while_at_sea = 0 -- how many times a fish was caught, rather than amount of fish caught in total
|
||||
|
||||
memory.boat.speed = 0
|
||||
memory.boat.position = new_boatposition
|
||||
memory.boat.surface_name = seaname
|
||||
memory.boat.fish_caught_while_at_sea = 0 -- how many times a fish was caught, rather than amount of fish caught in total
|
||||
local force = memory.force
|
||||
if not (force and force.valid) then return end
|
||||
if memory.victory_continue_message then
|
||||
memory.victory_continue_message = false
|
||||
Common.notify_force(force, {'pirates.crew_continue_on_freeplay'}, CoreData.colors.notify_victory)
|
||||
end
|
||||
|
||||
memory.enemy_force.reset_evolution()
|
||||
|
||||
|
@ -50,9 +50,11 @@ local swimming_biters_tick_token =
|
||||
end
|
||||
)
|
||||
|
||||
function Public.get_active_kraken_count()
|
||||
local memory = Memory.get_crew_memory()
|
||||
if memory.active_sea_enemies and memory.active_sea_enemies.kraken_count then
|
||||
function Public.get_active_kraken_count(crew_id)
|
||||
local global_memory = Memory.get_global_memory()
|
||||
local memory = global_memory.crew_memories[crew_id]
|
||||
|
||||
if memory and memory.active_sea_enemies and memory.active_sea_enemies.kraken_count then
|
||||
return memory.active_sea_enemies.kraken_count
|
||||
else
|
||||
return 0
|
||||
@ -71,7 +73,7 @@ function Public.swimming_biters_tick(crew_id, kraken_id)
|
||||
local surface = game.surfaces[memory.sea_name]
|
||||
local spawners_biters = surface.find_entities_filtered{force = memory.enemy_force_name}
|
||||
|
||||
if Public.get_active_kraken_count() == 0 and #spawners_biters == 0 then return end
|
||||
if Public.get_active_kraken_count(memory.id) == 0 and #spawners_biters == 0 then return end
|
||||
|
||||
for _, biter in pairs(spawners_biters) do
|
||||
if biter and biter.valid then
|
||||
@ -280,7 +282,7 @@ end
|
||||
function Public.overall_kraken_tick()
|
||||
local memory = Memory.get_crew_memory()
|
||||
|
||||
if Public.get_active_kraken_count() > 0 then
|
||||
if Public.get_active_kraken_count(memory.id) > 0 then
|
||||
local evo_increase = Balance.kraken_evo_increase_per_second()
|
||||
if evo_increase > 0 then
|
||||
if not memory.dynamic_kraken_evo then memory.dynamic_kraken_evo = 0 end
|
||||
@ -322,7 +324,7 @@ function Public.try_spawn_kraken()
|
||||
Task.set_timeout_in_ticks(10, kraken_tick_token, {crew_id = memory.id, kraken_id = kraken_id, step = 1, substep = 1})
|
||||
|
||||
-- creating multiple swim tick tokens, causes biters to swim faster
|
||||
if Public.get_active_kraken_count() == 1 then
|
||||
if Public.get_active_kraken_count(memory.id) == 1 then
|
||||
Task.set_timeout_in_ticks(10, swimming_biters_tick_token, {crew_id = memory.id, kraken_id = kraken_id})
|
||||
end
|
||||
end
|
||||
|
Loading…
Reference in New Issue
Block a user