mirror of
https://github.com/vgstation-coders/vgstation13.git
synced 2025-12-10 10:21:11 +00:00
- Added a new permission type called 'ADVDEBUG', which contains the debug verbs, which should really not be available to run-of-the-mill admins, but should be available to coders, who can use them properly. (debug-verbs and advanced proc call).
- Moved 'reload admins' into the SERVER permission. It already had a check for R_SERVER when it was run, so it being in the debug list was likely a typo. There should probably be an ADVANCEDADMIN permission type or something, that contains the admin-related tools that you don't want all admins to have access to. A 'game masters only' list of verbs, so to speak. - Edited admin_ranks.txt and the other dm files accordingly. - Standardized diagnostics.dm PS: I really love permission based admin verb assignment. So much easier to work with! git-svn-id: http://tgstation13.googlecode.com/svn/trunk@5012 316c924e-a436-60f5-8080-3fe189b3f50e
This commit is contained in:
@@ -262,4 +262,5 @@ proc/tg_list2text(list/list, glue=",")
|
|||||||
if(rights & R_REJUVINATE) . += "+REJUVINATE"
|
if(rights & R_REJUVINATE) . += "+REJUVINATE"
|
||||||
if(rights & R_VAREDIT) . += "+VAREDIT"
|
if(rights & R_VAREDIT) . += "+VAREDIT"
|
||||||
if(rights & R_SOUNDS) . += "+SOUND"
|
if(rights & R_SOUNDS) . += "+SOUND"
|
||||||
|
if(rights & R_ADVDEBUG) . += "+ADVDEBUG"
|
||||||
return .
|
return .
|
||||||
@@ -221,7 +221,8 @@ var/fileaccess_timer = 1800 //Cannot access files by ftp until the game is finis
|
|||||||
#define R_REJUVINATE 512
|
#define R_REJUVINATE 512
|
||||||
#define R_VAREDIT 1024
|
#define R_VAREDIT 1024
|
||||||
#define R_SOUNDS 2048
|
#define R_SOUNDS 2048
|
||||||
|
#define R_ADVDEBUG 4096
|
||||||
|
|
||||||
#define R_MAXPERMISSION 2048 //This holds the maximum value for a permission. It is used in iteration, so keep it updated.
|
#define R_MAXPERMISSION 4096 //This holds the maximum value for a permission. It is used in iteration, so keep it updated.
|
||||||
|
|
||||||
#define R_HOST 65535
|
#define R_HOST 65535
|
||||||
|
|||||||
@@ -39,6 +39,7 @@ var/list/admin_ranks = list() //list of all ranks with associated rights
|
|||||||
if("varedit") rights |= R_VAREDIT
|
if("varedit") rights |= R_VAREDIT
|
||||||
if("everything","host","all") rights |= R_HOST
|
if("everything","host","all") rights |= R_HOST
|
||||||
if("sound","sounds") rights |= R_SOUNDS
|
if("sound","sounds") rights |= R_SOUNDS
|
||||||
|
if("advdebug") rights |= R_ADVDEBUG
|
||||||
|
|
||||||
admin_ranks[rank] = rights
|
admin_ranks[rank] = rights
|
||||||
previous_rights = rights
|
previous_rights = rights
|
||||||
|
|||||||
@@ -102,23 +102,24 @@ var/list/admin_verbs_server = list(
|
|||||||
/datum/admins/proc/toggleoocdead,
|
/datum/admins/proc/toggleoocdead,
|
||||||
/datum/admins/proc/adrev,
|
/datum/admins/proc/adrev,
|
||||||
/datum/admins/proc/adspawn,
|
/datum/admins/proc/adspawn,
|
||||||
/datum/admins/proc/adjump
|
/datum/admins/proc/adjump,
|
||||||
|
/client/proc/reload_admins
|
||||||
)
|
)
|
||||||
var/list/admin_verbs_debug = list(
|
var/list/admin_verbs_debug = list(
|
||||||
/client/proc/restart_controller,
|
/client/proc/restart_controller,
|
||||||
/client/proc/cmd_admin_list_open_jobs,
|
/client/proc/cmd_admin_list_open_jobs,
|
||||||
/client/proc/callproc,
|
|
||||||
/client/proc/Debug2,
|
/client/proc/Debug2,
|
||||||
/client/proc/reload_admins,
|
|
||||||
/client/proc/kill_air,
|
/client/proc/kill_air,
|
||||||
/client/proc/cmd_debug_make_powernets,
|
/client/proc/cmd_debug_make_powernets,
|
||||||
/client/proc/kill_airgroup,
|
/client/proc/kill_airgroup,
|
||||||
/client/proc/debug_controller,
|
/client/proc/debug_controller,
|
||||||
/client/proc/startSinglo,
|
|
||||||
/client/proc/cmd_debug_mob_lists,
|
/client/proc/cmd_debug_mob_lists,
|
||||||
/client/proc/cmd_debug_del_all,
|
/client/proc/cmd_debug_del_all,
|
||||||
/client/proc/cmd_debug_tog_aliens,
|
/client/proc/cmd_debug_tog_aliens,
|
||||||
/client/proc/air_report,
|
/client/proc/air_report,
|
||||||
|
)
|
||||||
|
var/list/admin_verbs_advdebug = list(
|
||||||
|
/client/proc/restart_controller,
|
||||||
/client/proc/enable_debug_verbs
|
/client/proc/enable_debug_verbs
|
||||||
)
|
)
|
||||||
var/list/admin_verbs_possess = list(
|
var/list/admin_verbs_possess = list(
|
||||||
@@ -228,6 +229,7 @@ var/list/admin_verbs_hideable = list(
|
|||||||
if(rights & R_STEALTH) verbs += /client/proc/stealth
|
if(rights & R_STEALTH) verbs += /client/proc/stealth
|
||||||
if(rights & R_REJUVINATE) verbs += admin_verbs_rejuv
|
if(rights & R_REJUVINATE) verbs += admin_verbs_rejuv
|
||||||
if(rights & R_SOUNDS) verbs += admin_verbs_sounds
|
if(rights & R_SOUNDS) verbs += admin_verbs_sounds
|
||||||
|
if(rights & R_ADVDEBUG) verbs += admin_verbs_advdebug
|
||||||
|
|
||||||
/client/proc/remove_admin_verbs()
|
/client/proc/remove_admin_verbs()
|
||||||
if(holder)
|
if(holder)
|
||||||
|
|||||||
@@ -29,9 +29,7 @@ But you can call procs that are of type /mob/living/carbon/human/proc/ for that
|
|||||||
set category = "Debug"
|
set category = "Debug"
|
||||||
set name = "Advanced ProcCall"
|
set name = "Advanced ProcCall"
|
||||||
|
|
||||||
if(!holder)
|
if(!check_rights(R_ADVDEBUG)) return
|
||||||
src << "Only administrators may use this command."
|
|
||||||
return
|
|
||||||
|
|
||||||
spawn(0)
|
spawn(0)
|
||||||
var/target = null
|
var/target = null
|
||||||
|
|||||||
@@ -1,27 +1,26 @@
|
|||||||
/client/proc
|
/client/proc/air_report()
|
||||||
air_report()
|
set category = "Debug"
|
||||||
set category = "Debug"
|
set name = "Show Air Report"
|
||||||
set name = "Show Air Report"
|
|
||||||
|
|
||||||
if(!master_controller || !air_master)
|
if(!master_controller || !air_master)
|
||||||
alert(usr,"Master_controller or air_master not found.","Air Report")
|
alert(usr,"Master_controller or air_master not found.","Air Report")
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
var/active_groups = 0
|
var/active_groups = 0
|
||||||
var/inactive_groups = 0
|
var/inactive_groups = 0
|
||||||
var/active_tiles = 0
|
var/active_tiles = 0
|
||||||
for(var/datum/air_group/group in air_master.air_groups)
|
for(var/datum/air_group/group in air_master.air_groups)
|
||||||
if(group.group_processing)
|
if(group.group_processing)
|
||||||
active_groups++
|
active_groups++
|
||||||
else
|
else
|
||||||
inactive_groups++
|
inactive_groups++
|
||||||
active_tiles += group.members.len
|
active_tiles += group.members.len
|
||||||
|
|
||||||
var/hotspots = 0
|
var/hotspots = 0
|
||||||
for(var/obj/effect/hotspot/hotspot in world)
|
for(var/obj/effect/hotspot/hotspot in world)
|
||||||
hotspots++
|
hotspots++
|
||||||
|
|
||||||
var/output = {"<B>AIR SYSTEMS REPORT</B><HR>
|
var/output = {"<B>AIR SYSTEMS REPORT</B><HR>
|
||||||
<B>General Processing Data</B><BR>
|
<B>General Processing Data</B><BR>
|
||||||
<B># of Groups:</B> [air_master.air_groups.len]<BR>
|
<B># of Groups:</B> [air_master.air_groups.len]<BR>
|
||||||
---- <I>Active:</I> [active_groups]<BR>
|
---- <I>Active:</I> [active_groups]<BR>
|
||||||
@@ -39,143 +38,143 @@
|
|||||||
<B>Tile Update:</B> [air_master.tiles_to_update.len]<BR>
|
<B>Tile Update:</B> [air_master.tiles_to_update.len]<BR>
|
||||||
"}
|
"}
|
||||||
|
|
||||||
usr << browse(output,"window=airreport")
|
usr << browse(output,"window=airreport")
|
||||||
feedback_add_details("admin_verb","SAR") //If you are copy-pasting this, ensure the 2nd parameter is unique to the new proc!
|
feedback_add_details("admin_verb","SAR") //If you are copy-pasting this, ensure the 2nd parameter is unique to the new proc!
|
||||||
|
|
||||||
air_status(turf/target as turf)
|
/client/proc/air_status(turf/target as turf)
|
||||||
set category = "Debug"
|
set category = "Debug"
|
||||||
set name = "Display Air Status"
|
set name = "Display Air Status"
|
||||||
|
|
||||||
if(!isturf(target))
|
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]"
|
|
||||||
feedback_add_details("admin_verb","DAST") //If you are copy-pasting this, ensure the 2nd parameter is unique to the new proc!
|
|
||||||
|
|
||||||
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)
|
|
||||||
feedback_add_details("admin_verb","UFE") //If you are copy-pasting this, ensure the 2nd parameter is unique to the new proc!
|
|
||||||
return
|
return
|
||||||
|
|
||||||
radio_report()
|
var/datum/gas_mixture/GM = target.return_air()
|
||||||
set category = "Debug"
|
var/burning = 0
|
||||||
set name = "Radio report"
|
if(istype(target, /turf/simulated))
|
||||||
|
var/turf/simulated/T = target
|
||||||
|
if(T.active_hotspot)
|
||||||
|
burning = 1
|
||||||
|
|
||||||
var/filters = list(
|
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)]"
|
||||||
"1" = "RADIO_TO_AIRALARM",
|
for(var/datum/gas/trace_gas in GM.trace_gases)
|
||||||
"2" = "RADIO_FROM_AIRALARM",
|
usr << "[trace_gas.type]: [trace_gas.moles]"
|
||||||
"3" = "RADIO_CHAT",
|
feedback_add_details("admin_verb","DAST") //If you are copy-pasting this, ensure the 2nd parameter is unique to the new proc!
|
||||||
"4" = "RADIO_ATMOSIA",
|
|
||||||
"5" = "RADIO_NAVBEACONS",
|
/client/proc/fix_next_move()
|
||||||
"6" = "RADIO_AIRLOCK",
|
set category = "Debug"
|
||||||
"7" = "RADIO_SECBOT",
|
set name = "Unfreeze Everyone"
|
||||||
"8" = "RADIO_MULEBOT",
|
var/largest_move_time = 0
|
||||||
"_default" = "NO_FILTER"
|
var/largest_click_time = 0
|
||||||
)
|
var/mob/largest_move_mob = null
|
||||||
var/output = "<b>Radio Report</b><hr>"
|
var/mob/largest_click_mob = null
|
||||||
for (var/fq in radio_controller.frequencies)
|
for(var/mob/M in world)
|
||||||
output += "<b>Freq: [fq]</b><br>"
|
if(!M.client)
|
||||||
var/list/datum/radio_frequency/fqs = radio_controller.frequencies[fq]
|
continue
|
||||||
if (!fqs)
|
if(M.next_move >= largest_move_time)
|
||||||
output += " <b>ERROR</b><br>"
|
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)
|
||||||
|
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 = "<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
|
continue
|
||||||
for (var/filter in fqs.devices)
|
output += " [filters[filter]]: [f.len]<br>"
|
||||||
var/list/f = fqs.devices[filter]
|
for (var/device in f)
|
||||||
if (!f)
|
if (isobj(device))
|
||||||
output += " [filters[filter]]: ERROR<br>"
|
output += " [device] ([device:x],[device:y],[device:z] in area [get_area(device:loc)])<br>"
|
||||||
continue
|
else
|
||||||
output += " [filters[filter]]: [f.len]<br>"
|
output += " [device]<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")
|
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!
|
feedback_add_details("admin_verb","RR") //If you are copy-pasting this, ensure the 2nd parameter is unique to the new proc!
|
||||||
|
|
||||||
reload_admins()
|
/client/proc/reload_admins()
|
||||||
set name = "Reload Admins"
|
set name = "Reload Admins"
|
||||||
set category = "Debug"
|
set category = "Debug"
|
||||||
|
|
||||||
if(!check_rights(R_SERVER)) return
|
if(!check_rights(R_SERVER)) return
|
||||||
|
|
||||||
message_admins("[usr] manually reloaded admins.txt")
|
message_admins("[usr] manually reloaded admins.txt")
|
||||||
load_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!
|
feedback_add_details("admin_verb","RLDA") //If you are copy-pasting this, ensure the 2nd parameter is unique to the new proc!
|
||||||
|
|
||||||
|
|
||||||
jump_to_dead_group()
|
/client/proc/jump_to_dead_group()
|
||||||
set name = "Jump to dead group"
|
set name = "Jump to dead group"
|
||||||
set category = "Debug"
|
set category = "Debug"
|
||||||
if(!holder)
|
if(!holder)
|
||||||
src << "Only administrators may use this command."
|
src << "Only administrators may use this command."
|
||||||
return
|
|
||||||
|
|
||||||
if(!air_master)
|
|
||||||
usr << "Cannot find air_system"
|
|
||||||
return
|
|
||||||
var/datum/air_group/dead_groups = list()
|
|
||||||
for(var/datum/air_group/group in air_master.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
|
return
|
||||||
|
|
||||||
kill_airgroup()
|
if(!air_master)
|
||||||
set name = "Kill Local Airgroup"
|
usr << "Cannot find air_system"
|
||||||
set desc = "Use this to allow manual manupliation of atmospherics."
|
return
|
||||||
set category = "Debug"
|
var/datum/air_group/dead_groups = list()
|
||||||
if(!holder)
|
for(var/datum/air_group/group in air_master.air_groups)
|
||||||
src << "Only administrators may use this command."
|
if (!group.group_processing)
|
||||||
return
|
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
|
||||||
|
|
||||||
if(!air_master)
|
/client/proc/kill_airgroup()
|
||||||
usr << "Cannot find air_system"
|
set name = "Kill Local Airgroup"
|
||||||
return
|
set desc = "Use this to allow manual manupliation of atmospherics."
|
||||||
|
set category = "Debug"
|
||||||
|
if(!holder)
|
||||||
|
src << "Only administrators may use this command."
|
||||||
|
return
|
||||||
|
|
||||||
var/turf/T = get_turf(usr)
|
if(!air_master)
|
||||||
if(istype(T, /turf/simulated))
|
usr << "Cannot find air_system"
|
||||||
var/datum/air_group/AG = T:parent
|
return
|
||||||
AG.next_check = 30
|
|
||||||
AG.group_processing = 0
|
var/turf/T = get_turf(usr)
|
||||||
else
|
if(istype(T, /turf/simulated))
|
||||||
usr << "Local airgroup is unsimulated!"
|
var/datum/air_group/AG = T:parent
|
||||||
feedback_add_details("admin_verb","KLAG") //If you are copy-pasting this, ensure the 2nd parameter is unique to the new proc!
|
AG.next_check = 30
|
||||||
|
AG.group_processing = 0
|
||||||
|
else
|
||||||
|
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!
|
||||||
|
|||||||
@@ -127,6 +127,9 @@ var/intercom_range_display_status = 0
|
|||||||
/client/proc/enable_debug_verbs()
|
/client/proc/enable_debug_verbs()
|
||||||
set category = "Debug"
|
set category = "Debug"
|
||||||
set name = "Debug verbs"
|
set name = "Debug verbs"
|
||||||
|
|
||||||
|
if(!check_rights(R_ADVDEBUG)) return
|
||||||
|
|
||||||
src.verbs += /client/proc/do_not_use_these //-errorage
|
src.verbs += /client/proc/do_not_use_these //-errorage
|
||||||
src.verbs += /client/proc/camera_view //-errorage
|
src.verbs += /client/proc/camera_view //-errorage
|
||||||
src.verbs += /client/proc/sec_camera_report //-errorage
|
src.verbs += /client/proc/sec_camera_report //-errorage
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
set name = "Set Ticklag"
|
set name = "Set Ticklag"
|
||||||
set desc = "Sets a new tick lag. Recommend you don't mess with this too much! Stable, time-tested ticklag value is 0.9"
|
set desc = "Sets a new tick lag. Recommend you don't mess with this too much! Stable, time-tested ticklag value is 0.9"
|
||||||
|
|
||||||
if(!check_rights(R_DEBUG)) return
|
if(!check_rights(R_ADVDEBUG)) return
|
||||||
|
|
||||||
var/newtick = input("Sets a new tick lag. Please don't mess with this too much! The stable, time-tested ticklag value is 0.9","Lag of Tick", world.tick_lag) as num|null
|
var/newtick = input("Sets a new tick lag. Please don't mess with this too much! The stable, time-tested ticklag value is 0.9","Lag of Tick", world.tick_lag) as num|null
|
||||||
//I've used ticks of 2 before to help with serious singulo lags
|
//I've used ticks of 2 before to help with serious singulo lags
|
||||||
|
|||||||
@@ -20,7 +20,8 @@
|
|||||||
# +REJUV (or +REJUVINATE) = the ability to heal, respawn, modify damage and use godmode
|
# +REJUV (or +REJUVINATE) = the ability to heal, respawn, modify damage and use godmode
|
||||||
# +BUILD (or +BUILDMODE) = the ability to use buildmode
|
# +BUILD (or +BUILDMODE) = the ability to use buildmode
|
||||||
# +SERVER = higher-risk admin verbs and abilities, such as those which affect the server configuration.
|
# +SERVER = higher-risk admin verbs and abilities, such as those which affect the server configuration.
|
||||||
# +DEBUG = debug tools used for diagnosing and fixing problems. It's useful to give this to coders so they can investigate problems on a live server
|
# +DEBUG = debug tools used for diagnosing and fixing problems. The use of these requires some technical know-how, but can generally be used by trusted admins.
|
||||||
|
# +ADVDEBUG = advanced debug tools, which can destroy the game if used improperly. Only suitable for coders.
|
||||||
# +VAREDIT = everyone may view viewvars/debugvars/whatever you call it. This keyword allows you to actually EDIT those variables.
|
# +VAREDIT = everyone may view viewvars/debugvars/whatever you call it. This keyword allows you to actually EDIT those variables.
|
||||||
# +RIGHTS (or +PERMISSIONS) = allows you to promote and/or demote people.
|
# +RIGHTS (or +PERMISSIONS) = allows you to promote and/or demote people.
|
||||||
# +SOUND (or +SOUNDS) = allows you to upload and play sounds
|
# +SOUND (or +SOUNDS) = allows you to upload and play sounds
|
||||||
@@ -36,4 +37,4 @@ Game Master +EVERYTHING
|
|||||||
|
|
||||||
Host +EVERYTHING
|
Host +EVERYTHING
|
||||||
|
|
||||||
Coder +DEBUG +VAREDIT +SERVER
|
Coder +DEBUG +VAREDIT +SERVER +ADVDEBUG
|
||||||
Reference in New Issue
Block a user