1
0
mirror of https://github.com/ComfyFactory/ComfyFactorio.git synced 2025-01-16 02:47:48 +02:00

code cleanup

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

View File

@ -47,7 +47,7 @@ local side_attack_target_names = {
--=== Tick Actions
function Public.Tick_actions(tickinterval)
function Public.Tick_actions(tick_interval)
local memory = Memory.get_crew_memory()
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 game.tick % (tickinterval * 2) == 0 and memory.boat.state == Boats.enum_state.LANDED then
local extra_evo = 2 * tickinterval / 60 * Balance.evolution_per_second()
if game.tick % (tick_interval * 2) == 0 and memory.boat.state == Boats.enum_state.LANDED then
local extra_evo = 2 * tick_interval / 60 * Balance.evolution_per_second()
Common.increment_evo(extra_evo)
destination.dynamic_data.evolution_accrued_time = destination.dynamic_data.evolution_accrued_time + extra_evo
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
if initial_spawner_count > 0 then
local spawnerscount = Common.spawner_count(surface)
if spawnerscount > 0 then
map_pollution_cost_multiplier = Math.max(initial_spawner_count / spawnerscount, 1)
local spawners_count = Common.spawner_count(surface)
if spawners_count > 0 then
map_pollution_cost_multiplier = Math.max(initial_spawner_count / spawners_count, 1)
else
map_pollution_cost_multiplier = 1000000
end
@ -502,8 +502,8 @@ function Public.generate_main_attack_target()
local destination = Common.current_destination()
local target
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
fractioncharged = destination.dynamic_data.rocketsiloenergyconsumed / destination.dynamic_data.rocketsiloenergyneeded
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.rocket_silo_energy_consumed / destination.dynamic_data.rocket_silo_energy_needed
if memory.overworldx > 40 * 22 then --chance of biters going directly to silo
fractioncharged = fractioncharged + 0.03

View File

@ -56,7 +56,7 @@ function Public.silo_die()
if CoreData.rocket_silo_death_causes_loss then
-- Crew.lose_life()
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
Crew.try_lose({ 'pirates.loss_silo_destroyed_before_necessary_launch' })
else
@ -1510,31 +1510,9 @@ local function event_on_player_joined_game(event)
-- end
end
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)
-- -- 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_coin_reward = Balance.rocket_launch_coin_reward()
destination.dynamic_data.rocketlaunched = true
destination.dynamic_data.rocket_launched = true
if memory.stored_fuel then
memory.stored_fuel = memory.stored_fuel + rocket_launch_coal_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
local function event_on_console_chat(event)
if not (event.message and event.player_index and game.players[event.player_index]) then return end
local global_memory = Memory.get_global_memory()
if not (event.message and event.player_index) then return end
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 color = player.chat_color
-- if global.tournament_mode then
-- return
-- end
local crew_id = Common.get_id_from_force_name(player.force.name)
Memory.set_working_id(crew_id)
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!
if player.force.name == Common.lobby_force_name then
local other_force_indices = global_memory.crew_active_ids
local message_prefix = player.name .. tag
local full_message = message_prefix .. ': ' .. event.message
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
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
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 and player.name then
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')
if memory.name then
full_message = message_prefix .. ' [' .. memory.name .. ']: ' .. event.message
end
game.forces.player.print(full_message, color)
end
end
@ -2082,8 +2052,6 @@ local function event_on_market_item_purchased(event)
Shop.event_on_market_item_purchased(event)
end
local remove_boost_movement_speed_on_respawn =
Token.register(
function (data)

View File

@ -1,7 +1,7 @@
-- This file is part of thesixthroc's Pirate Ship softmod, licensed under GPLv3 and stored at https://github.com/ComfyFactory/ComfyFactorio and https://github.com/danielmartin0/ComfyFactorio-Pirates.
--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 Gui = require 'maps.pirates.gui.gui'
@ -36,7 +36,7 @@ local QuestStructures = require 'maps.pirates.structures.quest_structures.quest_
local Public = {}
function Public.strobe_player_colors(tickinterval)
function Public.strobe_player_colors(tick_interval)
local memory = Memory.get_crew_memory()
local strobing_players = memory.speed_boost_characters
@ -54,7 +54,7 @@ function Public.strobe_player_colors(tickinterval)
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.activecrewcount() == 0 then return end
@ -80,7 +80,7 @@ function Public.prevent_unbarreling_off_ship(tickinterval)
end
end
function Public.apply_restrictions_to_machines(tickinterval)
function Public.apply_restrictions_to_machines(tick_interval)
local memory = Memory.get_crew_memory()
local boat = memory.boat
@ -172,7 +172,7 @@ function Public.apply_restrictions_to_machines(tickinterval)
end
end
function Public.prevent_disembark(tickinterval)
function Public.prevent_disembark(tick_interval)
local memory = Memory.get_crew_memory()
if Common.activecrewcount() == 0 then return end
@ -223,7 +223,7 @@ function Public.prevent_disembark(tickinterval)
end
end
function Public.check_all_spawners_dead(tickinterval)
function Public.check_all_spawners_dead(tick_interval)
local memory = Memory.get_crew_memory()
local destination = Common.current_destination()
local boat = memory.boat
@ -233,8 +233,8 @@ function Public.check_all_spawners_dead(tickinterval)
local surface = game.surfaces[destination.surface_name]
if not (surface and surface.valid) then return end
local spawnerscount = Common.spawner_count(surface)
if spawnerscount == 0 then
local spawners_count = Common.spawner_count(surface)
if spawners_count == 0 then
destination.static_params.base_cost_to_undock = nil
Common.notify_force(memory.force, { 'pirates.destroyed_all_nests' })
end
@ -242,7 +242,7 @@ function Public.check_all_spawners_dead(tickinterval)
end
end
function Public.raft_raids(tickinterval)
function Public.raft_raids(tick_interval)
local memory = Memory.get_crew_memory()
if memory.game_lost then return end
local destination = Common.current_destination()
@ -268,7 +268,7 @@ function Public.raft_raids(tickinterval)
end
end
function Public.ship_deplete_fuel(tickinterval)
function Public.ship_deplete_fuel(tick_interval)
local memory = Memory.get_crew_memory()
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
@ -294,7 +294,7 @@ function Public.ship_deplete_fuel(tickinterval)
inv.remove { name = 'coal', count = count }
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
memory.parrot_fuel_most_recent_warning = game.tick
@ -317,7 +317,7 @@ function Public.victory_continue_reminder()
end
end
function Public.transfer_pollution(tickinterval)
function Public.transfer_pollution(tick_interval)
local memory = Memory.get_crew_memory()
local p = 0
@ -333,20 +333,20 @@ function Public.transfer_pollution(tickinterval)
memory.floating_pollution = memory.floating_pollution + p
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
-- 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
function Public.captain_warn_afk(tickinterval)
function Public.captain_warn_afk(tick_interval)
local memory = Memory.get_crew_memory()
if memory.game_lost then return end
if memory.run_is_protected then return end
if memory.playerindex_captain then
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' })
player.play_sound { path = 'utility/scenario_message' }
end
@ -354,7 +354,7 @@ function Public.captain_warn_afk(tickinterval)
end
end
function Public.prune_offline_characters_list(tickinterval)
function Public.prune_offline_characters_list(tick_interval)
local memory = Memory.get_crew_memory()
if memory.game_lost then return end
@ -399,7 +399,7 @@ function Public.prune_offline_characters_list(tickinterval)
end
end
function Public.periodic_free_resources(tickinterval)
function Public.periodic_free_resources(tick_interval)
local memory = Memory.get_crew_memory()
if memory.game_lost then return end
local destination = Common.current_destination()
@ -418,7 +418,7 @@ function Public.periodic_free_resources(tickinterval)
end
end
function Public.pick_up_tick(tickinterval)
function Public.pick_up_tick(tick_interval)
if Common.activecrewcount() == 0 then return end
local destination = Common.current_destination()
@ -552,7 +552,7 @@ function Public.interpret_shorthanded_force_name(shorthanded_name)
return ret
end
function Public.place_cached_structures(tickinterval)
function Public.place_cached_structures(tick_interval)
local memory = Memory.get_crew_memory()
local destination = Common.current_destination()
local surface_name = destination.surface_name
@ -777,13 +777,13 @@ function Public.place_cached_structures(tickinterval)
end
end
function Public.update_boat_stored_resources(tickinterval)
function Public.update_boat_stored_resources(tick_interval)
if Common.activecrewcount() == 0 then return end
Common.update_boat_stored_resources()
end
function Public.buried_treasure_check(tickinterval)
function Public.buried_treasure_check(tick_interval)
if Common.activecrewcount() == 0 then return end
-- local memory = Memory.get_crew_memory()
@ -881,14 +881,14 @@ function Public.buried_treasure_check(tickinterval)
end
end
function Public.boat_movement_tick(tickinterval)
function Public.boat_movement_tick(tick_interval)
local memory = Memory.get_crew_memory()
local destination = Common.current_destination()
local enemy_force_name = memory.enemy_force_name
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
local ticker_increase = boat.speed / 60 * tickinterval
local ticker_increase = boat.speed / 60 * tick_interval
boat.speedticker1 = boat.speedticker1 + ticker_increase
boat.speedticker2 = boat.speedticker2 + 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]
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
local ticker_increase = eboat.speed / 60 * tickinterval
local ticker_increase = eboat.speed / 60 * tick_interval
eboat.speedticker1 = eboat.speedticker1 + ticker_increase
if eboat.speedticker1 >= 1 then
eboat.speedticker1 = 0
@ -940,124 +940,62 @@ function Public.boat_movement_tick(tickinterval)
end
end
function Public.crowsnest_natural_move(tickinterval)
function Public.crowsnest_natural_move(tick_interval)
local memory = Memory.get_crew_memory()
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
Overworld.try_overworld_move_v2 { x = 1, y = 0 }
end
function Public.overworld_check_collisions(tickinterval)
function Public.overworld_check_collisions(tick_interval)
local memory = Memory.get_crew_memory()
if not memory.loadingticks then
if not memory.loading_ticks then
Overworld.check_for_kraken_collisions()
return Overworld.check_for_destination_collisions()
end
return false
end
function Public.loading_update(tickinterval)
local global_memory = Memory.get_global_memory()
function Public.loading_update(tick_interval)
local memory = Memory.get_crew_memory()
if not memory.loading_ticks or memory.game_lost then return end
local boat = memory.boat
if not boat or not boat.state then return end
if not memory.loadingticks then return end
if memory.game_lost then return end
local destination_index = memory.map_being_loaded_destination_index
if not destination_index then
memory.loading_ticks = nil
return
end
local currentdestination = Common.current_destination()
if not currentdestination then return end
local destination_index = memory.mapbeingloadeddestination_index
if not destination_index then
memory.loadingticks = nil
return
end
if not boat.state then return end
local map_loads = false
if boat.state == Boats.enum_state.LANDED then map_loads = true end
if boat.state == Boats.enum_state.ATSEA_LOADING_MAP then map_loads = true end
if boat.state == Boats.enum_state.LEAVING_DOCK then map_loads = true end
if boat.state == Boats.enum_state.APPROACHING and destination_index == 1 then map_loads = true end
if not map_loads then return end
-- if memory.loadingticks % 100 == 0 then game.print(memory.loadingticks) end
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
if currentdestination.type == Surfaces.enum.LOBBY then
Public.loading_update_lobby(tick_interval, memory, boat, destination_index, currentdestination)
elseif boat.state == Boats.enum_state.ATSEA_LOADING_MAP then
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
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
function Public.loading_update_lobby(tick_interval, memory, boat, destination_index, currentdestination)
memory.loading_ticks = memory.loading_ticks + tick_interval
-- 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 memory.loading_ticks >= 350 - Common.loading_interval then
if Boats.players_on_boat_count(boat) > 0 then
if memory.loadingticks < 350 then
if memory.loading_ticks < 350 then
Common.notify_game({ '', '[' .. memory.name .. '] ', { 'pirates.loading_new_game' } })
elseif memory.loadingticks > 410 then
elseif memory.loading_ticks > 410 then
if not Crowsnest.get_crowsnest_surface() then
Crew.initialise_crowsnest_1()
elseif memory.loadingticks >= 470 then
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)
@ -1065,33 +1003,48 @@ function Public.loading_update(tickinterval)
for i = 1, #memory.destinations do
if memory.destinations[i].overworld_position.x == 0 then
memory.mapbeingloadeddestination_index = i
memory.map_being_loaded_destination_index = i
break
end
end
Surfaces.create_surface(memory.destinations[memory.mapbeingloadeddestination_index])
Surfaces.create_surface(memory.destinations[memory.map_being_loaded_destination_index])
end
end
else
if memory.loadingticks >= 1100 then
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
return
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
local surface_name = destination_data.surface_name
if not surface_name then return end
local surface = game.surfaces[surface_name]
if not surface then return end
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 currentdestination.type == Surfaces.enum.LOBBY then
if memory.loadingticks >= 1260 then
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
@ -1100,32 +1053,12 @@ function Public.loading_update(tickinterval)
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
function Public.loading_update_atsea(tick_interval, memory, boat, destination_index, currentdestination)
memory.loading_ticks = memory.loading_ticks + tick_interval
-- 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
@ -1133,9 +1066,7 @@ function Public.loading_update(tickinterval)
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))
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
@ -1145,24 +1076,32 @@ function Public.loading_update(tickinterval)
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
local surface = game.surfaces[currentdestination.surface_name]
if surface and surface.valid then
PiratesApiEvents.load_some_map_chunks_random_order(surface, currentdestination, fraction)
if currentdestination.subtype == IslandEnum.enum.CAVE then
PiratesApiEvents.load_some_map_chunks_random_order(currentdestination.dynamic_data.cave_miner.cave_surface, currentdestination, fraction)
local cave_surface = currentdestination.dynamic_data.cave_miner.cave_surface
if cave_surface and cave_surface.valid then
PiratesApiEvents.load_some_map_chunks_random_order(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
end
end
end
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.loadingticks = nil
memory.loading_ticks = nil
else
PiratesApiEvents.load_some_map_chunks(destination_index, fraction)
end
end
end
end
function Public.crowsnest_steer(tickinterval)
function Public.crowsnest_steer(tick_interval)
local memory = Memory.get_crew_memory()
local boat = memory.boat
@ -1174,18 +1113,18 @@ function Public.crowsnest_steer(tickinterval)
boat.state and
boat.state == Structures.Boats.enum_state.ATSEA_SAILING and
memory.game_lost == false and
boat.crowsneststeeringchests
boat.crows_nest_steering_chests
)
then
return
end
local leftchest = boat.crowsneststeeringchests.left
local rightchest = boat.crowsneststeeringchests.right
if not (leftchest and leftchest.valid and rightchest and rightchest.valid) then return end
local left_chest = boat.crows_nest_steering_chests.left
local right_chest = boat.crows_nest_steering_chests.right
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_right = rightchest.get_inventory(defines.inventory.chest)
local inv_left = left_chest.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_right = inv_right.get_item_count("rail-signal")
@ -1206,37 +1145,41 @@ function Public.crowsnest_steer(tickinterval)
end
end
function Public.silo_update(tickinterval)
function Public.silo_update(tick_interval)
local memory = Memory.get_crew_memory()
local destination = Common.current_destination()
if destination.type == Surfaces.enum.ISLAND then
local dynamic_data = destination.dynamic_data
local silos = dynamic_data.rocketsilos
if not (destination and destination.type == Surfaces.enum.ISLAND) then return end
local dynamic_data = destination.dynamic_data
if not dynamic_data then return end
local silos = dynamic_data.rocketsilos
if not silos then return end
if silos then
local silo = silos[1]
if silo and silo.valid then
if dynamic_data.silocharged then
if not dynamic_data.rocketlaunched then
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.energychargedinsilosincelastcheck or 0
dynamic_data.energychargedinsilosincelastcheck = 0
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.rocketsiloenergyconsumed = dynamic_data.rocketsiloenergyconsumed + e
dynamic_data.rocket_silo_energy_consumed = (dynamic_data.rocket_silo_energy_consumed or 0) + e
dynamic_data.rocketsiloenergyconsumedwithinlasthalfsecond = 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.rocketsiloenergyneeded
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 + extra_evo
dynamic_data.evolution_accrued_silo = (dynamic_data.evolution_accrued_silo or 0) + extra_evo
end
end
@ -1244,27 +1187,22 @@ function Public.silo_update(tickinterval)
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)
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
memory.floating_pollution = (memory.floating_pollution or 0) + 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
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 spawnerscount = Common.spawner_count(surface)
if spawnerscount > 0 then
local spawners_count = Common.spawner_count(surface)
if spawners_count > 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
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
silo.rocket_parts = 100
dynamic_data.silocharged = true
dynamic_data.silo_is_charged = true
if CoreData.rocket_silo_death_causes_loss then
-- become immune after launching
silo.destructible = false
end
end
@ -1272,21 +1210,19 @@ function Public.silo_update(tickinterval)
end
end
end
end
end
function Public.slower_boat_tick(tickinterval)
function Public.slower_boat_tick(tick_interval)
local memory = Memory.get_crew_memory()
if memory.game_lost then return end
local destination = Common.current_destination()
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
local p = memory.boat.position
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]
if surface and surface.valid then
@ -1308,7 +1244,7 @@ function Public.slower_boat_tick(tickinterval)
-- end
end
function Public.LOS_tick(tickinterval)
function Public.LOS_tick(tick_interval)
local memory = Memory.get_crew_memory()
local boat = memory.boat
local destination = Common.current_destination()
@ -1332,7 +1268,7 @@ function Public.LOS_tick(tickinterval)
end
end
function Public.minimap_jam(tickinterval)
function Public.minimap_jam(tick_interval)
local memory = Memory.get_crew_memory()
local boat = memory.boat
@ -1347,7 +1283,7 @@ function Public.minimap_jam(tickinterval)
end
end
-- function Public.crewtick_handle_delayed_tasks(tickinterval)
-- function Public.crewtick_handle_delayed_tasks(tick_interval)
-- local memory = Memory.get_crew_memory()
-- for _, task in pairs(memory.buffered_tasks) do
@ -1367,7 +1303,7 @@ end
-- Delay.move_tasks_to_buffer()
-- 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 boat = memory.boat
@ -1397,7 +1333,7 @@ function Public.Kraken_Destroyed_Backup_check(tickinterval) -- a server became s
end
end
function Public.quest_progress_tick(tickinterval)
function Public.quest_progress_tick(tick_interval)
local memory = Memory.get_crew_memory()
if memory.game_lost then return end
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 == 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
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
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
if silo and silo.valid then --sometimes theyre overwritten by other structures e.g. market
silo.energy = silo.electric_buffer_size
@ -1475,14 +1411,14 @@ function Public.silo_insta_update()
for i, silo in ipairs(silos) do
if silo and silo.valid then --sometimes theyre overwritten by other structures e.g. market
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
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
if dynamic_data.rocketsilochargedbools and (not dynamic_data.rocketsilochargedbools[i]) then
dynamic_data.rocketsilochargedbools[i] = true
if dynamic_data.rocket_silo_charged_bools and (not dynamic_data.rocket_silo_charged_bools[i]) then
dynamic_data.rocket_silo_charged_bools[i] = true
local inv = silo.get_inventory(defines.inventory.assembling_machine_input)
inv.insert { name = 'processing-unit', count = 10 }
inv.insert { name = 'low-density-structure', count = 10 }
@ -1497,13 +1433,13 @@ function Public.silo_insta_update()
end
end
-- function Public.parrot_tick(tickinterval)
-- function Public.parrot_tick(tick_interval)
-- Parrot.parrot_tick()
-- end
function Public.update_player_guis(tickinterval)
function Public.update_player_guis(tick_interval)
-- local global_memory = Memory.get_global_memory()
local players = game.connected_players
@ -1742,12 +1678,12 @@ function Public.revealed_buried_treasure_distance_check()
end
end
function Public.update_pet_biter_lifetime(tickinterval)
function Public.update_pet_biter_lifetime(tick_interval)
local memory = Memory.get_crew_memory()
if memory.pet_biters then
for id, pet_biter in pairs(memory.pet_biters) do
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
memory.pet_biters[id].pet.die()
memory.pet_biters[id] = nil

