mirror of
https://github.com/yogstation13/Yogstation.git
synced 2025-02-26 09:04:50 +00:00
* SSMetrics * We were a bit too silly * Forgot to commit this * Logs CPU * Removes global data from all ss * And puts it on the metrics ss * Update metrics.dm * Logs profiler data * Adds profile configs * Update code/controllers/subsystem/metrics.dm Co-authored-by: adamsong <adamsong@users.noreply.github.com> * Log request errors * Final fixes * Rebuilds for 1.2.0-yogs1 * Apparnetly you can't split macro calls on multiple lines * Org is called yogstation13 not yogstation --------- Co-authored-by: alexkar598 <> Co-authored-by: adamsong <adamsong@users.noreply.github.com>
64 lines
1.5 KiB
Plaintext
64 lines
1.5 KiB
Plaintext
SUBSYSTEM_DEF(spacedrift)
|
|
name = "Space Drift"
|
|
priority = FIRE_PRIORITY_SPACEDRIFT
|
|
wait = 5
|
|
flags = SS_NO_INIT|SS_KEEP_TIMING
|
|
runlevels = RUNLEVEL_GAME | RUNLEVEL_POSTGAME
|
|
|
|
var/list/currentrun = list()
|
|
var/list/processing = list()
|
|
|
|
/datum/controller/subsystem/spacedrift/stat_entry(msg)
|
|
msg = "P:[length(processing)]"
|
|
return ..()
|
|
|
|
/datum/controller/subsystem/spacedrift/get_metrics()
|
|
. = ..()
|
|
.["queued"] = length(processing)
|
|
|
|
/datum/controller/subsystem/spacedrift/fire(resumed = 0)
|
|
if (!resumed)
|
|
src.currentrun = processing.Copy()
|
|
|
|
//cache for sanic speed (lists are references anyways)
|
|
var/list/currentrun = src.currentrun
|
|
|
|
while (currentrun.len)
|
|
var/atom/movable/AM = currentrun[currentrun.len]
|
|
currentrun.len--
|
|
if (!AM)
|
|
processing -= AM
|
|
if (MC_TICK_CHECK)
|
|
return
|
|
continue
|
|
|
|
if (AM.inertia_next_move > world.time)
|
|
if (MC_TICK_CHECK)
|
|
return
|
|
continue
|
|
|
|
if (!AM.loc || AM.loc != AM.inertia_last_loc || AM.Process_Spacemove(0))
|
|
AM.inertia_dir = 0
|
|
|
|
if (!AM.inertia_dir)
|
|
AM.inertia_last_loc = null
|
|
processing -= AM
|
|
if (MC_TICK_CHECK)
|
|
return
|
|
continue
|
|
|
|
var/old_dir = AM.dir
|
|
var/old_loc = AM.loc
|
|
AM.inertia_moving = TRUE
|
|
AM.set_glide_size(DELAY_TO_GLIDE_SIZE(AM.inertia_move_delay))
|
|
step(AM, AM.inertia_dir)
|
|
AM.inertia_moving = FALSE
|
|
AM.inertia_next_move = world.time + AM.inertia_move_delay
|
|
if (AM.loc == old_loc)
|
|
AM.inertia_dir = 0
|
|
|
|
AM.setDir(old_dir)
|
|
AM.inertia_last_loc = AM.loc
|
|
if (MC_TICK_CHECK)
|
|
return
|