diff --git a/code/_helpers/global_lists.dm b/code/_helpers/global_lists.dm index 33b50af54b..31e19b3082 100644 --- a/code/_helpers/global_lists.dm +++ b/code/_helpers/global_lists.dm @@ -203,6 +203,13 @@ var/global/list/string_slot_flags = list( var/datum/poster/P = new T NT_poster_designs += P + // VOREStation Add - Vore Modes! + paths = typesof(/datum/digest_mode) - /datum/digest_mode/transform + for(var/T in paths) + var/datum/digest_mode/DM = new T + GLOB.digest_modes[DM.id] = DM + // VOREStation Add End + return 1 /* // Uncomment to debug chemical reaction list. diff --git a/code/modules/vore/eating/belly_obj_vr.dm b/code/modules/vore/eating/belly_obj_vr.dm index 627934c6f3..ebde3b5eae 100644 --- a/code/modules/vore/eating/belly_obj_vr.dm +++ b/code/modules/vore/eating/belly_obj_vr.dm @@ -54,7 +54,6 @@ var/tmp/mob/living/owner // The mob whose belly this is. var/tmp/digest_mode = DM_HOLD // Current mode the belly is set to from digest_modes (+transform_modes if human) - var/tmp/tf_mode = DM_TRANSFORM_REPLICA // Current transformation mode. var/tmp/list/items_preserved = list() // Stuff that wont digest so we shouldn't process it again. var/tmp/next_emote = 0 // When we're supposed to print our next emote, as a world.time var/tmp/recent_sound = FALSE // Prevent audio spam diff --git a/code/modules/vore/eating/bellymodes_datum_vr.dm b/code/modules/vore/eating/bellymodes_datum_vr.dm new file mode 100644 index 0000000000..19deb66621 --- /dev/null +++ b/code/modules/vore/eating/bellymodes_datum_vr.dm @@ -0,0 +1,254 @@ +GLOBAL_LIST_INIT(digest_modes, list()) + +/datum/digest_mode + var/id = DM_HOLD + var/noise_chance = 0 + +/** + * This proc has all the behavior for the given digestion mode. + * It returns either null, or an associative list in the following format: + * list("to_update" = TRUE/FALSE, "soundToPlay" = sound()) + * where to_update is whether or not a updateVorePanel() call is necessary, + * and soundToPlay will play the given sound at the end of the process tick. + */ +/datum/digest_mode/proc/process_mob(obj/belly/B, mob/living/L) + return null + +/datum/digest_mode/digest + id = DM_DIGEST + noise_chance = 50 + +/datum/digest_mode/digest/process_mob(obj/belly/B, mob/living/L) + //Pref protection! + if(!L.digestable || L.absorbed) + return null + + //Person just died in guts! + if(L.stat == DEAD) + if(L.is_preference_enabled(/datum/client_preference/digestion_noises)) + if(!B.fancy_vore) + SEND_SOUND(L, sound(get_sfx("classic_death_sounds"))) + else + SEND_SOUND(L, sound(get_sfx("fancy_death_prey"))) + B.handle_digestion_death(L) + if(!B.fancy_vore) + return list("to_update" = TRUE, "soundToPlay" = sound(get_sfx("classic_death_sounds"))) + return list("to_update" = TRUE, "soundToPlay" = sound(get_sfx("fancy_death_pred"))) + + // Deal digestion damage (and feed the pred) + var/old_brute = L.getBruteLoss() + var/old_burn = L.getFireLoss() + L.adjustBruteLoss(B.digest_brute) + L.adjustFireLoss(B.digest_burn) + var/actual_brute = L.getBruteLoss() - old_brute + var/actual_burn = L.getFireLoss() - old_burn + var/damage_gain = actual_brute + actual_burn + + var/offset = (1 + ((L.weight - 137) / 137)) // 130 pounds = .95 140 pounds = 1.02 + var/difference = B.owner.size_multiplier / L.size_multiplier + if(isrobot(B.owner)) + var/mob/living/silicon/robot/R = B.owner + R.cell.charge += 25 * damage_gain + if(offset) // If any different than default weight, multiply the % of offset. + B.owner.adjust_nutrition(offset*((B.nutrition_percent / 100) * 4.5 * (damage_gain) / difference)) //4.5 nutrition points per health point. Normal same size 100+100 health prey with average weight would give 900 points if the digestion was instant. With all the size/weight offset taxes plus over time oxyloss+hunger taxes deducted with non-instant digestion, this should be enough to not leave the pred starved. + else + B.owner.adjust_nutrition((B.nutrition_percent / 100) * 4.5 * (damage_gain) / difference) + +/datum/digest_mode/absorb + id = DM_ABSORB + noise_chance = 10 + +/datum/digest_mode/absorb/process_mob(obj/belly/B, mob/living/L) + if(!L.absorbable || L.absorbed) + return null + B.steal_nutrition(L) + if(L.nutrition < 100) + B.absorb_living(L) + return list("to_update" = TRUE) + +/datum/digest_mode/unabsorb + id = DM_UNABSORB + +/datum/digest_mode/unabsorb/process_mob(obj/belly/B, mob/living/L) + if(L.absorbed && B.owner.nutrition >= 100) + L.absorbed = FALSE + to_chat(L, "You suddenly feel solid again.") + to_chat(B.owner,"You feel like a part of you is missing.") + B.owner.adjust_nutrition(-100) + return list("to_update" = TRUE) + +/datum/digest_mode/drain + id = DM_DRAIN + noise_chance = 10 + +/datum/digest_mode/drain/process_mob(obj/belly/B, mob/living/L) + B.steal_nutrition(L) + +/datum/digest_mode/drain/shrink + id = DM_SHRINK + +/datum/digest_mode/drain/shrink/process_mob(obj/belly/B, mob/living/L) + if(L.size_multiplier > B.shrink_grow_size) + L.resize(L.size_multiplier - 0.01) // Shrink by 1% per tick + . = ..() + +/datum/digest_mode/grow + id = DM_GROW + noise_chance = 10 + +/datum/digest_mode/grow/process_mob(obj/belly/B, mob/living/L) + if(L.size_multiplier < B.shrink_grow_size) + L.resize(L.size_multiplier + 0.01) // Shrink by 1% per tick + +/datum/digest_mode/drain/sizesteal + id = DM_SIZE_STEAL + +/datum/digest_mode/drain/sizesteal/process_mob(obj/belly/B, mob/living/L) + if(L.size_multiplier > B.shrink_grow_size && B.owner.size_multiplier < 2) //Grow until either pred is large or prey is small. + B.owner.resize(B.owner.size_multiplier + 0.01) //Grow by 1% per tick. + L.resize(L.size_multiplier - 0.01) //Shrink by 1% per tick + . = ..() + +/datum/digest_mode/heal + id = DM_HEAL + noise_chance = 50 //Wet heals! The secret is you can leave this on for gurgle noises for fun. + +/datum/digest_mode/heal/process_mob(obj/belly/B, mob/living/L) + if(L.stat == DEAD) + return null // Can't heal the dead with healbelly + if(B.owner.nutrition > 90 && (L.health < L.maxHealth)) + L.adjustBruteLoss(-2.5) + L.adjustFireLoss(-2.5) + L.adjustToxLoss(-5) + L.adjustOxyLoss(-5) + L.adjustCloneLoss(-1.25) + B.owner.adjust_nutrition(-2) + if(L.nutrition <= 400) + L.adjust_nutrition(1) + else if(B.owner.nutrition > 90 && (L.nutrition <= 400)) + B.owner.adjust_nutrition(-1) + L.adjust_nutrition(1) + +// TRANSFORM MODES +/datum/digest_mode/transform + var/stabilize_nutrition = FALSE + var/changes_eyes = FALSE + var/changes_hair_solo = FALSE + var/changes_hairandskin = FALSE + var/changes_gender = FALSE + var/changes_gender_to = null + var/changes_species = FALSE + var/changes_ears_tail_wing_nocolor = FALSE + var/changes_ears_tail_wing_color = FALSE + var/eggs = FALSE + +/datum/digest_mode/transform/process_mob(obj/belly/B, mob/living/carbon/human/H) + if(!istype(H) || H.stat == DEAD) + return null + if(stabilize_nutrition) + if(B.owner.nutrition > 400 && H.nutrition < 400) + B.owner.adjust_nutrition(-2) + H.adjust_nutrition(1.5) + if(changes_eyes && B.check_eyes(H)) + B.change_eyes(H, 1) + return null + if(changes_hair_solo && B.check_hair(H)) + B.change_hair(H) + return null + if(changes_hairandskin && (B.check_hair(H) || B.check_skin(H))) + B.change_hair(H) + B.change_skin(H, 1) + return null + if(changes_species) + if(changes_ears_tail_wing_nocolor && (B.check_ears(H) || B.check_tail_nocolor(H) || B.check_wing_nocolor(H) || B.check_species(H))) + B.change_ears(H) + B.change_tail_nocolor(H) + B.change_wing_nocolor(H) + B.change_species(H, 1, 1) // ,1) preserves coloring + return null + if(changes_ears_tail_wing_color && (B.check_ears(H) || B.check_tail(H) || B.check_wing(H) || B.check_species(H))) + B.change_ears(H) + B.change_tail(H) + B.change_wing(H) + B.change_species(H, 1, 2) // ,2) does not preserve coloring. + return null + if(changes_gender && B.check_gender(H, changes_gender_to)) + B.change_gender(H, changes_gender_to, 1) + return null + if(eggs && (!H.absorbed)) + B.put_in_egg(H, 1) + return null + +// Regular TF Modes +/datum/digest_mode/transform/hairandeyes + id = DM_TRANSFORM_HAIR_AND_EYES + stabilize_nutrition = TRUE + changes_eyes = TRUE + changes_hair_solo = TRUE + +/datum/digest_mode/transform/gender + id = DM_TRANSFORM_FEMALE + changes_eyes = TRUE + changes_hairandskin = TRUE + changes_gender = TRUE + changes_gender_to = FEMALE + stabilize_nutrition = TRUE + +/datum/digest_mode/transform/gender/male + id = DM_TRANSFORM_FEMALE + changes_gender_to = MALE + +/datum/digest_mode/transform/keepgender + id = DM_TRANSFORM_KEEP_GENDER + changes_eyes = TRUE + changes_hairandskin = TRUE + stabilize_nutrition = TRUE + +/datum/digest_mode/transform/speciesandtaur + id = DM_TRANSFORM_CHANGE_SPECIES_AND_TAUR + changes_species = TRUE + changes_ears_tail_wing_nocolor = TRUE + stabilize_nutrition = TRUE + +/datum/digest_mode/transform/replica + id = DM_TRANSFORM_REPLICA + changes_eyes = TRUE + changes_hairandskin = TRUE + changes_species = TRUE + changes_ears_tail_wing_color = TRUE + +// E G G +/datum/digest_mode/transform/egg + id = DM_EGG + eggs = TRUE + +/datum/digest_mode/transform/egg/gender + id = DM_TRANSFORM_FEMALE_EGG + changes_eyes = TRUE + changes_hairandskin = TRUE + changes_gender = TRUE + changes_gender_to = FEMALE + stabilize_nutrition = TRUE + +/datum/digest_mode/transform/egg/gender/male + id = DM_TRANSFORM_MALE_EGG + changes_gender_to = MALE + +/datum/digest_mode/transform/egg/nogender + id = DM_TRANSFORM_KEEP_GENDER_EGG + changes_eyes = TRUE + changes_hairandskin = TRUE + stabilize_nutrition = TRUE + +/datum/digest_mode/transform/egg/speciesandtaur + id = DM_TRANSFORM_CHANGE_SPECIES_AND_TAUR_EGG + changes_species = TRUE + changes_ears_tail_wing_nocolor = TRUE + stabilize_nutrition = TRUE + +/datum/digest_mode/transform/egg/replica + id = DM_TRANSFORM_REPLICA_EGG + changes_eyes = TRUE + changes_hairandskin = TRUE + changes_species = TRUE + changes_ears_tail_wing_color = TRUE \ No newline at end of file diff --git a/code/modules/vore/eating/bellymodes_tf_vr.dm b/code/modules/vore/eating/bellymodes_tf_vr.dm deleted file mode 100644 index 2120ea78fd..0000000000 --- a/code/modules/vore/eating/bellymodes_tf_vr.dm +++ /dev/null @@ -1,92 +0,0 @@ -/obj/belly/proc/process_tf(mode, list/touchable_mobs) //We pass mode so it's mega-ultra local. - /* May not be necessary... Transform only shows up in the panel for humans. - if(!ishuman(owner)) - return //Need DNA and junk for this. - */ - - //Cast here for reduced duplication - var/mob/living/carbon/human/O = owner - - var/stabilize_nutrition = FALSE - var/changes_eyes = FALSE - var/changes_hair_solo = FALSE - var/changes_hairandskin = FALSE - var/changes_gender = FALSE - var/changes_gender_to = null - var/changes_species = FALSE - var/changes_ears_tail_wing_nocolor = FALSE - var/changes_ears_tail_wing_color = FALSE - var/eggs = FALSE - - switch(mode) - if(DM_TRANSFORM_HAIR_AND_EYES) - stabilize_nutrition = TRUE - changes_eyes = TRUE - changes_hair_solo = TRUE - if(DM_TRANSFORM_MALE, DM_TRANSFORM_FEMALE, DM_TRANSFORM_MALE_EGG, DM_TRANSFORM_FEMALE_EGG) - changes_eyes = TRUE - changes_hairandskin = TRUE - changes_gender = TRUE - changes_gender_to = (mode == DM_TRANSFORM_MALE || mode == DM_TRANSFORM_MALE_EGG) ? MALE : FEMALE - stabilize_nutrition = TRUE - eggs = (mode == DM_TRANSFORM_MALE_EGG || mode == DM_TRANSFORM_FEMALE_EGG) - if(DM_TRANSFORM_KEEP_GENDER, DM_TRANSFORM_KEEP_GENDER_EGG) - changes_eyes = TRUE - changes_hairandskin = TRUE - stabilize_nutrition = TRUE - eggs = (mode == DM_TRANSFORM_KEEP_GENDER_EGG) - if(DM_TRANSFORM_CHANGE_SPECIES_AND_TAUR, DM_TRANSFORM_CHANGE_SPECIES_AND_TAUR_EGG) - changes_species = TRUE - changes_ears_tail_wing_nocolor = TRUE - stabilize_nutrition = TRUE - eggs = (mode == DM_TRANSFORM_CHANGE_SPECIES_AND_TAUR_EGG) - if(DM_TRANSFORM_REPLICA, DM_TRANSFORM_REPLICA_EGG) - changes_eyes = TRUE - changes_hairandskin = TRUE - changes_species = TRUE - changes_ears_tail_wing_color = TRUE - eggs = (mode == DM_TRANSFORM_REPLICA_EGG) - if(DM_EGG) - eggs = TRUE - - /* This is designed to do *gradual* transformations. - * For each human in the TF belly per cycle, they can only have one "stage" of transformation applied to them. - * Some transformation modes have different amounts of stages than others and that's okay. - * All stages in order: Eyes, Hair & Skin, Ears & Tail & Wings & Species, Gender, Egg - */ - for(var/mob/living/carbon/human/H in touchable_mobs) - if(H.stat == DEAD) - continue - if(stabilize_nutrition) - if(O.nutrition > 400 && H.nutrition < 400) - O.adjust_nutrition(-2) - H.adjust_nutrition(1.5) - if(changes_eyes && check_eyes(H)) - change_eyes(H, 1) - continue - if(changes_hair_solo && check_hair(H)) - change_hair(H) - continue - if(changes_hairandskin && (check_hair(H) || check_skin(H))) - change_hair(H) - change_skin(H, 1) - continue - if(changes_species) - if(changes_ears_tail_wing_nocolor && (check_ears(H) || check_tail_nocolor(H) || check_wing_nocolor(H) || check_species(H))) - change_ears(H) - change_tail_nocolor(H) - change_wing_nocolor(H) - change_species(H, 1, 1) // ,1) preserves coloring - continue - if(changes_ears_tail_wing_color && (check_ears(H) || check_tail(H) || check_wing(H) || check_species(H))) - change_ears(H) - change_tail(H) - change_wing(H) - change_species(H, 1, 2) // ,2) does not preserve coloring. - continue - if(changes_gender && check_gender(H, changes_gender_to)) - change_gender(H, changes_gender_to, 1) - continue - if(eggs && (!H.absorbed)) - put_in_egg(H, 1) - continue \ No newline at end of file diff --git a/code/modules/vore/eating/bellymodes_vr.dm b/code/modules/vore/eating/bellymodes_vr.dm index caf75ac3c6..d11af09376 100644 --- a/code/modules/vore/eating/bellymodes_vr.dm +++ b/code/modules/vore/eating/bellymodes_vr.dm @@ -16,39 +16,88 @@ prey_loop() /////////////////////////// Sound Selections /////////////////////////// + var/digestion_noise_chance = 0 var/sound/prey_digest - var/sound/prey_death var/sound/pred_digest - var/sound/pred_death if(!fancy_vore) prey_digest = sound(get_sfx("classic_digestion_sounds")) - prey_death = sound(get_sfx("classic_death_sounds")) pred_digest = sound(get_sfx("classic_digestion_sounds")) - pred_death = sound(get_sfx("classic_death_sounds")) else prey_digest = sound(get_sfx("fancy_digest_prey")) - prey_death = sound(get_sfx("fancy_death_prey")) pred_digest = sound(get_sfx("fancy_digest_pred")) - pred_death = sound(get_sfx("fancy_death_pred")) /////////////////////////// Exit Early //////////////////////////// var/list/touchable_atoms = contents - items_preserved if(!length(touchable_atoms)) return - var/list/touchable_mobs = list() + var/list/touchable_mobs = null + + var/list/hta_returns = handle_touchable_atoms(touchable_atoms) + if(islist(hta_returns)) + if(hta_returns["digestion_noise_chance"]) + digestion_noise_chance = hta_returns["digestion_noise_chance"] + if(hta_returns["touchable_mobs"]) + touchable_mobs = hta_returns["touchable_mobs"] + if(hta_returns["to_update"]) + to_update = hta_returns["to_update"] + + if(!islist(touchable_mobs)) + return ///////////////////// Early Non-Mode Handling ///////////////////// - if(contents.len && next_emote <= world.time) + var/list/EL = emote_lists[digest_mode] + if(LAZYLEN(EL) && touchable_mobs && next_emote <= world.time) next_emote = world.time + emote_time - var/list/EL = emote_lists[digest_mode] - if(LAZYLEN(EL)) - for(var/mob/living/M in contents) - if(M.digestable || digest_mode != DM_DIGEST) // don't give digesty messages to indigestible people - to_chat(M, "[pick(EL)]") + for(var/mob/living/M in contents) + if(digest_mode == DM_DIGEST && !M.digestable) + continue // don't give digesty messages to indigestible people + to_chat(M, "[pick(EL)]") + var/datum/digest_mode/DM = GLOB.digest_modes["[digest_mode]"] + if(!DM) + log_debug("Digest mode [digest_mode] didn't exist in the digest_modes list!!") + return FALSE + + if(!digestion_noise_chance) + digestion_noise_chance = DM.noise_chance + + for(var/target in touchable_mobs) + var/mob/living/L = target + if(!istype(L)) + continue + var/list/returns = DM.process_mob(src, target) + if(istype(returns) && returns["to_update"]) + to_update = TRUE + if(istype(returns) && returns["soundToPlay"] && !play_sound) + play_sound = returns["soundToPlay"] + +/////////////////////////// Make any noise /////////////////////////// + if(digestion_noise_chance && prob(digestion_noise_chance)) + for(var/mob/M in contents) + if(M && M.is_preference_enabled(/datum/client_preference/digestion_noises)) + SEND_SOUND(M, prey_digest) + play_sound = pred_digest + + if(play_sound) + for(var/mob/M in hearers(VORE_SOUND_RANGE, owner)) //so we don't fill the whole room with the sound effect + if(!M.is_preference_enabled(/datum/client_preference/digestion_noises)) + continue + if(isturf(M.loc) || (M.loc != src)) //to avoid people on the inside getting the outside sounds and their direct sounds + built in sound pref check + if(fancy_vore) + M.playsound_local(owner.loc, play_sound, vol = 75, vary = 1, falloff = VORE_SOUND_FALLOFF) + else + M.playsound_local(owner.loc, play_sound, vol = 100, vary = 1, falloff = VORE_SOUND_FALLOFF) + //these are all external sound triggers now, so it's ok. + + if(to_update) + updateVRPanels() + +/obj/belly/proc/handle_touchable_atoms(list/touchable_atoms) var/did_an_item = FALSE // Only do one item per cycle. + var/to_update = FALSE var/digestion_noise_chance = 0 + var/list/touchable_mobs = list() for(var/A in touchable_atoms) //Handle stray items @@ -99,125 +148,7 @@ else if(istype(A, /obj/effect/decal/cleanable)) qdel(A) - if(digest_mode == DM_HOLD) - //We deliberately do not want any gurgly noises if the belly is in DM_HOLD - if(to_update) - updateVRPanels() - return - - if(digest_mode == DM_TRANSFORM) - process_tf(tf_mode, touchable_mobs) - - for(var/target in touchable_mobs) - var/mob/living/L = target - if(!istype(L)) - continue - switch(digest_mode) - if(DM_DIGEST) - digestion_noise_chance = 50 - //Pref protection! - if(!L.digestable || L.absorbed) - continue - - //Person just died in guts! - if(L.stat == DEAD) - play_sound = pred_death - if(L.is_preference_enabled(/datum/client_preference/digestion_noises)) - SEND_SOUND(L, prey_death) - handle_digestion_death(L) - to_update = TRUE - continue - - // Deal digestion damage (and feed the pred) - var/old_brute = L.getBruteLoss() - var/old_burn = L.getFireLoss() - L.adjustBruteLoss(digest_brute) - L.adjustFireLoss(digest_burn) - var/actual_brute = L.getBruteLoss() - old_brute - var/actual_burn = L.getFireLoss() - old_burn - var/damage_gain = actual_brute + actual_burn - - var/offset = (1 + ((L.weight - 137) / 137)) // 130 pounds = .95 140 pounds = 1.02 - var/difference = owner.size_multiplier / L.size_multiplier - if(isrobot(owner)) - var/mob/living/silicon/robot/R = owner - R.cell.charge += 25 * damage_gain - if(offset) // If any different than default weight, multiply the % of offset. - owner.adjust_nutrition(offset*((nutrition_percent / 100) * 4.5 * (damage_gain) / difference)) //4.5 nutrition points per health point. Normal same size 100+100 health prey with average weight would give 900 points if the digestion was instant. With all the size/weight offset taxes plus over time oxyloss+hunger taxes deducted with non-instant digestion, this should be enough to not leave the pred starved. - else - owner.adjust_nutrition((nutrition_percent / 100) * 4.5 * (damage_gain) / difference) - if(DM_ABSORB) - if(!L.absorbable || L.absorbed) - continue - digestion_noise_chance = 10 - steal_nutrition(L) - if(L.nutrition < 100) - absorb_living(L) - to_update = TRUE - if(DM_UNABSORB) - if(L.absorbed && owner.nutrition >= 100) - L.absorbed = FALSE - to_chat(L, "You suddenly feel solid again.") - to_chat(owner,"You feel like a part of you is missing.") - owner.adjust_nutrition(-100) - to_update = TRUE - if(DM_DRAIN) - digestion_noise_chance = 10 - steal_nutrition(L) - if(DM_SHRINK) - digestion_noise_chance = 10 - if(L.size_multiplier > shrink_grow_size) - L.resize(L.size_multiplier - 0.01) // Shrink by 1% per tick - steal_nutrition(L) - if(DM_GROW) - digestion_noise_chance = 10 - if(L.size_multiplier < shrink_grow_size) - L.resize(L.size_multiplier - 0.01) // Grow by 1% per tick - if(DM_SIZE_STEAL) - digestion_noise_chance = 10 - if(L.size_multiplier > shrink_grow_size && owner.size_multiplier < 2) //Grow until either pred is large or prey is small. - owner.resize(owner.size_multiplier+0.01) //Grow by 1% per tick. - L.resize(L.size_multiplier-0.01) //Shrink by 1% per tick - steal_nutrition(L) - if(DM_HEAL) - digestion_noise_chance = 50 //Wet heals! The secret is you can leave this on for gurgle noises for fun. - if(L.stat == DEAD) - continue // Can't heal the dead with healbelly - if(owner.nutrition > 90 && (L.health < L.maxHealth)) - L.adjustBruteLoss(-2.5) - L.adjustFireLoss(-2.5) - L.adjustToxLoss(-5) - L.adjustOxyLoss(-5) - L.adjustCloneLoss(-1.25) - owner.adjust_nutrition(-2) - if(L.nutrition <= 400) - L.adjust_nutrition(1) - else if(owner.nutrition > 90 && (L.nutrition <= 400)) - owner.adjust_nutrition(-1) - L.adjust_nutrition(1) - -/////////////////////////// Make any noise /////////////////////////// - if(digestion_noise_chance && prob(digestion_noise_chance)) - for(var/mob/M in contents) - if(M && M.is_preference_enabled(/datum/client_preference/digestion_noises)) - SEND_SOUND(M, prey_digest) - play_sound = pred_digest - - if(play_sound) - for(var/mob/M in hearers(VORE_SOUND_RANGE, owner)) //so we don't fill the whole room with the sound effect - if(!M.is_preference_enabled(/datum/client_preference/digestion_noises)) - continue - if(isturf(M.loc) || (M.loc != src)) //to avoid people on the inside getting the outside sounds and their direct sounds + built in sound pref check - if(fancy_vore) - M.playsound_local(owner.loc, play_sound, vol = 75, vary = 1, falloff = VORE_SOUND_FALLOFF) - else - M.playsound_local(owner.loc, play_sound, vol = 100, vary = 1, falloff = VORE_SOUND_FALLOFF) - //these are all external sound triggers now, so it's ok. - - if(to_update) - updateVRPanels() - - return + return list("to_update" = to_update, "touchable_mobs" = touchable_mobs, "digestion_noise_chance" = digestion_noise_chance) /obj/belly/proc/prey_loop() for(var/mob/living/M in contents) diff --git a/code/modules/vore/eating/transforming_vr.dm b/code/modules/vore/eating/transforming_vr.dm index 3e78920419..8f9eea2371 100644 --- a/code/modules/vore/eating/transforming_vr.dm +++ b/code/modules/vore/eating/transforming_vr.dm @@ -206,7 +206,7 @@ if(!istype(M) || !istype(O)) return 0 - if(M.species != O.species || M.custom_species != O.custom_species) + if(M.species.name != O.species.name || M.custom_species != O.custom_species) return 1 return 0 @@ -227,7 +227,7 @@ if(color_action == 1) M.set_species(O.species.name,0,1,M) else if(color_action == 2) - M.set_species(O.species.name,0,1,O) + M.species = O.species else M.set_species(O.species.name) M.custom_species = O.custom_species diff --git a/code/modules/vore/eating/vorepanel_vr.dm b/code/modules/vore/eating/vorepanel_vr.dm index 02421f8298..357345d273 100644 --- a/code/modules/vore/eating/vorepanel_vr.dm +++ b/code/modules/vore/eating/vorepanel_vr.dm @@ -125,32 +125,30 @@ spanstyle = "color:purple;" if(DM_SIZE_STEAL) spanstyle = "color:purple;" - if(DM_TRANSFORM) - switch(B.tf_mode) - if(DM_TRANSFORM_MALE) - spanstyle = "color:purple;" - if(DM_TRANSFORM_HAIR_AND_EYES) - spanstyle = "color:purple;" - if(DM_TRANSFORM_FEMALE) - spanstyle = "color:purple;" - if(DM_TRANSFORM_KEEP_GENDER) - spanstyle = "color:purple;" - if(DM_TRANSFORM_CHANGE_SPECIES_AND_TAUR) - spanstyle = "color:purple;" - if(DM_TRANSFORM_CHANGE_SPECIES_AND_TAUR_EGG) - spanstyle = "color:purple;" - if(DM_TRANSFORM_REPLICA) - spanstyle = "color:purple;" - if(DM_TRANSFORM_REPLICA_EGG) - spanstyle = "color:purple;" - if(DM_TRANSFORM_KEEP_GENDER_EGG) - spanstyle = "color:purple;" - if(DM_TRANSFORM_MALE_EGG) - spanstyle = "color:purple;" - if(DM_TRANSFORM_FEMALE_EGG) - spanstyle = "color:purple;" - if(DM_EGG) - spanstyle = "color:purple;" + if(DM_TRANSFORM_MALE) + spanstyle = "color:purple;" + if(DM_TRANSFORM_HAIR_AND_EYES) + spanstyle = "color:purple;" + if(DM_TRANSFORM_FEMALE) + spanstyle = "color:purple;" + if(DM_TRANSFORM_KEEP_GENDER) + spanstyle = "color:purple;" + if(DM_TRANSFORM_CHANGE_SPECIES_AND_TAUR) + spanstyle = "color:purple;" + if(DM_TRANSFORM_CHANGE_SPECIES_AND_TAUR_EGG) + spanstyle = "color:purple;" + if(DM_TRANSFORM_REPLICA) + spanstyle = "color:purple;" + if(DM_TRANSFORM_REPLICA_EGG) + spanstyle = "color:purple;" + if(DM_TRANSFORM_KEEP_GENDER_EGG) + spanstyle = "color:purple;" + if(DM_TRANSFORM_MALE_EGG) + spanstyle = "color:purple;" + if(DM_TRANSFORM_FEMALE_EGG) + spanstyle = "color:purple;" + if(DM_EGG) + spanstyle = "color:purple;" belly_list += " ([B.contents.len])" @@ -203,7 +201,7 @@ //Digest Mode Button var/mode = selected.digest_mode - dat += "
Belly Mode: [mode == DM_TRANSFORM ? selected.tf_mode : mode]" + dat += "
Belly Mode: [mode]" //Mode addons button var/list/flag_list = list() @@ -581,10 +579,11 @@ if(new_mode == DM_TRANSFORM) //Snowflek submenu var/list/tf_list = selected.transform_modes - var/new_tf_mode = input("Choose TF Mode (currently [selected.tf_mode])") as null|anything in tf_list + var/new_tf_mode = input("Choose TF Mode (currently [selected.digest_mode])") as null|anything in tf_list if(!new_tf_mode) return FALSE - selected.tf_mode = new_tf_mode + selected.digest_mode = new_tf_mode + return selected.digest_mode = new_mode //selected.items_preserved.Cut() //Re-evaltuate all items in belly on belly-mode change //Handled with item modes now diff --git a/vorestation.dme b/vorestation.dme index 4eef2efec0..64714d7c56 100644 --- a/vorestation.dme +++ b/vorestation.dme @@ -3438,7 +3438,7 @@ #include "code\modules\vore\appearance\update_icons_vr.dm" #include "code\modules\vore\eating\belly_dat_vr.dm" #include "code\modules\vore\eating\belly_obj_vr.dm" -#include "code\modules\vore\eating\bellymodes_tf_vr.dm" +#include "code\modules\vore\eating\bellymodes_datum_vr.dm" #include "code\modules\vore\eating\bellymodes_vr.dm" #include "code\modules\vore\eating\contaminate_vr.dm" #include "code\modules\vore\eating\digest_act_vr.dm"