From 3bd8e5831ee0038f3bd6f19549f775977b421b97 Mon Sep 17 00:00:00 2001 From: EgorDinamit Date: Sun, 3 Mar 2024 12:24:48 +0300 Subject: [PATCH 1/2] Limb tweaks --- code/__defines/damage_organs.dm | 4 +-- .../mob/living/carbon/human/human_organs.dm | 18 ++++++------- code/modules/organs/external/_external.dm | 25 ++++++++++++------- code/modules/organs/robolimbs.dm | 1 + 4 files changed, 28 insertions(+), 20 deletions(-) diff --git a/code/__defines/damage_organs.dm b/code/__defines/damage_organs.dm index ba00c8467e7..a37287596fe 100644 --- a/code/__defines/damage_organs.dm +++ b/code/__defines/damage_organs.dm @@ -84,8 +84,8 @@ // that dealing just enough burn damage to kill the player will cause the given // proportion of their max blood volume to be lost // (e.g. 0.6 == 60% lost if 200 burn damage is taken). -#define FLUIDLOSS_WIDE_BURN 0.6 //for burns from heat applied over a wider area, like from fire -#define FLUIDLOSS_CONC_BURN 0.4 //for concentrated burns, like from lasers +#define FLUIDLOSS_WIDE_BURN 0.2 //for burns from heat applied over a wider area, like from fire +#define FLUIDLOSS_CONC_BURN 0.1 //for concentrated burns, like from lasers // Damage above this value must be repaired with surgery. #define ROBOLIMB_SELF_REPAIR_CAP 30 diff --git a/code/modules/mob/living/carbon/human/human_organs.dm b/code/modules/mob/living/carbon/human/human_organs.dm index 0bb90f7052d..73828985bc8 100644 --- a/code/modules/mob/living/carbon/human/human_organs.dm +++ b/code/modules/mob/living/carbon/human/human_organs.dm @@ -106,7 +106,8 @@ else if (E.is_dislocated()) stance_damage += 0.5 - if(E) limb_pain = E.can_feel_pain() + if(E) + limb_pain = E.can_feel_pain() // Canes and crutches help you stand (if the latter is ever added) // One cane mitigates a broken leg+foot, or a missing foot. @@ -195,9 +196,9 @@ to_chat(src, SPAN_WARNING("You lose your balance as [affected.name] [pick("malfunctions", "freezes","shudders")]!")) else return - Weaken(4) + Weaken(1) -/mob/living/carbon/human/proc/grasp_damage_disarm(var/obj/item/organ/external/affected) +/mob/living/carbon/human/proc/grasp_damage_disarm(obj/item/organ/external/affected) var/disarm_slot switch(affected.body_part) if(HAND_LEFT, ARM_LEFT) @@ -217,14 +218,13 @@ return if(BP_IS_ROBOTIC(affected)) - visible_message("\The [src] drops what they were holding, \his [affected.name] malfunctioning!") + visible_message(SPAN_WARNING("\The [src] drops what they were holding, \his [affected.name] malfunctioning!")) var/datum/effect/effect/system/spark_spread/spark_system = new /datum/effect/effect/system/spark_spread() spark_system.set_up(5, 0, src) spark_system.attach(src) spark_system.start() - spawn(10) - qdel(spark_system) + QDEL_IN(spark_system, 10) else var/grasp_name = affected.name @@ -236,13 +236,13 @@ var/emote_scream = pick("screams in pain", "lets out a sharp cry", "cries out") var/emote_scream_alt = pick("scream in pain", "let out a sharp cry", "cry out") visible_message( - "\The [src] [emote_scream] and drops what they were holding in their [grasp_name]!", + SPAN_WARNING("\The [src] [emote_scream] and drops what they were holding in their [grasp_name]!"), null, - "You hear someone [emote_scream_alt]!" + SPAN_WARNING("You hear someone [emote_scream_alt]!"), ) custom_pain("The sharp pain in your [affected.name] forces you to drop [thing]!", 30) else - visible_message("\The [src] drops what they were holding in their [grasp_name]!") + visible_message(SPAN_WARNING("\The [src] drops what they were holding in their [grasp_name]!")) /mob/living/carbon/human/proc/sync_organ_dna() var/list/all_bits = internal_organs|organs diff --git a/code/modules/organs/external/_external.dm b/code/modules/organs/external/_external.dm index a178f7bff8e..8762f96a9a0 100644 --- a/code/modules/organs/external/_external.dm +++ b/code/modules/organs/external/_external.dm @@ -83,6 +83,8 @@ r/**************************************************** var/sever_artery_threshold /// Minimum amount of damage required to have a chance to sever tendons upon receiving new wound var/sever_tendon_threshold + /// Minimum amount of damage required for robotic limb to be considered malfunctioning (causes dropping items and such) + var/malfunction_threshold = 20 /obj/item/organ/external/proc/get_fingerprint() @@ -494,8 +496,10 @@ This function completely restores a damaged organ to perfect condition. if((type in list(BURN, LASER)) && (damage > 5 || damage + burn_dam >= 15) && !BP_IS_ROBOTIC(src)) var/fluid_loss_severity switch(type) - if(BURN) fluid_loss_severity = FLUIDLOSS_WIDE_BURN - if(LASER) fluid_loss_severity = FLUIDLOSS_CONC_BURN + if(BURN) + fluid_loss_severity = FLUIDLOSS_WIDE_BURN + if(LASER) + fluid_loss_severity = FLUIDLOSS_CONC_BURN var/fluid_loss = (damage/(owner.maxHealth - config.health_threshold_dead)) * SPECIES_BLOOD_DEFAULT * fluid_loss_severity owner.remove_blood(fluid_loss) @@ -1118,13 +1122,11 @@ obj/item/organ/external/proc/remove_clamps() return 0 /obj/item/organ/external/robotize(company, skip_prosthetics = 0, keep_organs = 0) - if(BP_IS_ROBOTIC(src)) return ..() - if(company) var/datum/robolimb/R = all_robolimbs[company] if(!istype(R) || (species && (species.name in R.species_cannot_use)) || \ @@ -1132,11 +1134,9 @@ obj/item/organ/external/proc/remove_clamps() (R.applies_to_part.len && !(organ_tag in R.applies_to_part))) R = basic_robolimb else - model = company - force_icon = R.icon - name = "robotic [initial(name)]" - desc = "[R.desc] It looks like it was produced by [R.company]." + ApplyModel(R) + name = "robotic [initial(name)]" dislocated = -1 remove_splint() update_icon(1) @@ -1168,6 +1168,13 @@ obj/item/organ/external/proc/remove_clamps() return 1 +/obj/item/organ/external/proc/ApplyModel(datum/robolimb/R) + model = R.company + force_icon = R.icon + desc = "[R.desc] It looks like it was produced by [R.company]." + malfunction_threshold = R.limb_malfunction_threshold + return TRUE + /obj/item/organ/external/proc/get_damage() //returns total damage return (brute_dam+burn_dam) //could use max_damage? @@ -1181,7 +1188,7 @@ obj/item/organ/external/proc/remove_clamps() return ..() && !is_stump() && !(status & ORGAN_TENDON_CUT) && (!can_feel_pain() || get_pain() < pain_disability_threshold) && brute_ratio < 1 && burn_ratio < 1 /obj/item/organ/external/proc/is_malfunctioning() - return (BP_IS_ROBOTIC(src) && (brute_dam + burn_dam) >= 10 && prob(brute_dam + burn_dam)) + return (BP_IS_ROBOTIC(src) && (brute_dam + burn_dam) >= malfunction_threshold && prob((brute_dam + burn_dam) - malfunction_threshold)) /obj/item/organ/external/proc/embed(var/obj/item/W, var/silent = 0, var/supplied_message, var/datum/wound/supplied_wound) if(!owner || loc != owner) diff --git a/code/modules/organs/robolimbs.dm b/code/modules/organs/robolimbs.dm index 05c4844e472..84dc30a07cc 100644 --- a/code/modules/organs/robolimbs.dm +++ b/code/modules/organs/robolimbs.dm @@ -25,6 +25,7 @@ var/datum/robolimb/basic_robolimb var/list/restricted_to = list() var/list/applies_to_part = list() //TODO. var/list/allowed_bodytypes = list(SPECIES_HUMAN, SPECIES_IPC, SPECIES_SKRELL, SPECIES_UNATHI) + var/limb_malfunction_threshold = 20 /datum/robolimb/bishop company = "Bishop" From 3bc6fb462cbd30b818fd8c11bb8ac0b9804fde47 Mon Sep 17 00:00:00 2001 From: EgorDinamit Date: Sun, 3 Mar 2024 12:36:11 +0300 Subject: [PATCH 2/2] Stupid check paths --- test/check-paths.sh | 1 - 1 file changed, 1 deletion(-) diff --git a/test/check-paths.sh b/test/check-paths.sh index 711e430807c..feb92c1035e 100755 --- a/test/check-paths.sh +++ b/test/check-paths.sh @@ -38,7 +38,6 @@ exactly 144 "<< uses" '(?