mirror of
https://github.com/yogstation13/Yogstation.git
synced 2025-02-26 09:04:50 +00:00
33 lines
911 B
Plaintext
33 lines
911 B
Plaintext
/proc/empulse(turf/epicenter, heavy_range, light_range, log=0)
|
|
if(!epicenter)
|
|
return
|
|
|
|
if(!isturf(epicenter))
|
|
epicenter = get_turf(epicenter.loc)
|
|
|
|
if(log)
|
|
message_admins("EMP with size ([heavy_range], [light_range]) in area [epicenter.loc.name] ")
|
|
log_game("EMP with size ([heavy_range], [light_range]) in area [epicenter.loc.name] ")
|
|
|
|
if(heavy_range > 1)
|
|
new /obj/effect/temp_visual/emp/pulse(epicenter)
|
|
|
|
if(heavy_range > light_range)
|
|
light_range = heavy_range
|
|
|
|
for(var/A in spiral_range(light_range, epicenter))
|
|
var/atom/T = A
|
|
var/distance = get_dist(epicenter, T)
|
|
if(distance < 0)
|
|
distance = 0
|
|
if(distance < heavy_range)
|
|
T.emp_act(EMP_HEAVY)
|
|
else if(heavy_range && distance == heavy_range) //0 radius heavy EMPs will have no effect
|
|
if(prob(50))
|
|
T.emp_act(EMP_HEAVY)
|
|
else
|
|
T.emp_act(EMP_LIGHT)
|
|
else if(distance <= light_range)
|
|
T.emp_act(EMP_LIGHT)
|
|
return 1
|