Files
Aurora.3/code/controllers/subsystems/vis_contents.dm
Fluffy 1ba0b35838 New opendream pragmas (#20260)
Enabled new opendream pragmas
Fixed some runtime access check operators (`:`) around the codebase (not
all, some are unfixable as they're used in macros)

No player facing changes (hopefully)
2024-12-29 11:12:09 +00:00

123 lines
3.1 KiB
Plaintext

SUBSYSTEM_DEF(vis_contents_update)
name = "Vis Contents"
flags = SS_BACKGROUND
wait = 1
init_order = INIT_ORDER_VISCONTENTS
runlevels = RUNLEVEL_LOBBY | RUNLEVELS_DEFAULT
var/list/queue_refs = list()
/datum/controller/subsystem/vis_contents_update/stat_entry(msg)
..("Queue: [queue_refs.len]")
/datum/controller/subsystem/vis_contents_update/Initialize()
fire(FALSE, TRUE)
return SS_INIT_SUCCESS
/datum/controller/subsystem/vis_contents_update/StartLoadingMap()
can_fire = FALSE
/datum/controller/subsystem/vis_contents_update/StopLoadingMap()
can_fire = TRUE
// Largely copied from SSicon_update.
/datum/controller/subsystem/vis_contents_update/fire(resumed = FALSE, no_mc_tick = FALSE)
if(!queue_refs.len)
can_fire = FALSE
return
for(var/i in 1 to length(queue_refs))
var/atom/movable/MA = queue_refs[i]
if(QDELETED(MA))
continue
if(Master.map_loading)
queue_refs.Cut(1, i+1)
return
MA.vis_update_queued = FALSE
MA.update_vis_contents(force_no_queue = TRUE)
if (no_mc_tick)
CHECK_TICK
else if (MC_TICK_CHECK)
queue_refs.Cut(1, i+1)
return
queue_refs.Cut()
/atom
var/vis_update_queued = FALSE
/atom/proc/queue_vis_contents_update()
if(vis_update_queued)
return
vis_update_queued = TRUE
SSvis_contents_update.queue_refs.Add(src)
SSvis_contents_update.can_fire = TRUE
/atom/proc/add_vis_contents(adding)
SHOULD_CALL_PARENT(FALSE)
crash_with("Turfs, movable atoms, and images can be given a list of atoms, but not atmos themselves!")
/atom/movable/add_vis_contents(adding)
vis_contents |= adding
/turf/add_vis_contents(adding)
vis_contents |= adding
/atom/proc/remove_vis_contents(removing)
SHOULD_CALL_PARENT(FALSE)
crash_with("Turfs, movable atoms, and images can be given a list of atoms, but not atmos themselves!")
/atom/movable/remove_vis_contents(removing)
vis_contents -= removing
/turf/remove_vis_contents(removing)
vis_contents -= removing
/atom/proc/clear_vis_contents()
SHOULD_CALL_PARENT(FALSE)
crash_with("Turfs, movable atoms, and images can be given a list of atoms, but not atmos themselves!")
/atom/movable/clear_vis_contents()
vis_contents = null
/turf/clear_vis_contents()
vis_contents = null
/atom/proc/set_vis_contents(list/adding)
SHOULD_CALL_PARENT(FALSE)
crash_with("Turfs, movable atoms, and images can be given a list of atoms, but not atmos themselves!")
/atom/movable/set_vis_contents(list/adding)
vis_contents = adding
/turf/set_vis_contents(list/adding)
vis_contents = adding
/atom/proc/get_vis_contents_to_add()
return
/atom/movable/proc/update_vis_contents(force_no_queue = FALSE)
if(!force_no_queue && (!SSvis_contents_update.initialized || TICK_CHECK))
queue_vis_contents_update()
return
vis_update_queued = FALSE
var/new_vis_contents = get_vis_contents_to_add()
if(length(new_vis_contents))
set_vis_contents(new_vis_contents)
else if(length(vis_contents))
clear_vis_contents()
/image/proc/add_vis_contents(adding)
vis_contents |= adding
/image/proc/remove_vis_contents(removing)
vis_contents -= removing
/image/proc/clear_vis_contents()
vis_contents.Cut()
/image/proc/set_vis_contents(list/adding)
vis_contents = adding