mirror of
https://github.com/VOREStation/VOREStation.git
synced 2026-03-21 03:02:57 +00:00
* Unit Test rework & Master/Ticker update * Fixes and working unit testing * Fixes * Test fixes and FA update * Fixed runtimes * Radio subsystem * move that glob wherever later * ident * CIBUILDING compile option * Fixed runtimes * Some changes to the workflow * CI Split * More split * Pathing * Linters and Annotators * ci dir fix * Missing undef fixed * Enable grep checks * More test conversions * More split * Correct file * Removes unneeded inputs * oop * More dependency changes * More conversions * Conversion fixes * Fixes * Some assert fixes * Corrects start gate * Converted some README.dms to README.mds * Removes duplicate proc * Removes unused defines * Example configs * fix dll access viol by double calling * Post-rebase fixes * Cleans up names global list * Undef restart counter * More code/game/ cleanup * Statpanel update * Skybox * add * Fix ticker * Roundend fix * Persistence dependency update * Reordering * Reordering * Reordering * Initstage fix * . * . * Reorder * Reorder * Circle * Mobs * Air * Test fix * CI Script Fix * Configs * More ticker stuff * This is now in 'reboot world' * Restart world announcements * no glob in PreInit * to define * Update * Removed old include * Make this file normal again * moved * test * shared unit testing objects * Updates batched_spritesheets and universal_icon * . * job data debug * rm that * init order * show us * . * i wonder * . * . * urg * do we not have a job ID? * . * rm sleep for now * updated rust-g linux binaries * binaries update 2 * binaries update 3 * testing something * change that * test something * . * . * . * locavar * test * move that * . * debug * don't run this test * strack trace it * cleaner * . * . * cras again * also comment this out * return to official rust g * Update robot_icons.dm * monitor the generation * . --------- Co-authored-by: Kashargul <144968721+Kashargul@users.noreply.github.com>
66 lines
2.0 KiB
Plaintext
66 lines
2.0 KiB
Plaintext
/// The byond-tracy instance.
|
|
/// This is a GLOBAL_REAL because it is the VERY FIRST THING to initialize, even before the MC or GLOB.
|
|
GLOBAL_REAL(Tracy, /datum/tracy)
|
|
|
|
/datum/tracy
|
|
/// Is byond-tracy enabled and running?
|
|
VAR_FINAL/enabled = FALSE
|
|
/// The error text, if initializing byond-tracy errored.
|
|
VAR_FINAL/error
|
|
/// A description of what / who enabled byond-tracy.
|
|
VAR_FINAL/init_reason
|
|
/// A path to the file containing the output trace, if any.
|
|
VAR_FINAL/trace_path
|
|
|
|
/datum/tracy/New()
|
|
if(!isnull(Tracy))
|
|
CRASH("Attempted to initialize /datum/tracy when global.Tracy is already set!")
|
|
Tracy = src
|
|
|
|
/datum/tracy/Destroy()
|
|
#ifndef OPENDREAM_REAL
|
|
if(enabled)
|
|
call_ext(TRACY_DLL_PATH, "destroy")()
|
|
#endif
|
|
return ..()
|
|
|
|
/// Tries to initialize byond-tracy.
|
|
/datum/tracy/proc/enable(init_reason)
|
|
#ifndef OPENDREAM_REAL
|
|
if(enabled)
|
|
return TRUE
|
|
src.init_reason = init_reason
|
|
if(!fexists(TRACY_DLL_PATH))
|
|
error = "[TRACY_DLL_PATH] not found"
|
|
SEND_TEXT(world.log, "Error initializing byond-tracy: [error]")
|
|
return FALSE
|
|
|
|
var/init_result = call_ext(TRACY_DLL_PATH, "init")("block")
|
|
if(length(init_result) != 0 && init_result[1] == ".") // if first character is ., then it returned the output filename
|
|
SEND_TEXT(world.log, "byond-tracy initialized (logfile: [init_result])")
|
|
enabled = TRUE
|
|
trace_path = init_result
|
|
return TRUE
|
|
else if(init_result == "already initialized") // not gonna question it.
|
|
enabled = TRUE
|
|
SEND_TEXT(world.log, "byond-tracy already initialized ([trace_path ? "logfile: [trace_path]" : "no logfile"])")
|
|
return TRUE
|
|
else if(init_result != "0")
|
|
error = init_result
|
|
SEND_TEXT(world.log, "Error initializing byond-tracy: [init_result]")
|
|
return FALSE
|
|
else
|
|
enabled = TRUE
|
|
SEND_TEXT(world.log, "byond-tracy initialized (no logfile)")
|
|
return TRUE
|
|
#else
|
|
error = "OpenDream not supported"
|
|
return FALSE
|
|
#endif
|
|
|
|
/datum/tracy/vv_edit_var(var_name, var_value)
|
|
return FALSE // no.
|
|
|
|
/datum/tracy/CanProcCall(procname)
|
|
return FALSE // double no.
|