130 lines
4.8 KiB
Plaintext
130 lines
4.8 KiB
Plaintext
//Generates a markdown txt file for use with the wiki
|
|
|
|
/client/proc/generate_wikichem_list()
|
|
set name = "Generate Wikichems"
|
|
set category = "Debug"
|
|
set desc = "Generate a huge loglist of all the chems. Do not click unless you want lag."
|
|
|
|
message_admins("Someone pressed the superlag button. (Generate Wikichems)")
|
|
to_chat(usr, "Generating list")
|
|
var/prefix = "|Name | Reagent pH | Reagents | Reaction temp | Explosion temp | pH range | Kinetics | Description | OD level | Addiction level | Metabolism rate | Impure chem | InverseChem|\n|---|---|---|---|---|---|---|----------|---|---|---|---|---|\n"
|
|
var/medicine = ""
|
|
var/toxin = ""
|
|
var/consumable = ""
|
|
var/plant = ""
|
|
var/uranium = ""
|
|
var/colours = ""
|
|
var/muta = ""
|
|
var/fermi = ""
|
|
var/remainder = ""
|
|
|
|
///datum/reagent/medicine, /datum/reagent/toxin, /datum/reagent/consumable, /datum/reagent/plantnutriment, /datum/reagent/uranium,
|
|
///datum/reagent/colorful_reagent, /datum/reagent/mutationtoxin, /datum/reagent/fermi
|
|
|
|
//Probably not the most eligant of solutions.
|
|
to_chat(usr, "Attempting reagent scan. Length of list [LAZYLEN(GLOB.chemical_reagents_list)]")
|
|
var/datum/reagent/R
|
|
var/tally = 0
|
|
for(var/X in GLOB.chemical_reagents_list)
|
|
R = GLOB.chemical_reagents_list[X]
|
|
if(istype(R, /datum/reagent/medicine))
|
|
medicine += generate_chemwiki_line(R, X)
|
|
|
|
else if(istype(R, /datum/reagent/toxin))
|
|
toxin += generate_chemwiki_line(R, X)
|
|
|
|
else if(istype(R, /datum/reagent/consumable))
|
|
consumable += generate_chemwiki_line(R, X)
|
|
|
|
else if(istype(R, /datum/reagent/plantnutriment))
|
|
plant += generate_chemwiki_line(R, X)
|
|
|
|
else if(istype(R, /datum/reagent/uranium))
|
|
uranium += generate_chemwiki_line(R, X)
|
|
|
|
else if(istype(R, /datum/reagent/colorful_reagent))
|
|
colours += generate_chemwiki_line(R, X)
|
|
|
|
else if(istype(R, /datum/reagent/mutationtoxin))
|
|
muta += generate_chemwiki_line(R, X)
|
|
|
|
else if(istype(R, /datum/reagent/fermi))
|
|
fermi += generate_chemwiki_line(R, X)
|
|
|
|
else
|
|
remainder += generate_chemwiki_line(R, X)
|
|
|
|
tally++
|
|
if((tally%50)==0)
|
|
to_chat(usr, "[tally] of [LAZYLEN(GLOB.chemical_reagents_list)] done.")
|
|
|
|
to_chat(usr, "finished")
|
|
log_sql("------------BEGINNING OF REAGENTS VAR DUMP:------------------\n----------------------------------------------------------------------------------\n\n\n# BASIC REAGENTS\n\n[prefix][remainder]\n\n# MEDICINE:\n\n[prefix][medicine]\n\n# TOXIN:\n\n[prefix][toxin]\n\n# CONSUMABLE\n\n[prefix][consumable]\n\n# FERMI\n\nThese chems lie on the cutting edge of chemical technology, and as such are not recommended for beginners!\n\n[prefix][fermi]\n\n# PLANTS\n\n[prefix][plant]\n\n# URANIUM\n\n[prefix][uranium]\n\n# COLOURS\n\n[prefix][colours]\n\n# RACE MUTATIONS\n[prefix][muta]\n")
|
|
|
|
|
|
/proc/generate_chemwiki_line(datum/reagent/R, X)
|
|
//name | Reagent pH | reagents | reaction temp | explosion temp | pH range | Kinetics | description | OD level | Addiction level | Metabolism rate | impure chem | inverse chem
|
|
|
|
var/datum/chemical_reaction/CR = get_chemical_reaction(R.id)
|
|
|
|
//message_admins("[CR]")
|
|
var/outstring = "|[R.name] !\[[R.color]\](https://placehold.it/15/[copytext(R.color, 2, 8)]/000000?text=+)| [R.pH] | "
|
|
var/datum/reagent/R3
|
|
if(CR)
|
|
outstring += "<ul>"
|
|
for(var/R2 in CR.required_reagents)
|
|
R3 = GLOB.chemical_reagents_list[R2]//What a convoluted mess
|
|
outstring += "<li>[R3.name]</li>"
|
|
outstring += "</ul> | "
|
|
else
|
|
outstring += "N/A | "
|
|
|
|
|
|
//Temp, Explosions and pH
|
|
if(CR)
|
|
outstring += "[(CR.FermiChem?"[CR.OptimalTempMin]":"[(CR.required_temp?"[CR.required_temp]":"N/A")]")] | [(CR.FermiChem?"[CR.ExplodeTemp]":"N/A")] | [(CR.FermiChem?"[max((CR.OptimalpHMin - CR.ReactpHLim), 0)] to [min((CR.OptimalpHMax + CR.ReactpHLim), 14)]":"N/A")] | "
|
|
else
|
|
outstring += "N/A | N/A | N/A | "
|
|
|
|
//Kinetics
|
|
if(CR)
|
|
if(CR.FermiChem)
|
|
switch(CR.ThermicConstant)
|
|
if(-INFINITY to -9.9)
|
|
outstring += "Extremely endothermic | "
|
|
if(-9.9 to -4.9)
|
|
outstring += "Very endothermic | "
|
|
if(-4.9 to -0.1)
|
|
outstring += "Endothermic | "
|
|
if(-0.1 to 0.1)
|
|
outstring += "Neutral | "
|
|
if(0.1 to 4.9)
|
|
outstring += "Exothermic | "
|
|
if(4.9 to 9.9)
|
|
outstring += "Very exothermic | "
|
|
if(9.9 to INFINITY)
|
|
outstring += "Extremely exothermic | "
|
|
else
|
|
outstring += "N/A | "
|
|
else
|
|
outstring += "N/A | "
|
|
|
|
//Description, OD, Addict, Meta
|
|
outstring += "[R.description] | [(R.overdose_threshold?"[R.overdose_threshold]":"No OD")] | [(R.addiction_threshold?"[R.addiction_threshold]":"No addiction")] | [R.metabolization_rate] | "
|
|
|
|
if(R.ImpureChem != "fermiTox" || !R.ImpureChem)
|
|
R3 = GLOB.chemical_reagents_list[R.ImpureChem]
|
|
outstring += "[R3.name] | "
|
|
else
|
|
outstring += "N/A |"
|
|
|
|
if(R.InverseChem != "fermiTox" || !R.InverseChem)
|
|
R3 = GLOB.chemical_reagents_list[R.InverseChem]
|
|
outstring += "[R3.name] | "
|
|
else
|
|
outstring += "N/A|"
|
|
|
|
outstring += "\n"
|
|
//message_admins("[outstring]")
|
|
return outstring
|