2021-03-24 19:14:12 +01:00
|
|
|
local Event = require 'utils.event'
|
2019-04-19 23:27:13 +02:00
|
|
|
local gain_multiplier = 4
|
2019-04-15 20:19:32 +02:00
|
|
|
|
2020-08-31 00:31:01 +02:00
|
|
|
local balance_functions = {
|
2021-03-24 16:46:00 +01:00
|
|
|
['land-mine'] = function(force_name)
|
|
|
|
if not global.combat_balance[force_name].land_mine then
|
|
|
|
global.combat_balance[force_name].land_mine = -0.5
|
|
|
|
end
|
|
|
|
game.forces[force_name].set_ammo_damage_modifier('landmine', global.combat_balance[force_name].land_mine)
|
|
|
|
end,
|
|
|
|
['stronger-explosives'] = function(force_name)
|
|
|
|
if not global.combat_balance[force_name].land_mine then
|
|
|
|
global.combat_balance[force_name].land_mine = -0.5
|
|
|
|
end
|
|
|
|
global.combat_balance[force_name].land_mine = global.combat_balance[force_name].land_mine + 0.05
|
|
|
|
game.forces[force_name].set_ammo_damage_modifier('landmine', global.combat_balance[force_name].land_mine)
|
|
|
|
end
|
2020-08-31 00:31:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
local function combat_balance(event)
|
2021-03-24 16:46:00 +01:00
|
|
|
local research_name = event.research.name
|
|
|
|
local force_name = event.research.force.name
|
|
|
|
local key
|
|
|
|
for b = 1, string.len(research_name), 1 do
|
|
|
|
key = string.sub(research_name, 0, b)
|
|
|
|
if balance_functions[key] then
|
|
|
|
if not global.combat_balance[force_name] then
|
|
|
|
global.combat_balance[force_name] = {}
|
|
|
|
end
|
|
|
|
balance_functions[key](force_name)
|
|
|
|
return
|
|
|
|
end
|
|
|
|
end
|
2020-08-31 00:31:01 +02:00
|
|
|
end
|
|
|
|
|
2019-04-15 20:19:32 +02:00
|
|
|
local function on_research_finished(event)
|
2021-03-24 16:46:00 +01:00
|
|
|
local research = event.research
|
|
|
|
local force_name = research.force.name
|
|
|
|
|
|
|
|
if not global.shotgun_shell_damage_modifier_old[force_name] then
|
|
|
|
global.shotgun_shell_damage_modifier_old[force_name] = game.forces[force_name].get_ammo_damage_modifier('shotgun-shell') - 0.1
|
|
|
|
end
|
|
|
|
|
|
|
|
if string.sub(research.name, 0, 26) == 'physical-projectile-damage' then
|
|
|
|
local current_damage = game.forces[force_name].get_ammo_damage_modifier('shotgun-shell')
|
|
|
|
local vanilla_gain = current_damage - global.shotgun_shell_damage_modifier_old[force_name]
|
|
|
|
local additional_gain = vanilla_gain * (gain_multiplier - 1)
|
|
|
|
game.forces[force_name].set_ammo_damage_modifier('shotgun-shell', current_damage + additional_gain)
|
|
|
|
end
|
|
|
|
|
|
|
|
global.shotgun_shell_damage_modifier_old[force_name] = game.forces[force_name].get_ammo_damage_modifier('shotgun-shell')
|
|
|
|
|
|
|
|
combat_balance(event)
|
2019-04-15 20:19:32 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
local function on_init()
|
2021-03-24 16:46:00 +01:00
|
|
|
game.forces.player.set_ammo_damage_modifier('shotgun-shell', 1)
|
|
|
|
global.shotgun_shell_damage_modifier_old = {}
|
|
|
|
global.combat_balance = {}
|
2019-04-15 20:19:32 +02:00
|
|
|
end
|
|
|
|
|
2021-03-24 19:14:12 +01:00
|
|
|
Event.on_init(on_init)
|
|
|
|
Event.add(defines.events.on_research_finished, on_research_finished)
|