mirror of
https://github.com/CHOMPStation2/CHOMPStation2.git
synced 2025-12-10 10:12:45 +00:00
43 lines
1.3 KiB
Plaintext
43 lines
1.3 KiB
Plaintext
#define FIRE_PRIORITY_REFLECTOR 20
|
|
SUBSYSTEM_DEF(reflector)
|
|
name = "Reflectors"
|
|
priority = FIRE_PRIORITY_REFLECTOR
|
|
flags = SS_BACKGROUND|SS_NO_INIT
|
|
wait = 5
|
|
|
|
var/stat_tag = "R" //Used for logging
|
|
var/list/processing = list()
|
|
var/list/currentrun = list()
|
|
var/process_proc = /datum/proc/process
|
|
|
|
var/obj/structure/reflector/current_thing
|
|
|
|
/datum/controller/subsystem/reflector/Recover()
|
|
log_debug("[name] subsystem Recover().")
|
|
if(SSreflector.current_thing)
|
|
log_debug("current_thing was: (\ref[SSreflector.current_thing])[SSreflector.current_thing]([SSreflector.current_thing.type]) - currentrun: [SSreflector.currentrun.len] vs total: [SSreflector.processing.len]")
|
|
var/list/old_processing = SSreflector.processing.Copy()
|
|
for(var/datum/D in old_processing)
|
|
if(CHECK_BITFIELD(D.datum_flags, DF_ISPROCESSING))
|
|
processing |= D
|
|
|
|
/datum/controller/subsystem/reflector/stat_entry()
|
|
..("[stat_tag]:[processing.len]")
|
|
|
|
/datum/controller/subsystem/reflector/fire(resumed = 0)
|
|
if (!resumed)
|
|
currentrun = processing.Copy()
|
|
//cache for sanic speed (lists are references anyways)
|
|
var/list/current_run = currentrun
|
|
|
|
while(current_run.len)
|
|
current_thing = current_run[current_run.len]
|
|
current_run.len--
|
|
if(QDELETED(current_thing))
|
|
processing -= current_thing
|
|
current_thing.Fire()
|
|
if (MC_TICK_CHECK)
|
|
current_thing = null
|
|
return
|
|
|
|
current_thing = null |