limb
Vars | |
body_size | body size of the owner, used for limb appearance, set in [/obj/limb/proc/update_limb()] |
---|---|
body_type | body muscularity of the owner, used for limb appearance, set in [/obj/limb/proc/update_limb()] |
cavity | Name of internal cavity. |
encased | Name of bones encasing the limb. |
hidden | Surgically implanted item. |
implants | Embedded or implanter implanted items. |
limb_gender | defines which sprite the limb should use if dimorphic, set in [/obj/limb/proc/update_limb()] |
skin_color | skin color of the owner, used for limb appearance, set in [/obj/limb/proc/update_limb()] |
species | species of the owner, used for limb appearance, set in [/obj/limb/proc/update_limb()] |
Procs | |
add_bleeding | Adds bleeding to the limb. Damage_amount lets you apply an amount worth of bleeding, otherwise it uses the given wound's damage. |
bandage | bandages brute wounds and removes bleeding. Returns WOUNDS_BANDAGED if at least one wound was bandaged. Returns WOUNDS_ALREADY_TREATED if a relevant wound exists but none were treated. Skips wounds that are already bandaged. treat_sutured var tells it to apply to sutured but unbandaged wounds, for trauma kits that heal damage directly. |
can_emp_delimb | If this limb can be dropped as a result of an EMP |
get_active_limb_surgeries | Returns a description of active surgeries. |
get_damage | Returns total damage, or, if broken, the minimum fracture threshold, whichever is higher. |
get_incision_depth | Returns a description of opened incisions. |
get_limb_icon | generates a list of overlays that should be applied to the owner |
get_limb_icon_key | generates a key for the purpose of caching the icon to avoid duplicate generations |
is_bandaged | Checks for bandageable wounds (type = CUT or type = BRUISE). Returns TRUE if all are bandaged, FALSE if not. |
is_salved | Checks for salveable wounds (type = BURN). Returns TRUE if all are salved, FALSE if not. |
limb_delimb | Special delimbs for different limbs |
remove_wound_bleeding | Checks if there's any external limb wounds, removes bleeding if there isn't. |
reset_limb_surgeries | called when limb is removed or robotized, any ongoing surgery and related vars are reset unless set otherwise. |
salve | salves burn wounds. Returns WOUNDS_BANDAGED if at least one wound was salved. Returns WOUNDS_ALREADY_TREATED if a relevant wound exists but none were treated. Skips wounds that are already salved. treat_grafted var tells it to apply to grafted but unsalved wounds, for burn kits that heal damage directly. |
take_damage | Describes how limbs (body parts) of human mobs get damage applied. |
update_limb | updates the various internal variables of the limb from the owner |
Var Details
body_size
body size of the owner, used for limb appearance, set in [/obj/limb/proc/update_limb()]
body_type
body muscularity of the owner, used for limb appearance, set in [/obj/limb/proc/update_limb()]
cavity
Name of internal cavity.
encased
Name of bones encasing the limb.
hidden
Surgically implanted item.
implants
Embedded or implanter implanted items.
limb_gender
defines which sprite the limb should use if dimorphic, set in [/obj/limb/proc/update_limb()]
skin_color
skin color of the owner, used for limb appearance, set in [/obj/limb/proc/update_limb()]
species
species of the owner, used for limb appearance, set in [/obj/limb/proc/update_limb()]
Proc Details
add_bleeding
Adds bleeding to the limb. Damage_amount lets you apply an amount worth of bleeding, otherwise it uses the given wound's damage.
bandage
bandages brute wounds and removes bleeding. Returns WOUNDS_BANDAGED if at least one wound was bandaged. Returns WOUNDS_ALREADY_TREATED if a relevant wound exists but none were treated. Skips wounds that are already bandaged. treat_sutured var tells it to apply to sutured but unbandaged wounds, for trauma kits that heal damage directly.
can_emp_delimb
If this limb can be dropped as a result of an EMP
get_active_limb_surgeries
Returns a description of active surgeries.
get_damage
Returns total damage, or, if broken, the minimum fracture threshold, whichever is higher.
get_incision_depth
Returns a description of opened incisions.
get_limb_icon
generates a list of overlays that should be applied to the owner
get_limb_icon_key
generates a key for the purpose of caching the icon to avoid duplicate generations
is_bandaged
Checks for bandageable wounds (type = CUT or type = BRUISE). Returns TRUE if all are bandaged, FALSE if not.
is_salved
Checks for salveable wounds (type = BURN). Returns TRUE if all are salved, FALSE if not.
limb_delimb
Special delimbs for different limbs
remove_wound_bleeding
Checks if there's any external limb wounds, removes bleeding if there isn't.
reset_limb_surgeries
called when limb is removed or robotized, any ongoing surgery and related vars are reset unless set otherwise.
salve
salves burn wounds. Returns WOUNDS_BANDAGED if at least one wound was salved. Returns WOUNDS_ALREADY_TREATED if a relevant wound exists but none were treated. Skips wounds that are already salved. treat_grafted var tells it to apply to grafted but unsalved wounds, for burn kits that heal damage directly.
take_damage
Describes how limbs (body parts) of human mobs get damage applied.
Any damage past the limb maximum health is transfered onto the next limb up the line, by calling this proc recursively. When a hand is too damaged it is passed to the arm, then to the chest and so on.
Since parent limbs usually have more armor than their children, just passing the damage directly would allow the attacker to effectively bypass all of that armor. A lurker with 35 slash damage repeatedly slashing a hand protected by marine combat gloves (20 armor) would do 20 damage to the hand, then would start doing the same 20 to the arm, and then the chest. But if the lurker slashes the arm direclty it would only do 16 damage, assuming the marine is wearing medium armor which has armor value of 30.
Thus we have to apply armor damage reduction on each limb to which the damage is transfered. When this proc is called recursively for the first damage transfer to the parent, we set reduced_by variables to be the armor of the original limb hit. Then we compare the parent limb armor with the applicable reduced_by and if it's higher we reduce the damage by the difference between the two. Then we set reduced_by to the current(parent) limb armor value.
This generally works ok because our armor calculations are mostly distributive in practice: reducing the damage by 20 and then by 10 would generally give the same result as reducing by 30. But this is not strictly true, the lower the damage is, the more it gets reduced. As an extreme example, a lurker doing his first 35 damage slash on a combat gloves covered marine hand would do 30 damage to the hand, transfer 5 to the arm and those 5 would get mitigated to 0 by the marine medium armor.
One problem that still exists here, is that we currently don't have any code that allows us to increase the damage when the parent limb armor is lower than the initial child limb armor. One practical example where this would happen is when a human is wearing a set of armor that does not protect legs, like the UPP officer. If a xeno keeps slashing his foot, the damage would eventually get transfered to the leg, which has 0 armor. But this damage has been already reduced by the boot armor even before this proc got first called. So, assuming 35 damage slash, the leg would only be damaged by 21 even though it has 0 armor. Fixing this would require a new proc that would be able to unapply armor from the damage.
Organ damage and bone break have their own armor damage reduction calculations. Since armor is already applied at least once outside of this proc, this means that damage is always reduced twice, hence the formulas for those looks so weird.
Currently all brute damage is reduced by ARMOR_MELEE and GLOB.marine_melee, while burn damage is reduced by ARMOR_BIO and GLOB.marine_fire, which may not be correct for all cases.
update_limb
updates the various internal variables of the limb from the owner