Skip to content

Commit

Permalink
[MIRROR] Fixes surgeries runtiming constantly when having the surgery…
Browse files Browse the repository at this point in the history
… initator open, fixes some surgeries missing sounds (#840)

* Fixes surgeries runtiming constantly when having the surgery initator open, fixes some surgeries missing sounds (#81307)

Fixes #79318

- See the issue for more information. I fixed the runtimes as expected,
and then removed `SURGERY_REQUIRE_LIMB` from some surgeries which don't
actually require a limb, such as implant removal, dissection, and living
revival. I could've easily missed some, and as a result some surgeries
are lost to the void and unselectable, but from what I could tell in
testing it seems... fine.

- Adds `SHOULD_CALL_PARENT` to surgery `can_start`. Cleans up some
surgery `can_start` overrides.

- Adds missing sounds to puncture repair surgery.

:cl: Melbert
fix: Fixed Puncture Repair surgery not having surgical sounds
fix: Fixed Surgery Initiator potentially showing invalid surgeries
/:cl:

* Fixes surgeries runtiming constantly when having the surgery initator open, fixes some surgeries missing sounds

* Update robot_brain_surgery.dm

---------

Co-authored-by: MrMelbert <[email protected]>
Co-authored-by: SomeRandomOwl <[email protected]>
  • Loading branch information
3 people authored and FFMirrorBot committed Feb 8, 2024
1 parent 107a5d8 commit fcdd127
Show file tree
Hide file tree
Showing 22 changed files with 179 additions and 102 deletions.
49 changes: 22 additions & 27 deletions code/datums/components/surgery_initiator.dm
Original file line number Diff line number Diff line change
Expand Up @@ -81,32 +81,31 @@
/datum/component/surgery_initiator/proc/get_available_surgeries(mob/user, mob/living/target)
var/list/available_surgeries = list()

var/mob/living/carbon/carbon_target
var/obj/item/bodypart/affecting
if (iscarbon(target))
carbon_target = target
affecting = carbon_target.get_bodypart(check_zone(user.zone_selected))
var/obj/item/bodypart/affecting = target.get_bodypart(check_zone(user.zone_selected))

for(var/datum/surgery/surgery as anything in GLOB.surgeries_list)
if(!surgery.possible_locs.Find(user.zone_selected))
continue
if(affecting)
if(!(surgery.surgery_flags & SURGERY_REQUIRE_LIMB))
if(!is_type_in_list(target, surgery.target_mobtypes))
continue

if(isnull(affecting))
if(surgery.surgery_flags & SURGERY_REQUIRE_LIMB)
continue
else
if(surgery.requires_bodypart_type && !(affecting.bodytype & surgery.requires_bodypart_type))
continue
if(surgery.targetable_wound && !affecting.get_wound_type(surgery.targetable_wound))
continue
if((surgery.surgery_flags & SURGERY_REQUIRES_REAL_LIMB) && (affecting.bodypart_flags & BODYPART_PSEUDOPART))
continue
else if(carbon_target && (surgery.surgery_flags & SURGERY_REQUIRE_LIMB)) //mob with no limb in surgery zone when we need a limb
continue

if(IS_IN_INVALID_SURGICAL_POSITION(target, surgery))
continue
if(!surgery.can_start(user, target))
continue
for(var/path in surgery.target_mobtypes)
if(istype(target, path))
available_surgeries += surgery
break

available_surgeries += surgery

return available_surgeries

Expand Down Expand Up @@ -295,24 +294,20 @@
target.balloon_alert(user, "can't start the surgery!")
return

var/obj/item/bodypart/affecting_limb

var/selected_zone = user.zone_selected
var/obj/item/bodypart/affecting_limb = target.get_bodypart(check_zone(selected_zone))

if (iscarbon(target))
var/mob/living/carbon/carbon_target = target
affecting_limb = carbon_target.get_bodypart(check_zone(selected_zone))

if ((surgery.surgery_flags & SURGERY_REQUIRE_LIMB) == isnull(affecting_limb))
if (surgery.surgery_flags & SURGERY_REQUIRE_LIMB)
target.balloon_alert(user, "patient has no [parse_zone(selected_zone)]!")
else
target.balloon_alert(user, "patient has \a [parse_zone(selected_zone)]!")
if ((surgery.surgery_flags & SURGERY_REQUIRE_LIMB) && isnull(affecting_limb))
target.balloon_alert(user, "patient has no [parse_zone(selected_zone)]!")
return

if (!isnull(affecting_limb) && surgery.requires_bodypart_type && !(affecting_limb.bodytype & surgery.requires_bodypart_type))
target.balloon_alert(user, "not the right type of limb!")
return
if (!isnull(affecting_limb))
if(surgery.requires_bodypart_type && !(affecting_limb.bodytype & surgery.requires_bodypart_type))
target.balloon_alert(user, "not the right type of limb!")
return
if(surgery.targetable_wound && !affecting_limb.get_wound_type(surgery.targetable_wound))
target.balloon_alert(user, "no wound to operate on!")
return

// NOVA EDIT START - Limbs that can't be surgically removed
if (surgery.removes_target_bodypart && !isnull(affecting_limb) && !affecting_limb.can_be_surgically_removed)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,12 @@
/datum/surgery/organ_extraction/can_start(mob/user, mob/living/carbon/target)
if(!ishuman(user))
return FALSE
var/mob/living/carbon/human/H = user
if(H.dna.species.id == SPECIES_ABDUCTOR)
if(!..())
return FALSE
if(isabductor(user))
return TRUE
for(var/obj/item/implant/abductor/A in H.implants)
var/mob/living/non_abductor = user
if(locate(/obj/item/implant/abductor) in non_abductor.implants)
return TRUE
return FALSE

Expand Down
3 changes: 2 additions & 1 deletion code/modules/surgery/autopsy.dm
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,8 @@
)

/datum/surgery/autopsy/can_start(mob/user, mob/living/patient)
. = ..()
if(!..())
return FALSE
if(patient.stat != DEAD)
return FALSE
if(HAS_TRAIT_FROM(patient, TRAIT_DISSECTED, AUTOPSY_TRAIT))
Expand Down
92 changes: 79 additions & 13 deletions code/modules/surgery/bone_mending.dm
Original file line number Diff line number Diff line change
Expand Up @@ -20,13 +20,6 @@
/datum/surgery_step/close,
)

