mirror of
https://github.com/ComfyFactory/ComfyFactorio.git
synced 2024-12-30 23:17:53 +02:00
code cleanup
This commit is contained in:
parent
9bbfe2ffb3
commit
baf267732c
@ -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
|
||||||
|
@ -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)
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -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,
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -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
|
||||||
|
@ -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")
|
||||||
|
|
||||||
|
@ -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()
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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]
|
||||||
|
@ -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)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user