mirror of
https://github.com/VOREStation/VOREStation.git
synced 2026-03-29 08:03:03 +01:00
* These two are easy * !!!runlevel_flags the fact it was global.runlevel_flags.len has me a bit...iffy on this. * !!!json_cache Same as above. used global. * player_list & observer_mob_list * mechas_list * this wasn't even used * surgery_steps * event_triggers * landmarks_list * dead_mob_list * living_mob_list * ai_list * cable_list * cleanbot_reserved_turfs * listening_objects * silicon_mob_list * human_mob_list * Update global_lists.dm * joblist * mob_list * Update global_lists.dm * holomap_markers * mapping_units * mapping_beacons * hair_styles_list * facial_hair_styles_list * Update global_lists.dm * facial_hair_styles_male_list * facial_hair_styles_female_list * body_marking_styles_list * body_marking_nopersist_list * ear_styles_list * hair_styles_male_list * tail_styles_list * wing_styles_list * escape_list & rune_list & endgame_exits these were all really small * endgame_safespawns * stool_cache * emotes_by_key * random_maps & map_count * item_tf_spawnpoints * narsie_list * active_radio_jammers * unused * paikeys * pai_software_by_key & default_pai_software * plant_seed_sprites * magazine_icondata_keys & magazine_icondata_states * unused * ashtray_cache * light_type_cache * HOLIDAY!!! this one was annoying * faction stuff (red?!) * Update preferences_factions.dm * vs edit removal * backbaglist, pdachoicelist, exclude_jobs * item_digestion_blacklist, edible_tech, blacklisted_artifact_effect, selectable_footstep, hexNums, syndicate_access * string_slot_flags and hexdigits->hexNums * possible_changeling_IDs * vr_mob_tf_options * vr_mob_spawner_options * pipe_colors * vr_mob_spawner_options * common_tools * newscaster_standard_feeds * Update periodic_news.dm * changeling_fabricated_clothing * semirandom_mob_spawner_decisions * id_card_states * Update syndicate_ids.dm * overlay_cache & gear_distributed_to * more * radio_channels_by_freq * Update global_lists.dm * proper * default_medbay_channels & default_internal_channels default_internal_channels is weird as it has a mapbased proc() but that proc is never called... * valid_ringtones * move this * possible_plants * more * separate these moves xeno2chemlist from a hook to a new global list. * tube_dir_list * valid_bloodreagents & monitor_states * Junk * valid_bloodtypes * breach_burn_descriptors & burn * more!! appliance_available_recipes seems uber cursed, re-look at later * Appliance code is cursed * wide_chassis & flying_chassis * allows_eye_color * all_tooltip_styles * direction_table * gun_choices * severity_to_string * old event_viruses * description_icons * MOVE_KEY_MAPPINGS * more more * pai & robot modules * Update global_lists.dm * GEOSAMPLES Also swaps a .len to LAZYLEN() * shieldgens * reagent recipies * global ammo types * rad collector * old file and unused global * nif_look_messages * FESH * nifsoft * chamelion * the death of sortAtom * globulins * lazylen that * Update global_lists.dm * LAZY * Theese too * quick fix --------- Co-authored-by: Kashargul <144968721+Kashargul@users.noreply.github.com>
192 lines
6.0 KiB
Plaintext
192 lines
6.0 KiB
Plaintext
/client/proc/air_report()
|
|
set category = "Debug.Investigate"
|
|
set name = "Show Air Report"
|
|
|
|
if(!master_controller || !SSair)
|
|
tgui_alert_async(usr,"Master_controller or SSair not found.","Air Report")
|
|
return
|
|
|
|
var/active_groups = SSair.active_zones
|
|
var/inactive_groups = SSair.zones.len - active_groups
|
|
|
|
var/hotspots = 0
|
|
for(var/obj/fire/hotspot in world)
|
|
hotspots++
|
|
|
|
var/active_on_main_station = 0
|
|
var/inactive_on_main_station = 0
|
|
for(var/zone/zone in SSair.zones)
|
|
var/turf/simulated/turf = locate() in zone.contents
|
|
if(turf?.z in using_map.station_levels)
|
|
if(zone.needs_update)
|
|
active_on_main_station++
|
|
else
|
|
inactive_on_main_station++
|
|
|
|
var/output = {"<B>AIR SYSTEMS REPORT</B><HR>
|
|
<B>General Processing Data</B><BR>
|
|
Cycle: [SSair.current_cycle]<br>
|
|
Groups: [SSair.zones.len]<BR>
|
|
---- <I>Active:</I> [active_groups]<BR>
|
|
---- <I>Inactive:</I> [inactive_groups]<BR><br>
|
|
---- <I>Active on station:</i> [active_on_main_station]<br>
|
|
---- <i>Inactive on station:</i> [inactive_on_main_station]<br>
|
|
<BR>
|
|
<B>Special Processing Data</B><BR>
|
|
Hotspot Processing: [hotspots]<BR>
|
|
<br>
|
|
<B>Geometry Processing Data</B><BR>
|
|
Tile Update: [SSair.tiles_to_update.len]<BR>
|
|
"}
|
|
|
|
var/datum/browser/popup = new(src, "airreport", "Airreport")
|
|
popup.set_content(output)
|
|
popup.open()
|
|
|
|
/client/proc/fix_next_move()
|
|
set category = "Debug.Game"
|
|
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 GLOB.mob_list)
|
|
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.next_click >= largest_click_time)
|
|
largest_click_mob = M
|
|
if(M.next_click > world.time)
|
|
largest_click_time = M.next_click - world.time
|
|
else
|
|
largest_click_time = 0
|
|
log_admin("DEBUG: [key_name(M)] next_move = [M.next_move] next_click = [M.next_click] world.time = [world.time]")
|
|
M.next_move = 1
|
|
M.next_click = 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)
|
|
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.Game"
|
|
set name = "Radio report"
|
|
|
|
var/output = "<b>Radio Report</b><hr>"
|
|
for (var/fq in radio_controller.frequencies)
|
|
output += "<b>Freq: [fq]</b><br>"
|
|
var/datum/radio_frequency/fqs = radio_controller.frequencies[fq]
|
|
if (!fqs)
|
|
output += " <b>ERROR</b><br>"
|
|
continue
|
|
for (var/radio_filter in fqs.devices)
|
|
var/list/f = fqs.devices[radio_filter]
|
|
if (!f)
|
|
output += " [radio_filter]: ERROR<br>"
|
|
continue
|
|
output += " [radio_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>"
|
|
|
|
var/datum/browser/popup = new(src, "radioreport", "Radioreport")
|
|
popup.set_content(output)
|
|
popup.open()
|
|
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.Server"
|
|
|
|
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/reload_eventMs()
|
|
set name = "Reload Event Managers"
|
|
set category = "Debug.Server"
|
|
|
|
if(!check_rights(R_SERVER)) return
|
|
|
|
message_admins("[usr] manually reloaded Event Managers")
|
|
world.load_mods()
|
|
|
|
|
|
//todo:
|
|
/client/proc/jump_to_dead_group()
|
|
set name = "Jump to dead group"
|
|
set category = "Debug.Game"
|
|
/*
|
|
if(!holder)
|
|
to_chat(src, "Only administrators may use this command.")
|
|
return
|
|
|
|
if(!SSair)
|
|
to_chat(usr, "Cannot find air_system")
|
|
return
|
|
var/datum/air_group/dead_groups = list()
|
|
for(var/datum/air_group/group in SSair.air_groups)
|
|
if (!group.group_processing)
|
|
dead_groups += group
|
|
var/datum/air_group/dest_group = pick(dead_groups)
|
|
usr.loc = pick(dest_group.members)
|
|
feedback_add_details("admin_verb","JDAG") //If you are copy-pasting this, ensure the 2nd parameter is unique to the new proc!
|
|
return
|
|
*/
|
|
|
|
/client/proc/kill_airgroup()
|
|
set name = "Kill Local Airgroup"
|
|
set desc = "Use this to allow manual manupliation of atmospherics."
|
|
set category = "Debug.Dangerous"
|
|
/*
|
|
if(!holder)
|
|
to_chat(src, "Only administrators may use this command.")
|
|
return
|
|
|
|
if(!SSair)
|
|
to_chat(usr, "Cannot find air_system")
|
|
return
|
|
|
|
var/turf/T = get_turf(usr)
|
|
if(istype(T, /turf/simulated))
|
|
var/datum/air_group/AG = T:parent
|
|
AG.next_check = 30
|
|
AG.group_processing = 0
|
|
else
|
|
to_chat(usr, "Local airgroup is unsimulated!")
|
|
feedback_add_details("admin_verb","KLAG") //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.Investigate"
|
|
|
|
to_chat(usr, span_bold("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.Investigate"
|
|
|
|
var/job_filter = tgui_input_text(usr, "Contains what?","Job Filter")
|
|
if(!job_filter)
|
|
return
|
|
|
|
to_chat(usr, span_bold("Jobbans active in this round."))
|
|
for(var/t in jobban_keylist)
|
|
if(findtext(t, job_filter))
|
|
to_chat(usr, "[t]")
|