Made radiation configurable

This commit is contained in:
number Zero 2016-04-10 21:47:24 +03:00 committed by ShadowNinja
parent 51be33deea
commit b739ed6cb1
2 changed files with 33 additions and 24 deletions

View File

@ -9,6 +9,8 @@ local defaults = {
enable_wind_mill = "false", enable_wind_mill = "false",
enable_frames = "false", enable_frames = "false",
enable_corium_griefing = "true", enable_corium_griefing = "true",
enable_entity_radiation_damage = "true",
enable_longterm_radiation_damage = "true",
} }
for k, v in pairs(defaults) do for k, v in pairs(defaults) do

View File

@ -242,6 +242,9 @@ local cache_scaled_shielding = {}
local rad_dmg_cutoff = 0.2 local rad_dmg_cutoff = 0.2
local radiated_players = {} local radiated_players = {}
local entity_damage = technic.config:get_bool("enable_entity_radiation_damage")
local longterm_damage = technic.config:get_bool("enable_longterm_radiation_damage")
local function apply_fractional_damage(o, dmg) local function apply_fractional_damage(o, dmg)
local dmg_int = math.floor(dmg) local dmg_int = math.floor(dmg)
-- The closer you are to getting one more damage point, -- The closer you are to getting one more damage point,
@ -297,17 +300,17 @@ end
local function dmg_object(pos, object, strength) local function dmg_object(pos, object, strength)
local obj_pos = vector.add(object:getpos(), calculate_object_center(object)) local obj_pos = vector.add(object:getpos(), calculate_object_center(object))
local dmg = calculate_base_damage(pos, obj_pos, strength)
if not dmg then
return
end
local mul = calculate_damage_multiplier(object) local mul = calculate_damage_multiplier(object)
if mul == 0 then if mul == 0 then
return return
end end
local dmg = calculate_base_damage(pos, obj_pos, strength)
if not dmg then
return
end
dmg = dmg * mul dmg = dmg * mul
apply_fractional_damage(object, dmg) apply_fractional_damage(object, dmg)
if object:is_player() then if longterm_damage and object:is_player() then
local pn = object:get_player_name() local pn = object:get_player_name()
radiated_players[pn] = (radiated_players[pn] or 0) + dmg radiated_players[pn] = (radiated_players[pn] or 0) + dmg
end end
@ -319,8 +322,10 @@ local function dmg_abm(pos, node)
local max_dist = strength * rad_dmg_mult_sqrt local max_dist = strength * rad_dmg_mult_sqrt
for _, o in pairs(minetest.get_objects_inside_radius(pos, for _, o in pairs(minetest.get_objects_inside_radius(pos,
max_dist + abdomen_offset)) do max_dist + abdomen_offset)) do
if entity_damage or o:is_player() then
dmg_object(pos, o, strength) dmg_object(pos, o, strength)
end end
end
end end
if minetest.setting_getbool("enable_damage") then if minetest.setting_getbool("enable_damage") then
@ -331,6 +336,7 @@ if minetest.setting_getbool("enable_damage") then
action = dmg_abm, action = dmg_abm,
}) })
if longterm_damage then
minetest.register_globalstep(function(dtime) minetest.register_globalstep(function(dtime)
for pn, dmg in pairs(radiated_players) do for pn, dmg in pairs(radiated_players) do
dmg = dmg - (dtime / 8) dmg = dmg - (dtime / 8)
@ -351,6 +357,7 @@ if minetest.setting_getbool("enable_damage") then
minetest.register_on_dieplayer(function(player) minetest.register_on_dieplayer(function(player)
radiated_players[player:get_player_name()] = nil radiated_players[player:get_player_name()] = nil
end) end)
end
end end
-- Radioactive materials that can result from destroying a reactor -- Radioactive materials that can result from destroying a reactor