1
0
mirror of https://github.com/ComfyFactory/ComfyFactorio.git synced 2025-01-10 00:43:27 +02:00
ComfyFactorio/modules/rpg/main.lua

1380 lines
42 KiB
Lua
Raw Normal View History

2021-05-25 22:19:20 +02:00
--RPG Modules
local Public = require 'modules.rpg.core'
2020-07-25 17:22:04 +02:00
local Gui = require 'utils.gui'
local Event = require 'utils.event'
2021-12-05 23:15:49 +02:00
local AntiGrief = require 'utils.antigrief'
2020-12-14 20:36:37 +02:00
local SpamProtection = require 'utils.spam_protection'
local BiterHealthBooster = require 'modules.biter_health_booster_v2'
2021-05-23 21:13:21 +02:00
local Explosives = require 'modules.explosives'
2020-07-25 17:22:04 +02:00
local WD = require 'modules.wave_defense.table'
local Math2D = require 'math2d'
--RPG Settings
2021-05-25 22:19:20 +02:00
local enemy_types = Public.enemy_types
local die_cause = Public.die_cause
local points_per_level = Public.points_per_level
local nth_tick = Public.nth_tick
2020-07-25 17:22:04 +02:00
--RPG Frames
2021-05-25 22:19:20 +02:00
local main_frame_name = Public.main_frame_name
2020-07-25 17:22:04 +02:00
2020-08-10 23:15:29 +02:00
local sub = string.sub
2021-11-13 03:11:17 +02:00
local round = math.round
2021-11-14 22:01:01 +02:00
local floor = math.floor
local random = math.random
2021-11-23 21:28:23 +02:00
local sqrt = math.sqrt
2021-11-13 03:11:17 +02:00
local abs = math.abs
2020-08-10 23:15:29 +02:00
2022-04-05 20:02:13 +02:00
local function log_aoe_punch(callback)
local debug = Public.get('rpg_extra').debug_aoe_punch
2021-11-14 14:02:00 +02:00
if not debug then
return
end
callback()
end
2020-07-25 17:22:04 +02:00
local function on_gui_click(event)
2020-12-14 20:36:37 +02:00
if not event then
return
end
local player = game.players[event.player_index]
if not (player and player.valid) then
return
end
2020-07-25 17:22:04 +02:00
if not event.element then
return
end
if not event.element.valid then
return
end
local element = event.element
2020-12-14 20:36:37 +02:00
if player.gui.screen[main_frame_name] then
2021-01-12 22:52:45 +02:00
local is_spamming = SpamProtection.is_spamming(player, nil, 'RPG Gui Click')
2020-12-14 20:36:37 +02:00
if is_spamming then
return
end
2020-08-10 23:15:29 +02:00
end
2021-05-25 22:19:20 +02:00
local surface_name = Public.get('rpg_extra').surface_name
2020-08-10 23:15:29 +02:00
if sub(player.surface.name, 0, #surface_name) ~= surface_name then
return
end
2020-07-25 17:22:04 +02:00
if element.type ~= 'sprite-button' then
return
end
local shift = event.shift
if element.caption ~= '' then
return
end
if element.sprite ~= 'virtual-signal/signal-red' then
return
end
2021-05-25 22:19:20 +02:00
local rpg_t = Public.get_value_from_player(player.index)
2020-07-25 17:22:04 +02:00
local index = element.name
if not rpg_t[index] then
2020-07-25 17:22:04 +02:00
return
end
if not player.character then
return
end
if shift then
2021-11-20 01:37:35 +02:00
if event.button == defines.mouse_button_type.left then
local count = rpg_t.points_left
if not count then
return
end
rpg_t.points_left = 0
rpg_t[index] = rpg_t[index] + count
if not rpg_t.reset then
rpg_t.total = rpg_t.total + count
end
Public.toggle(player, true)
Public.update_player_stats(player)
elseif event.button == defines.mouse_button_type.right then
local left = rpg_t.points_left / 2
if left > 2 then
for _ = 1, left, 1 do
if rpg_t.points_left <= 0 then
Public.toggle(player, true)
return
end
rpg_t.points_left = rpg_t.points_left - 1
rpg_t[index] = rpg_t[index] + 1
if not rpg_t.reset then
rpg_t.total = rpg_t.total + 1
end
Public.update_player_stats(player)
end
end
Public.toggle(player, true)
2020-07-25 17:22:04 +02:00
end
elseif event.button == defines.mouse_button_type.right then
for _ = 1, points_per_level, 1 do
2021-05-23 17:03:52 +02:00
if rpg_t.points_left <= 0 then
2021-05-25 22:19:20 +02:00
Public.toggle(player, true)
2020-07-25 17:22:04 +02:00
return
end
2021-05-23 17:03:52 +02:00
rpg_t.points_left = rpg_t.points_left - 1
rpg_t[index] = rpg_t[index] + 1
if not rpg_t.reset then
rpg_t.total = rpg_t.total + 1
2020-07-25 17:22:04 +02:00
end
2021-05-25 22:19:20 +02:00
Public.update_player_stats(player)
2020-07-25 17:22:04 +02:00
end
2021-05-25 22:19:20 +02:00
Public.toggle(player, true)
2020-07-25 17:22:04 +02:00
return
end
2021-05-23 17:03:52 +02:00
if rpg_t.points_left <= 0 then
2021-05-25 22:19:20 +02:00
Public.toggle(player, true)
2020-07-25 17:22:04 +02:00
return
end
2021-05-23 17:03:52 +02:00
rpg_t.points_left = rpg_t.points_left - 1
rpg_t[index] = rpg_t[index] + 1
if not rpg_t.reset then
rpg_t.total = rpg_t.total + 1
2020-07-25 17:22:04 +02:00
end
2021-05-25 22:19:20 +02:00
Public.update_player_stats(player)
Public.toggle(player, true)
2020-07-25 17:22:04 +02:00
end
local function train_type_cause(cause)
local players = {}
if cause.train.passengers then
for _, player in pairs(cause.train.passengers) do
players[#players + 1] = player
end
end
return players
end
local get_cause_player = {
['character'] = function(cause)
if not cause.player then
return
end
return {cause.player}
end,
['combat-robot'] = function(cause)
if not cause.last_user then
return
end
if not game.players[cause.last_user.index] then
return
end
return {game.players[cause.last_user.index]}
end,
['car'] = function(cause)
local players = {}
local driver = cause.get_driver()
if driver then
if driver.player then
players[#players + 1] = driver.player
end
end
local passenger = cause.get_passenger()
if passenger then
if passenger.player then
2021-01-26 21:17:52 +02:00
players[#players + 1] = passenger.player
end
end
return players
end,
['spider-vehicle'] = function(cause)
local players = {}
local driver = cause.get_driver()
if driver then
if driver.player then
players[#players + 1] = driver.player
end
end
local passenger = cause.get_passenger()
if passenger then
if passenger.player then
2020-07-25 17:22:04 +02:00
players[#players + 1] = passenger.player
end
end
return players
end,
['locomotive'] = train_type_cause,
['cargo-wagon'] = train_type_cause,
['artillery-wagon'] = train_type_cause,
['fluid-wagon'] = train_type_cause
}
local function on_entity_died(event)
if not event.entity or not event.entity.valid then
2020-07-25 17:22:04 +02:00
return
end
local entity = event.entity
2020-07-25 17:22:04 +02:00
--Grant XP for hand placed land mines
if entity.last_user then
if entity.type == 'land-mine' then
2020-07-25 17:22:04 +02:00
if event.cause then
if event.cause.valid then
if event.cause.force.index == entity.force.index then
2020-07-25 17:22:04 +02:00
return
end
end
end
2021-05-25 22:19:20 +02:00
Public.gain_xp(entity.last_user, 1)
Public.reward_mana(entity.last_user, 1)
2020-07-25 17:22:04 +02:00
return
end
end
2021-05-25 22:19:20 +02:00
local rpg_extra = Public.get('rpg_extra')
2020-07-25 17:22:04 +02:00
if rpg_extra.enable_wave_defense then
if rpg_extra.rpg_xp_yield['big-biter'] <= 16 then
local wave_number = WD.get_wave()
if wave_number >= 1000 then
rpg_extra.rpg_xp_yield['big-biter'] = 16
rpg_extra.rpg_xp_yield['behemoth-biter'] = 64
end
end
end
local biter_health_boost = BiterHealthBooster.get('biter_health_boost')
local biter_health_boost_units = BiterHealthBooster.get('biter_health_boost_units')
if not event.cause or not event.cause.valid then
2020-07-25 17:22:04 +02:00
return
end
local cause = event.cause
local type = cause.type
2020-07-25 17:22:04 +02:00
if not type then
goto continue
end
if cause.force.index == 1 then
2020-07-25 17:22:04 +02:00
if die_cause[type] then
if rpg_extra.rpg_xp_yield[entity.name] then
local amount = rpg_extra.rpg_xp_yield[entity.name]
2020-07-25 17:22:04 +02:00
amount = amount / 5
if biter_health_boost then
local health_pool = biter_health_boost_units[entity.unit_number]
2020-07-25 17:22:04 +02:00
if health_pool then
amount = amount * (1 / health_pool[2])
2020-07-25 17:22:04 +02:00
end
end
if rpg_extra.turret_kills_to_global_pool then
2021-05-25 22:19:20 +02:00
Public.add_to_global_pool(amount, false)
2020-07-25 17:22:04 +02:00
end
else
2021-05-25 22:19:20 +02:00
Public.add_to_global_pool(0.5, false)
2020-07-25 17:22:04 +02:00
end
return
end
end
::continue::
if cause.force.index == entity.force.index then
2020-07-25 17:22:04 +02:00
return
end
if not get_cause_player[cause.type] then
2020-07-25 17:22:04 +02:00
return
end
local players = get_cause_player[cause.type](cause)
2020-07-25 17:22:04 +02:00
if not players then
return
end
if not players[1] then
return
end
--Grant modified XP for health boosted units
if biter_health_boost then
if enemy_types[entity.type] then
local health_pool = biter_health_boost_units[entity.unit_number]
2020-07-25 17:22:04 +02:00
if health_pool then
for _, player in pairs(players) do
2021-10-24 21:50:48 +02:00
if entity.unit_number then
local mana_to_reward = random(1, 5)
2021-10-24 21:50:48 +02:00
if mana_to_reward > 1 then
Public.reward_mana(player, mana_to_reward)
end
end
if rpg_extra.rpg_xp_yield[entity.name] then
local amount = rpg_extra.rpg_xp_yield[entity.name] * (1 / health_pool[2])
if amount < rpg_extra.rpg_xp_yield[entity.name] then
amount = rpg_extra.rpg_xp_yield[entity.name]
end
2020-07-25 17:22:04 +02:00
if rpg_extra.turret_kills_to_global_pool then
2021-05-25 22:19:20 +02:00
local inserted = Public.add_to_global_pool(amount, true)
Public.gain_xp(player, inserted, true)
2020-07-25 17:22:04 +02:00
else
2021-05-25 22:19:20 +02:00
Public.gain_xp(player, amount)
2020-07-25 17:22:04 +02:00
end
else
2021-05-25 22:19:20 +02:00
Public.gain_xp(player, 0.5 * (1 / health_pool[2]))
2020-07-25 17:22:04 +02:00
end
end
return
end
end
end
--Grant normal XP
for _, player in pairs(players) do
2021-10-24 21:50:48 +02:00
if entity.unit_number then
local mana_to_reward = random(1, 5)
2021-10-24 21:50:48 +02:00
if mana_to_reward > 1 then
Public.reward_mana(player, mana_to_reward)
end
end
if rpg_extra.rpg_xp_yield[entity.name] then
local amount = rpg_extra.rpg_xp_yield[entity.name]
2020-07-25 17:22:04 +02:00
if rpg_extra.turret_kills_to_global_pool then
2021-05-25 22:19:20 +02:00
local inserted = Public.add_to_global_pool(amount, true)
Public.gain_xp(player, inserted, true)
2020-07-25 17:22:04 +02:00
else
2021-05-25 22:19:20 +02:00
Public.gain_xp(player, amount)
2020-07-25 17:22:04 +02:00
end
else
2021-05-25 22:19:20 +02:00
Public.gain_xp(player, 0.5)
2020-07-25 17:22:04 +02:00
end
end
end
local function regen_health_player(players)
for i = 1, #players do
local player = players[i]
2021-05-25 22:19:20 +02:00
local heal_per_tick = Public.get_heal_modifier(player)
2020-07-25 17:22:04 +02:00
if heal_per_tick <= 0 then
goto continue
end
2021-11-13 03:11:17 +02:00
heal_per_tick = round(heal_per_tick)
2020-07-25 17:22:04 +02:00
if player and player.valid and not player.in_combat then
if player.character and player.character.valid then
player.character.health = player.character.health + heal_per_tick
end
end
::continue::
2020-07-28 19:55:28 +02:00
2021-05-25 22:19:20 +02:00
Public.update_health(player)
2020-07-25 17:22:04 +02:00
end
end
local function regen_mana_player(players)
for i = 1, #players do
local player = players[i]
2021-05-25 22:19:20 +02:00
local mana_per_tick = Public.get_mana_modifier(player)
local rpg_extra = Public.get('rpg_extra')
local rpg_t = Public.get_value_from_player(player.index)
2020-07-25 17:22:04 +02:00
if mana_per_tick <= 0.1 then
mana_per_tick = rpg_extra.mana_per_tick
end
if rpg_extra.force_mana_per_tick then
mana_per_tick = 1
end
if player and player.valid and not player.in_combat then
if player.character and player.character.valid then
if rpg_t.mana < 0 then
rpg_t.mana = 0
2020-08-14 17:16:04 +02:00
end
if rpg_t.mana >= rpg_t.mana_max then
2020-07-25 17:22:04 +02:00
goto continue
end
rpg_t.mana = rpg_t.mana + mana_per_tick
if rpg_t.mana >= rpg_t.mana_max then
rpg_t.mana = rpg_t.mana_max
2020-07-25 17:22:04 +02:00
end
2021-11-13 03:11:17 +02:00
rpg_t.mana = (round(rpg_t.mana * 10) / 10)
2020-07-25 17:22:04 +02:00
end
end
::continue::
2020-07-28 19:55:28 +02:00
2021-05-25 22:19:20 +02:00
Public.update_mana(player)
2020-07-25 17:22:04 +02:00
end
end
local function give_player_flameboots(player)
2021-05-25 22:19:20 +02:00
local rpg_t = Public.get_value_from_player(player.index)
if not rpg_t then
return
end
if not rpg_t.flame_boots then
2020-07-25 17:22:04 +02:00
return
end
if not player.character then
2020-07-25 17:22:04 +02:00
return
end
if player.character.driving then
2020-07-25 17:22:04 +02:00
return
end
if not rpg_t.mana then
2020-07-25 17:22:04 +02:00
return
end
if rpg_t.mana <= 0 then
2020-09-04 22:04:28 +02:00
player.print(({'rpg_main.flame_boots_worn_out'}), {r = 0.22, g = 0.77, b = 0.44})
rpg_t.flame_boots = false
2020-07-25 17:22:04 +02:00
return
end
if rpg_t.mana % 500 == 0 then
player.print(({'rpg_main.flame_mana_remaining', rpg_t.mana}), {r = 0.22, g = 0.77, b = 0.44})
2020-07-25 17:22:04 +02:00
end
local p = player.position
player.surface.create_entity({name = 'fire-flame', position = p})
rpg_t.mana = rpg_t.mana - 5
if rpg_t.mana <= 0 then
rpg_t.mana = 0
2020-07-25 17:22:04 +02:00
end
if player.gui.screen[main_frame_name] then
local f = player.gui.screen[main_frame_name]
2020-07-25 17:22:04 +02:00
local data = Gui.get_data(f)
2020-07-28 11:24:16 +02:00
if data.mana and data.mana.valid then
data.mana.caption = rpg_t.mana
2020-07-28 11:24:16 +02:00
end
2020-07-25 17:22:04 +02:00
end
end
2021-11-14 22:01:01 +02:00
local function has_health_boost(entity, damage, final_damage_amount, cause)
local biter_health_boost = BiterHealthBooster.get('biter_health_boost')
local biter_health_boost_units = BiterHealthBooster.get('biter_health_boost_units')
local get_health_pool
--Handle the custom health pool of the biter health booster, if it is used in the map.
if biter_health_boost then
local health_pool = biter_health_boost_units[entity.unit_number]
if health_pool then
get_health_pool = health_pool[1]
--Set entity health relative to health pool
local max_health = health_pool[3].max_health
local m = health_pool[1] / max_health
local final_health = round(entity.prototype.max_health * m)
health_pool[1] = round(health_pool[1] + final_damage_amount)
health_pool[1] = round(health_pool[1] - damage)
--Set entity health relative to health pool
entity.health = final_health
if health_pool[1] <= 0 then
local entity_number = entity.unit_number
entity.die(entity.force.name, cause)
if biter_health_boost_units[entity_number] then
biter_health_boost_units[entity_number] = nil
end
end
else
entity.health = entity.health + final_damage_amount
entity.health = entity.health - damage
if entity.health <= 0 then
entity.die(cause.force.name, cause)
end
end
else
--Handle vanilla damage.
entity.health = entity.health + final_damage_amount
entity.health = entity.health - damage
if entity.health <= 0 then
entity.die(cause.force.name, cause)
end
end
return get_health_pool
end
local function set_health_boost(entity, damage, cause)
local biter_health_boost = BiterHealthBooster.get('biter_health_boost')
local biter_health_boost_units = BiterHealthBooster.get('biter_health_boost_units')
local get_health_pool
--Handle the custom health pool of the biter health booster, if it is used in the map.
if biter_health_boost then
local health_pool = biter_health_boost_units[entity.unit_number]
if health_pool then
get_health_pool = health_pool[1]
--Set entity health relative to health pool
local max_health = health_pool[3].max_health
local m = health_pool[1] / max_health
local final_health = round(entity.prototype.max_health * m)
health_pool[1] = round(health_pool[1] - damage)
--Set entity health relative to health pool
entity.health = final_health
if health_pool[1] <= 0 then
local entity_number = entity.unit_number
entity.die(entity.force.name, cause)
if biter_health_boost_units[entity_number] then
biter_health_boost_units[entity_number] = nil
end
end
end
end
return get_health_pool
end
2020-07-25 17:22:04 +02:00
--Melee damage modifier
2022-04-05 20:02:13 +02:00
local function aoe_punch(character, target, damage, get_health_pool)
2021-11-14 22:01:01 +02:00
if not (target and target.valid) then
return
end
2020-07-25 17:22:04 +02:00
local base_vector = {target.position.x - character.position.x, target.position.y - character.position.y}
local vector = {base_vector[1], base_vector[2]}
vector[1] = vector[1] * 1000
vector[2] = vector[2] * 1000
character.surface.create_entity(
{
name = 'flying-text',
position = {character.position.x + base_vector[1] * 0.5, character.position.y + base_vector[2] * 0.5},
2022-04-05 20:02:13 +02:00
text = ({'rpg_main.aoe_punch_text'}),
2020-07-25 17:22:04 +02:00
color = {255, 0, 0}
}
)
character.surface.create_entity({name = 'blood-explosion-huge', position = target.position})
character.surface.create_entity(
{
name = 'big-artillery-explosion',
position = {target.position.x + vector[1] * 0.5, target.position.y + vector[2] * 0.5}
}
)
2021-11-13 03:11:17 +02:00
if abs(vector[1]) > abs(vector[2]) then
local d = abs(vector[1])
if abs(vector[1]) > 0 then
2020-07-25 17:22:04 +02:00
vector[1] = vector[1] / d
end
2021-11-13 03:11:17 +02:00
if abs(vector[2]) > 0 then
2020-07-25 17:22:04 +02:00
vector[2] = vector[2] / d
end
else
2021-11-13 03:11:17 +02:00
local d = abs(vector[2])
if abs(vector[2]) > 0 then
2020-07-25 17:22:04 +02:00
vector[2] = vector[2] / d
end
2021-11-13 03:11:17 +02:00
if abs(vector[1]) > 0 and d > 0 then
2020-07-25 17:22:04 +02:00
vector[1] = vector[1] / d
end
end
vector[1] = vector[1] * 1.5
vector[2] = vector[2] * 1.5
2021-11-26 09:52:31 +02:00
local a = 0.20
2020-07-25 17:22:04 +02:00
2021-11-13 03:11:17 +02:00
local cs = character.surface
local cp = character.position
2020-07-25 17:22:04 +02:00
for i = 1, 16, 1 do
for x = i * -1 * a, i * a, 1 do
for y = i * -1 * a, i * a, 1 do
2021-11-13 03:11:17 +02:00
local p = {cp.x + x + vector[1] * i, cp.y + y + vector[2] * i}
cs.create_trivial_smoke({name = 'train-smoke', position = p})
for _, e in pairs(cs.find_entities({{p[1] - a, p[2] - a}, {p[1] + a, p[2] + a}})) do
2020-07-25 17:22:04 +02:00
if e.valid then
if e.health then
if e.destructible and e.minable and e.force.index ~= 3 then
if e.force.index ~= character.force.index then
2021-11-14 22:01:01 +02:00
if get_health_pool then
local max_unit_health = floor(get_health_pool * 0.00015)
if max_unit_health <= 0 then
max_unit_health = 4
end
2021-11-20 01:37:35 +02:00
if max_unit_health >= 10 then
max_unit_health = 10
2021-11-14 22:01:01 +02:00
end
local final = floor(damage * max_unit_health)
set_health_boost(e, final, character)
if e.valid and e.health <= 0 and get_health_pool <= 0 then
e.die(e.force.name, character)
end
else
if e.valid then
e.health = e.health - damage * 0.05
if e.health <= 0 then
e.die(e.force.name, character)
end
end
2020-07-25 17:22:04 +02:00
end
end
end
end
end
end
end
end
end
end
2021-02-04 13:27:10 +02:00
local function is_position_near(area, entity)
local status = false
local function inside(pos)
local lt = area.left_top
local rb = area.right_bottom
return pos.x >= lt.x and pos.y >= lt.y and pos.x <= rb.x and pos.y <= rb.y
end
if inside(entity, area) then
status = true
end
return status
end
2020-07-25 17:22:04 +02:00
local function on_entity_damaged(event)
if not event.cause then
return
end
if not event.cause.valid then
return
end
if event.cause.force.index == 2 then
return
end
if event.cause.name ~= 'character' then
return
end
2020-07-28 19:55:28 +02:00
2020-07-25 17:22:04 +02:00
if event.damage_type.name ~= 'physical' then
return
end
2020-07-28 19:55:28 +02:00
2020-07-25 17:22:04 +02:00
if not event.entity.valid then
return
end
2021-02-04 13:27:10 +02:00
local entity = event.entity
local cause = event.cause
2021-11-14 14:02:00 +02:00
local original_damage_amount = event.original_damage_amount
2021-11-14 22:01:01 +02:00
local final_damage_amount = event.final_damage_amount
2021-02-04 13:27:10 +02:00
2022-04-05 12:00:13 +02:00
if cause.get_inventory(defines.inventory.character_ammo)[cause.selected_gun_index].valid_for_read or cause.get_inventory(defines.inventory.character_guns)[cause.selected_gun_index].valid_for_read then
2021-05-25 22:19:20 +02:00
local is_explosive_bullets_enabled = Public.get_explosive_bullets()
2021-02-26 00:59:33 +02:00
if is_explosive_bullets_enabled then
2021-05-25 22:19:20 +02:00
Public.explosive_bullets(event)
2021-02-26 00:59:33 +02:00
end
2020-07-25 17:22:04 +02:00
return
end
2021-02-04 13:27:10 +02:00
if not cause.player then
2020-07-25 17:22:04 +02:00
return
end
2021-02-04 13:27:10 +02:00
local p = cause.player
2020-08-10 23:15:29 +02:00
2021-05-25 22:19:20 +02:00
local surface_name = Public.get('rpg_extra').surface_name
2021-02-04 13:27:10 +02:00
if sub(p.surface.name, 0, #surface_name) ~= surface_name then
return
end
2021-02-04 13:27:10 +02:00
if entity.force.index == cause.force.index then
2020-08-10 23:15:29 +02:00
return
end
2021-02-04 13:27:10 +02:00
local position = p.position
local area = {
left_top = {x = position.x - 5, y = position.y - 5},
right_bottom = {x = position.x + 5, y = position.y + 5}
2021-02-04 13:27:10 +02:00
}
if not is_position_near(area, entity.position) then
2021-02-01 21:01:07 +02:00
return
end
2021-02-10 22:31:26 +02:00
local item = p.cursor_stack
if item and item.valid_for_read then
if item.name == 'discharge-defense-remote' then
return
end
end
2021-05-25 22:19:20 +02:00
Public.reward_mana(cause.player, 2)
2020-07-28 19:55:28 +02:00
2020-07-25 17:22:04 +02:00
--Grant the player life-on-hit.
2021-05-25 22:19:20 +02:00
cause.health = cause.health + Public.get_life_on_hit(cause.player)
2020-07-25 17:22:04 +02:00
--Calculate modified damage.
2021-11-14 14:02:00 +02:00
local damage = Public.get_final_damage(cause.player, entity, original_damage_amount)
2022-04-05 20:02:13 +02:00
local enable_aoe_punch = Public.get('rpg_extra').enable_aoe_punch
2021-05-25 22:19:20 +02:00
local rpg_t = Public.get_value_from_player(cause.player.index)
2020-07-25 17:22:04 +02:00
--Floating messages and particle effects.
2021-11-13 03:11:17 +02:00
if random(1, 7) == 1 then
damage = damage * random(250, 350) * 0.01
2021-02-04 13:27:10 +02:00
cause.surface.create_entity(
2020-07-25 17:22:04 +02:00
{
name = 'flying-text',
2021-02-04 13:27:10 +02:00
position = entity.position,
2021-11-23 21:28:23 +02:00
text = '' .. floor(damage),
2020-07-25 17:22:04 +02:00
color = {255, 0, 0}
}
)
2021-02-04 13:27:10 +02:00
cause.surface.create_entity({name = 'blood-explosion-huge', position = entity.position})
2020-07-25 17:22:04 +02:00
else
2021-11-13 03:11:17 +02:00
damage = damage * random(100, 125) * 0.01
2021-02-04 13:27:10 +02:00
cause.player.create_local_flying_text(
2020-07-25 17:22:04 +02:00
{
2021-11-23 21:28:23 +02:00
text = floor(damage),
2021-02-04 13:27:10 +02:00
position = entity.position,
2020-07-25 17:22:04 +02:00
color = {150, 150, 150},
time_to_live = 90,
speed = 2
}
)
end
2021-11-14 22:01:01 +02:00
local get_health_pool = has_health_boost(entity, damage, final_damage_amount, cause)
2021-11-14 22:01:01 +02:00
--Cause a one punch.
2022-04-05 20:02:13 +02:00
if enable_aoe_punch then
if rpg_t.aoe_punch then
local chance = Public.get_aoe_punch_chance(cause.player) * 10
2021-11-14 22:01:01 +02:00
local chance_to_hit = random(0, 999)
local success = chance_to_hit < chance
2022-04-05 20:02:13 +02:00
log_aoe_punch(
2021-11-14 22:01:01 +02:00
function()
if success then
print('[OnePunch]: Chance: ' .. chance .. ' Chance to hit: ' .. chance_to_hit .. ' Success: true' .. ' Damage: ' .. damage)
else
print('[OnePunch]: Chance: ' .. chance .. ' Chance to hit: ' .. chance_to_hit .. ' Success: false' .. ' Damage: ' .. damage)
end
end
2021-11-14 22:01:01 +02:00
)
if success then
2022-04-05 20:02:13 +02:00
aoe_punch(cause, entity, damage, get_health_pool) -- only kill the biters if their health is below or equal to zero
2021-11-14 22:01:01 +02:00
return
2020-07-25 17:22:04 +02:00
end
end
end
2021-05-25 22:19:20 +02:00
local is_explosive_bullets_enabled = Public.get_explosive_bullets()
2021-02-26 00:59:33 +02:00
if is_explosive_bullets_enabled then
2021-05-25 22:19:20 +02:00
Public.explosive_bullets(event)
2021-02-26 00:59:33 +02:00
end
2020-07-25 17:22:04 +02:00
end
local function on_player_repaired_entity(event)
2021-11-13 03:11:17 +02:00
if random(1, 4) ~= 1 then
2020-07-25 17:22:04 +02:00
return
end
local entity = event.entity
if not entity then
return
end
if not entity.valid then
return
end
if not entity.health then
return
end
local player = game.players[event.player_index]
2020-08-10 23:15:29 +02:00
if not player or not player.valid or not player.character then
2020-07-25 17:22:04 +02:00
return
end
2020-08-10 23:15:29 +02:00
2021-05-25 22:19:20 +02:00
Public.gain_xp(player, 0.05)
Public.reward_mana(player, 0.2)
2020-07-25 17:22:04 +02:00
2021-05-25 22:19:20 +02:00
local repair_speed = Public.get_magicka(player)
2020-07-25 17:22:04 +02:00
if repair_speed <= 0 then
return
end
entity.health = entity.health + repair_speed
end
local function on_player_rotated_entity(event)
local player = game.players[event.player_index]
2020-08-10 23:15:29 +02:00
if not player or not player.valid then
return
end
2020-07-25 17:22:04 +02:00
if not player.character then
return
end
2020-08-10 23:15:29 +02:00
2021-05-25 22:19:20 +02:00
local rpg_t = Public.get_value_from_player(player.index)
if rpg_t.rotated_entity_delay > game.tick then
2020-07-25 17:22:04 +02:00
return
end
rpg_t.rotated_entity_delay = game.tick + 20
2021-05-25 22:19:20 +02:00
Public.gain_xp(player, 0.20)
2020-07-25 17:22:04 +02:00
end
local function on_player_changed_position(event)
local player = game.players[event.player_index]
2020-08-10 23:15:29 +02:00
if not player or not player.valid then
2020-07-25 17:22:04 +02:00
return
end
2021-05-25 22:19:20 +02:00
local enable_flame_boots = Public.get('rpg_extra').enable_flame_boots
2020-07-25 17:22:04 +02:00
if enable_flame_boots then
give_player_flameboots(player)
end
2021-11-13 03:11:17 +02:00
if random(1, 64) ~= 1 then
2020-07-25 17:22:04 +02:00
return
end
if not player.character then
return
end
if player.character.driving then
return
end
2021-05-25 22:19:20 +02:00
Public.gain_xp(player, 1.0)
2020-07-25 17:22:04 +02:00
end
local building_and_mining_blacklist = {
['tile-ghost'] = true,
['entity-ghost'] = true,
['item-entity'] = true
}
2020-08-27 13:27:34 +02:00
local function on_player_died(event)
local player = game.players[event.player_index]
if not player or not player.valid then
return
end
2021-05-25 22:19:20 +02:00
Public.remove_frame(player)
2020-08-27 13:27:34 +02:00
end
local function on_pre_player_left_game(event)
local player = game.players[event.player_index]
if not player or not player.valid then
return
end
2021-05-25 22:19:20 +02:00
Public.remove_frame(player)
2020-08-27 13:27:34 +02:00
end
2020-07-25 17:22:04 +02:00
local function on_pre_player_mined_item(event)
local entity = event.entity
if not entity.valid then
return
end
if building_and_mining_blacklist[entity.type] then
return
end
if entity.force.index ~= 3 then
return
end
local player = game.players[event.player_index]
2020-08-10 23:15:29 +02:00
if not player or not player.valid then
return
end
2021-05-25 22:19:20 +02:00
local surface_name = Public.get('rpg_extra').surface_name
2020-08-10 23:15:29 +02:00
if sub(player.surface.name, 0, #surface_name) ~= surface_name then
return
end
2021-05-25 22:19:20 +02:00
local rpg_t = Public.get_value_from_player(player.index)
2021-11-23 21:28:23 +02:00
if rpg_t.last_mined_entity_position.x == entity.position.x and rpg_t.last_mined_entity_position.y == entity.position.y then
2020-07-25 17:22:04 +02:00
return
end
rpg_t.last_mined_entity_position.x = entity.position.x
rpg_t.last_mined_entity_position.y = entity.position.y
2020-07-25 17:22:04 +02:00
2021-11-23 21:28:23 +02:00
local distance_multiplier = floor(sqrt(entity.position.x ^ 2 + entity.position.y ^ 2)) * 0.0005 + 1
local xp_modifier_when_mining = Public.get('rpg_extra').xp_modifier_when_mining
2020-07-25 17:22:04 +02:00
local xp_amount
if entity.type == 'resource' then
2021-11-23 21:28:23 +02:00
xp_amount = 0.9 * distance_multiplier
2020-07-25 17:22:04 +02:00
else
2021-11-23 21:28:23 +02:00
xp_amount = (1.5 + entity.prototype.max_health * xp_modifier_when_mining) * distance_multiplier
2020-07-25 17:22:04 +02:00
end
if player.gui.screen[main_frame_name] then
local f = player.gui.screen[main_frame_name]
2020-07-28 11:24:16 +02:00
local data = Gui.get_data(f)
if data.exp_gui and data.exp_gui.valid then
2021-11-23 21:28:23 +02:00
data.exp_gui.caption = floor(rpg_t.xp)
2020-07-28 11:24:16 +02:00
end
end
2021-05-25 22:19:20 +02:00
Public.gain_xp(player, xp_amount)
Public.reward_mana(player, 0.5 * distance_multiplier)
2020-07-25 17:22:04 +02:00
end
local function on_player_crafted_item(event)
if not event.recipe.energy then
return
end
local player = game.players[event.player_index]
2020-08-10 23:15:29 +02:00
if not player or not player.valid then
2020-07-25 17:22:04 +02:00
return
end
if player.cheat_mode then
return
end
2021-05-25 22:19:20 +02:00
local rpg_extra = Public.get('rpg_extra')
2020-11-15 20:23:54 +02:00
local is_blacklisted = rpg_extra.tweaked_crafting_items
local tweaked_crafting_items_enabled = rpg_extra.tweaked_crafting_items_enabled
local item = event.item_stack
2021-11-23 21:28:23 +02:00
local amount = 0.40 * random(1, 2)
local recipe = event.recipe
2020-11-15 20:23:54 +02:00
if tweaked_crafting_items_enabled then
if item and item.valid then
if is_blacklisted[item.name] then
amount = 0.2
end
end
end
2021-11-23 21:28:23 +02:00
local final_xp = recipe.energy * amount
Public.gain_xp(player, final_xp)
2021-05-25 22:19:20 +02:00
Public.reward_mana(player, amount)
2020-07-25 17:22:04 +02:00
end
local function on_player_respawned(event)
local player = game.players[event.player_index]
2021-05-25 22:19:20 +02:00
local rpg_t = Public.get_value_from_player(player.index)
if not rpg_t then
2021-05-25 22:19:20 +02:00
Public.rpg_reset_player(player)
2020-07-25 17:22:04 +02:00
return
end
2021-05-25 22:19:20 +02:00
Public.update_player_stats(player)
Public.draw_level_text(player)
Public.update_health(player)
Public.update_mana(player)
2020-07-25 17:22:04 +02:00
end
local function on_player_joined_game(event)
local player = game.players[event.player_index]
2021-05-25 22:19:20 +02:00
local rpg_t = Public.get_value_from_player(player.index)
local rpg_extra = Public.get('rpg_extra')
if not rpg_t then
2021-05-25 22:19:20 +02:00
Public.rpg_reset_player(player)
2020-07-25 17:22:04 +02:00
if rpg_extra.reward_new_players > 10 then
2021-05-25 22:19:20 +02:00
Public.gain_xp(player, rpg_extra.reward_new_players)
2020-07-25 17:22:04 +02:00
end
end
for _, p in pairs(game.connected_players) do
2021-05-25 22:19:20 +02:00
Public.draw_level_text(p)
2020-07-25 17:22:04 +02:00
end
2021-05-25 22:19:20 +02:00
Public.draw_gui_char_button(player)
2020-07-25 17:22:04 +02:00
if not player.character then
return
end
2021-05-25 22:19:20 +02:00
Public.update_player_stats(player)
2020-07-25 17:22:04 +02:00
end
local function create_projectile(surface, name, position, force, target, max_range)
if max_range then
surface.create_entity(
{
name = name,
position = position,
force = force,
source = position,
target = target,
max_range = max_range,
speed = 0.4
}
)
else
surface.create_entity(
{
name = name,
position = position,
force = force,
source = position,
target = target,
speed = 0.4
}
)
end
end
local function get_near_coord_modifier(range)
2021-11-13 03:11:17 +02:00
local coord = {x = (range * -1) + random(0, range * 2), y = (range * -1) + random(0, range * 2)}
2020-07-25 17:22:04 +02:00
for i = 1, 5, 1 do
2021-11-13 03:11:17 +02:00
local new_coord = {x = (range * -1) + random(0, range * 2), y = (range * -1) + random(0, range * 2)}
2020-07-25 17:22:04 +02:00
if new_coord.x ^ 2 + new_coord.y ^ 2 < coord.x ^ 2 + coord.y ^ 2 then
coord = new_coord
end
end
return coord
end
local function damage_entity(e)
2020-07-27 11:07:32 +02:00
if not e or not e.valid then
return
end
2020-07-25 17:22:04 +02:00
if not e.health then
return
end
if e.force.name == 'player' then
return
end
2021-11-23 21:28:23 +02:00
if not e.destructible then
return
end
e.surface.create_entity({name = 'ground-explosion', position = e.position})
2020-07-25 17:22:04 +02:00
if e.type == 'entity-ghost' then
e.destroy()
return
end
2021-11-13 03:11:17 +02:00
e.health = e.health - random(30, 90)
2020-07-25 17:22:04 +02:00
if e.health <= 0 then
e.die('enemy')
end
end
local function floaty_hearts(entity, c)
local position = {x = entity.position.x - 0.75, y = entity.position.y - 1}
local b = 1.35
for _ = 1, c, 1 do
local p = {
2021-11-13 03:11:17 +02:00
(position.x + 0.4) + (b * -1 + random(0, b * 20) * 0.1),
position.y + (b * -1 + random(0, b * 20) * 0.1)
2020-07-25 17:22:04 +02:00
}
2021-11-13 03:11:17 +02:00
entity.surface.create_entity({name = 'flying-text', position = p, text = '', color = {random(150, 255), 0, 255}})
2020-07-25 17:22:04 +02:00
end
end
local function tame_unit_effects(player, entity)
floaty_hearts(entity, 7)
rendering.draw_text {
text = '~' .. player.name .. "'s pet~",
surface = player.surface,
target = entity,
target_offset = {0, -2.6},
color = {
r = player.color.r * 0.6 + 0.25,
g = player.color.g * 0.6 + 0.25,
b = player.color.b * 0.6 + 0.25,
a = 1
},
scale = 1.05,
font = 'default-large-semibold',
alignment = 'center',
scale_with_zoom = false
}
end
local function on_player_used_capsule(event)
2021-05-25 22:19:20 +02:00
local enable_mana = Public.get('rpg_extra').enable_mana
local surface_name = Public.get('rpg_extra').surface_name
2020-07-25 17:22:04 +02:00
if not enable_mana then
return
end
2021-05-25 22:19:20 +02:00
local conjure_items = Public.get_spells()
local projectile_types = Public.get_projectiles
2020-07-27 11:07:32 +02:00
2020-07-25 17:22:04 +02:00
local player = game.players[event.player_index]
if not player or not player.valid then
return
end
2020-07-28 11:24:16 +02:00
if not player.character or not player.character.valid then
return
end
2020-08-10 23:15:29 +02:00
if sub(player.surface.name, 0, #surface_name) ~= surface_name then
2020-07-25 17:22:04 +02:00
return
end
local item = event.item
if not item then
return
end
local name = item.name
if name ~= 'raw-fish' then
return
end
Public.get_heal_modifier_from_using_fish(player)
2021-05-25 22:19:20 +02:00
local rpg_t = Public.get_value_from_player(player.index)
2020-07-25 17:22:04 +02:00
if not rpg_t.enable_entity_spawn then
2020-07-25 17:22:04 +02:00
return
end
if rpg_t.last_spawned >= game.tick then
2022-04-05 12:00:13 +02:00
return Public.cast_spell(player, true)
2020-07-25 17:22:04 +02:00
end
local mana = rpg_t.mana
2020-07-25 17:22:04 +02:00
local surface = player.surface
local object = conjure_items[rpg_t.dropdown_select_index]
2020-07-25 17:22:04 +02:00
if not object then
return
end
local position = event.position
if not position then
return
end
local radius = 15
local area = {
left_top = {x = position.x - radius, y = position.y - radius},
right_bottom = {x = position.x + radius, y = position.y + radius}
}
2021-05-23 21:13:21 +02:00
if rpg_t.level < object.level then
2022-04-05 12:00:13 +02:00
return Public.cast_spell(player, true)
2021-05-23 21:13:21 +02:00
end
if not object.enabled then
return
end
2020-07-25 17:22:04 +02:00
if not Math2D.bounding_box.contains_point(area, player.position) then
2022-04-05 12:00:13 +02:00
Public.cast_spell(player, true)
2020-07-25 17:22:04 +02:00
return
end
2020-08-21 13:56:01 +02:00
if mana < object.mana_cost then
2022-04-05 12:00:13 +02:00
return Public.cast_spell(player, true)
2020-07-25 17:22:04 +02:00
end
local target_pos
if object.target then
target_pos = {position.x, position.y}
2021-11-22 21:16:33 +02:00
elseif projectile_types[object.entityName] then
local coord_modifier = get_near_coord_modifier(projectile_types[object.entityName].max_range)
2021-11-23 21:28:23 +02:00
target_pos = {position.x + coord_modifier.x, position.y + coord_modifier.y}
2020-07-25 17:22:04 +02:00
end
local range
if object.range then
range = object.range
else
range = 0
end
local force
if object.force then
force = object.force
else
force = 'player'
end
2021-11-18 01:58:54 +02:00
2021-11-22 21:16:33 +02:00
if object.entityName == 'suicidal_comfylatron' then
2021-05-25 22:19:20 +02:00
Public.suicidal_comfylatron(position, surface)
2022-04-05 12:00:13 +02:00
Public.cast_spell(player)
2021-11-18 01:58:54 +02:00
Public.remove_mana(player, object.mana_cost)
2021-11-22 21:16:33 +02:00
elseif object.entityName == 'repair_aoe' then
2022-04-05 12:00:13 +02:00
Public.repair_aoe(player, position)
Public.cast_spell(player)
2021-11-18 01:58:54 +02:00
Public.remove_mana(player, object.mana_cost)
2021-11-22 21:16:33 +02:00
elseif object.entityName == 'pointy_explosives' then
2021-05-23 21:13:21 +02:00
local entities =
2021-11-18 01:58:54 +02:00
player.surface.find_entities_filtered {
force = player.force,
type = 'container',
area = {{position.x - 1, position.y - 1}, {position.x + 1, position.y + 1}}
}
2021-05-23 21:13:21 +02:00
local detonate_chest
for i = 1, #entities do
local e = entities[i]
detonate_chest = e
end
2021-06-06 20:35:04 +02:00
if detonate_chest and detonate_chest.valid then
local success = Explosives.detonate_chest(detonate_chest)
if success then
2021-11-18 01:58:54 +02:00
Public.remove_mana(player, object.mana_cost)
2021-06-06 20:35:04 +02:00
end
2022-04-05 12:00:13 +02:00
Public.cast_spell(player)
2021-05-23 21:13:21 +02:00
end
2021-11-22 21:16:33 +02:00
elseif object.entityName == 'warp-gate' then
2021-07-07 12:22:22 +02:00
local pos = surface.find_non_colliding_position('character', game.forces.player.get_spawn_position(surface), 3, 0, 5)
if pos then
player.teleport(pos, surface)
else
pos = game.forces.player.get_spawn_position(surface)
player.teleport(pos, surface)
end
2021-11-18 01:58:54 +02:00
Public.remove_mana(player, 999999)
2021-11-13 03:11:17 +02:00
Public.damage_player_over_time(player, random(8, 16))
2021-05-04 19:51:02 +02:00
player.play_sound {path = 'utility/armor_insert', volume_modifier = 1}
2022-04-05 12:00:13 +02:00
Public.cast_spell(player)
2021-11-22 21:16:33 +02:00
elseif object.capsule then -- spawn in capsules i.e objects that are usable with mouse-click
player.insert({name = object.entityName, count = object.amount})
2022-04-05 12:00:13 +02:00
Public.cast_spell(player)
2021-11-18 01:58:54 +02:00
Public.remove_mana(player, object.mana_cost)
2021-11-22 21:16:33 +02:00
elseif projectile_types[object.entityName] then -- projectiles
2020-07-25 17:22:04 +02:00
for i = 1, object.amount do
local damage_area = {
left_top = {x = position.x - 2, y = position.y - 2},
right_bottom = {x = position.x + 2, y = position.y + 2}
}
2021-11-23 21:28:23 +02:00
create_projectile(surface, projectile_types[object.entityName].name, position, force, target_pos, range)
2020-07-25 17:22:04 +02:00
if object.damage then
for _, e in pairs(surface.find_entities_filtered({area = damage_area})) do
damage_entity(e)
end
end
end
2022-04-05 12:00:13 +02:00
Public.cast_spell(player)
2021-11-18 01:58:54 +02:00
Public.remove_mana(player, object.mana_cost)
2020-07-25 17:22:04 +02:00
else
2021-02-13 14:04:22 +02:00
if object.target then -- rockets and such
2021-11-22 21:16:33 +02:00
surface.create_entity({name = object.entityName, position = position, force = force, target = target_pos, speed = 1})
2022-04-05 12:00:13 +02:00
Public.cast_spell(player)
2021-11-18 01:58:54 +02:00
Public.remove_mana(player, object.mana_cost)
2021-11-22 21:16:33 +02:00
elseif surface.can_place_entity {name = object.entityName, position = position} then
2020-07-25 17:22:04 +02:00
if object.biter then
2021-11-22 21:16:33 +02:00
local e = surface.create_entity({name = object.entityName, position = position, force = force})
2020-07-25 17:22:04 +02:00
tame_unit_effects(player, e)
2021-11-18 01:58:54 +02:00
Public.remove_mana(player, object.mana_cost)
2021-05-23 21:13:21 +02:00
elseif object.aoe then
for x = 1, -1, -1 do
for y = 1, -1, -1 do
local pos = {x = position.x + x, y = position.y + y}
2021-11-22 21:16:33 +02:00
if surface.can_place_entity {name = object.entityName, position = pos} then
2021-05-23 21:13:21 +02:00
if object.mana_cost > rpg_t.mana then
break
end
2021-11-22 21:16:33 +02:00
local e = surface.create_entity({name = object.entityName, position = pos, force = force})
2021-05-23 21:13:21 +02:00
e.direction = player.character.direction
2021-11-18 01:58:54 +02:00
Public.remove_mana(player, object.mana_cost)
2021-05-23 21:13:21 +02:00
end
end
end
2020-07-25 17:22:04 +02:00
else
2021-11-22 21:16:33 +02:00
local e = surface.create_entity({name = object.entityName, position = position, force = force})
2021-05-23 21:13:21 +02:00
e.direction = player.character.direction
2021-11-18 01:58:54 +02:00
Public.remove_mana(player, object.mana_cost)
2020-07-25 17:22:04 +02:00
end
2022-04-05 12:00:13 +02:00
Public.cast_spell(player)
2020-07-25 17:22:04 +02:00
else
2022-04-05 12:00:13 +02:00
Public.cast_spell(player, true)
2020-07-25 17:22:04 +02:00
return
end
end
2021-11-22 21:16:33 +02:00
local msg = player.name .. ' casted ' .. object.entityName .. '. '
2020-07-28 11:24:16 +02:00
rpg_t.last_spawned = game.tick + object.tick
2021-05-25 22:19:20 +02:00
Public.update_mana(player)
2020-07-25 17:22:04 +02:00
2021-02-04 21:21:48 +02:00
local reward_xp = object.mana_cost * 0.085
2020-07-28 19:55:28 +02:00
if reward_xp < 1 then
reward_xp = 1
end
2021-05-25 22:19:20 +02:00
Public.gain_xp(player, reward_xp)
2020-07-28 19:55:28 +02:00
2020-07-28 11:24:16 +02:00
AntiGrief.insert_into_capsule_history(player, position, msg)
2020-07-26 22:06:19 +02:00
2020-07-28 11:24:16 +02:00
return
2020-07-25 17:22:04 +02:00
end
2020-10-24 14:46:14 +02:00
local function on_player_changed_surface(event)
local player = game.get_player(event.player_index)
2021-05-25 22:19:20 +02:00
Public.draw_level_text(player)
end
local function on_player_removed(event)
Public.remove_player(event.player_index)
2020-10-24 14:46:14 +02:00
end
2020-07-25 17:22:04 +02:00
local function tick()
local ticker = game.tick
local players = game.connected_players
2021-11-13 03:11:17 +02:00
local count = #players
2021-05-25 22:19:20 +02:00
local enable_flameboots = Public.get('rpg_extra').enable_flameboots
local enable_mana = Public.get('rpg_extra').enable_mana
2020-07-25 17:22:04 +02:00
if ticker % nth_tick == 0 then
2021-05-25 22:19:20 +02:00
Public.global_pool(players, count)
2020-07-25 17:22:04 +02:00
end
if ticker % 30 == 0 then
regen_health_player(players)
if enable_mana then
regen_mana_player(players)
end
if enable_flameboots then
give_player_flameboots(players)
end
end
end
2020-08-27 13:27:34 +02:00
Event.add(defines.events.on_pre_player_left_game, on_pre_player_left_game)
Event.add(defines.events.on_player_died, on_player_died)
2020-07-25 17:22:04 +02:00
Event.add(defines.events.on_entity_damaged, on_entity_damaged)
Event.add(defines.events.on_entity_died, on_entity_died)
Event.add(defines.events.on_gui_click, on_gui_click)
Event.add(defines.events.on_player_changed_position, on_player_changed_position)
Event.add(defines.events.on_player_crafted_item, on_player_crafted_item)
Event.add(defines.events.on_player_joined_game, on_player_joined_game)
2021-05-25 22:19:20 +02:00
Event.add(defines.events.on_player_created, on_player_joined_game)
2020-07-25 17:22:04 +02:00
Event.add(defines.events.on_player_repaired_entity, on_player_repaired_entity)
Event.add(defines.events.on_player_respawned, on_player_respawned)
Event.add(defines.events.on_player_rotated_entity, on_player_rotated_entity)
Event.add(defines.events.on_pre_player_mined_item, on_pre_player_mined_item)
Event.add(defines.events.on_player_used_capsule, on_player_used_capsule)
2020-10-24 14:46:14 +02:00
Event.add(defines.events.on_player_changed_surface, on_player_changed_surface)
2021-05-25 22:19:20 +02:00
Event.add(defines.events.on_player_removed, on_player_removed)
2020-07-25 17:22:04 +02:00
Event.on_nth_tick(10, tick)
2021-05-25 22:19:20 +02:00
return Public