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>
39 lines
1.1 KiB
Plaintext
39 lines
1.1 KiB
Plaintext
/// Allows us to lazyload asset datums
|
|
/// Anything inserted here will fully load if directly gotten
|
|
/// So this just serves to remove the requirement to load assets fully during init
|
|
SUBSYSTEM_DEF(asset_loading)
|
|
name = "Asset Loading"
|
|
priority = FIRE_PRIORITY_ASSETS
|
|
flags = SS_NO_INIT
|
|
runlevels = RUNLEVEL_LOBBY|RUNLEVELS_DEFAULT
|
|
|
|
var/list/datum/asset/generate_queue = list()
|
|
|
|
/datum/controller/subsystem/asset_loading/stat_entry(msg)
|
|
msg = "Q:[length(generate_queue)]"
|
|
|
|
return ..()
|
|
|
|
/datum/controller/subsystem/asset_loading/get_metrics()
|
|
. = ..()
|
|
.["queued"] = length(generate_queue)
|
|
|
|
/datum/controller/subsystem/asset_loading/fire(resumed)
|
|
while(length(generate_queue))
|
|
var/datum/asset/to_load = generate_queue[generate_queue.len]
|
|
|
|
to_load.queued_generation()
|
|
|
|
if(MC_TICK_CHECK)
|
|
return
|
|
generate_queue.len--
|
|
|
|
/datum/controller/subsystem/asset_loading/proc/queue_asset(datum/asset/queue)
|
|
#ifdef DO_NOT_DEFER_ASSETS
|
|
stack_trace("We queued an instance of [queue.type] for lateloading despite not allowing it")
|
|
#endif
|
|
generate_queue += queue
|
|
|
|
/datum/controller/subsystem/asset_loading/proc/dequeue_asset(datum/asset/queue)
|
|
generate_queue -= queue
|