From e8c0a64ffdaffba88e12c41baa0c1865fda83c66 Mon Sep 17 00:00:00 2001 From: TheNightingale <137739943+TheNightingale@users.noreply.github.com> Date: Tue, 31 Oct 2023 17:28:14 +0300 Subject: [PATCH] [MIRROR] More Reliable Shrapnel Removal --- code/modules/surgery/implant.dm | 41 +++++++++++---------------------- 1 file changed, 13 insertions(+), 28 deletions(-) diff --git a/code/modules/surgery/implant.dm b/code/modules/surgery/implant.dm index 997f6d13ec590..ea1a1a38ae00b 100644 --- a/code/modules/surgery/implant.dm +++ b/code/modules/surgery/implant.dm @@ -150,8 +150,8 @@ /obj/item/wirecutters = 75, /obj/item/material/kitchen/utensil/fork = 20 ) - min_duration = 80 - max_duration = 100 + min_duration = 120 + max_duration = 150 /singleton/surgery_step/cavity/implant_removal/assess_bodypart(mob/living/user, mob/living/carbon/human/target, target_zone, obj/item/tool) var/obj/item/organ/external/affected = ..() @@ -177,7 +177,6 @@ if(BP_IS_ROBOTIC(affected) && affected.hatch_state == HATCH_OPENED) exposed = 1 - var/find_prob = 0 var/list/loot = list() if(exposed) loot = affected.implants @@ -185,41 +184,27 @@ for(var/datum/wound/wound in affected.wounds) if(LAZYLEN(wound.embedded_objects)) loot |= wound.embedded_objects - find_prob += 50 if (length(loot)) var/obj/item/obj = pick(loot) - if(istype(obj,/obj/item/implant)) - var/obj/item/implant/imp = obj - if (imp.islegal()) - find_prob +=60 - else - find_prob +=40 - else - find_prob +=50 - - if (prob(find_prob)) - user.visible_message(SPAN_NOTICE("[user] takes something out of incision on [target]'s [affected.name] with \the [tool]."), \ - SPAN_NOTICE("You take \the [obj] out of incision on \the [target]'s [affected.name] with \the [tool].") ) - target.remove_implant(obj, TRUE, affected) + user.visible_message(SPAN_NOTICE("[user] takes something out of incision on [target]'s [affected.name] with \the [tool]."), \ + SPAN_NOTICE("You take \the [obj] out of incision on \the [target]'s [affected.name] with \the [tool].") ) + target.remove_implant(obj, TRUE, affected) - SET_BIT(target.hud_updateflag, IMPLOYAL_HUD) + SET_BIT(target.hud_updateflag, IMPLOYAL_HUD) - //Handle possessive brain borers. - if(istype(obj,/mob/living/simple_animal/borer)) - var/mob/living/simple_animal/borer/worm = obj - if(worm.controlling) - target.release_control() - worm.detatch() - worm.leave_host() + //Handle possessive brain borers. + if(istype(obj,/mob/living/simple_animal/borer)) + var/mob/living/simple_animal/borer/worm = obj + if(worm.controlling) + target.release_control() + worm.detatch() + worm.leave_host() playsound(target.loc, 'sound/effects/squelch1.ogg', 15, 1) - else - user.visible_message(SPAN_NOTICE("[user] removes \the [tool] from [target]'s [affected.name]."), \ - SPAN_NOTICE("There's something inside [target]'s [affected.name], but you just missed it this time.") ) else user.visible_message(SPAN_NOTICE("[user] could not find anything inside [target]'s [affected.name], and pulls \the [tool] out."), \ SPAN_NOTICE("You could not find anything inside [target]'s [affected.name].") )