/datum/surgery/repair_bone_hairline/can_start(mob/living/user, mob/living/carbon/target)
. = ..()
if(.)
var/obj/item/bodypart/targeted_bodypart = target.get_bodypart(user.zone_selected)
return(targeted_bodypart.get_wound_type(targetable_wound))


///// Repair Compound Fracture (Critical)
/datum/surgery/repair_bone_compound
name = "Repair Compound Fracture"
Expand All @@ -49,12 +42,6 @@
/datum/surgery_step/close,
)

/datum/surgery/repair_bone_compound/can_start(mob/living/user, mob/living/carbon/target)
. = ..()
if(.)
var/obj/item/bodypart/targeted_bodypart = target.get_bodypart(user.zone_selected)
return(targeted_bodypart.get_wound_type(targetable_wound))

//SURGERY STEPS

///// Repair Hairline Fracture (Severe)
Expand Down Expand Up @@ -200,3 +187,82 @@
if(isstack(tool))
var/obj/item/stack/used_stack = tool
used_stack.use(1)
<<<<<<< HEAD

Check failure on line 190 in code/modules/surgery/bone_mending.dm

View workflow job for this annotation

GitHub Actions / Run Linters

got '<<', expected one of: newline, '/', identifier
=======

/// Surgery to repair cranial fissures
/datum/surgery/cranial_reconstruction
name = "Cranial reconstruction"
surgery_flags = SURGERY_REQUIRE_RESTING | SURGERY_REQUIRE_LIMB | SURGERY_REQUIRES_REAL_LIMB
targetable_wound = /datum/wound/cranial_fissure
possible_locs = list(
BODY_ZONE_HEAD,
)
steps = list(
/datum/surgery_step/clamp_bleeders/discard_skull_debris,
/datum/surgery_step/repair_skull
)

/datum/surgery_step/clamp_bleeders/discard_skull_debris
name = "discard skull debris (hemostat)"
implements = list(
TOOL_HEMOSTAT = 100,
TOOL_WIRECUTTER = 40,
TOOL_SCREWDRIVER = 40,
)
time = 2.4 SECONDS
preop_sound = 'sound/surgery/hemostat1.ogg'

/datum/surgery_step/clamp_bleeders/discard_skull_debris/preop(mob/user, mob/living/carbon/target, target_zone, obj/item/tool, datum/surgery/surgery)
display_results(
user,
target,
span_notice("You begin to discard the smaller skull debris in [target]'s [parse_zone(target_zone)]..."),
span_notice("[user] begins to discard the smaller skull debris in [target]'s [parse_zone(target_zone)]..."),
span_notice("[user] begins to poke around in [target]'s [parse_zone(target_zone)]..."),
)

display_pain(target, "Your brain feels like it's getting stabbed by little shards of glass!")

/datum/surgery_step/repair_skull
name = "repair skull (bone gel/tape)"
implements = IMPLEMENTS_THAT_FIX_BONES
time = 4 SECONDS

/datum/surgery_step/repair_skull/preop(mob/user, mob/living/target, target_zone, obj/item/tool, datum/surgery/surgery)
ASSERT(surgery.operated_wound, "Repairing skull without a wound")

