/client/proc/_fix_delayers(var/dtype)
var/largest_delay = 0
var/mob/most_delayed_mob = null
var/delay=0
for(var/mob/M in mob_list)
if(!M.client)
continue
// Get stats
var/datum/delay_controller/delayer = M.vars["[dtype]_delayer"]
if(delayer.blocked())
delay = delayer.next_allowed - world.time
if(delay > largest_delay)
most_delayed_mob=M
largest_delay=delay
// Unfreeze
delayer.next_allowed = 0
message_admins("[key_name_admin(most_delayed_mob)] had the largest [dtype] delay with [largest_delay] frames / [largest_delay/10] seconds!", 1)
/client/proc/fix_next_move()
set category = "Debug"
set name = "Unfreeze Everyone"
if(!usr.client.holder)
return
_fix_delayers("move")
_fix_delayers("click")
_fix_delayers("attack")
_fix_delayers("special")
message_admins("world.time = [world.time]", 1)
feedback_add_details("admin_verb","UFE") //If you are copy-pasting this, ensure the 2nd parameter is unique to the new proc!
return
/client/proc/radio_report()
set category = "Debug"
set name = "Radio report"
var/filters = list(
"1" = "RADIO_TO_AIRALARM",
"2" = "RADIO_FROM_AIRALARM",
"3" = "RADIO_CHAT",
"4" = "RADIO_ATMOSIA",
"5" = "RADIO_NAVBEACONS",
"6" = "RADIO_AIRLOCK",
"7" = "RADIO_SECBOT",
"8" = "RADIO_MULEBOT",
"_default" = "NO_FILTER"
)
var/output = "Radio Report
"
for (var/fq in radio_controller.frequencies)
output += "Freq: [fq]
"
var/datum/radio_frequency/fqs = radio_controller.frequencies[fq]
if (!fqs)
output += " ERROR
"
continue
for (var/filter in fqs.devices)
var/list/f = fqs.devices[filter]
if (!f)
output += " [filters[filter]]: ERROR
"
continue
output += " [filters[filter]]: [f.len]
"
for (var/device in f)
if (isobj(device))
output += " [device] ([device:x],[device:y],[device:z] in area [get_area(device:loc)])
"
else
output += " [device]
"
usr << browse(output,"window=radioreport")
feedback_add_details("admin_verb","RR") //If you are copy-pasting this, ensure the 2nd parameter is unique to the new proc!
/client/proc/reload_admins()
set name = "Reload Admins"
set category = "Debug"
if(!check_rights(R_SERVER))
return
message_admins("[usr] manually reloaded admins")
load_admins()
feedback_add_details("admin_verb","RLDA") //If you are copy-pasting this, ensure the 2nd parameter is unique to the new proc!
/client/proc/print_jobban_old()
set name = "Print Jobban Log"
set desc = "This spams all the active jobban entries for the current round to standard output."
set category = "Debug"
to_chat(usr, "Jobbans active in this round.")
for(var/t in jobban_keylist)
to_chat(usr, "[t]")
/client/proc/print_jobban_old_filter()
set name = "Search Jobban Log"
set desc = "This searches all the active jobban entries for the current round and outputs the results to standard output."
set category = "Debug"
var/filter = input("Contains what?","Filter") as text|null
if(!filter)
return
to_chat(usr, "Jobbans active in this round.")
for(var/t in jobban_keylist)
if(findtext(t, filter))
to_chat(usr, "[t]")
// For /vg/ Wiki docs
/client/proc/dump_chemreactions()
set category = "Debug"
set name = "Dump Chemical Reactions"
var/paths = typesof(/datum/chemical_reaction) - /datum/chemical_reaction
var/str = {"
{| class="wikitable"
|-
! Name
! Reactants
! Result"}
for(var/path in paths)
var/datum/chemical_reaction/R = new path()
str += {"
|-
! [R.name]"}
if(R.required_reagents)
str += "\n|"
for(var/r_id in R.required_reagents)
str += "- {{reagent|[R.required_reagents[r_id]]|[r_id]}}
"
for(var/r_id in R.required_catalysts)
str += "- {{reagent|[R.required_catalysts[r_id]]|[r_id]}}
"
str += "
"
else
str += "\n|''None!''"
if(R.result)
str += "\n|{{reagent|[R.result_amount]|[R.result]}}"
else
str += "\n|''(Check [R.type]/on_reaction()!)''"
text2file(str+"\n|}","chemistry-recipes.wiki")