Files
Bubberstation/code/datums/elements/radioactive.dm
SkyratBot 5fd1bea8f8 [MIRROR] [NO-GBP] Optimizes rad nebula [MDB IGNORE] (#22675)
* [NO-GBP] Optimizes rad nebula (#77014)

Switches rad nebula to only directly irradiate carbons and use radiated component

* [NO-GBP] Optimizes rad nebula

---------

Co-authored-by: Time-Green <7501474+Time-Green@users.noreply.github.com>
2023-07-25 13:26:22 -04:00

59 lines
1.5 KiB
Plaintext

#define DELAY_BETWEEN_RADIATION_PULSES (3 SECONDS)
/// This atom will regularly pulse radiation.
/datum/element/radioactive
element_flags = ELEMENT_DETACH_ON_HOST_DESTROY | ELEMENT_BESPOKE
argument_hash_start_idx = 2
///Range of our wave in tiles
var/range
///Threshold for radioactive permeance
var/threshold
///Chance the object is irradiated
var/chance
///Minimum time needed in order to be irradiated
var/minimum_exposure_time
var/list/radioactive_objects = list()
/datum/element/radioactive/New()
START_PROCESSING(SSdcs, src)
/datum/element/radioactive/Attach(
datum/target,
range = 3,
threshold = RAD_LIGHT_INSULATION,
chance = URANIUM_IRRADIATION_CHANCE,
minimum_exposure_time = URANIUM_RADIATION_MINIMUM_EXPOSURE_TIME,
)
. = ..()
radioactive_objects[target] = world.time
src.range = range
src.threshold = threshold
src.chance = chance
src.minimum_exposure_time = minimum_exposure_time
/datum/element/radioactive/Detach(datum/source, ...)
radioactive_objects -= source
return ..()
/datum/element/radioactive/process(seconds_per_tick)
for (var/radioactive_object in radioactive_objects)
if (world.time - radioactive_objects[radioactive_object] < DELAY_BETWEEN_RADIATION_PULSES)
continue
radiation_pulse(
radioactive_object,
max_range = range,
threshold = threshold,
chance = chance,
minimum_exposure_time = minimum_exposure_time,
)
radioactive_objects[radioactive_object] = world.time
#undef DELAY_BETWEEN_RADIATION_PULSES