mirror of
https://github.com/CHOMPStation2/CHOMPStation2.git
synced 2025-12-16 05:02:42 +00:00
Added sanitize() to naming the buffers in DNA machine and to alien whispering. Added 0.5 sec timeout for BANG BANG. Added drinking glasses to the Dinnerware vending machine. Update from Nikie: Verb Reload Admins rereads admins.txt Parameter sql_enabled in config. Prevents spam when sql is not installed. NOTE FOR HOSTERS: it is currently ON in code (i.e. behavior is unchanged yet), you have to add SQL_ENABLED to your config.txt during next week. Thanks for your attention. Fixed "Delay" command. Messages for help intent are gender-aware now. git-svn-id: http://tgstation13.googlecode.com/svn/trunk@1463 316c924e-a436-60f5-8080-3fe189b3f50e
178 lines
5.6 KiB
Plaintext
178 lines
5.6 KiB
Plaintext
/client/proc
|
|
general_report()
|
|
set category = "Debug"
|
|
set name = "Show General Report"
|
|
|
|
if(!master_controller)
|
|
usr << alert("Master_controller not found.")
|
|
|
|
var/mobs = 0
|
|
for(var/mob/M in world)
|
|
mobs++
|
|
|
|
var/output = {"<B>GENERAL SYSTEMS REPORT</B><HR>
|
|
<B>General Processing Data</B><BR>
|
|
<B># of Machines:</B> [machines.len]<BR>
|
|
<B># of Pipe Networks:</B> [pipe_networks.len]<BR>
|
|
<B># of Processing Items:</B> [processing_items.len]<BR>
|
|
<B># of Power Nets:</B> [powernets.len]<BR>
|
|
<B># of Mobs:</B> [mobs]<BR>
|
|
"}
|
|
|
|
usr << browse(output,"window=generalreport")
|
|
|
|
air_report()
|
|
set category = "Debug"
|
|
set name = "Show Air Report"
|
|
|
|
if(!master_controller || !air_master)
|
|
alert(usr,"Master_controller or air_master not found.","Air Report")
|
|
return 0
|
|
|
|
var/active_groups = 0
|
|
var/inactive_groups = 0
|
|
var/active_tiles = 0
|
|
for(var/datum/air_group/group in air_master.air_groups)
|
|
if(group.group_processing)
|
|
active_groups++
|
|
else
|
|
inactive_groups++
|
|
active_tiles += group.members.len
|
|
|
|
var/hotspots = 0
|
|
for(var/obj/hotspot/hotspot in world)
|
|
hotspots++
|
|
|
|
var/output = {"<B>AIR SYSTEMS REPORT</B><HR>
|
|
<B>General Processing Data</B><BR>
|
|
<B># of Groups:</B> [air_master.air_groups.len]<BR>
|
|
---- <I>Active:</I> [active_groups]<BR>
|
|
---- <I>Inactive:</I> [inactive_groups]<BR>
|
|
-------- <I>Tiles:</I> [active_tiles]<BR>
|
|
<B># of Active Singletons:</B> [air_master.active_singletons.len]<BR>
|
|
<BR>
|
|
<B>Special Processing Data</B><BR>
|
|
<B>Hotspot Processing:</B> [hotspots]<BR>
|
|
<B>High Temperature Processing:</B> [air_master.active_super_conductivity.len]<BR>
|
|
<B>High Pressure Processing:</B> [air_master.high_pressure_delta.len] (not yet implemented)<BR>
|
|
<BR>
|
|
<B>Geometry Processing Data</B><BR>
|
|
<B>Group Rebuild:</B> [air_master.groups_to_rebuild.len]<BR>
|
|
<B>Tile Update:</B> [air_master.tiles_to_update.len]<BR>
|
|
"}
|
|
|
|
usr << browse(output,"window=airreport")
|
|
|
|
air_status(turf/target as turf)
|
|
set category = "Debug"
|
|
set name = "Display Air Status"
|
|
|
|
if(!isturf(target))
|
|
return
|
|
|
|
var/datum/gas_mixture/GM = target.return_air()
|
|
var/burning = 0
|
|
if(istype(target, /turf/simulated))
|
|
var/turf/simulated/T = target
|
|
if(T.active_hotspot)
|
|
burning = 1
|
|
|
|
usr << "\blue @[target.x],[target.y] ([GM.group_multiplier]): O:[GM.oxygen] T:[GM.toxins] N:[GM.nitrogen] C:[GM.carbon_dioxide] w [GM.temperature] Kelvin, [GM.return_pressure()] kPa [(burning)?("\red BURNING"):(null)]"
|
|
for(var/datum/gas/trace_gas in GM.trace_gases)
|
|
usr << "[trace_gas.type]: [trace_gas.moles]"
|
|
|
|
fix_next_move()
|
|
set category = "Debug"
|
|
set name = "Unfreeze Everyone"
|
|
var/largest_move_time = 0
|
|
var/largest_click_time = 0
|
|
var/mob/largest_move_mob = null
|
|
var/mob/largest_click_mob = null
|
|
for(var/mob/M in world)
|
|
if(!M.client)
|
|
continue
|
|
if(M.next_move >= largest_move_time)
|
|
largest_move_mob = M
|
|
if(M.next_move > world.time)
|
|
largest_move_time = M.next_move - world.time
|
|
else
|
|
largest_move_time = 1
|
|
if(M.lastDblClick >= largest_click_time)
|
|
largest_click_mob = M
|
|
if(M.lastDblClick > world.time)
|
|
largest_click_time = M.lastDblClick - world.time
|
|
else
|
|
largest_click_time = 0
|
|
log_admin("DEBUG: [key_name(M)] next_move = [M.next_move] lastDblClick = [M.lastDblClick] world.time = [world.time]")
|
|
M.next_move = 1
|
|
M.lastDblClick = 0
|
|
message_admins("[key_name_admin(largest_move_mob)] had the largest move delay with [largest_move_time] frames / [largest_move_time/10] seconds!", 1)
|
|
message_admins("[key_name_admin(largest_click_mob)] had the largest click delay with [largest_click_time] frames / [largest_click_time/10] seconds!", 1)
|
|
message_admins("world.time = [world.time]", 1)
|
|
return
|
|
|
|
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 = "<b>Radio Report</b><hr>"
|
|
for (var/fq in radio_controller.frequencies)
|
|
output += "<b>Freq: [fq]</b><br>"
|
|
var/list/datum/radio_frequency/fqs = radio_controller.frequencies[fq]
|
|
if (!fqs)
|
|
output += " <b>ERROR</b><br>"
|
|
continue
|
|
for (var/filter in fqs.devices)
|
|
var/list/f = fqs.devices[filter]
|
|
if (!f)
|
|
output += " [filters[filter]]: ERROR<br>"
|
|
continue
|
|
output += " [filters[filter]]: [f.len]<br>"
|
|
for (var/device in f)
|
|
if (isobj(device))
|
|
output += " [device] ([device:x],[device:y],[device:z] in area [get_area(device:loc)])<br>"
|
|
else
|
|
output += " [device]<br>"
|
|
|
|
usr << browse(output,"window=radioreport")
|
|
|
|
reload_admins()
|
|
set name = "Reload Admins"
|
|
set category = "Debug"
|
|
|
|
if(!(usr.client.holder && usr.client.holder.level >= 6)) // protect and prevent
|
|
usr << "\red Not a good cop"
|
|
return
|
|
|
|
message_admins("[usr] manually reloaded admins.txt")
|
|
usr << "You reload admins.txt"
|
|
var/text = file2text("config/admins.txt")
|
|
if (!text)
|
|
diary << "Failed to reload config/admins.txt\n"
|
|
else
|
|
var/list/lines = dd_text2list(text, "\n")
|
|
for(var/line in lines)
|
|
if (!line)
|
|
continue
|
|
|
|
if (copytext(line, 1, 2) == ";")
|
|
continue
|
|
|
|
var/pos = findtext(line, " - ", 1, null)
|
|
if (pos)
|
|
var/m_key = copytext(line, 1, pos)
|
|
var/a_lev = copytext(line, pos + 3, length(line) + 1)
|
|
admins[m_key] = a_lev
|
|
diary << ("ADMIN: [m_key] = [a_lev]")
|