diff --git a/ModularTegustation/tegu_items/gadgets/unpowered.dm b/ModularTegustation/tegu_items/gadgets/unpowered.dm
index e1beedea043a..1f0698d5401d 100644
--- a/ModularTegustation/tegu_items/gadgets/unpowered.dm
+++ b/ModularTegustation/tegu_items/gadgets/unpowered.dm
@@ -143,7 +143,7 @@
/obj/item/deepscanner/examine(mob/living/M)
. = ..()
if(deep_scan_log)
- to_chat(M, "Previous Scan:[deep_scan_log].")
+ to_chat(M, "Previous Scan:[deep_scan_log]")
/obj/item/deepscanner/attack(mob/living/M, mob/user)
user.visible_message("[user] takes a tool out of [src] and begins scanning [M].", "You set down the deep scanner and begin scanning [M].")
@@ -165,17 +165,22 @@
check1d = 1 - (H.getarmor(null, PALE_DAMAGE) / 100)
if(H.job)
check1e = H.job
- to_chat(user, "[check1e] [H] [H.maxHealth] [check1a] [check1b] [check1c] [check1d].")
else
var/mob/living/simple_animal/hostile/mon = M
if((mon.status_flags & GODMODE))
return
- check1a = mon.damage_coeff[RED_DAMAGE]
- check1b = mon.damage_coeff[WHITE_DAMAGE]
- check1c = mon.damage_coeff[BLACK_DAMAGE]
- check1d = mon.damage_coeff[PALE_DAMAGE]
- to_chat(user, "[mon] [mon.maxHealth] [check1a] [check1b] [check1c] [check1d].")
- deep_scan_log = "[mon] [mon.maxHealth] [check1a] [check1b] [check1c] [check1d]"
+ check1a = mon.damage_coeff.getCoeff(RED_DAMAGE)
+ check1b = mon.damage_coeff.getCoeff(WHITE_DAMAGE)
+ check1c = mon.damage_coeff.getCoeff(BLACK_DAMAGE)
+ check1d = mon.damage_coeff.getCoeff(PALE_DAMAGE)
+ if(isabnormalitymob(mon))
+ var/mob/living/simple_animal/hostile/abnormality/abno = mon
+ check1e = THREAT_TO_NAME[abno.threat_level]
+ else
+ check1e = FALSE
+ var/output = "----------\n[check1e ? check1e+" " : ""][M]\nHP [M.health]/[M.maxHealth]\nR [check1a] W [check1b] B [check1c] P [check1d]\n----------"
+ to_chat(user, "[output]")
+ deep_scan_log = output
playsound(get_turf(M), 'sound/misc/box_deploy.ogg', 5, 0, 3)
diff --git a/ModularTegustation/tegu_items/workshop/mods/curing.dm b/ModularTegustation/tegu_items/workshop/mods/curing.dm
index 1fbc4adeeeef..8fd1f6632348 100644
--- a/ModularTegustation/tegu_items/workshop/mods/curing.dm
+++ b/ModularTegustation/tegu_items/workshop/mods/curing.dm
@@ -9,8 +9,8 @@
var/heal_amt = T.force*0.04
if(isanimal(target))
var/mob/living/simple_animal/S = target
- if(S.damage_coeff[damtype] > 0)
- heal_amt *= S.damage_coeff[damtype]
+ if(S.damage_coeff.getCoeff(damtype) > 0)
+ heal_amt *= S.damage_coeff.getCoeff(damtype)
else
heal_amt = 0
user.adjustSanityLoss(-heal_amt)
diff --git a/ModularTegustation/tegu_items/workshop/mods/healthup.dm b/ModularTegustation/tegu_items/workshop/mods/healthup.dm
index 229e29bf587b..9af81776495c 100644
--- a/ModularTegustation/tegu_items/workshop/mods/healthup.dm
+++ b/ModularTegustation/tegu_items/workshop/mods/healthup.dm
@@ -9,8 +9,8 @@
var/heal_amt = T.force*0.10
if(isanimal(target))
var/mob/living/simple_animal/S = target
- if(S.damage_coeff[damtype] > 0)
- heal_amt *= S.damage_coeff[damtype]
+ if(S.damage_coeff.getCoeff(damtype) > 0)
+ heal_amt *= S.damage_coeff.getCoeff(damtype)
else
heal_amt = 0
user.adjustBruteLoss(-heal_amt)
diff --git a/ModularTegustation/tegu_items/workshop/mods/sapping.dm b/ModularTegustation/tegu_items/workshop/mods/sapping.dm
index 0c3682c21374..66442ad0101e 100644
--- a/ModularTegustation/tegu_items/workshop/mods/sapping.dm
+++ b/ModularTegustation/tegu_items/workshop/mods/sapping.dm
@@ -9,8 +9,8 @@
var/heal_amt = T.force*0.10
if(isanimal(target))
var/mob/living/simple_animal/S = target
- if(S.damage_coeff[damtype] > 0)
- heal_amt *= S.damage_coeff[damtype]
+ if(S.damage_coeff.getCoeff(damtype) > 0)
+ heal_amt *= S.damage_coeff.getCoeff(damtype)
else
heal_amt = 0
user.adjustSanityLoss(-heal_amt)
diff --git a/ModularTegustation/tegu_mobs/chaos_marine.dm b/ModularTegustation/tegu_mobs/chaos_marine.dm
index ef6c7bdd6f37..2c8483218b0b 100644
--- a/ModularTegustation/tegu_mobs/chaos_marine.dm
+++ b/ModularTegustation/tegu_mobs/chaos_marine.dm
@@ -394,12 +394,12 @@
playsound(src, 'sound/magic/clockwork/narsie_attack.ogg', 200, TRUE)
/mob/living/simple_animal/hostile/megafauna/chaos_marine/proc/cmempower()
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.25, WHITE_DAMAGE = 2, BLACK_DAMAGE = 0.5, PALE_DAMAGE = 0.1)
+ ChangeResistances(list(RED_DAMAGE = 0.25, WHITE_DAMAGE = 2, BLACK_DAMAGE = 0.5, PALE_DAMAGE = 0.1))
add_atom_colour(newcolor, TEMPORARY_COLOUR_PRIORITY)
new /obj/effect/temp_visual/cult/sparks(get_turf(src))
/mob/living/simple_animal/hostile/megafauna/chaos_marine/proc/cmdepower()
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.5, WHITE_DAMAGE = 0, BLACK_DAMAGE = 1, PALE_DAMAGE = 0.2)
+ ChangeResistances(list(RED_DAMAGE = 0.5, WHITE_DAMAGE = 0, BLACK_DAMAGE = 1, PALE_DAMAGE = 0.2))
remove_atom_colour(TEMPORARY_COLOUR_PRIORITY, newcolor)
new /obj/effect/temp_visual/cult/sparks(get_turf(src))
diff --git a/code/controllers/subsystem/lobotomy_events.dm b/code/controllers/subsystem/lobotomy_events.dm
index 3a45cec54275..46ef5ce73129 100644
--- a/code/controllers/subsystem/lobotomy_events.dm
+++ b/code/controllers/subsystem/lobotomy_events.dm
@@ -133,7 +133,7 @@ SUBSYSTEM_DEF(lobotomy_events)
A.density = FALSE // They ignore you and walk past you.
A.AIStatus = AI_OFF
A.can_patrol = FALSE
- A.damage_coeff = list(BRUTE = 0, RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0) // You can kill the portal but not them.
+ A.ChangeResistances(list(BRUTE = 0, RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0)) // You can kill the portal but not them.
AB_types = list() // So the event can't run again.
return
if(YINYANG)
diff --git a/code/datums/status_effects/buffs.dm b/code/datums/status_effects/buffs.dm
index 8da5522a9181..f0942635fd87 100644
--- a/code/datums/status_effects/buffs.dm
+++ b/code/datums/status_effects/buffs.dm
@@ -513,33 +513,31 @@
//LC13 AI entity Buffs
//Buff Maroon Ordeal Soldiers, Feel free to cannibalize and rework to work for other creatures.
+
/datum/status_effect/all_armor_buff //due to multiplication the effect works more on entities that are weak to the damage value.
id = "all armor armor"
status_type = STATUS_EFFECT_UNIQUE
- duration = 120 //6 seconds
+ duration = 120 //12 seconds
alert_type = null
var/visual
/datum/status_effect/all_armor_buff/on_apply()
. = ..()
+ if(!isanimal(owner))
+ qdel(src)
+ return
visual = mutable_appearance('ModularTegustation/Teguicons/tegu_effects.dmi', "manager_shield")
- if(isanimal(owner))
- var/mob/living/simple_animal/M = owner
- M.add_overlay(visual)
- M.damage_coeff[RED_DAMAGE] *= 0.8 //20% damage decrease
- M.damage_coeff[WHITE_DAMAGE] *= 0.8
- M.damage_coeff[BLACK_DAMAGE] *= 0.8
- M.damage_coeff[PALE_DAMAGE] *= 0.8
+ var/mob/living/simple_animal/M = owner
+ M.add_overlay(visual)
+ M.AddModifier(/datum/dc_change/maroon_buff)
/datum/status_effect/all_armor_buff/on_remove()
. = ..()
if(isanimal(owner))
var/mob/living/simple_animal/M = owner
- M.damage_coeff[RED_DAMAGE] /= 0.8
- M.damage_coeff[WHITE_DAMAGE] /= 0.8
- M.damage_coeff[BLACK_DAMAGE] /= 0.8
- M.damage_coeff[PALE_DAMAGE] /= 0.8
- owner.cut_overlay(visual)
+ M.RemoveModifier(/datum/dc_change/maroon_buff)
+ if(visual)
+ owner.cut_overlay(visual)
/datum/status_effect/minor_damage_buff
diff --git a/code/datums/status_effects/debuffs.dm b/code/datums/status_effects/debuffs.dm
index 9c5093b035fd..c50865c23446 100644
--- a/code/datums/status_effects/debuffs.dm
+++ b/code/datums/status_effects/debuffs.dm
@@ -1012,28 +1012,33 @@
owner.cut_overlay(statuseffectvisual)
return ..()
-/datum/status_effect/sunder_red
- id = "sunder red armor"
+//update_stamina() is move_to_delay = (initial(move_to_delay) + (staminaloss * 0.06))
+// 100 stamina damage equals 6 additional move_to_delay. So 167*0.06 = 10.02
+
+/datum/status_effect/rend_red
+ id = "rend red armor"
status_type = STATUS_EFFECT_UNIQUE
- duration = 60 //3 seconds
+ duration = 60 //6 seconds
alert_type = null
-/datum/status_effect/sunder_red/on_apply()
+/datum/status_effect/rend_red/on_apply()
. = ..()
- if(isanimal(owner))
- var/mob/living/simple_animal/M = owner
- M.damage_coeff[RED_DAMAGE] *= 1.2
+ if(!isanimal(owner))
+ qdel(src)
+ return
+ var/mob/living/simple_animal/M = owner
+ M.AddModifier(/datum/dc_change/rend/red)
//20% damage increase. Hitting any abnormality that has a negative value will cause this
//to be a buff to their healing.
-/datum/status_effect/sunder_red/on_remove()
+/datum/status_effect/rend_red/on_remove()
. = ..()
if(isanimal(owner))
var/mob/living/simple_animal/M = owner
- M.damage_coeff[RED_DAMAGE] /= 1.2
+ M.RemoveModifier(/datum/dc_change/rend/red)
- //White Damage Debuff
+//White Damage Debuff
/datum/status_effect/rend_white
id = "rend white armor"
status_type = STATUS_EFFECT_UNIQUE
@@ -1042,13 +1047,17 @@
/datum/status_effect/rend_white/on_apply()
. = ..()
+ if(!isanimal(owner))
+ qdel(src)
+ return
var/mob/living/simple_animal/M = owner
- M.damage_coeff[WHITE_DAMAGE] *= 1.2
+ M.AddModifier(/datum/dc_change/rend/white)
/datum/status_effect/rend_white/on_remove()
. = ..()
- var/mob/living/simple_animal/M = owner
- M.damage_coeff[WHITE_DAMAGE] /= 1.2
+ if(isanimal(owner))
+ var/mob/living/simple_animal/M = owner
+ M.RemoveModifier(/datum/dc_change/rend/white)
//Black Damage Debuff
@@ -1060,13 +1069,17 @@
/datum/status_effect/rend_black/on_apply()
. = ..()
+ if(!isanimal(owner))
+ qdel(src)
+ return
var/mob/living/simple_animal/M = owner
- M.damage_coeff[BLACK_DAMAGE] *= 1.2
+ M.AddModifier(/datum/dc_change/rend/black)
/datum/status_effect/rend_black/on_remove()
. = ..()
- var/mob/living/simple_animal/M = owner
- M.damage_coeff[BLACK_DAMAGE] /= 1.2
+ if(isanimal(owner))
+ var/mob/living/simple_animal/M = owner
+ M.RemoveModifier(/datum/dc_change/rend/black)
#undef CARBON_HALFSPEED
diff --git a/code/game/machinery/computer/manager_camera.dm b/code/game/machinery/computer/manager_camera.dm
index de955806e188..8fb4cfeea1b9 100644
--- a/code/game/machinery/computer/manager_camera.dm
+++ b/code/game/machinery/computer/manager_camera.dm
@@ -195,7 +195,7 @@
to_chat(user, "[clicked_atom]'s resistances are : ")
var/list/damage_types = list(RED_DAMAGE, WHITE_DAMAGE, BLACK_DAMAGE, PALE_DAMAGE)
for(var/i in damage_types)
- var/resistance = SimpleResistanceToText(monster.damage_coeff[i])
+ var/resistance = SimpleResistanceToText(monster.damage_coeff.getCoeff(i))
if(isnull(resistance))
continue
to_chat(user, "[i]: [resistance].")
diff --git a/code/game/objects/items/ego_weapons/aleph.dm b/code/game/objects/items/ego_weapons/aleph.dm
index 1c02d83b84eb..338db831f8a1 100644
--- a/code/game/objects/items/ego_weapons/aleph.dm
+++ b/code/game/objects/items/ego_weapons/aleph.dm
@@ -182,8 +182,8 @@
var/heal_amt = force*0.15
if(isanimal(target))
var/mob/living/simple_animal/S = target
- if(S.damage_coeff[damtype] > 0)
- heal_amt *= S.damage_coeff[damtype]
+ if(S.damage_coeff.getCoeff(damtype) > 0)
+ heal_amt *= S.damage_coeff.getCoeff(damtype)
else
heal_amt = 0
user.adjustBruteLoss(-heal_amt)
diff --git a/code/game/objects/items/ego_weapons/non_abnormality/limbus_ego.dm b/code/game/objects/items/ego_weapons/non_abnormality/limbus_ego.dm
index 1211bd81cf57..8247e25dcdd2 100644
--- a/code/game/objects/items/ego_weapons/non_abnormality/limbus_ego.dm
+++ b/code/game/objects/items/ego_weapons/non_abnormality/limbus_ego.dm
@@ -37,8 +37,8 @@
var/heal_amt = force*0.10
if(isanimal(target))
var/mob/living/simple_animal/S = target
- if(S.damage_coeff[damtype] > 0)
- heal_amt *= S.damage_coeff[damtype]
+ if(S.damage_coeff.getCoeff(damtype) > 0)
+ heal_amt *= S.damage_coeff.getCoeff(damtype)
else
heal_amt = 0
user.adjustBruteLoss(-heal_amt)
diff --git a/code/game/objects/items/ego_weapons/non_abnormality/pierre.dm b/code/game/objects/items/ego_weapons/non_abnormality/pierre.dm
index b5cc22f2f8dd..9aa21ee79bf8 100644
--- a/code/game/objects/items/ego_weapons/non_abnormality/pierre.dm
+++ b/code/game/objects/items/ego_weapons/non_abnormality/pierre.dm
@@ -20,8 +20,8 @@
var/heal_amt = force*0.2
if(isanimal(target))
var/mob/living/simple_animal/S = target
- if(S.damage_coeff[damtype] > 0)
- heal_amt *= S.damage_coeff[damtype]
+ if(S.damage_coeff.getCoeff(damtype) > 0)
+ heal_amt *= S.damage_coeff.getCoeff(damtype)
else
heal_amt = 0
user.adjustBruteLoss(-heal_amt)
diff --git a/code/game/objects/items/ego_weapons/non_abnormality/purple_tear.dm b/code/game/objects/items/ego_weapons/non_abnormality/purple_tear.dm
index b973578797d8..65f7d6bb9462 100644
--- a/code/game/objects/items/ego_weapons/non_abnormality/purple_tear.dm
+++ b/code/game/objects/items/ego_weapons/non_abnormality/purple_tear.dm
@@ -228,16 +228,9 @@
L.physiology.pale_mod *= 2
return
var/mob/living/simple_animal/M = owner
- if(M.damage_coeff[RED_DAMAGE] > 0)
- M.damage_coeff[RED_DAMAGE] *= 2
- if(M.damage_coeff[WHITE_DAMAGE] > 0)
- M.damage_coeff[WHITE_DAMAGE] *= 2
- if(M.damage_coeff[BLACK_DAMAGE] > 0)
- M.damage_coeff[BLACK_DAMAGE] *= 2
- if(M.damage_coeff[PALE_DAMAGE] > 0)
- M.damage_coeff[PALE_DAMAGE] *= 2
-
-/datum/status_effect/pt_lacerate/on_apply()
+ M.AddModifier(/datum/dc_change/lacerated)
+
+/datum/status_effect/pt_lacerate/on_remove()
. = ..()
if(ishuman(owner))
var/mob/living/carbon/human/L = owner
@@ -248,14 +241,7 @@
L.physiology.pale_mod /= 2
return
var/mob/living/simple_animal/M = owner
- if(M.damage_coeff[RED_DAMAGE] > 0)
- M.damage_coeff[RED_DAMAGE] /= 2
- if(M.damage_coeff[WHITE_DAMAGE] > 0)
- M.damage_coeff[WHITE_DAMAGE] /= 2
- if(M.damage_coeff[BLACK_DAMAGE] > 0)
- M.damage_coeff[BLACK_DAMAGE] /= 2
- if(M.damage_coeff[PALE_DAMAGE] > 0)
- M.damage_coeff[PALE_DAMAGE] /= 2
+ M.RemoveModifier(/datum/dc_change/lacerated)
// Slow black damage with a buff attack
/obj/item/ego_weapon/city/pt/blunt
@@ -314,7 +300,7 @@
L.physiology.pale_mod /= 2
return
-/datum/status_effect/pt_lacerate/on_apply()
+/datum/status_effect/pt_defense/on_remove()
. = ..()
if(ishuman(owner))
var/mob/living/carbon/human/L = owner
diff --git a/code/game/objects/items/ego_weapons/non_abnormality/wcorp.dm b/code/game/objects/items/ego_weapons/non_abnormality/wcorp.dm
index 4233da0ce267..489eeb99e50b 100644
--- a/code/game/objects/items/ego_weapons/non_abnormality/wcorp.dm
+++ b/code/game/objects/items/ego_weapons/non_abnormality/wcorp.dm
@@ -223,29 +223,13 @@
..()
sleep(5)
target.apply_damage(force*2, damtype, null, target.run_armor_check(null, damtype), spread_damage = TRUE)
- target.apply_status_effect(/datum/status_effect/rendBlackArmor)
+ target.apply_status_effect(/datum/status_effect/rend_black/w_corp)
playsound(src, 'sound/abnormalities/thunderbird/tbird_bolt.ogg', 50, TRUE)
var/turf/T = get_turf(target)
new /obj/effect/temp_visual/justitia_effect(T)
-/datum/status_effect/rendBlackArmor
- id = "rend Black armor"
- status_type = STATUS_EFFECT_UNIQUE
- duration = 50 //5 seconds since it's melee-ish
- alert_type = null
-
-/datum/status_effect/rendBlackArmor/on_apply()
- . = ..()
- if(isanimal(owner))
- var/mob/living/simple_animal/M = owner
- M.damage_coeff[BLACK_DAMAGE] *= 1.2
-
-/datum/status_effect/rendBlackArmor/on_remove()
- . = ..()
- if(isanimal(owner))
- var/mob/living/simple_animal/M = owner
- M.damage_coeff[BLACK_DAMAGE] /= 1.2
-
+/datum/status_effect/rend_black/w_corp // Duplicate of "rend_black", giving it a unique id so it can stack.
+ id = "w-corp rend black armor"
//Type C weapons
diff --git a/code/game/objects/items/ego_weapons/special.dm b/code/game/objects/items/ego_weapons/special.dm
index 13a8ce4ae581..24fffd711978 100644
--- a/code/game/objects/items/ego_weapons/special.dm
+++ b/code/game/objects/items/ego_weapons/special.dm
@@ -35,7 +35,7 @@
icon_state = "eyeball2" // Cool sprite
if(isanimal(target))
var/mob/living/simple_animal/S = target
- if(S.damage_coeff[damtype] <= 0)
+ if(S.damage_coeff.getCoeff(damtype) <= 0)
resistance = 100
if(resistance >= 100) // If the eyeball wielder is going no-balls and using one fucking weapon, let's throw them a bone.
force *= 0.1
diff --git a/code/game/objects/items/ego_weapons/waw.dm b/code/game/objects/items/ego_weapons/waw.dm
index adc47b3e21a3..5c0703e2bd75 100644
--- a/code/game/objects/items/ego_weapons/waw.dm
+++ b/code/game/objects/items/ego_weapons/waw.dm
@@ -964,8 +964,8 @@
var/heal_amt = force*0.10
if(isanimal(target))
var/mob/living/simple_animal/S = target
- if(S.damage_coeff[damtype] > 0)
- heal_amt *= S.damage_coeff[damtype]
+ if(S.damage_coeff.getCoeff(damtype) > 0)
+ heal_amt *= S.damage_coeff.getCoeff(damtype)
else
heal_amt = 0
user.adjustBruteLoss(-heal_amt)
@@ -1592,8 +1592,8 @@
var/heal_amt = force*0.05
if(isanimal(target))
var/mob/living/simple_animal/S = target
- if(S.damage_coeff[damtype] > 0)
- heal_amt *= S.damage_coeff[damtype]
+ if(S.damage_coeff.getCoeff(damtype) > 0)
+ heal_amt *= S.damage_coeff.getCoeff(damtype)
else
heal_amt = 0
amount_filled = clamp(amount_filled + heal_amt, 0, amount_max)
diff --git a/code/modules/mob/living/simple_animal/_damage_coeff.dm b/code/modules/mob/living/simple_animal/_damage_coeff.dm
new file mode 100644
index 000000000000..b4d1325188f6
--- /dev/null
+++ b/code/modules/mob/living/simple_animal/_damage_coeff.dm
@@ -0,0 +1,89 @@
+#define DAMCOEFFID "damage_coeff-[red]-[white]-[black]-[pale]-[brute]-[burn]-[tox]-[clone]-[stamina]-[oxy]"
+
+/proc/getDamCoeff(red = 1, white = 1, black = 1, pale = 1, brute = 1, burn = 1, tox = 1, clone = 1, stamina = 1, oxy = 1)
+ . = locate(DAMCOEFFID)
+ if(!.)
+ . = new /datum/dam_coeff(red, white, black, pale, brute, burn, tox, clone, stamina, oxy)
+
+/proc/makeDamCoeff(list/dc = list())
+ var/list/coeffs = list(RED_DAMAGE = 1, WHITE_DAMAGE = 1, BLACK_DAMAGE = 1, PALE_DAMAGE = 1, BRUTE = 1, BURN = 1, TOX = 1, CLONE = 1, STAMINA = 1, OXY = 1)
+ for(var/I in dc)
+ coeffs[I] = dc[I]
+ return getDamCoeff(coeffs[RED_DAMAGE], coeffs[WHITE_DAMAGE], coeffs[BLACK_DAMAGE], coeffs[PALE_DAMAGE], coeffs[BRUTE], coeffs[BURN], coeffs[TOX], coeffs[CLONE], coeffs[STAMINA], coeffs[OXY])
+
+/datum/dam_coeff
+ datum_flags = DF_USE_TAG
+ var/brute
+ var/burn
+ var/tox
+ var/clone
+ var/stamina
+ var/oxy
+ var/red
+ var/white
+ var/black
+ var/pale
+
+/datum/dam_coeff/New(red = 1, white = 1, black = 1, pale = 1, brute = 1, burn = 1, tox = 1, clone = 1, stamina = 1, oxy = 1)
+ src.red = red
+ src.white = white
+ src.black = black
+ src.pale = pale
+ src.brute = brute
+ src.burn = burn
+ src.tox = tox
+ src.clone = clone
+ src.stamina = stamina
+ src.oxy = oxy
+ tag = DAMCOEFFID
+
+/datum/dam_coeff/proc/modifyCoeff(red = 0, white = 0, black = 0, pale = 0, brute = 0, burn = 0, tox = 0, clone = 0, stamina = 0, oxy = 0)
+ return getDamCoeff(src.red+red, src.white+white, src.black+black, src.pale+pale, src.brute+brute, src.burn+burn, src.tox+tox, src.clone+clone, src.stamina+stamina, src.oxy+oxy)
+
+/datum/dam_coeff/proc/setCoeff(red, white, black, pale, brute, burn, tox, clone, stamina, oxy)
+ return getDamCoeff((isnull(red) ? src.red : red),\
+ (isnull(white) ? src.white : white),\
+ (isnull(black) ? src.black : black),\
+ (isnull(pale) ? src.pale : pale),\
+ (isnull(brute) ? src.brute : brute),\
+ (isnull(burn) ? src.burn : burn),\
+ (isnull(tox) ? src.tox : clone),\
+ (isnull(clone) ? src.clone : clone),\
+ (isnull(stamina) ? src.stamina : stamina),\
+ (isnull(oxy) ? src.oxy : oxy))
+
+/datum/dam_coeff/proc/getCoeff(coeff)
+ . = 0
+ switch(coeff)
+ if(BRUTE)
+ . = brute
+ if(BURN)
+ . = burn
+ if(TOX)
+ . = tox
+ if(CLONE)
+ . = clone
+ if(STAMINA)
+ . = stamina
+ if(OXY)
+ . = oxy
+ if(RED_DAMAGE)
+ . = red
+ if(WHITE_DAMAGE)
+ . = white
+ if(BLACK_DAMAGE)
+ . = black
+ if(PALE_DAMAGE)
+ . = pale
+ return
+
+/datum/dam_coeff/proc/getList()
+ return list(RED_DAMAGE = red, WHITE_DAMAGE = white, BLACK_DAMAGE = black, PALE_DAMAGE = pale, BRUTE = brute, BURN = burn, TOX = tox, CLONE = clone, STAMINA = stamina, OXY = oxy)
+
+/datum/dam_coeff/vv_edit_var(var_name, var_value)
+ if (var_name == NAMEOF(src, tag))
+ return FALSE
+ . = ..()
+ tag = DAMCOEFFID // update tag in case damage_coeff values were edited
+
+#undef DAMCOEFFID
diff --git a/code/modules/mob/living/simple_animal/abnormality/_abnormality.dm b/code/modules/mob/living/simple_animal/abnormality/_abnormality.dm
index d81d525ec704..4bbaebfc4f18 100644
--- a/code/modules/mob/living/simple_animal/abnormality/_abnormality.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/_abnormality.dm
@@ -86,7 +86,7 @@
if(!(type in GLOB.cached_abno_work_rates))
GLOB.cached_abno_work_rates[type] = work_chances.Copy()
if(!(type in GLOB.cached_abno_resistances))
- GLOB.cached_abno_resistances[type] = damage_coeff.Copy()
+ GLOB.cached_abno_resistances[type] = damage_coeff.getList()
for(var/action_type in attack_action_types)
var/datum/action/innate/abnormality_attack/attack_action = new action_type()
attack_action.Grant(src)
diff --git a/code/modules/mob/living/simple_animal/abnormality/aleph/censored.dm b/code/modules/mob/living/simple_animal/abnormality/aleph/censored.dm
index 5243fa0ed2cc..930d5804e13e 100644
--- a/code/modules/mob/living/simple_animal/abnormality/aleph/censored.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/aleph/censored.dm
@@ -92,7 +92,7 @@
return
can_act = FALSE
forceMove(get_turf(H))
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0)
+ ChangeResistances(list(RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0))
playsound(src, 'sound/abnormalities/censored/convert.ogg', 45, FALSE, 5)
SLEEP_CHECK_DEATH(3)
new /obj/effect/temp_visual/censored(get_turf(src))
@@ -103,7 +103,7 @@
if(!QDELETED(H))
C.desc = "What the hell is this? It shouldn't exist... On the second thought, it reminds you of [H.real_name]..."
H.gib()
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.6, WHITE_DAMAGE = 0.8, BLACK_DAMAGE = 0.4, PALE_DAMAGE = 1)
+ ChangeResistances(list(RED_DAMAGE = 0.6, WHITE_DAMAGE = 0.8, BLACK_DAMAGE = 0.4, PALE_DAMAGE = 1))
adjustBruteLoss(-(maxHealth*0.1))
can_act = TRUE
diff --git a/code/modules/mob/living/simple_animal/abnormality/aleph/nothing_there.dm b/code/modules/mob/living/simple_animal/abnormality/aleph/nothing_there.dm
index 46f299c1902b..2e733dd15455 100644
--- a/code/modules/mob/living/simple_animal/abnormality/aleph/nothing_there.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/aleph/nothing_there.dm
@@ -272,7 +272,7 @@
switch(current_stage)
if(1)
icon_state = "nothing_egg"
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0, WHITE_DAMAGE = 0.6, BLACK_DAMAGE = 0.6, PALE_DAMAGE = 1)
+ ChangeResistances(list(RED_DAMAGE = 0, WHITE_DAMAGE = 0.6, BLACK_DAMAGE = 0.6, PALE_DAMAGE = 1))
can_act = FALSE
next_transform = world.time + rand(10 SECONDS, 25 SECONDS)
heartbeat.start()
@@ -286,7 +286,7 @@
icon_state = icon_living
pixel_x = -16
base_pixel_x = -16
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0, WHITE_DAMAGE = 0.4, BLACK_DAMAGE = 0.4, PALE_DAMAGE = 0.8)
+ ChangeResistances(list(WHITE_DAMAGE = 0.4, BLACK_DAMAGE = 0.4, PALE_DAMAGE = 0.8))
can_act = TRUE
melee_damage_lower = 65
melee_damage_upper = 75
diff --git a/code/modules/mob/living/simple_animal/abnormality/aleph/seasons.dm b/code/modules/mob/living/simple_animal/abnormality/aleph/seasons.dm
index 87d199843182..91dc4fa64a42 100644
--- a/code/modules/mob/living/simple_animal/abnormality/aleph/seasons.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/aleph/seasons.dm
@@ -203,10 +203,9 @@
/mob/living/simple_animal/hostile/abnormality/seasons/proc/Transform()
current_season = SSlobotomy_events.current_season
var/list/new_work_chances = modular_work_chance[current_season]
- var/list/new_damage_coeff = modular_damage_coeff[current_season]
work_chances = new_work_chances.Copy()
datum_reference.available_work = work_chances
- damage_coeff = new_damage_coeff.Copy()
+ ChangeResistances(modular_damage_coeff[current_season])
work_damage_type = season_stats[current_season][2]
melee_damage_type = season_stats[current_season][2]
icon_state = current_season
diff --git a/code/modules/mob/living/simple_animal/abnormality/aleph/silent_orchestra.dm b/code/modules/mob/living/simple_animal/abnormality/aleph/silent_orchestra.dm
index 6e794cb139a2..5535d9879a4c 100644
--- a/code/modules/mob/living/simple_animal/abnormality/aleph/silent_orchestra.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/aleph/silent_orchestra.dm
@@ -81,26 +81,26 @@
next_movement_time = world.time + 4 SECONDS
if(1)
next_movement_time = world.time + 22 SECONDS
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 1)
+ ChangeResistances(list(PALE_DAMAGE = 1))
spawn_performer(1, WEST)
if(2)
next_movement_time = world.time + 14.5 SECONDS
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 1, PALE_DAMAGE = 0)
+ ChangeResistances(list(BLACK_DAMAGE = 1, PALE_DAMAGE = 0))
spawn_performer(2, WEST)
if(3)
next_movement_time = world.time + 11.5 SECONDS
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0, WHITE_DAMAGE = 1, BLACK_DAMAGE = 0, PALE_DAMAGE = 0)
+ ChangeResistances(list(WHITE_DAMAGE = 1, BLACK_DAMAGE = 0))
symphony_damage = 18
movement_volume = 3 // No more tinnitus
spawn_performer(1, EAST)
if(4)
next_movement_time = world.time + 23 SECONDS
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 1, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0)
+ ChangeResistances(list(RED_DAMAGE = 1, WHITE_DAMAGE = 0))
symphony_damage = 12
spawn_performer(2, EAST)
if(5)
next_movement_time = world.time + 999 SECONDS // Never
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0)
+ ChangeResistances(list(RED_DAMAGE = 0))
movement_volume = 65 // TA-DA!!!
if(current_movement_num < 6)
sound_to_playing_players_on_level("sound/abnormalities/silentorchestra/movement[current_movement_num].ogg", movement_volume, zlevel = z)
diff --git a/code/modules/mob/living/simple_animal/abnormality/aleph/titania.dm b/code/modules/mob/living/simple_animal/abnormality/aleph/titania.dm
index e2e4093528b3..0c9117111d2e 100644
--- a/code/modules/mob/living/simple_animal/abnormality/aleph/titania.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/aleph/titania.dm
@@ -170,10 +170,10 @@
if(currentlaw == "fairies")
for(var/mob/living/simple_animal/L in spawned_mobs)
- L.damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.2, WHITE_DAMAGE = 0.2, BLACK_DAMAGE = 0.2, PALE_DAMAGE = 1)
+ L.ChangeResistances(list(RED_DAMAGE = 0.2, WHITE_DAMAGE = 0.2, BLACK_DAMAGE = 0.2, PALE_DAMAGE = 1))
else
for(var/mob/living/simple_animal/L in spawned_mobs)
- L.damage_coeff = list(BRUTE = 1, RED_DAMAGE = 1, WHITE_DAMAGE = 1, BLACK_DAMAGE = 1, PALE_DAMAGE = 1)
+ L.ChangeResistances(list(RED_DAMAGE = 1, WHITE_DAMAGE = 1, BLACK_DAMAGE = 1, PALE_DAMAGE = 1))
/mob/living/simple_animal/hostile/abnormality/titania/proc/Punishment(mob/living/sinner)
diff --git a/code/modules/mob/living/simple_animal/abnormality/he/doomsday_calendar.dm b/code/modules/mob/living/simple_animal/abnormality/he/doomsday_calendar.dm
index 30ed41cdf24a..1675ac10046a 100644
--- a/code/modules/mob/living/simple_animal/abnormality/he/doomsday_calendar.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/he/doomsday_calendar.dm
@@ -305,10 +305,7 @@
adjustBruteLoss(100)
pulse_damage -= 1
playsound(get_turf(src),'sound/abnormalities/doomsdaycalendar/Limbus_Dead_Generic.ogg', 50, 1)
- for(var/damtype in src.damage_coeff)
- if(damtype == BRUTE)
- continue
- damage_coeff[damtype] += 0.1
+ AddModifier(/datum/dc_change/sacrificed)
//***Simple Mobs***//
//clay dolls
diff --git a/code/modules/mob/living/simple_animal/abnormality/he/golden_false_apple.dm b/code/modules/mob/living/simple_animal/abnormality/he/golden_false_apple.dm
index 909a5476a969..978e1b98e4d1 100644
--- a/code/modules/mob/living/simple_animal/abnormality/he/golden_false_apple.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/he/golden_false_apple.dm
@@ -305,7 +305,7 @@
melee_damage_upper = 45
attack_verb_continuous = "pummels"
attack_verb_simple = "pummel"
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 1.5, WHITE_DAMAGE = 1.5, BLACK_DAMAGE = 1, PALE_DAMAGE = 0.5)
+ ChangeResistances(list(RED_DAMAGE = 1.5, WHITE_DAMAGE = 1.5, BLACK_DAMAGE = 1, PALE_DAMAGE = 0.5))
melee_damage_type = BLACK_DAMAGE
fear_level = WAW_LEVEL
is_maggot = TRUE
diff --git a/code/modules/mob/living/simple_animal/abnormality/he/norinori.dm b/code/modules/mob/living/simple_animal/abnormality/he/norinori.dm
index 70794a518cf8..21b38d585881 100644
--- a/code/modules/mob/living/simple_animal/abnormality/he/norinori.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/he/norinori.dm
@@ -165,10 +165,7 @@
playsound(src, 'sound/effects/blobattack.ogg', 150, FALSE, 4)
playsound(src, 'sound/weapons/chainsawhit.ogg', 250, FALSE, 4)
attack_sound = 'sound/abnormalities/helper/attack.ogg'
- for(var/damtype in src.damage_coeff)
- if(damtype == BRUTE)
- continue
- damage_coeff[damtype] -= 0.4
+ ChangeResistances(list(RED_DAMAGE = 0.1, WHITE_DAMAGE = 1.1, BLACK_DAMAGE = 0.6, PALE_DAMAGE = 1.6))
can_act = TRUE
rapid_melee = 3
melee_reach = 3
@@ -182,10 +179,7 @@
icon_state = icon_aggro
attack_sound = 'sound/weapons/slashmiss.ogg'
SLEEP_CHECK_DEATH(10)
- for(var/damtype in src.damage_coeff)
- if(damtype == BRUTE)
- continue
- damage_coeff[damtype] += 0.4
+ ChangeResistances(list(RED_DAMAGE = 0.5, WHITE_DAMAGE = 1.5, BLACK_DAMAGE = 1, PALE_DAMAGE = 2))
can_act = TRUE
rapid_melee = 1
melee_reach = 1
diff --git a/code/modules/mob/living/simple_animal/abnormality/he/pisc_mermaid.dm b/code/modules/mob/living/simple_animal/abnormality/he/pisc_mermaid.dm
index c6108213d229..e627f50a5545 100644
--- a/code/modules/mob/living/simple_animal/abnormality/he/pisc_mermaid.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/he/pisc_mermaid.dm
@@ -91,7 +91,7 @@
pixel_y = -16
base_pixel_y = -16
if(!isnull(crown?.loved))
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.3, WHITE_DAMAGE = 0.3, BLACK_DAMAGE = 0.3, PALE_DAMAGE = 0.3) //others can still help but it's going to take a lot of damage
+ ChangeResistances(list(RED_DAMAGE = 0.3, WHITE_DAMAGE = 0.3, BLACK_DAMAGE = 0.3, PALE_DAMAGE = 0.3)) //others can still help but it's going to take a lot of damage
love_target = crown.loved
qdel(crown)
love_target.add_or_update_variable_movespeed_modifier(/datum/movespeed_modifier/unrequited_slowdown)
@@ -136,7 +136,7 @@
if(love_target.stat == DEAD)
say("[love_target.name]? Are you okay? I'm sorry, is it my fault? Will you come back if I love you enough? Will you love me back in death at least?")
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 1.5, WHITE_DAMAGE = 1.5, BLACK_DAMAGE = 0.5, PALE_DAMAGE = 2) //back to being a pushover
+ ChangeResistances(list(RED_DAMAGE = 1.5, WHITE_DAMAGE = 1.5, BLACK_DAMAGE = 0.5, PALE_DAMAGE = 2)) //back to being a pushover
love_target = null
return
//Not having a cooldown on the oxyloss sounds bad, but people's breathing is dictated by Life(), so it's actually the perfect pace of oxyloss
diff --git a/code/modules/mob/living/simple_animal/abnormality/he/red_shoes.dm b/code/modules/mob/living/simple_animal/abnormality/he/red_shoes.dm
index ce796f871f3c..8be75be83711 100644
--- a/code/modules/mob/living/simple_animal/abnormality/he/red_shoes.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/he/red_shoes.dm
@@ -156,10 +156,10 @@
if(ishuman(H) && (H.sanity_lost))
var/obj/item/clothing/suit/armor/ego_gear/EQ = H.get_item_by_slot(ITEM_SLOT_OCLOTHING)//copies all resistances from worn E.G.O
if(EQ)
- for(var/damtype in damage_coeff)
- if(damtype == BRUTE)
- continue
- damage_coeff[damtype] -= (EQ.armor[damtype] / 100)
+ var/list/temp = EQ.armor.getList()
+ for(var/damtype in temp)
+ temp[damtype] = 1 - (temp[damtype] / 100)
+ ChangeResistances(temp)
user.forceMove(src)
playsound(src, 'sound/abnormalities/redshoes/RedShoes_Activate.ogg', 50, 1)
name = user.name
@@ -192,7 +192,7 @@
desc = "The Red Shoes’s bloody enameled leather glistens in the light."
icon_state = "redshoes_breach"
icon_living = "redshoes_breach"
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.5, WHITE_DAMAGE = 1.5, BLACK_DAMAGE = 1, PALE_DAMAGE = 1.5)
+ ChangeResistances(list(BRUTE = 1, RED_DAMAGE = 0.5, WHITE_DAMAGE = 1.5, BLACK_DAMAGE = 1, PALE_DAMAGE = 1.5))
sleep(10)
new /mob/living/simple_animal/hostile/red_shoe(get_turf(src))
datum_reference.qliphoth_change(-2)
diff --git a/code/modules/mob/living/simple_animal/abnormality/he/scaredy_cat.dm b/code/modules/mob/living/simple_animal/abnormality/he/scaredy_cat.dm
index 1516d5048c8a..3bd7a03166ba 100644
--- a/code/modules/mob/living/simple_animal/abnormality/he/scaredy_cat.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/he/scaredy_cat.dm
@@ -169,7 +169,7 @@
if(courage)
melee_damage_lower = 15
melee_damage_upper = 20
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.5, WHITE_DAMAGE = 2, BLACK_DAMAGE = 1.5, PALE_DAMAGE = 0.5)
+ ChangeResistances(list(RED_DAMAGE = 0.5, WHITE_DAMAGE = 2, BLACK_DAMAGE = 1.5, PALE_DAMAGE = 0.5))
icon = 'ModularTegustation/Teguicons/48x48.dmi'
icon_living = "cat_courage"
icon_dead = "dead_courage"
@@ -180,7 +180,7 @@
faction = list("neutral")
melee_damage_lower = initial(melee_damage_lower)
melee_damage_upper = initial(melee_damage_upper) //it shouldn't attack in that form in the first place but...
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 4, WHITE_DAMAGE = 4, BLACK_DAMAGE = 4, PALE_DAMAGE = 4)
+ ChangeResistances(list(RED_DAMAGE = 4, WHITE_DAMAGE = 4, BLACK_DAMAGE = 4, PALE_DAMAGE = 4))
playsound(src, 'sound/abnormalities/scaredycat/catchange.ogg', 75, FALSE, 4)
icon = 'ModularTegustation/Teguicons/32x32.dmi'
icon_living = "scaredy_cat"
diff --git a/code/modules/mob/living/simple_animal/abnormality/he/schadenfreude.dm b/code/modules/mob/living/simple_animal/abnormality/he/schadenfreude.dm
index 19b699854624..3278a0648895 100644
--- a/code/modules/mob/living/simple_animal/abnormality/he/schadenfreude.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/he/schadenfreude.dm
@@ -53,7 +53,7 @@
solo_punish = TRUE
if(living_players == 1)
seen = TRUE
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 1.2, WHITE_DAMAGE = 0.5, BLACK_DAMAGE = 1.0, PALE_DAMAGE = 1.5)
+ ChangeResistances(list(RED_DAMAGE = 1.2, WHITE_DAMAGE = 0.5, BLACK_DAMAGE = 1.0, PALE_DAMAGE = 1.5))
return
solo_punish = FALSE //Reset to normal if the amount of living players on your z-level is something other than 1, to allow normal behavior.
@@ -69,10 +69,10 @@
datum_reference.qliphoth_change(-1)
if(people_watching == 1)
seen = FALSE
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.6, WHITE_DAMAGE = 0.2, BLACK_DAMAGE = 0.5, PALE_DAMAGE = 0.7)
+ ChangeResistances(list(RED_DAMAGE = 0.6, WHITE_DAMAGE = 0.2, BLACK_DAMAGE = 0.5, PALE_DAMAGE = 0.7))
else //any amount of people that's not 1.
seen = TRUE
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 1.2, WHITE_DAMAGE = 0.5, BLACK_DAMAGE = 1.0, PALE_DAMAGE = 1.5)
+ ChangeResistances(list(RED_DAMAGE = 1.2, WHITE_DAMAGE = 0.5, BLACK_DAMAGE = 1.0, PALE_DAMAGE = 1.5))
//Stuff that needs sight check
/mob/living/simple_animal/hostile/abnormality/schadenfreude/Move()
diff --git a/code/modules/mob/living/simple_animal/abnormality/teth/punishing_bird.dm b/code/modules/mob/living/simple_animal/abnormality/teth/punishing_bird.dm
index af73ceeb658d..f5baa58e5800 100644
--- a/code/modules/mob/living/simple_animal/abnormality/teth/punishing_bird.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/teth/punishing_bird.dm
@@ -93,7 +93,7 @@
obj_damage = 2500
environment_smash = ENVIRONMENT_SMASH_STRUCTURES
stat_attack = DEAD
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.5, WHITE_DAMAGE = 0.5, BLACK_DAMAGE = 0.5, PALE_DAMAGE = 0.5)
+ ChangeResistances(list(RED_DAMAGE = 0.5, WHITE_DAMAGE = 0.5, BLACK_DAMAGE = 0.5, PALE_DAMAGE = 0.5))
bird_angry = TRUE
update_icon()
@@ -114,7 +114,7 @@
environment_smash = initial(environment_smash)
stat_attack = initial(stat_attack)
adjustHealth(-maxHealth) // Full restoration
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 2, WHITE_DAMAGE = 2, BLACK_DAMAGE = 2, PALE_DAMAGE = 2)
+ ChangeResistances(list(RED_DAMAGE = 2, WHITE_DAMAGE = 2, BLACK_DAMAGE = 2, PALE_DAMAGE = 2))
bird_angry = FALSE
update_icon()
diff --git a/code/modules/mob/living/simple_animal/abnormality/waw/naked_nest.dm b/code/modules/mob/living/simple_animal/abnormality/waw/naked_nest.dm
index af378b728025..bd539c0be689 100644
--- a/code/modules/mob/living/simple_animal/abnormality/waw/naked_nest.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/waw/naked_nest.dm
@@ -295,30 +295,31 @@
var/mob/living/simple_animal/hostile/abnormality/naked_nest/N = new(get_turf(src))
for(var/atom/movable/AM in src) //morph code
AM.forceMove(N)
- N.damage_coeff = damage_coeff
+ N.ChangeResistances(damage_coeff)
playsound(get_turf(src), 'sound/misc/moist_impact.ogg', 30, 1)
qdel(src)
/mob/living/simple_animal/hostile/naked_nested/proc/UpdateArmor()
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.6, WHITE_DAMAGE = 0.8, BLACK_DAMAGE = 1.2, PALE_DAMAGE = 1.5)
+ var/list/damage_list = list(RED_DAMAGE = 0.6, WHITE_DAMAGE = 0.8, BLACK_DAMAGE = 1.2, PALE_DAMAGE = 1.5)
var/obj/item/clothing/suit/armor/host_armor = locate(/obj/item/clothing/suit/armor) in contents
if(host_armor)
if(host_armor.armor[RED_DAMAGE])
fortitude = 1 - (host_armor.armor[RED_DAMAGE] / 100) // 100 armor / 100 = 1
- if(fortitude <= damage_coeff[RED_DAMAGE] && fortitude > 0) //if armor is less than current red armor and is more than 0 since anything 0 or below is healing or immune to damage
- damage_coeff[RED_DAMAGE] = fortitude
+ if(fortitude <= damage_list[RED_DAMAGE] && fortitude > 0) //if armor is less than current red armor and is more than 0 since anything 0 or below is healing or immune to damage
+ damage_list[RED_DAMAGE] = fortitude
if(host_armor.armor[WHITE_DAMAGE])
prudence = 1 - (host_armor.armor[WHITE_DAMAGE] / 100)
- if(prudence <= damage_coeff[WHITE_DAMAGE] && prudence > 0)
- damage_coeff[WHITE_DAMAGE] = prudence
+ if(prudence <= damage_list[WHITE_DAMAGE] && prudence > 0)
+ damage_list[WHITE_DAMAGE] = prudence
if(host_armor.armor[BLACK_DAMAGE])
temperance = 1 - (host_armor.armor[BLACK_DAMAGE] / 100)
if(temperance > 0)
- damage_coeff[BLACK_DAMAGE] = temperance
+ damage_list[BLACK_DAMAGE] = temperance
if(host_armor.armor[PALE_DAMAGE])
justice = 1 - (host_armor.armor[PALE_DAMAGE] / 100)
if(justice > 0)
- damage_coeff[PALE_DAMAGE] = justice
+ damage_list[PALE_DAMAGE] = justice
+ ChangeResistances(damage_list)
return TRUE
/mob/living/simple_animal/hostile/naked_nested/hour_nesting //for dungeon gamemodes
diff --git a/code/modules/mob/living/simple_animal/abnormality/waw/wrath_servant.dm b/code/modules/mob/living/simple_animal/abnormality/waw/wrath_servant.dm
index 088d839e6fee..4f708bcb1ea5 100644
--- a/code/modules/mob/living/simple_animal/abnormality/waw/wrath_servant.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/waw/wrath_servant.dm
@@ -333,7 +333,7 @@
continue
if(faction_check(H.faction, list("neutral"), FALSE))
continue
- if(H.damage_coeff[RED_DAMAGE] <= 0) // Can't be hurt (Feasibly)
+ if(H.unmodified_damage_coeff_datum.getCoeff(RED_DAMAGE) <= 0) // Can't be hurt (Feasibly)
continue
if(H.health < highest_params[1])
continue
diff --git a/code/modules/mob/living/simple_animal/abnormality/waw/yang.dm b/code/modules/mob/living/simple_animal/abnormality/waw/yang.dm
index bfb4c8fb1319..3084e601f2c2 100644
--- a/code/modules/mob/living/simple_animal/abnormality/waw/yang.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/waw/yang.dm
@@ -144,14 +144,14 @@
icon_state = icon_dead
playsound(src, 'sound/effects/magic.ogg', 60)
SSlobotomy_events.yang_downed = TRUE
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0)
+ ChangeResistances(list(RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0))
for(var/i = 1 to 12)
SLEEP_CHECK_DEATH(5 SECONDS)
if(SSlobotomy_events.yin_downed)
death()
return
adjustBruteLoss(-maxHealth)
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 1, WHITE_DAMAGE = 0.2, BLACK_DAMAGE = 1.7, PALE_DAMAGE = 2)
+ ChangeResistances(list(RED_DAMAGE = 1, WHITE_DAMAGE = 0.2, BLACK_DAMAGE = 1.7, PALE_DAMAGE = 2))
SSlobotomy_events.yang_downed = FALSE
icon_state = icon_breach
diff --git a/code/modules/mob/living/simple_animal/abnormality/waw/yin.dm b/code/modules/mob/living/simple_animal/abnormality/waw/yin.dm
index dcb7ff38ef37..d341797ee7fa 100644
--- a/code/modules/mob/living/simple_animal/abnormality/waw/yin.dm
+++ b/code/modules/mob/living/simple_animal/abnormality/waw/yin.dm
@@ -134,14 +134,14 @@
icon_state = icon_dead
playsound(src, 'sound/effects/magic.ogg', 60)
SSlobotomy_events.yin_downed = TRUE
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0)
+ ChangeResistances(list(RED_DAMAGE = 0, WHITE_DAMAGE = 0, PALE_DAMAGE = 0))
for(var/i = 1 to 12)
SLEEP_CHECK_DEATH(5 SECONDS)
if(SSlobotomy_events.yang_downed)
death()
return
adjustBruteLoss(-maxHealth)
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.5, WHITE_DAMAGE = 1.5, BLACK_DAMAGE = 0, PALE_DAMAGE = 1)
+ ChangeResistances(list(RED_DAMAGE = 0.5, WHITE_DAMAGE = 1.5, PALE_DAMAGE = 1))
SSlobotomy_events.yin_downed = FALSE
icon_state = icon_breach
diff --git a/code/modules/mob/living/simple_animal/animal_defense.dm b/code/modules/mob/living/simple_animal/animal_defense.dm
index 46f0e30eaa5a..b1256d420b2c 100644
--- a/code/modules/mob/living/simple_animal/animal_defense.dm
+++ b/code/modules/mob/living/simple_animal/animal_defense.dm
@@ -127,10 +127,10 @@
/mob/living/simple_animal/proc/attack_threshold_check(damage, damagetype = BRUTE, actuallydamage = TRUE)
var/temp_damage = damage
- if(!damage_coeff[damagetype])
+ if(!damage_coeff.getList()[damagetype])
temp_damage = 0
else
- temp_damage *= damage_coeff[damagetype]
+ temp_damage *= damage_coeff.getList()[damagetype]
if(temp_damage >= 0 && temp_damage <= force_threshold)
visible_message("[src] looks unharmed!")
diff --git a/code/modules/mob/living/simple_animal/damage_coeff_helper.dm b/code/modules/mob/living/simple_animal/damage_coeff_helper.dm
new file mode 100644
index 000000000000..3607458b1a7b
--- /dev/null
+++ b/code/modules/mob/living/simple_animal/damage_coeff_helper.dm
@@ -0,0 +1,203 @@
+// This is a modifier to Simple Animal's damage coeff.
+// It's built to standarize the damage changes to abnos and other simple animals without causing them to desync during phase changes.
+/datum/dc_change
+ /// TRUE if it adds the potency value to damage_coeff, FALSE if it multiplies.
+ var/additive = FALSE
+ /// The amount the damage type is added or multiplied by.
+ var/potency = 0
+ /// Affected Damage Type
+ var/damage_type = RED_DAMAGE
+
+/**
+ * Adds a resistance modifier from an simple animal.
+ *
+ * vars:
+ * * DC - the path of the dc_change to be added OR a list of paths to add.
+ *
+ * returns:
+ * * FALSE if no value added, otherwise TRUE.
+ */
+/mob/living/simple_animal/proc/AddModifier(DC)
+ . = FALSE
+ if(islist(DC)) // If List
+ for(var/p in DC) // Check each item in the list
+ if(!ispath(p,/datum/dc_change)) // If it's not a path, skip it
+ continue
+ damage_mods.Add(new p) // Add a new one to the list
+ else if(!ispath(DC,/datum/dc_change)) // Otherwise, if it's not a path, return.
+ return
+ else
+ damage_mods.Add(new DC) // Otherwise, add a new one to the list.
+ UpdateResistances()
+ return TRUE
+
+/**
+ * Removes a resistance modifier from an simple animal.
+ *
+ * vars:
+ * * DC - the path of the dc_change to be removed.
+ *
+ * returns:
+ * * FALSE if no value removed, otherwise TRUE.
+ */
+/mob/living/simple_animal/proc/RemoveModifier(DC)
+ . = FALSE
+ if(islist(DC)) // If list
+ for(var/p in DC) // Check each item in the list
+ if(!ispath(p,/datum/dc_change))
+ continue
+ var/modifier = HasDamageMod(p) // Grab it if it exists
+ if(!modifier)
+ continue
+ damage_mods.Remove(modifier) // Then remove it
+ QDEL_NULL(modifier)
+ else if(!ispath(DC,/datum/dc_change)) // Otherwise, if it's not a path, return.
+ return
+ else // If it IS a path
+ var/modifier = HasDamageMod(DC) // Grab it
+ if(!modifier)
+ return
+ damage_mods.Remove(modifier) // And Remove it
+ QDEL_NULL(modifier)
+ UpdateResistances()
+ return TRUE
+
+/**
+ * Used to change a multiple resistances of an simple animal.
+ *
+ * vars:
+ * * resistances - An associative list of damage types to be changed. See: list(RED_DAMAGE = 100, WHITE_DAMAGE = 50)
+ */
+/mob/living/simple_animal/proc/ChangeResistances(list/resistances = list())
+ for(var/DT in resistances)
+ ChangeResistance(DT, resistances[DT], FALSE)
+ UpdateResistances()
+ return
+
+/**
+ * Used to change a single resistance of an simple animal.
+ *
+ * vars:
+ * * resistance - the damage type being altered.
+ * * value - the number it's being set to.
+ * * update (optional) - TRUE by default, if TRUE it will call UpdateResistances() after alteration.
+ *
+ * returns:
+ * * TRUE if value was successfully changed.
+ */
+/mob/living/simple_animal/proc/ChangeResistance(resistance, value, update = TRUE)
+ switch(resistance)
+ if(BRUTE)
+ unmodified_damage_coeff_datum = unmodified_damage_coeff_datum.setCoeff(brute = value)
+ if(BURN)
+ unmodified_damage_coeff_datum = unmodified_damage_coeff_datum.setCoeff(burn = value)
+ if(TOX)
+ unmodified_damage_coeff_datum = unmodified_damage_coeff_datum.setCoeff(tox = value)
+ if(CLONE)
+ unmodified_damage_coeff_datum = unmodified_damage_coeff_datum.setCoeff(clone = value)
+ if(STAMINA)
+ unmodified_damage_coeff_datum = unmodified_damage_coeff_datum.setCoeff(stamina = value)
+ if(OXY)
+ unmodified_damage_coeff_datum = unmodified_damage_coeff_datum.setCoeff(oxy = value)
+ if(RED_DAMAGE)
+ unmodified_damage_coeff_datum = unmodified_damage_coeff_datum.setCoeff(red = value)
+ if(WHITE_DAMAGE)
+ unmodified_damage_coeff_datum = unmodified_damage_coeff_datum.setCoeff(white = value)
+ if(BLACK_DAMAGE)
+ unmodified_damage_coeff_datum = unmodified_damage_coeff_datum.setCoeff(black = value)
+ if(PALE_DAMAGE)
+ unmodified_damage_coeff_datum = unmodified_damage_coeff_datum.setCoeff(pale = value)
+ else
+ return FALSE
+ if(update)
+ UpdateResistances()
+ return TRUE
+
+/**
+ * Updates all of a mob's resistances to be based on their base value with modifiers added.
+ */
+/mob/living/simple_animal/proc/UpdateResistances()
+ var/list/cached_resistances = unmodified_damage_coeff_datum.getList() // Reset resistances
+ for(var/datum/dc_change/D in damage_mods) // Check our multiplicative mods
+ if(D.additive)
+ continue
+ if(islist(D.damage_type))
+ for(var/dam_type in D.damage_type)
+ if(cached_resistances[dam_type] <= 0) // Immunity / Healing is not modified
+ continue
+ cached_resistances[dam_type] *= D.potency
+ else
+ if(cached_resistances[D.damage_type] <= 0) // Immunity / Healing is not modified
+ continue
+ cached_resistances[D.damage_type] *= D.potency
+ for(var/datum/dc_change/D in damage_mods) // Then include additive modifiers
+ if(!D.additive)
+ continue
+ if(islist(D.damage_type))
+ for(var/dam_type in D.damage_type)
+ if(damage_coeff[dam_type] <= 0) // Immunity / Healing is not modified
+ continue
+ cached_resistances[dam_type] += D.potency
+ else
+ if(damage_coeff[D.damage_type] <= 0) // Immunity / Healing is not modified
+ continue
+ cached_resistances[D.damage_type] += D.potency
+
+ for(var/I in cached_resistances)
+ cached_resistances[I] = round(cached_resistances[I], 0.1) // Minimizes damage_coeff datums created due to rampant decimals.
+
+ damage_coeff = damage_coeff.setCoeff(
+ cached_resistances[RED_DAMAGE],\
+ cached_resistances[WHITE_DAMAGE],\
+ cached_resistances[BLACK_DAMAGE],\
+ cached_resistances[PALE_DAMAGE],\
+ cached_resistances[BRUTE],\
+ cached_resistances[BURN],\
+ cached_resistances[TOX],\
+ cached_resistances[CLONE],\
+ cached_resistances[STAMINA],\
+ cached_resistances[OXY])
+
+/**
+ * Give it a dc_change modifier path and it will check aganist that. If it exists in the list, it will be returned.
+ *
+ * vars:
+ * * mod - A dc_change path
+ *
+ * returns:
+ * * The matching modifier, otherwise FALSE.
+ */
+/mob/living/simple_animal/proc/HasDamageMod(mod)
+ . = FALSE
+ if(LAZYLEN(damage_mods))
+ for(var/datum/dc_change/DC in damage_mods)
+ if(istype(DC, mod))
+ return DC
+
+
+/**
+ * Modify a group of resistances by a custom amount.
+ * Note: This is permanent unless the returned DCs are kept and removed semi-manually later.
+ * Using the other procs and making a custom dc_change datum is preferable to this, along with tying it to a status effect.
+ *
+ * vars:
+ * * target - a simple animal
+ * * changes - an associated list of damage types and values (RED_DAMAGE = 1.2, WHITE_DAMAGE = 0.8, ...)
+ * * additive - TRUE if the values should be added/subtracted to the damage_coeff or FALSE if used multiplicatively.
+ *
+ * returns: A list of DC_Changes if successful, otherwise FALSE.
+ */
+/proc/ModifyResistances(mob/living/simple_animal/target, list/changes = list(), additive = FALSE)
+ if(!target || !LAZYLEN(changes))
+ return FALSE
+ . = list()
+ for(var/DT in changes)
+ var/datum/dc_change/DC = new
+ DC.additive = additive
+ DC.potency = changes[DT]
+ DC.damage_type = DT
+ . += DC
+ target.damage_mods += .
+ target.UpdateResistances()
+ return
+
diff --git a/code/modules/mob/living/simple_animal/damage_procs.dm b/code/modules/mob/living/simple_animal/damage_procs.dm
index baf4dca53243..2e7003d36f74 100644
--- a/code/modules/mob/living/simple_animal/damage_procs.dm
+++ b/code/modules/mob/living/simple_animal/damage_procs.dm
@@ -22,60 +22,60 @@
/mob/living/simple_animal/adjustBruteLoss(amount, updating_health = TRUE, forced = FALSE)
if(forced)
. = adjustHealth(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
- else if(damage_coeff[BRUTE])
- . = adjustHealth(amount * damage_coeff[BRUTE] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else
+ . = adjustHealth(amount * damage_coeff.brute * CONFIG_GET(number/damage_multiplier), updating_health, forced)
/mob/living/simple_animal/adjustFireLoss(amount, updating_health = TRUE, forced = FALSE)
if(forced)
. = adjustHealth(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
- else if(damage_coeff[BURN])
- . = adjustHealth(amount * damage_coeff[BURN] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else
+ . = adjustHealth(amount * damage_coeff.burn * CONFIG_GET(number/damage_multiplier), updating_health, forced)
/mob/living/simple_animal/adjustOxyLoss(amount, updating_health = TRUE, forced = FALSE)
if(forced)
. = adjustHealth(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
- else if(damage_coeff[OXY])
- . = adjustHealth(amount * damage_coeff[OXY] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else
+ . = adjustHealth(amount * damage_coeff.oxy * CONFIG_GET(number/damage_multiplier), updating_health, forced)
/mob/living/simple_animal/adjustToxLoss(amount, updating_health = TRUE, forced = FALSE)
if(forced)
. = adjustHealth(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
- else if(damage_coeff[TOX])
- . = adjustHealth(amount * damage_coeff[TOX] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else
+ . = adjustHealth(amount * damage_coeff.tox * CONFIG_GET(number/damage_multiplier), updating_health, forced)
/mob/living/simple_animal/adjustCloneLoss(amount, updating_health = TRUE, forced = FALSE)
if(forced)
. = adjustHealth(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
- else if(damage_coeff[CLONE])
- . = adjustHealth(amount * damage_coeff[CLONE] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else
+ . = adjustHealth(amount * damage_coeff.clone * CONFIG_GET(number/damage_multiplier), updating_health, forced)
/mob/living/simple_animal/adjustStaminaLoss(amount, updating_health = FALSE, forced = FALSE)
if(forced)
staminaloss = max(0, min(max_staminaloss, staminaloss + amount))
else
- staminaloss = max(0, min(max_staminaloss, staminaloss + (amount * damage_coeff[STAMINA])))
+ staminaloss = max(0, min(max_staminaloss, staminaloss + (amount * damage_coeff.stamina)))
update_stamina()
/mob/living/simple_animal/adjustRedLoss(amount, updating_health = TRUE, forced = FALSE)
if(forced)
. = adjustHealth(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
- else if(damage_coeff[RED_DAMAGE])
- . = adjustHealth(amount * damage_coeff[RED_DAMAGE] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else
+ . = adjustHealth(amount * damage_coeff.red * CONFIG_GET(number/damage_multiplier), updating_health, forced)
/mob/living/simple_animal/adjustWhiteLoss(amount, updating_health = TRUE, forced = FALSE, white_healable = FALSE)
if(forced)
. = adjustHealth(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
- else if(damage_coeff[WHITE_DAMAGE])
- . = adjustHealth(amount * damage_coeff[WHITE_DAMAGE] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else
+ . = adjustHealth(amount * damage_coeff.white * CONFIG_GET(number/damage_multiplier), updating_health, forced)
/mob/living/simple_animal/adjustBlackLoss(amount, updating_health = TRUE, forced = FALSE, white_healable = FALSE)
if(forced)
. = adjustHealth(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
- else if(damage_coeff[BLACK_DAMAGE])
- . = adjustHealth(amount * damage_coeff[BLACK_DAMAGE] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else
+ . = adjustHealth(amount * damage_coeff.black * CONFIG_GET(number/damage_multiplier), updating_health, forced)
/mob/living/simple_animal/adjustPaleLoss(amount, updating_health = TRUE, forced = FALSE)
if(forced)
. = adjustHealth(amount * CONFIG_GET(number/damage_multiplier), updating_health, forced)
- else if(damage_coeff[PALE_DAMAGE])
- . = adjustHealth(amount * damage_coeff[PALE_DAMAGE] * CONFIG_GET(number/damage_multiplier), updating_health, forced)
+ else
+ . = adjustHealth(amount * damage_coeff.pale * CONFIG_GET(number/damage_multiplier), updating_health, forced)
diff --git a/code/modules/mob/living/simple_animal/dc_changes.dm b/code/modules/mob/living/simple_animal/dc_changes.dm
new file mode 100644
index 000000000000..932b28985174
--- /dev/null
+++ b/code/modules/mob/living/simple_animal/dc_changes.dm
@@ -0,0 +1,52 @@
+
+/// 0.8x, Maroon Soldier (used for steel???) damage_coeff changes
+/datum/dc_change/maroon_buff
+ potency = 0.8
+ damage_type = list(RED_DAMAGE, WHITE_DAMAGE, BLACK_DAMAGE, PALE_DAMAGE)
+
+/// 1.2x Rends, used for various EGO
+/datum/dc_change/rend
+ potency = 1.2
+
+/datum/dc_change/rend/red
+ damage_type = RED_DAMAGE
+
+/datum/dc_change/rend/white
+ damage_type = WHITE_DAMAGE
+
+/datum/dc_change/rend/black
+ damage_type = BLACK_DAMAGE
+
+/datum/dc_change/rend/pale // Unused atm
+ damage_type = PALE_DAMAGE
+
+/// 1.1x modifiers, used by Salvation
+/datum/dc_change/salvation
+ potency = 1.1
+ damage_type = list(RED_DAMAGE, WHITE_DAMAGE, BLACK_DAMAGE, PALE_DAMAGE)
+
+/// 1.5x Black modifier, used by Laughter
+/datum/dc_change/mosb_black
+ potency = 1.5
+ damage_type = BLACK_DAMAGE
+
+/// +0.5 Pale modifier, used by Head of God
+/datum/dc_change/godhead
+ additive = TRUE
+ potency = 0.5
+ damage_type = PALE_DAMAGE
+
+/// +0.1 Universal modifier, self-inflicted by Doomsday calender
+/datum/dc_change/sacrificed
+ additive = TRUE
+ potency = 0.1
+ damage_type = list(RED_DAMAGE, WHITE_DAMAGE, BLACK_DAMAGE, PALE_DAMAGE)
+
+/// Universal x2 modifer, inflicted by PT
+/datum/dc_change/lacerated
+ potency = 2
+ damage_type = list(RED_DAMAGE, WHITE_DAMAGE, BLACK_DAMAGE, PALE_DAMAGE)
+
+/// x1.05 - x2 Red Modifier, inflicted by Naked Nest Realization
+/datum/dc_change/infested
+ potency = 1.05
diff --git a/code/modules/mob/living/simple_animal/distortion/_distortion.dm b/code/modules/mob/living/simple_animal/distortion/_distortion.dm
index 4d6e280dbf58..6ca9ff6903f9 100644
--- a/code/modules/mob/living/simple_animal/distortion/_distortion.dm
+++ b/code/modules/mob/living/simple_animal/distortion/_distortion.dm
@@ -146,7 +146,7 @@
patrol_reset()
density = FALSE
AIStatus = AI_OFF
- damage_coeff = list(BRUTE = 0, RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0) // Prevent death jank
+ ChangeResistances(list(BRUTE = 0, RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0)) // Prevent death jank
forceMove(egoist) //Hide the distortion inside of the spawned human in case of shinanigains
if(unmanifest_effect)
new unmanifest_effect(get_turf(src))
diff --git a/code/modules/mob/living/simple_animal/distortion/plague/bunnyman.dm b/code/modules/mob/living/simple_animal/distortion/plague/bunnyman.dm
index ffee4f76c1b8..dd88675fe2c0 100644
--- a/code/modules/mob/living/simple_animal/distortion/plague/bunnyman.dm
+++ b/code/modules/mob/living/simple_animal/distortion/plague/bunnyman.dm
@@ -94,10 +94,7 @@
playsound(src, 'sound/effects/blobattack.ogg', 150, FALSE, 4)
playsound(src, 'sound/weapons/chainsawhit.ogg', 250, FALSE, 4)
attack_sound = 'sound/abnormalities/helper/attack.ogg'
- for(var/damtype in src.damage_coeff)
- if(damtype == BRUTE)
- continue
- damage_coeff[damtype] += 0.5
+ ChangeResistances(list(RED_DAMAGE = 0.7, WHITE_DAMAGE = 1.5, BLACK_DAMAGE = 1.5, PALE_DAMAGE = 2))
melee_damage_lower = 30
melee_damage_upper = 45
rapid_melee = 3
diff --git a/code/modules/mob/living/simple_animal/guardian/types/protector.dm b/code/modules/mob/living/simple_animal/guardian/types/protector.dm
index 22252c5ed523..c3b814913c7b 100644
--- a/code/modules/mob/living/simple_animal/guardian/types/protector.dm
+++ b/code/modules/mob/living/simple_animal/guardian/types/protector.dm
@@ -39,7 +39,7 @@
melee_damage_lower = initial(melee_damage_lower)
melee_damage_upper = initial(melee_damage_upper)
speed = initial(speed)
- damage_coeff = list(BRUTE = 0.4, BURN = 0.4, TOX = 0.4, CLONE = 0.4, STAMINA = 0, OXY = 0.4)
+ ChangeResistances(list(BRUTE = 0.4, BURN = 0.4, TOX = 0.4, CLONE = 0.4, STAMINA = 0, OXY = 0.4))
to_chat(src, "You switch to combat mode.")
toggle = FALSE
else
@@ -50,7 +50,7 @@
melee_damage_lower = 2
melee_damage_upper = 2
speed = 1
- damage_coeff = list(BRUTE = 0.05, BURN = 0.05, TOX = 0.05, CLONE = 0.05, STAMINA = 0, OXY = 0.05) //damage? what's damage?
+ ChangeResistances(list(BRUTE = 0.05, BURN = 0.05, TOX = 0.05, CLONE = 0.05, STAMINA = 0, OXY = 0.05)) //damage? what's damage?
to_chat(src, "You switch to protection mode.")
toggle = TRUE
diff --git a/code/modules/mob/living/simple_animal/guardian/types/support.dm b/code/modules/mob/living/simple_animal/guardian/types/support.dm
index c5256950040a..79873261de9c 100644
--- a/code/modules/mob/living/simple_animal/guardian/types/support.dm
+++ b/code/modules/mob/living/simple_animal/guardian/types/support.dm
@@ -48,7 +48,7 @@
if(toggle)
a_intent = INTENT_HARM
speed = 0
- damage_coeff = list(BRUTE = 0.7, BURN = 0.7, TOX = 0.7, CLONE = 0.7, STAMINA = 0, OXY = 0.7)
+ ChangeResistances(list(BRUTE = 0.7, BURN = 0.7, TOX = 0.7, CLONE = 0.7, STAMINA = 0, OXY = 0.7))
melee_damage_lower = 15
melee_damage_upper = 15
to_chat(src, "You switch to combat mode.")
@@ -56,7 +56,7 @@
else
a_intent = INTENT_HELP
speed = 1
- damage_coeff = list(BRUTE = 1, BURN = 1, TOX = 1, CLONE = 1, STAMINA = 0, OXY = 1)
+ ChangeResistances(list(BURN = 1, TOX = 1, CLONE = 1, STAMINA = 0, OXY = 1))
melee_damage_lower = 0
melee_damage_upper = 0
to_chat(src, "You switch to healing mode.")
diff --git a/code/modules/mob/living/simple_animal/hostile/ordeal/indigo.dm b/code/modules/mob/living/simple_animal/hostile/ordeal/indigo.dm
index 31bd33dd785f..2280fbd4ee5a 100644
--- a/code/modules/mob/living/simple_animal/hostile/ordeal/indigo.dm
+++ b/code/modules/mob/living/simple_animal/hostile/ordeal/indigo.dm
@@ -517,7 +517,7 @@
SLEEP_CHECK_DEATH(5)
maxHealth = 4000
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.4, WHITE_DAMAGE = 0.6, BLACK_DAMAGE = 0.25, PALE_DAMAGE = 0.8)
+ ChangeResistances(list(RED_DAMAGE = 0.4, WHITE_DAMAGE = 0.6, BLACK_DAMAGE = 0.25, PALE_DAMAGE = 0.8))
SpeedChange(phasespeedchange)
rapid_melee +=1
melee_damage_lower -= 10
@@ -535,7 +535,7 @@
SLEEP_CHECK_DEATH(5)
maxHealth = 3000
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.5, WHITE_DAMAGE = 0.8, BLACK_DAMAGE = 0.3, PALE_DAMAGE = 1)
+ ChangeResistances(list(RED_DAMAGE = 0.5, WHITE_DAMAGE = 0.8, BLACK_DAMAGE = 0.3, PALE_DAMAGE = 1))
SpeedChange(phasespeedchange)
rapid_melee += 2
melee_damage_lower -= 15
diff --git a/code/modules/mob/living/simple_animal/hostile/ordeal/steel.dm b/code/modules/mob/living/simple_animal/hostile/ordeal/steel.dm
index 5612e0c26121..be5fce1a068e 100644
--- a/code/modules/mob/living/simple_animal/hostile/ordeal/steel.dm
+++ b/code/modules/mob/living/simple_animal/hostile/ordeal/steel.dm
@@ -314,7 +314,7 @@
if(prob(20))
say(pick("Lads we got a hostile!", "Shit, wake up troops hell just found us!", "I warn you, we dont die easy.", "Keep your cool and we can all get out of this alive!"))
for(var/mob/living/simple_animal/hostile/ordeal/G in oview(9, src))
- if(istype(G, /mob/living/simple_animal/hostile/ordeal/steel_dawn) && G.stat != DEAD && !has_status_effect(/datum/status_effect/all_armor_buff || /datum/status_effect/minor_damage_buff))
+ if(istype(G, /mob/living/simple_animal/hostile/ordeal/steel_dawn) && G.stat != DEAD && (!has_status_effect(/datum/status_effect/all_armor_buff) || !has_status_effect(/datum/status_effect/minor_damage_buff)))
G.GiveTarget(target)
G.TemporarySpeedChange(-1, 1 SECONDS)
last_command = 1
diff --git a/code/modules/mob/living/simple_animal/hostile/ordeal/white.dm b/code/modules/mob/living/simple_animal/hostile/ordeal/white.dm
index 30dbd0181140..10f3c5d5bf8b 100644
--- a/code/modules/mob/living/simple_animal/hostile/ordeal/white.dm
+++ b/code/modules/mob/living/simple_animal/hostile/ordeal/white.dm
@@ -282,10 +282,10 @@
playsound(src, 'sound/effects/ordeals/white/white_reflect.ogg', 50, TRUE, 7)
visible_message("[pick("This subject is incompatible", \
diff --git a/code/modules/projectiles/projectile/ego_bullets/waw.dm b/code/modules/projectiles/projectile/ego_bullets/waw.dm
index 7c024486bb23..84092bf26491 100644
--- a/code/modules/projectiles/projectile/ego_bullets/waw.dm
+++ b/code/modules/projectiles/projectile/ego_bullets/waw.dm
@@ -237,9 +237,9 @@
. = ..()
if(isliving(target))
var/mob/living/simple_animal/M = target
- if(!ishuman(M) && !M.has_status_effect(/datum/status_effect/sunder_red))
+ if(!ishuman(M) && !M.has_status_effect(/datum/status_effect/rend_red))
new /obj/effect/temp_visual/cult/sparks(get_turf(M))
- M.apply_status_effect(/datum/status_effect/sunder_red)
+ M.apply_status_effect(/datum/status_effect/rend_red)
//feather of valor
/obj/projectile/ego_bullet/ego_warring
diff --git a/code/modules/spells/ability_types/realized.dm b/code/modules/spells/ability_types/realized.dm
index cc62808c1bba..e81a66ce4eda 100644
--- a/code/modules/spells/ability_types/realized.dm
+++ b/code/modules/spells/ability_types/realized.dm
@@ -92,28 +92,14 @@
if(!isanimal(owner))
return
var/mob/living/simple_animal/M = owner
- if(M.damage_coeff[RED_DAMAGE] > 0)
- M.damage_coeff[RED_DAMAGE] *= 1.1
- if(M.damage_coeff[WHITE_DAMAGE] > 0)
- M.damage_coeff[WHITE_DAMAGE] *= 1.1
- if(M.damage_coeff[BLACK_DAMAGE] > 0)
- M.damage_coeff[BLACK_DAMAGE] *= 1.1
- if(M.damage_coeff[PALE_DAMAGE] > 0)
- M.damage_coeff[PALE_DAMAGE] *= 1.1
+ M.AddModifier(/datum/dc_change/salvation)
/datum/status_effect/salvation/on_remove()
. = ..()
if(!isanimal(owner))
return
var/mob/living/simple_animal/M = owner
- if(M.damage_coeff[RED_DAMAGE] > 0)
- M.damage_coeff[RED_DAMAGE] /= 1.1
- if(M.damage_coeff[WHITE_DAMAGE] > 0)
- M.damage_coeff[WHITE_DAMAGE] /= 1.1
- if(M.damage_coeff[BLACK_DAMAGE] > 0)
- M.damage_coeff[BLACK_DAMAGE] /= 1.1
- if(M.damage_coeff[PALE_DAMAGE] > 0)
- M.damage_coeff[PALE_DAMAGE] /= 1.1
+ M.RemoveModifier(/datum/dc_change/salvation)
/atom/movable/screen/alert/status_effect/salvation
name = "Salvation"
@@ -194,10 +180,7 @@
H.physiology.black_mod *= 1.5
return
var/mob/living/simple_animal/M = owner
- if(M.damage_coeff[BLACK_DAMAGE] <= 0)
- qdel(src)
- return
- M.damage_coeff[BLACK_DAMAGE] *= 1.5
+ M.AddModifier(/datum/dc_change/mosb_black)
/datum/status_effect/mosb_black_debuff/on_remove()
. = ..()
@@ -206,7 +189,7 @@
H.physiology.black_mod /= 1.5
return
var/mob/living/simple_animal/M = owner
- M.damage_coeff[BLACK_DAMAGE] /= 1.5
+ M.RemoveModifier(/datum/dc_change/mosb_black)
/atom/movable/screen/alert/status_effect/mosb_black_debuff
name = "Dread"
@@ -257,10 +240,7 @@
H.physiology.pale_mod /= 1.5
return
var/mob/living/simple_animal/M = owner
- if(M.damage_coeff[PALE_DAMAGE] <= 0)
- qdel(src)
- return
- M.damage_coeff[PALE_DAMAGE] += 0.5
+ M.AddModifier(/datum/dc_change/godhead)
/datum/status_effect/judgement_pale_debuff/on_remove()
. = ..()
@@ -269,7 +249,7 @@
H.physiology.pale_mod *= 1.5
return
var/mob/living/simple_animal/M = owner
- M.damage_coeff[PALE_DAMAGE] -= 0.5
+ M.RemoveModifier(/datum/dc_change/godhead)
/atom/movable/screen/alert/status_effect/judgement_pale_debuff
name = "Soul Drain"
@@ -1187,22 +1167,21 @@
/datum/status_effect/stacking/infestation/on_apply()
. = ..()
var/mob/living/simple_animal/M = owner
- red = M.damage_coeff[RED_DAMAGE]
+ M.AddModifier(/datum/dc_change/infested)
/datum/status_effect/stacking/infestation/on_remove()
. = ..()
var/mob/living/simple_animal/M = owner
- M.damage_coeff[RED_DAMAGE] = red
+ M.RemoveModifier(/datum/dc_change/infested)
/datum/status_effect/stacking/infestation/add_stacks(stacks_added)
. = ..()
if(!isanimal(owner))
return
var/mob/living/simple_animal/M = owner
- if(M.damage_coeff[RED_DAMAGE] <= 0)
- qdel(src)
- return
- M.damage_coeff[RED_DAMAGE] = red * (1+(stacks/20))
+ var/datum/dc_change/infested/mod = M.HasDamageMod(/datum/dc_change/infested)
+ mod.potency = 1+(stacks/20)
+ M.UpdateResistances()
linked_alert.desc = initial(linked_alert.desc)+"[stacks*5]%!"
/mob/living/simple_animal/hostile/naked_nest_serpent_friend
diff --git a/code/modules/suppressions/extraction.dm b/code/modules/suppressions/extraction.dm
index 8bc55c488297..10501a00c7d5 100644
--- a/code/modules/suppressions/extraction.dm
+++ b/code/modules/suppressions/extraction.dm
@@ -31,7 +31,7 @@
desc = "The elite agent of the head; Despite being a mere imitation, it is nonetheless an intimidating foe."
health = 10000
maxHealth = 10000
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.1, WHITE_DAMAGE = 0.1, BLACK_DAMAGE = 0.1, PALE_DAMAGE = 0.1)
+ damage_coeff = list(RED_DAMAGE = 0.1, WHITE_DAMAGE = 0.1, BLACK_DAMAGE = 0.1, PALE_DAMAGE = 0.1)
icon_state = "arbiter"
icon_living = "arbiter"
icon_dead = "arbiter"
@@ -159,7 +159,7 @@
return FALSE // Death
life_stage += 1
adjustHealth(-maxHealth)
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.1, WHITE_DAMAGE = 0.1, BLACK_DAMAGE = 0.1, PALE_DAMAGE = 0.1)
+ ChangeResistances(list(RED_DAMAGE = 0.1, WHITE_DAMAGE = 0.1, BLACK_DAMAGE = 0.1, PALE_DAMAGE = 0.1))
fairy_cooldown_time = max(4 SECONDS, fairy_cooldown_time - 2 SECONDS)
key_cooldown_time = max(10 SECONDS, fairy_cooldown_time - 4 SECONDS)
playsound(get_turf(src), 'sound/magic/arbiter/repulse.ogg', 50, TRUE, 24)
@@ -169,7 +169,7 @@
if(2)
possible_meltdown_types |= MELTDOWN_PURPLE
if(3)
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0)
+ ChangeResistances(list(RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0))
return TRUE
/* Combat */
@@ -291,7 +291,7 @@
return
charging = TRUE
icon_state = "arbiter_ability"
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.1, WHITE_DAMAGE = 0.1, BLACK_DAMAGE = 0.1, PALE_DAMAGE = 0.1)
+ ChangeResistances(list(RED_DAMAGE = 0.1, WHITE_DAMAGE = 0.1, BLACK_DAMAGE = 0.1, PALE_DAMAGE = 0.1))
SLEEP_CHECK_DEATH(1 SECONDS)
playsound(get_turf(src), 'sound/magic/arbiter/repulse.ogg', 50, TRUE, 7)
@@ -372,7 +372,7 @@
switch(current_meltdown_type)
if(MELTDOWN_GRAY)
INVOKE_ASYNC(GLOBAL_PROC, .proc/show_global_blurb, 5 SECONDS, "I am fading.", 1 SECONDS, "black", "yellow", "left", "CENTER,BOTTOM+2")
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 2, WHITE_DAMAGE = 2, BLACK_DAMAGE = 2, PALE_DAMAGE = 2)
+ ChangeResistances(list(RED_DAMAGE = 2, WHITE_DAMAGE = 2, BLACK_DAMAGE = 2, PALE_DAMAGE = 2))
SLEEP_CHECK_DEATH(10 SECONDS)
if(MELTDOWN_GOLD)
INVOKE_ASYNC(GLOBAL_PROC, .proc/show_global_blurb, 5 SECONDS, "The sandman calls me.", 1 SECONDS, "black", "yellow", "left", "CENTER,BOTTOM+2")
@@ -383,7 +383,7 @@
SLEEP_CHECK_DEATH(1 SECONDS)
check_count += 1
charging = TRUE
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.8, WHITE_DAMAGE = 0.8, BLACK_DAMAGE = 0.8, PALE_DAMAGE = 0.8)
+ ChangeResistances(list(RED_DAMAGE = 0.8, WHITE_DAMAGE = 0.8, BLACK_DAMAGE = 0.8, PALE_DAMAGE = 0.8))
SLEEP_CHECK_DEATH(10 SECONDS)
charging = FALSE
if(MELTDOWN_PURPLE)
@@ -393,13 +393,13 @@
INVOKE_ASYNC(src, .proc/StopPillarStorm)
if(last_stage == life_stage)
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.8, WHITE_DAMAGE = 0.8, BLACK_DAMAGE = 0.8, PALE_DAMAGE = 0.8)
+ ChangeResistances(list(RED_DAMAGE = 0.8, WHITE_DAMAGE = 0.8, BLACK_DAMAGE = 0.8, PALE_DAMAGE = 0.8))
// Pillar Storm
/mob/living/simple_animal/hostile/megafauna/arbiter/proc/StartPillarStorm()
charging = TRUE
icon_state = "arbiter_ability"
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0)
+ ChangeResistances(list(RED_DAMAGE = 0, WHITE_DAMAGE = 0, BLACK_DAMAGE = 0, PALE_DAMAGE = 0))
SLEEP_CHECK_DEATH(2 SECONDS)
@@ -459,7 +459,7 @@
pillar_storm_cooldown = world.time + pillar_storm_cooldown_time
charging = FALSE
icon_state = icon_living
- damage_coeff = list(BRUTE = 1, RED_DAMAGE = 0.1, WHITE_DAMAGE = 0.1, BLACK_DAMAGE = 0.1, PALE_DAMAGE = 0.1)
+ ChangeResistances(list(RED_DAMAGE = 0.1, WHITE_DAMAGE = 0.1, BLACK_DAMAGE = 0.1, PALE_DAMAGE = 0.1))
// Arbiter either died(somehow) or meltdown of pillars was cleared
/mob/living/simple_animal/hostile/megafauna/arbiter/proc/StopPillarStorm()
diff --git a/lobotomy-corp13.dme b/lobotomy-corp13.dme
index 7e04b06521d1..15a3a8990818 100644
--- a/lobotomy-corp13.dme
+++ b/lobotomy-corp13.dme
@@ -2668,10 +2668,13 @@
#include "code\modules\mob\living\silicon\robot\robot_modules.dm"
#include "code\modules\mob\living\silicon\robot\robot_movement.dm"
#include "code\modules\mob\living\silicon\robot\robot_say.dm"
+#include "code\modules\mob\living\simple_animal\_damage_coeff.dm"
#include "code\modules\mob\living\simple_animal\animal_defense.dm"
#include "code\modules\mob\living\simple_animal\constructs.dm"
#include "code\modules\mob\living\simple_animal\corpse.dm"
+#include "code\modules\mob\living\simple_animal\damage_coeff_helper.dm"
#include "code\modules\mob\living\simple_animal\damage_procs.dm"
+#include "code\modules\mob\living\simple_animal\dc_changes.dm"
#include "code\modules\mob\living\simple_animal\eldritch_demons.dm"
#include "code\modules\mob\living\simple_animal\parrot.dm"
#include "code\modules\mob\living\simple_animal\shade.dm"