View File

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

View File

@ -582,7 +582,7 @@ function Public.query_can_pay_cost_to_leave()
local can_leave = true
for name, count in pairs(adjusted_cost) do
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
end
else

View File

@ -315,9 +315,9 @@ function Public.player_and_crew_state_bools(player)
atsea_victorious_bool = boat and boat.state == Boats.enum_state.ATSEA_VICTORIOUS
landed_bool = boat and boat.state == Boats.enum_state.LANDED
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)
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_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
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

View File

@ -542,7 +542,7 @@ function Public.process_etaframe_update(player, flow1, bools)
total = Common.map_loading_ticks_atsea_maze
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_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
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
else
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_label_3.visible = false
local consumed = dynamic_data.rocketsiloenergyconsumed
local needed = dynamic_data.rocketsiloenergyneeded
local recent = (dynamic_data.rocketsiloenergyconsumedwithinlasthalfsecond * 2)
local consumed = dynamic_data.rocket_silo_energy_consumed
local needed = dynamic_data.rocket_silo_energy_needed
local recent = (dynamic_data.rocket_silo_energy_consumed_within_last_half_second * 2)
flow1.silo_progressbar.value = consumed / needed
@ -1199,7 +1199,7 @@ local function on_gui_click(event)
end
elseif memory.boat.state == Boats.enum_state.ATSEA_WAITING_TO_SAIL 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)
end

