mirror of
https://github.com/yogstation13/Yogstation.git
synced 2025-02-26 09:04:50 +00:00
* Add the system for managed global variables * Travis ban old globals * So you CAN inline proccall, that's neat * Fix that * master.dm * Remove the hack procs * Move InitGlobals to the proper spot * configuration.dm * Fix the missing pre-slash * clockcult.dm * This is probably for the best * Doy * Fix shit * Rest of the DEFINES tree * Fix * Use global. for access * Update find_references_in_globals Always hated that proc Whoever made it must've bee a r e a l idiot... * __HELPERS tree * Move global initialization to master. Fix the declaration * database.dm * Dat newline * I said DECLARATIVE order! * Here's something you can chew on @Iamgoofball * game_modes.dm * Fix this * genetics.dm * flavor_misc.dm * More stuff * Do it mso's way. Keep the controllers as global * Make master actually see it * Fix * Finish _globalvars/lists * Finish the rest of the _globalvars tree * This is weird * Migrate the controllers * SLOTH -> GLOB * Lighting globals * round_start_time -> ticker * PAI card list -> pai SS * record_id_num -> static * Diseases list -> SSdisease * More disease globals to the SS * More disease stuff * Emote list * Better and better * Bluh * So much stuff * Ahh * Wires * dview * station_areas * Teleportlocs * blood_splatter_icons * Stuff and such * More stuff * RAD IO * More stuff and such * Blob shit * Changeling stuff * Add "Balance" to changelogs * Balance for changelog compiler + Auto Tagging * Update the PR template * hivemind_bank * Bip * sacrificed * Good shit * Better define * More cult shit * Devil shit * Gang shit * > borers Fix shit * Rename the define * Nuke * Objectives * Sandbox * Multiverse sword * Announce systems * Stuff and such * TC con * Airlock * doppllllerrrrrr * holopads * Shut up byond you inconsistent fuck * Sneaky fuck * Burp * Bip * Fixnshit * Port without regard * askdlfjs; * asdfjasoidojfi * Protected globals and more * SO MANY * ajsimkvahsaoisd * akfdsiaopwimfeoiwafaw * gsdfigjosidjfgiosdg * AHHHHHHHHHHHHHHHHHHHHHHH!!!!! * facerolll * ASDFASDFASDF * Removes the unused parts of dmm_suite * WIP * Fix quote * asdfjauwfnkjs * afwlunhskjfda * asfjlaiwuefhaf * SO CLOSE * wwwweeeeeewwwww * agdgmoewranwg * HOLY MOTHER OF FUCK AND THATS JUST HALF THE JOB?!? * Fix syntax errors * 100 errors * Another 100 * So many... * Ugh * More shit * kilme * Stuuuuuufffff * ajrgmrlshio;djfa;sdkl * jkbhkhjbmjvjmh * soi soi soi * butt * TODAY WE LEARNED THAT GLOBAL AND STATIC ARE THE EXACT SAME FUCKING THING * lllllllllllllllllllllllllllllllllllllllllll * afsdijfiawhnflnjhnwsdfs * yugykihlugk,kj * time to go * STUFFF!!! * AAAAAAAAAAAAAAAAAHHHHHHHHHHHHHHHHHHHHHHHHHHH!!!!!!!!!!!!!!!!!!!!!!! * ngoaijdjlfkamsdlkf * Break time * aufjsdklfalsjfi * CONTROL KAY AND PRAY * IT COMPILEELEELELAKLJFKLDAFJLKFDJLADKJHFLJKAJGAHIEJALDFJ!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! * Goteem * Fix testing mode * This does not belong in this PR * Convert it to a controller * Eh, fuck this option * Revert controllerization Ill do it some other time * Fix * Working controllerization * FOR THE LOVE OF CHRIST PROTECT THE LOGS * Protect admins and deadmins * Use the inbuilt proc
122 lines
4.7 KiB
Plaintext
122 lines
4.7 KiB
Plaintext
/datum/getrev
|
|
var/parentcommit
|
|
var/commit
|
|
var/list/testmerge = list()
|
|
var/has_pr_details = FALSE //example data in a testmerge entry when this is true: https://api.github.com/repositories/3234987/pulls/22586
|
|
var/date
|
|
|
|
/datum/getrev/New()
|
|
var/head_file = return_file_text(".git/logs/HEAD")
|
|
if(SERVERTOOLS && fexists("..\\prtestjob.lk"))
|
|
var/list/tmp = file2list("..\\prtestjob.lk")
|
|
for(var/I in tmp)
|
|
if(I)
|
|
testmerge |= I
|
|
var/testlen = max(testmerge.len - 1, 0)
|
|
var/regex/head_log = new("(\\w{40}) .+> (\\d{10}).+(?=(\n.*(\\w{40}).*){[testlen]}\n*\\Z)")
|
|
head_log.Find(head_file)
|
|
parentcommit = head_log.group[1]
|
|
date = unix2date(text2num(head_log.group[2]))
|
|
commit = head_log.group[4]
|
|
log_world("Running /tg/ revision:")
|
|
log_world("[date]")
|
|
if(testmerge.len)
|
|
log_world(commit)
|
|
for(var/line in testmerge)
|
|
if(line)
|
|
log_world("Test merge active of PR #[line]")
|
|
feedback_add_details("testmerged_prs","[line]")
|
|
log_world("Based off master commit [parentcommit]")
|
|
else
|
|
log_world(parentcommit)
|
|
|
|
/datum/getrev/proc/DownloadPRDetails()
|
|
if(!config.githubrepoid)
|
|
if(testmerge.len)
|
|
log_world("PR details download failed: No github repo config set")
|
|
return
|
|
if(!isnum(text2num(config.githubrepoid)))
|
|
log_world("PR details download failed: Invalid github repo id: [config.githubrepoid]")
|
|
return
|
|
for(var/line in testmerge)
|
|
if(!isnum(text2num(line)))
|
|
log_world("PR details download failed: Invalid PR number: [line]")
|
|
return
|
|
|
|
var/url = "https://api.github.com/repositories/[config.githubrepoid]/pulls/[line].json"
|
|
GLOB.valid_HTTPSGet = TRUE
|
|
var/json = HTTPSGet(url)
|
|
if(!json)
|
|
return
|
|
|
|
testmerge[line] = json_decode(json)
|
|
|
|
if(!testmerge[line])
|
|
log_world("PR details download failed: null details returned")
|
|
return
|
|
CHECK_TICK
|
|
log_world("PR details successfully downloaded")
|
|
has_pr_details = TRUE
|
|
|
|
/datum/getrev/proc/GetTestMergeInfo(header = TRUE)
|
|
if(!testmerge.len)
|
|
return ""
|
|
. = header ? "The following pull requests are currently test merged:<br>" : ""
|
|
for(var/line in testmerge)
|
|
var/details = ""
|
|
if(has_pr_details)
|
|
details = ": '" + html_encode(testmerge[line]["title"]) + "' by " + html_encode(testmerge[line]["user"]["login"])
|
|
. += "<a href='[config.githuburl]/pull/[line]'>#[line][details]</a><br>"
|
|
|
|
/client/verb/showrevinfo()
|
|
set category = "OOC"
|
|
set name = "Show Server Revision"
|
|
set desc = "Check the current server code revision"
|
|
|
|
if(GLOB.revdata.parentcommit)
|
|
to_chat(src, "<b>Server revision compiled on:</b> [GLOB.revdata.date]")
|
|
if(GLOB.revdata.testmerge.len)
|
|
to_chat(src, GLOB.revdata.GetTestMergeInfo())
|
|
to_chat(src, "Based off master commit:")
|
|
to_chat(src, "<a href='[config.githuburl]/commit/[GLOB.revdata.parentcommit]'>[GLOB.revdata.parentcommit]</a>")
|
|
else
|
|
to_chat(src, "Revision unknown")
|
|
to_chat(src, "<b>Current Infomational Settings:</b>")
|
|
to_chat(src, "Protect Authority Roles From Traitor: [config.protect_roles_from_antagonist]")
|
|
to_chat(src, "Protect Assistant Role From Traitor: [config.protect_assistant_from_antagonist]")
|
|
to_chat(src, "Enforce Human Authority: [config.enforce_human_authority]")
|
|
to_chat(src, "Allow Latejoin Antagonists: [config.allow_latejoin_antagonists]")
|
|
to_chat(src, "Enforce Continuous Rounds: [config.continuous.len] of [config.modes.len] roundtypes")
|
|
to_chat(src, "Allow Midround Antagonists: [config.midround_antag.len] of [config.modes.len] roundtypes")
|
|
if(config.show_game_type_odds)
|
|
if(SSticker.current_state == GAME_STATE_PLAYING)
|
|
var/prob_sum = 0
|
|
var/current_odds_differ = FALSE
|
|
var/list/probs = list()
|
|
var/list/modes = config.gamemode_cache
|
|
for(var/mode in modes)
|
|
var/datum/game_mode/M = mode
|
|
var/ctag = initial(M.config_tag)
|
|
if(!(ctag in config.probabilities))
|
|
continue
|
|
if((config.min_pop[ctag] && (config.min_pop[ctag] > SSticker.totalPlayersReady)) || (config.max_pop[ctag] && (config.max_pop[ctag] < SSticker.totalPlayersReady)) || (initial(M.required_players) > SSticker.totalPlayersReady))
|
|
current_odds_differ = TRUE
|
|
continue
|
|
probs[ctag] = 1
|
|
prob_sum += config.probabilities[ctag]
|
|
if(current_odds_differ)
|
|
src <<"<b>Game Mode Odds for current round:</b>"
|
|
for(var/ctag in probs)
|
|
if(config.probabilities[ctag] > 0)
|
|
var/percentage = round(config.probabilities[ctag] / prob_sum * 100, 0.1)
|
|
to_chat(src, "[ctag] [percentage]%")
|
|
|
|
src <<"<b>All Game Mode Odds:</b>"
|
|
var/sum = 0
|
|
for(var/ctag in config.probabilities)
|
|
sum += config.probabilities[ctag]
|
|
for(var/ctag in config.probabilities)
|
|
if(config.probabilities[ctag] > 0)
|
|
var/percentage = round(config.probabilities[ctag] / sum * 100, 0.1)
|
|
to_chat(src, "[ctag] [percentage]%")
|