mirror of
https://github.com/CHOMPStation2/CHOMPStation2.git
synced 2025-12-11 10:43:20 +00:00
238 lines
6.0 KiB
Plaintext
238 lines
6.0 KiB
Plaintext
/mob/proc/HasDisease(datum/disease/D)
|
|
for(var/thing in GetViruses())
|
|
var/datum/disease/DD = thing
|
|
if(DD.IsSame(D))
|
|
return TRUE
|
|
return FALSE
|
|
|
|
/mob/proc/addDisease(datum/disease/D)
|
|
LAZYADD(viruses, D)
|
|
return TRUE
|
|
|
|
/mob/proc/RemoveDisease(datum/disease/D)
|
|
LAZYREMOVE(viruses, D)
|
|
return TRUE
|
|
|
|
/mob/proc/HasResistance(resistance)
|
|
if(LAZYFIND(resistances, resistance))
|
|
return TRUE
|
|
return FALSE
|
|
|
|
/mob/proc/IsInfected()
|
|
if(isemptylist(GetViruses()))
|
|
return FALSE
|
|
return TRUE
|
|
|
|
/mob/proc/CanContractDisease(datum/disease/D)
|
|
if(stat == DEAD && !global_flag_check(D.virus_modifiers, SPREAD_DEAD))
|
|
return FALSE
|
|
|
|
if(D.GetDiseaseID() in GetResistances())
|
|
return FALSE
|
|
|
|
if(HasDisease(D))
|
|
return FALSE
|
|
|
|
if(istype(D, /datum/disease/advance))
|
|
var/active_diseases = 0
|
|
for(var/datum/disease/AD in GetViruses())
|
|
if(!(AD.virus_modifiers & DORMANT)) // You can have as many dormant diseases as you want
|
|
active_diseases++
|
|
if(active_diseases > 0) // But ONLY one active disease
|
|
return FALSE
|
|
|
|
var/compatible_type = FALSE
|
|
for(var/type_to_test in D.viable_mobtypes)
|
|
if(ispath(type, type_to_test))
|
|
compatible_type = TRUE
|
|
break
|
|
if(!compatible_type)
|
|
return FALSE
|
|
|
|
if(isSynthetic())
|
|
if(global_flag_check(D.virus_modifiers, INFECT_SYNTHETICS))
|
|
return TRUE
|
|
return FALSE
|
|
|
|
return TRUE
|
|
|
|
/mob/proc/ContractDisease(datum/disease/D, var/target_zone)
|
|
if(!CanContractDisease(D))
|
|
return 0
|
|
D.infect(src)
|
|
return TRUE
|
|
|
|
/mob/living/carbon/human/ContractDisease(datum/disease/D, target_zone)
|
|
if(!CanContractDisease(D))
|
|
return FALSE
|
|
|
|
if(species.virus_immune && !global_flag_check(D.virus_modifiers, BYPASSES_IMMUNITY))
|
|
return FALSE
|
|
|
|
var/obj/item/clothing/Cl = null
|
|
var/passed = TRUE
|
|
|
|
var/head_chance = 80
|
|
var/body_chance = 100
|
|
var/hands_chance = 35/2
|
|
var/feet_chance = 15/2
|
|
|
|
if(prob(15/D.permeability_mod))
|
|
return
|
|
|
|
if(nutrition > 300 && prob(nutrition/50))
|
|
return
|
|
|
|
if(!target_zone)
|
|
target_zone = pick(list(
|
|
BP_HEAD = head_chance,
|
|
BP_TORSO = body_chance,
|
|
BP_R_HAND = hands_chance,
|
|
BP_L_HAND = hands_chance,
|
|
BP_R_FOOT = feet_chance,
|
|
BP_L_FOOT = feet_chance
|
|
))
|
|
else
|
|
target_zone = check_zone(target_zone)
|
|
|
|
if(ishuman(src))
|
|
var/mob/living/carbon/human/H = src
|
|
|
|
switch(target_zone)
|
|
if(BP_HEAD)
|
|
if(isobj(H.head) && !istype(H.head, /obj/item/paper))
|
|
Cl = H.head
|
|
passed = prob((Cl.permeability_coefficient*100) - 1)
|
|
if(passed && isobj(H.wear_mask))
|
|
Cl = H.wear_mask
|
|
passed = prob((Cl.permeability_coefficient*100) - 1)
|
|
if(BP_TORSO)
|
|
if(isobj(H.wear_suit))
|
|
Cl = H.wear_suit
|
|
passed = prob((Cl.permeability_coefficient*100) - 1)
|
|
if(passed && isobj(H.w_uniform))
|
|
Cl = H.w_uniform
|
|
passed = prob((Cl.permeability_coefficient*100) - 1)
|
|
if(BP_L_HAND, BP_R_HAND)
|
|
if(isobj(H.wear_suit) && H.wear_suit.body_parts_covered & HANDS)
|
|
Cl = H.wear_suit
|
|
passed = prob((Cl.permeability_coefficient*100) - 1)
|
|
|
|
if(passed && isobj(H.gloves))
|
|
Cl = H.gloves
|
|
passed = prob((Cl.permeability_coefficient*100) - 1)
|
|
if(BP_L_FOOT, BP_R_FOOT)
|
|
if(isobj(H.wear_suit) && H.wear_suit.body_parts_covered & FEET)
|
|
Cl = H.wear_suit
|
|
passed = prob((Cl.permeability_coefficient*100) - 1)
|
|
|
|
if(passed && isobj(H.shoes))
|
|
Cl = H.shoes
|
|
passed = prob((Cl.permeability_coefficient*100) - 1)
|
|
|
|
if(passed)
|
|
D.infect(src)
|
|
|
|
/mob/living/proc/AirborneContractDisease(datum/disease/D, force_spread)
|
|
if(((D.spread_flags & DISEASE_SPREAD_AIRBORNE) || force_spread) && prob(50*D.spreading_modifier) - 1)
|
|
ForceContractDisease(D)
|
|
|
|
/mob/living/carbon/AirborneContractDisease(datum/disease/D, force_spread)
|
|
if(internal)
|
|
return
|
|
if(mNobreath in mutations)
|
|
return
|
|
..()
|
|
|
|
/mob/proc/ForceContractDisease(datum/disease/D, respect_carrier)
|
|
if(!CanContractDisease(D))
|
|
return FALSE
|
|
|
|
D.infect(src, respect_carrier)
|
|
return TRUE
|
|
|
|
/mob/living/carbon/human/CanContractDisease(datum/disease/D)
|
|
for(var/organ in D.required_organs)
|
|
if(!((locate(organ) in organs) || (locate(organ) in internal_organs)))
|
|
return FALSE
|
|
|
|
if(species.virus_immune && !global_flag_check(D.virus_modifiers, BYPASSES_IMMUNITY))
|
|
D.virus_modifiers |= CARRIER
|
|
else
|
|
D.virus_modifiers &= ~CARRIER
|
|
|
|
return ..()
|
|
|
|
/mob/living/carbon/human/monkey/CanContractDisease(datum/disease/D)
|
|
. = ..()
|
|
if(. == -1)
|
|
if(D.viable_mobtypes.Find(/mob/living/carbon/human))
|
|
return
|
|
|
|
/mob/living/proc/CanSpreadAirborneDisease()
|
|
return !is_mouth_covered()
|
|
|
|
/mob/living/proc/handle_diseases()
|
|
return
|
|
|
|
/mob/proc/GetViruses()
|
|
LAZYINITLIST(viruses)
|
|
return viruses
|
|
|
|
/mob/proc/GetSpreadableViruses()
|
|
LAZYINITLIST(viruses)
|
|
var/list/viruses_to_return = list()
|
|
for(var/datum/disease/D in viruses)
|
|
if(D.spread_flags & (DISEASE_SPREAD_SPECIAL | DISEASE_SPREAD_NON_CONTAGIOUS))
|
|
continue
|
|
viruses_to_return += D
|
|
return viruses_to_return
|
|
|
|
/mob/proc/GetDormantDiseases()
|
|
LAZYINITLIST(viruses)
|
|
var/list/viruses_to_return = list()
|
|
for(var/datum/disease/D in viruses)
|
|
if(D.virus_modifiers & DORMANT)
|
|
viruses_to_return += D
|
|
return viruses_to_return
|
|
|
|
/mob/proc/GetResistances()
|
|
LAZYINITLIST(resistances)
|
|
return resistances
|
|
|
|
/mob/proc/AddResistances(var/list/resistance)
|
|
LAZYINITLIST(resistances)
|
|
resistances |= resistance
|
|
return TRUE
|
|
|
|
/client/proc/ReleaseVirus()
|
|
set category = "Fun.Event Kit"
|
|
set name = "Release Virus"
|
|
set desc = "Release a pre-set virus."
|
|
|
|
if(!check_rights(R_FUN|R_EVENT))
|
|
return FALSE
|
|
|
|
var/disease = tgui_input_list(usr, "Choose virus", "Viruses", subtypesof(/datum/disease), subtypesof(/datum/disease))
|
|
|
|
if(isnull(disease))
|
|
return FALSE
|
|
|
|
var/mob/living/carbon/human/H = tgui_input_list(usr, "Choose infectee", "Characters", human_mob_list)
|
|
|
|
if(isnull(H))
|
|
return FALSE
|
|
|
|
var/datum/disease/D = new disease
|
|
|
|
if(!H.HasDisease(D))
|
|
H.ForceContractDisease(D)
|
|
|
|
message_admins("[key_name_admin(usr)] has triggered a virus outbreak of [D.name]! Affected mob: [key_name_admin(H)]")
|
|
log_admin("[key_name_admin(usr)] infected [key_name_admin(H)] with [D.name]")
|
|
|
|
if(!GLOB.archive_diseases[D.GetDiseaseID()])
|
|
GLOB.archive_diseases[D.GetDiseaseID()] = D
|
|
|
|
return TRUE
|