View File

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

View File

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

View File

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

View File

@ -74,8 +74,8 @@ function Public.set_off_from_starting_dock()
Common.current_destination().type = Surfaces.enum.LOBBY
memory.mapbeingloadeddestination_index = 0 --This is a dummy value, overwritten later
memory.loadingticks = 0
memory.map_being_loaded_destination_index = 0 --This is a dummy value, overwritten later
memory.loading_ticks = 0
local surface = game.surfaces[CoreData.lobby_surface_name]
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)
Public.progress_to_destination(memory.mapbeingloadeddestination_index)
Public.progress_to_destination(memory.map_being_loaded_destination_index)
-- local scope = Boats.get_scope(boat)
-- 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)
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
game.delete_surface(oldsurface)
@ -513,8 +513,8 @@ function Public.go_from_currentdestination_to_sea()
Common.set_evo(base_evo)
memory.dynamic_kraken_evo = 0
memory.loadingticks = nil
memory.mapbeingloadeddestination_index = nil
memory.loading_ticks = nil
memory.map_being_loaded_destination_index = nil
local d = destination.iconized_map_width + Crowsnest.platformwidth

View File

@ -1,5 +1,5 @@
--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 Structures = require 'maps.pirates.structures.structures'
@ -39,7 +39,7 @@ local function discharge_accumulators(surface, position, force, power_needs)
end
-- 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()
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
-- 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)
end
end
@ -102,7 +102,7 @@ function Public.class_update_auxiliary_data(tickinterval)
end
end
function Public.class_renderings(tickinterval)
function Public.class_renderings(tick_interval)
local memory = Memory.get_crew_memory()
if not memory.classes_table then return end
@ -255,7 +255,7 @@ function Public.class_renderings(tickinterval)
end
end
function Public.update_character_properties(tickinterval)
function Public.update_character_properties(tick_interval)
local memory = Memory.get_crew_memory()
local crew = Common.crew_get_crew_members()
@ -352,15 +352,15 @@ function Public.update_character_properties(tickinterval)
end
end
function Public.class_rewards_tick(tickinterval)
--assuming tickinterval = 7 seconds for now
function Public.class_rewards_tick(tick_interval)
--assuming tick_interval = 7 seconds for now
local memory = Memory.get_crew_memory()
local crew = Common.crew_get_crew_members()
for _, player in pairs(crew) do
local class = Classes.get_class(player.index)
if Common.validate_player_and_character(player) and
game.tick % tickinterval == 0 and
game.tick % tick_interval == 0 and
class and
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
-- 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
-- local inv = player.get_inventory(defines.inventory.character_main)
-- if not (inv and inv.valid) then return end