display_results(
user,
target,
span_notice("You begin to repair [target]'s skull as best you can..."),
span_notice("[user] begins to repair [target]'s skull with [tool]."),
span_notice("[user] begins to repair [target]'s skull."),
)

display_pain(target, "You can feel pieces of your skull rubbing against your brain!")

/datum/surgery_step/repair_skull/success(mob/user, mob/living/target, target_zone, obj/item/tool, datum/surgery/surgery, default_display_results)
if (isnull(surgery.operated_wound))
to_chat(user, span_warning("[target]'s skull is fine!"))
return ..()


if (isstack(tool))
var/obj/item/stack/used_stack = tool
used_stack.use(1)

display_results(
user,
target,
span_notice("You successfully repair [target]'s skull."),
span_notice("[user] successfully repairs [target]'s skull with [tool]."),
span_notice("[user] successfully repairs [target]'s skull.")
)

qdel(surgery.operated_wound)

return ..()

#undef IMPLEMENTS_THAT_FIX_BONES
>>>>>>> 642fe07a5 ([MIRROR] Fixes surgeries runtiming constantly when having the surgery initator open, fixes some surgeries missing sounds (#840))
5 changes: 1 addition & 4 deletions code/modules/surgery/brain_surgery.dm
Original file line number Diff line number Diff line change
Expand Up @@ -24,10 +24,7 @@
failure_sound = 'sound/surgery/organ2.ogg'

/datum/surgery/brain_surgery/can_start(mob/user, mob/living/carbon/target)
var/obj/item/organ/internal/brain/target_brain = target.get_organ_slot(ORGAN_SLOT_BRAIN)
if(!target_brain)
return FALSE
return TRUE
return target.get_organ_slot(ORGAN_SLOT_BRAIN) && ..()

/datum/surgery_step/fix_brain/preop(mob/user, mob/living/carbon/target, target_zone, obj/item/tool, datum/surgery/surgery)
display_results(
Expand Down
14 changes: 8 additions & 6 deletions code/modules/surgery/burn_dressing.dm
Original file line number Diff line number Diff line change
Expand Up @@ -20,12 +20,14 @@
)

/datum/surgery/debride/can_start(mob/living/user, mob/living/carbon/target)
if(!istype(target))
return FALSE
if(..())
var/obj/item/bodypart/targeted_bodypart = target.get_bodypart(user.zone_selected)
var/datum/wound/burn/flesh/burn_wound = targeted_bodypart.get_wound_type(targetable_wound)
return(burn_wound && burn_wound.infestation > 0)
. = ..()
if(!.)
return .

var/datum/wound/burn/flesh/burn_wound = target.get_bodypart(user.zone_selected).get_wound_type(targetable_wound)
// Should be guaranteed to have the wound by this point
ASSERT(burn_wound, "[type] on [target] has no burn wound when it should have been guaranteed to have one by can_start")
return burn_wound.infestation > 0

//SURGERY STEPS

Expand Down
4 changes: 1 addition & 3 deletions code/modules/surgery/core_removal.dm
Original file line number Diff line number Diff line change
Expand Up @@ -16,9 +16,7 @@
)

/datum/surgery/core_removal/can_start(mob/user, mob/living/target)
if(target.stat == DEAD)
return TRUE
return FALSE
return target.stat == DEAD && ..()

//extract brain
/datum/surgery_step/extract_core
Expand Down
7 changes: 3 additions & 4 deletions code/modules/surgery/coronary_bypass.dm
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,9 @@

/datum/surgery/coronary_bypass/can_start(mob/user, mob/living/carbon/target)
var/obj/item/organ/internal/heart/target_heart = target.get_organ_slot(ORGAN_SLOT_HEART)
if(target_heart)
if(target_heart.damage > 60 && !target_heart.operated)
return TRUE
return FALSE
if(isnull(target_heart) || target_heart.damage < 60 || target_heart.operated)
return FALSE
return ..()


//an incision but with greater bleed, and a 90% base success chance
Expand Down
5 changes: 1 addition & 4 deletions code/modules/surgery/ear_surgery.dm
Original file line number Diff line number Diff line change
Expand Up @@ -23,10 +23,7 @@
time = 64

/datum/surgery/ear_surgery/can_start(mob/user, mob/living/carbon/target)
var/obj/item/organ/internal/ears/target_ears = target.get_organ_slot(ORGAN_SLOT_EARS)
if(!target_ears)
return FALSE
return TRUE
return target.get_organ_slot(ORGAN_SLOT_EARS) && ..()

/datum/surgery_step/fix_ears/preop(mob/user, mob/living/carbon/target, target_zone, obj/item/tool, datum/surgery/surgery)
display_results(
Expand Down
11 changes: 6 additions & 5 deletions code/modules/surgery/experimental_dissection.dm
Original file line number Diff line number Diff line change
Expand Up @@ -10,16 +10,19 @@
/datum/surgery_step/experimental_dissection,
/datum/surgery_step/close,
)
surgery_flags = SURGERY_REQUIRE_RESTING | SURGERY_REQUIRE_LIMB | SURGERY_MORBID_CURIOSITY
surgery_flags = SURGERY_REQUIRE_RESTING | SURGERY_MORBID_CURIOSITY
possible_locs = list(BODY_ZONE_CHEST)
target_mobtypes = list(/mob/living)

/datum/surgery/advanced/experimental_dissection/can_start(mob/user, mob/living/target)
. = ..()
if(!.)
return .
if(HAS_TRAIT_FROM(target, TRAIT_DISSECTED, EXPERIMENTAL_SURGERY_TRAIT))
return FALSE
if(target.stat != DEAD)
return FALSE
return .

/datum/surgery_step/experimental_dissection
name = "dissection"
Expand All @@ -44,8 +47,7 @@
var/obj/item/research_notes/hand_dossier = user.get_inactive_held_item()
hand_dossier.merge(the_dossier)

var/obj/item/bodypart/target_chest = target.get_bodypart(BODY_ZONE_CHEST)
target.apply_damage(80, BRUTE, target_chest)
target.apply_damage(80, BRUTE, BODY_ZONE_CHEST)
ADD_TRAIT(target, TRAIT_DISSECTED, EXPERIMENTAL_SURGERY_TRAIT)
return ..()

Expand All @@ -61,8 +63,7 @@
var/obj/item/research_notes/hand_dossier = user.get_inactive_held_item()
hand_dossier.merge(the_dossier)

var/obj/item/bodypart/L = target.get_bodypart(BODY_ZONE_CHEST)
target.apply_damage(80, BRUTE, L)
target.apply_damage(80, BRUTE, BODY_ZONE_CHEST)
return TRUE

///Calculates how many research points dissecting 'target' is worth.
Expand Down
3 changes: 1 addition & 2 deletions code/modules/surgery/eye_surgery.dm
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,7 @@
time = 64

/datum/surgery/eye_surgery/can_start(mob/user, mob/living/carbon/target)
var/obj/item/organ/internal/eyes/target_eyes = target.get_organ_slot(ORGAN_SLOT_EYES)
return !isnull(target_eyes)
return target.get_organ_slot(ORGAN_SLOT_EYES) && ..()

/datum/surgery_step/fix_eyes/preop(mob/user, mob/living/carbon/target, target_zone, obj/item/tool, datum/surgery/surgery)
display_results(
Expand Down
8 changes: 3 additions & 5 deletions code/modules/surgery/gastrectomy.dm
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,9 @@

/datum/surgery/gastrectomy/can_start(mob/user, mob/living/carbon/target)
var/obj/item/organ/internal/stomach/target_stomach = target.get_organ_slot(ORGAN_SLOT_STOMACH)
if(target_stomach)
if(target_stomach.damage > 50 && !target_stomach.operated)
return TRUE
return FALSE
if(isnull(target_stomach) || target_stomach.damage < 50 || target_stomach.operated)
return FALSE
return ..()

////Gastrectomy, because we truly needed a way to repair stomachs.
//95% chance of success to be consistent with most organ-repairing surgeries.
Expand Down Expand Up @@ -72,4 +71,3 @@
span_warning("[user] cuts the wrong part of [target]'s stomach!"),
)
display_pain(target, "Your stomach throbs with pain; it's not getting any better!")

8 changes: 6 additions & 2 deletions code/modules/surgery/healing.dm
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
target_mobtypes = list(/mob/living)
requires_bodypart_type = BODYTYPE_ORGANIC //NOVA EDIT CHANGE - ORIGINAL VALUE: requires_bodypart_type = FALSE
replaced_by = /datum/surgery
surgery_flags = SURGERY_IGNORE_CLOTHES | SURGERY_REQUIRE_RESTING | SURGERY_REQUIRE_LIMB
surgery_flags = SURGERY_IGNORE_CLOTHES | SURGERY_REQUIRE_RESTING
possible_locs = list(BODY_ZONE_CHEST)
steps = list(
/datum/surgery_step/incise,
Expand All @@ -18,16 +18,20 @@

/datum/surgery/healing/can_start(mob/user, mob/living/patient)
. = ..()
if(!.)
return .
if(!(patient.mob_biotypes & (MOB_ORGANIC|MOB_HUMANOID)))
return FALSE
return .

/datum/surgery/healing/New(surgery_target, surgery_location, surgery_bodypart)
..()
if(healing_step_type)
steps = list(
/datum/surgery_step/incise/nobleed,
healing_step_type, //hehe cheeky
/datum/surgery_step/close)
/datum/surgery_step/close,
)

/datum/surgery_step/heal
name = "repair body (hemostat)"
Expand Down
Loading

0 comments on commit fcdd127

Please sign in to comment.