View File

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

View File

@ -216,7 +216,7 @@ end
function Public.tick_quest_structure_entry_price_check()
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()
if memory.game_lost then return end
local destination = Common.current_destination()

View File

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

View File

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

View File

@ -251,14 +251,14 @@ local function radioactive_tick()
local memory = Memory.get_crew_memory()
local destination = Common.current_destination()
local tickinterval = 60
local tick_interval = 60
if destination.subtype == IslandEnum.enum.RADIOACTIVE then
-- Stop increasing evo when boat left the island
local surface_name = memory.boat and memory.boat.surface_name
if surface_name ~= memory.sea_name then
-- 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)
if (not destination.dynamic_data.evolution_accrued_time) then
destination.dynamic_data.evolution_accrued_time = 0
@ -271,7 +271,7 @@ local function radioactive_tick()
local pollution = 0
local timer = destination.dynamic_data.timer
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
local surface = game.surfaces[destination.surface_name]

View File

@ -100,12 +100,12 @@ function Public.on_surface_generation(destination)
destination.dynamic_data.rocketsilomaxhp = Balance.silo_max_hp
destination.dynamic_data.rocketsilohp = Balance.silo_max_hp
destination.dynamic_data.rocketsilochargedbools = {}
destination.dynamic_data.rocketsiloenergyconsumed = 0
destination.dynamic_data.rocketsiloenergyconsumedwithinlasthalfsecond = 0
destination.dynamic_data.energychargedinsilosincelastcheck = 0
destination.dynamic_data.silocharged = false
destination.dynamic_data.rocketlaunched = false
destination.dynamic_data.rocket_silo_charged_bools = {}
destination.dynamic_data.rocket_silo_energy_consumed = 0
destination.dynamic_data.rocket_silo_energy_consumed_within_last_half_second = 0
destination.dynamic_data.energy_charged_in_silo_since_last_check = 0
destination.dynamic_data.silo_is_charged = 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
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 = {}
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)