diff --git a/src/art/vector/VectorArtJS.js b/src/art/vector/VectorArtJS.js index ab842c9c0b06812875be75bd0af263ccf8d04937..f836b7ce2788fad894018c9b4c790f0801c1acb7 100644 --- a/src/art/vector/VectorArtJS.js +++ b/src/art/vector/VectorArtJS.js @@ -1337,7 +1337,7 @@ App.Art.vectorArtElement = (function() { } /* head addons */ - if (slave.collar === "porcelain mask") { + if (slave.faceAccessory === "porcelain mask") { T.glassesColor = slave.glassesColor || "#FFFFFF"; /* use custom color or white */ } else { T.glassesColor = slave.glassesColor || "#010101"; /* use custom color or default */ @@ -2513,15 +2513,17 @@ App.Art.vectorArtElement = (function() { /* ADDONS */ if (slave.fuckdoll === 0) { /* Fuckdolls cannot be decorated */ - if (slave.collar === "dildo gag") { + if (slave.mouthAccessory === "dildo gag") { res.appendChild(useSvg("Art_Vector_Dildo_Gag")); - } else if (slave.collar === "ball gag") { + } else if (slave.mouthAccessory === "ball gag") { res.appendChild(useSvg("Art_Vector_Ball_Gag")); - } else if (slave.collar === "bit gag") { + } else if (slave.mouthAccessory === "bit gag") { res.appendChild(useSvg("Art_Vector_Bit_Gag")); - } else if (slave.collar === "massive dildo gag") { + } else if (slave.mouthAccessory === "massive dildo gag") { res.appendChild(useSvg("Art_Vector_Massive_Dildo_Gag")); - } else if (slave.collar === "porcelain mask") { + } + + if (slave.faceAccessory === "porcelain mask") { res.appendChild(useSvg("Art_Vector_Porcelain_Mask")); } @@ -3040,10 +3042,15 @@ App.Art.legacyVectorArtElement = function() { case "shock punishment": case "tight steel": case "uncomfortable leather": + } + + /* Gag */ + switch (slave.mouthAccessory ) { case "dildo gag": addImg(res, `outfit/${slave.collar}`); } + /* Head base image */ if (wearingLatex === true) { addImg(res, "outfit/head latex"); diff --git a/src/art/vector_revamp/vectorRevampedArtControl.js b/src/art/vector_revamp/vectorRevampedArtControl.js index b7b6b3bf725b05efaccb1977d94781ce62a1791e..967fd9094a97677955c8258d05aa32f9824e52e4 100644 --- a/src/art/vector_revamp/vectorRevampedArtControl.js +++ b/src/art/vector_revamp/vectorRevampedArtControl.js @@ -1647,7 +1647,7 @@ class RevampedArtControl { } if (this.showMouth) { - switch (this.artSlave.collar) { + switch (this.artSlave.mouthAccessory) { case "dildo gag": result.push("Art_Vector_Revamp_Dildo_Gag"); break; diff --git a/src/endWeek/saClothes.js b/src/endWeek/saClothes.js index 593c50e77c984259d65c569e85a76db59f5fbf84..d88165cdefa13ad8d1ef7e97374e7b0b081a10f6 100644 --- a/src/endWeek/saClothes.js +++ b/src/endWeek/saClothes.js @@ -32,6 +32,12 @@ App.SlaveAssignment.clothes = (function() { if (slave.collar !== "none") { collarEffects(slave); } + if (slave.faceAccessory !== "none") { + maskEffects(slave); + } + if (slave.mouthAccessory !== "none") { + mouthEffects(slave); + } chastityEffects(slave); if (slave.bellyAccessory !== "none") { bellyAccessories(slave); @@ -395,25 +401,6 @@ App.SlaveAssignment.clothes = (function() { } else if (slave.collar === "uncomfortable leather" || slave.collar === "neck corset") { r.push(`The uncomfortable leather collar ${he}'s wearing <span class="gold">reminds ${him} to be afraid</span> every time ${he} turns ${his} head.`); slave.trust -= 1; - } else if (slave.collar === "dildo gag") { - r.push(`The dildo gag ${he}'s wearing <span class="gold">reminds ${him} to be afraid</span> with every breath ${he} must carefully take through ${his} nose.`); - slave.trust -= 1; - } else if (slave.collar === "ball gag") { - r.push(`The ball gag ${he}'s wearing keeps ${his} mouth filled and, since ${he} can't speak out, forces ${him} <span class="hotpink">to submit</span> to your will. ${He} <span class="gold">fears</span> for ${his} safety with every suppressed word.`); - slave.devotion++; - slave.trust -= 2; - } else if (slave.collar === "bit gag") { - r.push(`The uncomfortable bit gag ${he}'s wearing keeps ${his} mouth locked and, since ${he} can't speak out, forces ${him} <span class="hotpink">to submit</span> to your will. ${He} <span class="gold">fears</span> for ${his} safety with every suppressed word.`); - slave.devotion++; - slave.trust -= 2; - } else if (slave.collar === "porcelain mask") { - r.push(`The beautiful porcelain mask ${he}'s wearing slowly erodes ${his} identity, forcing ${him} <span class="hotpink">to submit</span> to your will. ${He} <span class="gold">questions</span> who ${he} is.`); - slave.devotion++; - slave.trust -= 2; - } else if (slave.collar === "massive dildo gag") { - r.push(`The enormous dildo gag ${he}'s wearing <span class="gold">terrifies ${him}</span> that ${he} will soon be choking down cocks of similar size. ${He} can feel ${his} throat stretching around the giant dildo, and <span class="mediumorchid">resents you</span> for tormenting ${him} this way.`); - slave.devotion -= 1; - slave.trust -= 2; } else if (slave.collar === "shock punishment") { r.push(`The shock collar ${he}'s wearing makes ${his} frequent, deserved punishments <span class="gold">immediate, inescapable,</span> and <span class="mediumorchid">awful.</span>`); slave.devotion -= 2; @@ -447,20 +434,63 @@ App.SlaveAssignment.clothes = (function() { r.push(`${He} <span class="hotpink">likes</span> how ${his} cow collar encourages everyone to touch ${his} udders.`); slave.devotion += 1; } - } else if (slave.collar === "ball gag" || slave.collar === "bit gag") { + } + } + } + + /** + * @param {App.Entity.SlaveState} slave + * + */ + function maskEffects(slave) { + if (slave.devotion <= 20) { + if (slave.collar === "porcelain mask") { + r.push(`The beautiful porcelain mask ${he}'s wearing slowly erodes ${his} identity, forcing ${him} <span class="hotpink">to submit</span> to your will. ${He} <span class="gold">questions</span> who ${he} is.`); + slave.devotion++; + slave.trust -= 2; + } + } else { + if (slave.collar === "porcelain mask") { if (slave.fetish === "submissive" && slave.fetishStrength > 95) { - r.push(`${He} <span class="hotpink">loves</span> how ${his} gag forces ${him} to keep silent.`); + r.push(`${He} <span class="hotpink">loves</span> how ${his} mask makes ${him} beautiful enough for you.`); slave.devotion += 1; } else if (slave.fetish === "submissive" || slave.energy > 95) { - r.push(`${He} <span class="hotpink">likes</span> how ${his} gag forces ${him} to keep silent.`); + r.push(`${He} <span class="hotpink">likes</span> how ${his} mask makes ${him} beautiful enough for you.`); slave.devotion += 1; } - } else if (slave.collar === "porcelain mask") { + } + } + } + + /** + * @param {App.Entity.SlaveState} slave + * + */ + function mouthEffects(slave) { + if (slave.devotion <= 20) { + if (slave.collar === "dildo gag") { + r.push(`The dildo gag ${he}'s wearing <span class="gold">reminds ${him} to be afraid</span> with every breath ${he} must carefully take through ${his} nose.`); + slave.trust -= 1; + } else if (slave.collar === "ball gag") { + r.push(`The ball gag ${he}'s wearing keeps ${his} mouth filled and, since ${he} can't speak out, forces ${him} <span class="hotpink">to submit</span> to your will. ${He} <span class="gold">fears</span> for ${his} safety with every suppressed word.`); + slave.devotion++; + slave.trust -= 2; + } else if (slave.collar === "bit gag") { + r.push(`The uncomfortable bit gag ${he}'s wearing keeps ${his} mouth locked and, since ${he} can't speak out, forces ${him} <span class="hotpink">to submit</span> to your will. ${He} <span class="gold">fears</span> for ${his} safety with every suppressed word.`); + slave.devotion++; + slave.trust -= 2; + } else if (slave.collar === "massive dildo gag") { + r.push(`The enormous dildo gag ${he}'s wearing <span class="gold">terrifies ${him}</span> that ${he} will soon be choking down cocks of similar size. ${He} can feel ${his} throat stretching around the giant dildo, and <span class="mediumorchid">resents you</span> for tormenting ${him} this way.`); + slave.devotion -= 1; + slave.trust -= 2; + } + } else { + if (slave.collar === "ball gag" || slave.collar === "bit gag") { if (slave.fetish === "submissive" && slave.fetishStrength > 95) { - r.push(`${He} <span class="hotpink">loves</span> how ${his} mask makes ${him} beautiful enough for you.`); + r.push(`${He} <span class="hotpink">loves</span> how ${his} gag forces ${him} to keep silent.`); slave.devotion += 1; } else if (slave.fetish === "submissive" || slave.energy > 95) { - r.push(`${He} <span class="hotpink">likes</span> how ${his} mask makes ${him} beautiful enough for you.`); + r.push(`${He} <span class="hotpink">likes</span> how ${his} gag forces ${him} to keep silent.`); slave.devotion += 1; } } diff --git a/src/endWeek/saPorn.js b/src/endWeek/saPorn.js index e5b71af2f88ada3a66883cf9c0e0454614a62560..2f51af66f0c395659b80586f570a1b217f323df3 100644 --- a/src/endWeek/saPorn.js +++ b/src/endWeek/saPorn.js @@ -114,7 +114,7 @@ App.SlaveAssignment.porn = (function() { decayRate = 5000; if (slave.fuckdoll > 0) { face = 50; - } else if (slave.collar === "porcelain mask") { + } else if (slave.faceAccessory === "porcelain mask") { face = 20; } else { face = slave.face * 4; @@ -124,7 +124,7 @@ App.SlaveAssignment.porn = (function() { decayRate = 500; if (slave.fuckdoll > 0) { face = 20; - } else if (slave.collar === "porcelain mask") { + } else if (slave.faceAccessory === "porcelain mask") { face = 50; } else { face = slave.face * 2; @@ -134,7 +134,7 @@ App.SlaveAssignment.porn = (function() { decayRate = 30; if (slave.fuckdoll > 0) { face = 0; - } else if (slave.collar === "porcelain mask") { + } else if (slave.faceAccessory === "porcelain mask") { face = 0; } else { face = slave.face / 20; @@ -167,7 +167,7 @@ App.SlaveAssignment.porn = (function() { function faceCommentary(slave) { if (slave.fuckdoll > 0) { return; - } else if (slave.collar === "porcelain mask") { + } else if (slave.faceAccessory === "porcelain mask") { r += `${His} mask adds an air of mystery to ${him}, `; if (slave.porn.prestige > 1) { r += `but people wonder if ${he} is trying to hide something. `; diff --git a/src/interaction/main/walkPast.js b/src/interaction/main/walkPast.js index 22c8ef88c804b6eb45cac0f692cbec138e61d7e4..587d179da1db92bcb9d5f8dcaaed87a8c8fceac9 100644 --- a/src/interaction/main/walkPast.js +++ b/src/interaction/main/walkPast.js @@ -9120,7 +9120,7 @@ globalThis.walkPast = (function() { t += `<<faceDescription>>`; t += `<<mouthDescription>>`; switch (slave.collar) { - case "a Fuckdoll suit": + case "a Fuckdoll suit": // TODO: there does not seem to be documentation for a fuckdoll suit collar. t += `${His} suit is expressly designed to encourage use of ${his} face hole.`; break; case "uncomfortable leather": @@ -9133,12 +9133,6 @@ globalThis.walkPast = (function() { case "preg biometrics": t += `${His} collar reveals everything about ${his} womb, bringing eyes straight to ${his} belly before drawing them back to ${his} neck.`; break; - case "dildo gag": - t += `${His} ring gag would make ${him} ready for oral service, as soon as the formidable dildo it secures down ${his} throat is removed.`; - break; - case "massive dildo gag": - t += `Your eyes are drawn to the distinct bulge in ${his} throat caused by the enormous dildo in it, though ${his} mouth would only be suitable for the largest of cocks right now.`; - break; case "shock punishment": t += `${His} shock collar rests threateningly at ${his} throat, ready to compel ${him} to do anything you wish.`; break; @@ -9173,23 +9167,38 @@ globalThis.walkPast = (function() { case "ancient Egyptian": t += `${His} wesekh glints richly as ${he} moves, sparkling with opulence and sensuality.`; break; + default: + t += `${His} unadorned `; + if (V.PC.dick !== 0) { + t += `throat is just waiting to be wrapped around a thick shaft.`; + } else { + t += `lips are just begging for a cunt to lavish attention on.`; + } + } + switch (slave.mouthAccessory ) { + case "dildo gag": + t += `${His} ring gag would make ${him} ready for oral service, as soon as the formidable dildo it secures down ${his} throat is removed.`; + break; + case "massive dildo gag": + t += `Your eyes are drawn to the distinct bulge in ${his} throat caused by the enormous dildo in it, though ${his} mouth would only be suitable for the largest of cocks right now.`; + break; case "ball gag": t += `${His} ball gag uncomfortably holds ${his} jaw apart as it fills ${his} mouth.`; break; case "bit gag": t += `${His} bit gag uncomfortably keeps ${him} from closing ${his} jaw; drool visibly pools along the corners of ${his} mouth, where the rod forces back ${his} cheeks.`; break; + case "ring gag": + // TODO: add desc + break; + } + + switch (slave.faceAccessory ) { case "porcelain mask": t += `${His} beautiful porcelain mask hides ${his} face and any unsightly facial features.`; break; - default: - t += `${His} unadorned `; - if (V.PC.dick !== 0) { - t += `throat is just waiting to be wrapped around a thick shaft.`; - } else { - t += `lips are just begging for a cunt to lavish attention on.`; - } } + if (jsRandom(1, 3) === 1) { V.target = "FKiss"; } else { diff --git a/src/js/descriptionWidgets.js b/src/js/descriptionWidgets.js index 86a273ae8a5ed236e7445f7f2351bc0f2d87d426..1966292bfecd805f3b4f4c8987fba3a2d17bec9d 100644 --- a/src/js/descriptionWidgets.js +++ b/src/js/descriptionWidgets.js @@ -1727,3 +1727,37 @@ App.Desc.sexualHistory = function(slave) { return r; }; + +App.Desc.faceAccessory = function(slave) { + const {He, his} = getPronouns(slave); + switch (slave.faceAccessory) { + case "porcelain mask": + return `${He} is wearing a beautiful porcelain mask to hide ${his} unsightly facial features.`; + } +}; + +App.Desc.mouthAccessory = function(slave) { + const {He, him, his, himself, girl} = getPronouns(slave); + let r = ``; + switch (slave.mouthAccessory ) { + case "ball gag": + r += `${He} is wearing a mouth filling, `; + if (slave.makeup === 3 || slave.makeup === 6 || slave.makeup === 8) { + r += `slave.hColor`; + } else { + r += `red`; + } + r += `ball-shaped gag that prevents ${him} from uttering a word while keeping ${him} uncomfortably aware of ${his} status.`; + break; + case "bit gag": + r += `${He} is wearing a jaw spreading, bar-shaped gag that prevents ${him} from speaking while keeping $him uncomfortably aware of ${his} status.`; + break; + case "dildo gag": + r += `${He} is wearing a sturdy leather collar that continues up to restrict ${his} jaw as well. It holds a ring gag in ${his} mouth, into which slots a formidable inward-facing dildo that reaches down ${his} throat. It can be removed to facefuck ${him}.`; + break; + case "massive dildo gag": + r += `${He} is wearing a sturdy leather collar that continues up to restrict ${his} jaw as well. It acts as an anchor for an enormous inward-facing dildo that reaches deep down ${his} throat. The sheer size of the phallus forces ${his} mouth as wide as it will go and considerably bulges ${his} throat. Fortunately for ${him}, it is designed to allow ${him} to be able to breathe through ${his} nose; though when removed, the poor ${girl} finds ${himself} incapable of closing ${his} mouth for some time.`; + break; + } + return r; +}; diff --git a/src/js/eventSelectionJS.js b/src/js/eventSelectionJS.js index 0bda43a6d0514d9952b5887b240c41b42c5d86a9..212e5a2b7d1e3d18a1ba3d1687b55917add380ba 100644 --- a/src/js/eventSelectionJS.js +++ b/src/js/eventSelectionJS.js @@ -816,7 +816,7 @@ globalThis.generateRandomEventPoolStandard = function(eventSlave) { } /* closes mute exempt */ if (eventSlave.devotion > 20) { - if (["ball gag", "bit gag", "dildo gag", "massive dildo gag"].includes(eventSlave.collar)) { + if (["ball gag", "bit gag", "dildo gag", "massive dildo gag"].includes(eventSlave.mouthAccessory )) { State.variables.RESSevent.push("gagged slave"); } } @@ -1025,7 +1025,7 @@ globalThis.generateRandomEventPoolStandard = function(eventSlave) { if (eventSlave.voice > 0) { if (eventSlave.lips <= 95) { - if (!["ball gag", "bit gag", "dildo gag", "massive dildo gag"].includes(eventSlave.collar)) { + if (!["ball gag", "bit gag", "dildo gag", "massive dildo gag"].includes(eventSlave.mouthAccessory)) { if (eventSlave.accent === 3) { if (eventSlave.devotion <= 50) { if (eventSlave.trust > -10) { @@ -2226,7 +2226,7 @@ globalThis.generateRandomEventPoolServant = function(eventSlave) { } /* closes mute exempt */ if (eventSlave.devotion > 20) { - if (["ball gag", "bit gag", "dildo gag", "massive dildo gag"].includes(eventSlave.collar)) { + if (["ball gag", "bit gag", "dildo gag", "massive dildo gag"].includes(eventSlave.mouthAccessory)) { State.variables.RESSevent.push("gagged slave"); } } diff --git a/src/js/statsChecker/statsChecker.js b/src/js/statsChecker/statsChecker.js index a4e164f4b5b78184c147bd750533030f89995935..c30d8c5bf8ea0cee0929d01a6990a5b7e44e9318 100644 --- a/src/js/statsChecker/statsChecker.js +++ b/src/js/statsChecker/statsChecker.js @@ -766,13 +766,15 @@ globalThis.canTalk = function(slave, checkLanguage = true) { return false; } else if (slave.lips > 95) { return false; - } else if (slave.collar === "dildo gag") { + } else if (slave.mouthAccessory === "dildo gag") { return false; - } else if (slave.collar === "massive dildo gag") { + } else if (slave.mouthAccessory === "massive dildo gag") { return false; - } else if (slave.collar === "ball gag") { + } else if (slave.mouthAccessory === "ball gag") { return false; - } else if (slave.collar === "bit gag") { + } else if (slave.mouthAccessory === "bit gag") { + return false; + } else if (slave.mouthAccessory === "ring gag") { return false; } return true; diff --git a/src/npc/interaction/fDance.tw b/src/npc/interaction/fDance.tw index c02b251217cac39298301e0494713f3bfccaa1d7..5f6dd21e53418ea14260d3f34684ba42a5eeb376 100644 --- a/src/npc/interaction/fDance.tw +++ b/src/npc/interaction/fDance.tw @@ -164,68 +164,84 @@ $His face is but $he is to terrified of you to see what happens if $he resists <<else>> and refuses to comply. In order to make $him obey, a leash is attached from - <<switch getSlave($AS).collar>> - <<case "uncomfortable leather">> - the steel ring on $his leather collar - <<case "dildo gag">> - a ring on $his gag strap - <<case "massive dildo gag">> - a ring on $his gag strap - <<case "preg biometrics">> - $his collar - <<case "silk ribbon">> - $his silk ribbon - <<case "tight steel">> - $his steel collar - <<case "porcelain mask">> - <<if getSlave($AS).nosePiercing == 2>> - $his nose ring - <<elseif getSlave($AS).nipplesPiercing == 2>> - $his nipple chain - <<else>> - a collar that is placed around $his neck - <</if>> - <<case "shock punishment">> - $his shock collar - <<case "neck corset">> - an O-ring at the from of $his neck corset - <<case "stylish leather">> - $his collar - <<case "satin choker">> - $his choker collar - <<case "heavy gold">> - $He is wearing a heavy gold collar, an outstanding bit of ostentation. - <<case "pretty jewelry">> - $his ornate collar - <<case "bell collar">> - the ring attaching $his bell to $his collar, and - <<case "leather with cowbell">> - the ring attaching $his bell to $his collar, and - <<case "bowtie">> - $his bowtie collar - <<case "ancient Egyptian">> - <<if getSlave($AS).nosePiercing == 2>> - $his nose ring - <<elseif getSlave($AS).nipplesPiercing == 2>> - $his nipple chain - <<else>> - $his wesekh - <</if>>. - <<case "ball gag">> - a ring on the back of $his gag - <<case "bit gag">> - the ring on the side of $his bit - <<case "cruel retirement counter" "nice retirement counter">> - $his retirement counter - <<case "default">> - <<if getSlave($AS).nosePiercing == 2>> - $his nose ring - <<elseif getSlave($AS).nipplesPiercing == 2>> - $his nipple chain - <<else>> - a collar that is placed on $his neck for the occasion, and - <</if>> - <</switch>> + <<if getSlave($AS).collar != "none">> + <<switch getSlave($AS).collar>> + <<case "uncomfortable leather">> + the steel ring on $his leather collar + <<case "dildo gag">> + a ring on $his gag strap + <<case "massive dildo gag">> + a ring on $his gag strap + <<case "preg biometrics">> + $his collar + <<case "silk ribbon">> + $his silk ribbon + <<case "tight steel">> + $his steel collar + <<case "shock punishment">> + $his shock collar + <<case "neck corset">> + an O-ring at the from of $his neck corset + <<case "stylish leather">> + $his collar + <<case "satin choker">> + $his choker collar + <<case "heavy gold">> + $He is wearing a heavy gold collar, an outstanding bit of ostentation. + <<case "pretty jewelry">> + $his ornate collar + <<case "bell collar">> + the ring attaching $his bell to $his collar, and + <<case "leather with cowbell">> + the ring attaching $his bell to $his collar, and + <<case "bowtie">> + $his bowtie collar + <<case "ancient Egyptian">> + <<if getSlave($AS).nosePiercing == 2>> + $his nose ring + <<elseif getSlave($AS).nipplesPiercing == 2>> + $his nipple chain + <<else>> + $his wesekh + <</if>>. + <<case "ball gag">> + a ring on the back of $his gag + <<case "bit gag">> + the ring on the side of $his bit + <<case "cruel retirement counter" "nice retirement counter">> + $his retirement counter + <<case "default">> + <<if getSlave($AS).nosePiercing == 2>> + $his nose ring + <<elseif getSlave($AS).nipplesPiercing == 2>> + $his nipple chain + <<else>> + a collar that is placed on $his neck for the occasion, and + <</if>> + <</switch>> + <<elseif getSlave($AS).mouthAccessory != "none">> + <<switch getSlave($AS).collar>> + <<case "dildo gag">> + a ring on $his gag strap + <<case "massive dildo gag">> + a ring on $his gag strap + <<case "ball gag">> + a ring on the back of $his gag + <<case "bit gag">> + the ring on the side of $his bit + <</switch>> + <<elseif getSlave($AS).faceAccessory != "none">> + <<switch getSlave($AS).collar>> + <<case "porcelain mask">> + <<if getSlave($AS).nosePiercing == 2>> + $his nose ring + <<elseif getSlave($AS).nipplesPiercing == 2>> + $his nipple chain + <<else>> + a collar that is placed around $his neck + <</if>> + <</switch>> + <</if>> to the pole in order to keep $him from getting down. Whenever $he stops dancing the chain is tightened a bit more, <<switch getSlave($AS).collar>> <<case "uncomfortable leather">> diff --git a/src/npc/surgery/surgery.js b/src/npc/surgery/surgery.js index a1b984d2f947c61a89190d2b613eb6c4f34d19e0..3edc3d395cd2a3dbb622d1c610c7efc7f2d61d89 100644 --- a/src/npc/surgery/surgery.js +++ b/src/npc/surgery/surgery.js @@ -1104,6 +1104,8 @@ globalThis.beginFuckdoll = function(slave) { slave.choosesOwnClothes = 0; slave.clothes = "a Fuckdoll suit"; slave.collar = "none"; + slave.faceAccessory = "none"; + slave.mouthAccessory = "none"; if ((!hasAnyLegs(slave)) || (slave.shoes !== "none")) { slave.shoes = "heels"; } diff --git a/src/pregmod/widgets/bodyswapWidgets.tw b/src/pregmod/widgets/bodyswapWidgets.tw index 0449dcf8102d1587e143f62490162e08fedb306d..c69a68d7bdb3ea609b87f64eca017a2cf397ab43 100644 --- a/src/pregmod/widgets/bodyswapWidgets.tw +++ b/src/pregmod/widgets/bodyswapWidgets.tw @@ -194,6 +194,8 @@ <<set $args[0].dietMilk = $args[1].dietMilk>> <<set $args[0].clothes = $args[1].clothes>> <<set $args[0].collar = $args[1].collar>> + <<set $args[0].faceAccessory = $args[1].faceAccessory >> + <<set $args[0].mouthAccessory = $args[1].mouthAccessory >> <<set $args[0].shoes = $args[1].shoes>> <<set $args[0].makeup = $args[1].makeup>> <<set $args[0].nails = $args[1].nails>> diff --git a/src/uncategorized/REFI.tw b/src/uncategorized/REFI.tw index df85f4d12a76f15326e0951bf1779262215daf52..41a89d8a37cd6c1fd1f6a72cefaf84eb9817f2aa 100644 --- a/src/uncategorized/REFI.tw +++ b/src/uncategorized/REFI.tw @@ -865,7 +865,7 @@ There was a glint of envy <<if canSee($activeSlave)>>in $his eyes when $he saw<< <<= VCheck.Vaginal()>> <<else>> $He hasn't recovered before $he feels - <<switch $activeSlave.collar>> + <<switch $activeSlave.mouthAccessory>> <<case "dildo gag" "massive dildo gag">> the relief of the dildo gag being drawn from $his throat before <<case "ball gag" "bit gag">> @@ -1000,7 +1000,7 @@ There was a glint of envy <<if canSee($activeSlave)>>in $his eyes when $he saw<< <<= VCheck.Vaginal()>> <<else>> $He hasn't recovered before $he feels - <<switch $activeSlave.collar>> + <<switch $activeSlave.mouthAccessory>> <<case "dildo gag" "massive dildo gag">> the relief of the dildo gag being drawn from $his throat before <<case "ball gag" "bit gag">> diff --git a/src/uncategorized/RESS.tw b/src/uncategorized/RESS.tw index fa3e61a47de0a40fc137528f92b171909eb9dd64..d712bc5cacaff55892324bcf4ccdaad76e0ceb84 100644 --- a/src/uncategorized/RESS.tw +++ b/src/uncategorized/RESS.tw @@ -2908,12 +2908,11 @@ $He comes to a stop right beside your elbow, waiting for further direction, just <<case "tittymonster inspection">> You enter your office from other business a few minutes after the scheduled start of <<= App.UI.slaveDescriptionDialog($activeSlave)>>'s inspection. The <<if $boobAccessibility == 1>>accessibility aids for slaves with immobilizing breasts<<else>>slaves who helped $him in<</if>> have gone, leaving $him waiting for you in front of your desk. The sight is an arresting one. $He's kneeling, but $his boobs are so enormous that they're resting on the ground in front of $him, completely concealing $his body below the chest<<if $activeSlave.belly >= 120000>>, save for the protruding mass of $his <<if $activeSlave.pregType > 8>>hyper pregnant<<elseif $activeSlave.pregType > 4>><<print pregNumberName($activeSlave.pregType, 1)>>-filled<<else>>overly distended<</if>> belly<</if>>. With $his arm<<if hasBothArms($activeSlave)>>s<</if>> tucked back, and $his torso, <<if $activeSlave.belly < 120000>><<if $activeSlave.bellyPreg > 100>>pregnancy,<<elseif $activeSlave.belly > 100>>swollen stomach,<<else>>abdomen,<</if>><</if>> and legs hidden, $he appears to consist of a <<if $activeSlave.face > 95>>gorgeous<<elseif $activeSlave.face > 50>>beautiful<<elseif $activeSlave.face >= 10>>pretty<<elseif $activeSlave.face >= 0>>nice<<else>>homely<</if>>, $activeSlave.faceShape face, a -<<switch $activeSlave.collar>> -<<case "none" "dildo gag" "ball gag" "bit gag" "massive dildo gag">> - bare -<<default>> +<<if $activeSlave.collar == "none">> + none +<<else>> collared -<</switch>> +<</if>> neck, $activeSlave.skin, <<if $activeSlave.muscles > 95>>hugely muscled<<elseif $activeSlave.muscles > 30>>strong<<elseif $activeSlave.shoulders > 0>>broad<<elseif $activeSlave.shoulders < 0>>feminine<<elseif $activeSlave.muscles > 5>>toned<<else>>soft<</if>> shoulders, and below that, breasts<<if $activeSlave.belly >= 120000>> parted by $his _belly dome of a stomach<</if>>. $He greets you <<if $activeSlave.devotion > 50>>devotedly, behaving for all the world like $he's pleased to be<<elseif $activeSlave.devotion >= -20>>properly, with just a hint of unhappiness about being<<else>>with more than a hint of resentment over being<</if>> pinned to the floor by $his own tits. <<case "bonded love">> @@ -4155,13 +4154,13 @@ beside your desk to await further orders. It occurs to you, gazing down at your <<case "gagged slave">> You cross paths with <<= App.UI.slaveDescriptionDialog($activeSlave)>> as $he returns from $activeSlave.assignment after a long day. One of the things most readily apparent about $activeSlave.slaveName is the -<<if ($activeSlave.collar == "ball gag")>> +<<if ($activeSlave.mouthAccessory == "ball gag")>> ball gag keeping $his mouth filled, -<<elseif ($activeSlave.collar == "bit gag")>> +<<elseif ($activeSlave.mouthAccessory == "bit gag")>> cruel bit gag keeping $his jaw locked, -<<elseif ($activeSlave.collar == "dildo gag")>> +<<elseif ($activeSlave.mouthAccessory == "dildo gag")>> dildo gag filling $his mouth and throat, -<<elseif ($activeSlave.collar == "massive dildo gag")>> +<<elseif ($activeSlave.mouthAccessory == "massive dildo gag")>> dildo gag hugely distending $his throat, <</if>> the existence of which is a constant reminder to $him of $his submission to you and your immense power over $him. @@ -19380,7 +19379,7 @@ brought in to you. This time <<= App.UI.slaveDescriptionDialog($activeSlave)>> h <<link "Give $him something else to gag on">> <<replace "#result">> - As pleasant an image as $activeSlave.slaveName's mouth filled by a $activeSlave.collar is, one of $his mouth's primary purposes is still to provide you with ample <<if $PC.dick != 0>>blowjobs<<if $PC.vagina != -1>> and <</if>><</if>><<if $PC.vagina != -1>>cunnilingus<</if>>. With $activeSlave.slaveName already kneeling, it is merely a matter of undoing $his gag before you can put $his mouth to work. + As pleasant an image as $activeSlave.slaveName's mouth filled by a $activeSlave.mouthAccessory is, one of $his mouth's primary purposes is still to provide you with ample <<if $PC.dick != 0>>blowjobs<<if $PC.vagina != -1>> and <</if>><</if>><<if $PC.vagina != -1>>cunnilingus<</if>>. With $activeSlave.slaveName already kneeling, it is merely a matter of undoing $his gag before you can put $his mouth to work. <<if $activeSlave.skill.oral >= 100>> Though $he has spent much time gagged, $his mastery at giving oral is unaffected. <<elseif $activeSlave.skill.oral > 60>> @@ -19412,20 +19411,20 @@ brought in to you. This time <<= App.UI.slaveDescriptionDialog($activeSlave)>> h <</link>> <br><<link "Remove the gag for a few minutes">> <<replace "#result">> - You wordlessly remove the $activeSlave.collar and watch as $activeSlave.slaveName opens and closes $his mouth testingly, as if $he has forgotten what it feels like to do so without obstruction. Though you eventually return to the gag to its rightful place in $his mouth, $he @@.mediumaquamarine;trusts you more@@ for granting $him a few moments respite from the gag. + You wordlessly remove the $activeSlave.mouthAccessory and watch as $activeSlave.slaveName opens and closes $his mouth testingly, as if $he has forgotten what it feels like to do so without obstruction. Though you eventually return to the gag to its rightful place in $his mouth, $he @@.mediumaquamarine;trusts you more@@ for granting $him a few moments respite from the gag. <<set $activeSlave.trust += 4>> <</replace>> <</link>> <br><<link "Torment $him with the gag">> <<replace "#result">> - Though having a $activeSlave.collar constrict $his mouth is torment enough, you take the time to linger and add to $his torturous existence. $activeSlave.slaveName soon discovers that the straps of a gag can always be made tighter, the - <<if ($activeSlave.collar == "ball gag")>> + Though having a $activeSlave.mouthAccessory constrict $his mouth is torment enough, you take the time to linger and add to $his torturous existence. $activeSlave.slaveName soon discovers that the straps of a gag can always be made tighter, the + <<if ($activeSlave.mouthAccessory == "ball gag")>> ball can always be made larger, - <<elseif ($activeSlave.collar == "bit gag")>> + <<elseif ($activeSlave.mouthAccessory == "bit gag")>> the bit can always be made thicker, - <<elseif ($activeSlave.collar == "dildo gag")>> + <<elseif ($activeSlave.mouthAccessory == "dildo gag")>> the dildo can always be made larger, - <<elseif ($activeSlave.collar == "massive dildo gag")>> + <<elseif ($activeSlave.mouthAccessory == "massive dildo gag")>> the dildo can always be made wider and longer, <</if>> and the punishments rendered for daring to show any discomfort can always be harsher and stricter. Come the end of your session with $him, $activeSlave.slaveName <<if $activeSlave.fetish == "masochist">> is mortified by the intensity of $his orgasms, @@.hotpink;and more convinced than ever that $he's a pain slut,@@ and yet<</if>> @@.gold;scuttles away quickly, having learnt a harsh lesson about your power over $his body.@@ diff --git a/src/uncategorized/dairyReport.tw b/src/uncategorized/dairyReport.tw index 7481e8a2993a5674152e1d566ab0eb4f06196905..e975241557b4f9072f6df7b7420ce4c531bb3ed9 100644 --- a/src/uncategorized/dairyReport.tw +++ b/src/uncategorized/dairyReport.tw @@ -365,7 +365,7 @@ <<set $slaves[$i].diet = "healthy">> <</if>> <<if $dairyRestraintsSetting > 1>> - <<set $slaves[$i].collar = "none", $slaves[$i].choosesOwnClothes = 0, $slaves[$i].clothes = "no clothing", $slaves[$i].vaginalAccessory = "none", $slaves[$i].vaginalAttachment = "none", $slaves[$i].dickAccessory = "none", $slaves[$i].buttplug = "none", $slaves[$i].chastityAnus = 0, $slaves[$i].chastityPenis = 0, $slaves[$i].chastityVagina = 0>> + <<set $slaves[$i].collar = "none", $slaves[$i].faceAccessory = "none", $slaves[$i].mouthAccessory = "none", $slaves[$i].choosesOwnClothes = 0, $slaves[$i].clothes = "no clothing", $slaves[$i].vaginalAccessory = "none", $slaves[$i].vaginalAttachment = "none", $slaves[$i].dickAccessory = "none", $slaves[$i].buttplug = "none", $slaves[$i].chastityAnus = 0, $slaves[$i].chastityPenis = 0, $slaves[$i].chastityVagina = 0>> <</if>> <<switch $dairyDecoration>> <<case "Arabian Revivalist" "Aztec Revivalist" "Chattel Religionist" "Chinese Revivalist" "Degradationist" "Edo Revivalist" "Egyptian Revivalist" "Roman Revivalist" "Subjugationist" "Supremacist">> diff --git a/src/uncategorized/longSlaveDescription.tw b/src/uncategorized/longSlaveDescription.tw index 1ae369626da629dd78ddb72c359497420ce333a4..82cb1109e2488a930f43cb0df1d06e543e66a0ea 100644 --- a/src/uncategorized/longSlaveDescription.tw +++ b/src/uncategorized/longSlaveDescription.tw @@ -1902,6 +1902,8 @@ $He is <<if $activeSlave.fuckdoll == 0>> <<collarDescription>> + <<= App.Desc.faceAccessory($activeSlave)>> + <<= App.Desc.mouthAccessory($activeSlave)>> <<if ($activeSlave.relationship > 4)>> <<if hasAnyArms($activeSlave)>> $He has a simple gold band on the little finger of $his <<if !hasLeftArm($activeSlave)>>right<<else>>left<</if>> hand. diff --git a/src/uncategorized/randomNonindividualEvent.tw b/src/uncategorized/randomNonindividualEvent.tw index 384aa92f8749652c400a601dfe98500dd5098eaf..9d62a044c20d7b1c7904f274ca2a65b5a482c25c 100644 --- a/src/uncategorized/randomNonindividualEvent.tw +++ b/src/uncategorized/randomNonindividualEvent.tw @@ -187,7 +187,7 @@ <</if>> <<elseif ($slaves[$i].fetish == "cumslut")>> <<if ($cumslutID == 0)>> - <<if !["dildo gag", "massive dildo gag", "ball gag", "bit gag"].includes($slaves[$i].collar)>> + <<if !["dildo gag", "massive dildo gag", "ball gag", "bit gag"].includes($slaves[$i].mouthAccessory)>> <<set $cumslutID = $slaves[$i].ID>> <</if>> <</if>> diff --git a/src/uncategorized/reBoomerang.tw b/src/uncategorized/reBoomerang.tw index ed98acb50cd33914c9753acec6f6229369d93d0f..1343e924d6501ee9ad55bc9f81b5b830a210a314 100644 --- a/src/uncategorized/reBoomerang.tw +++ b/src/uncategorized/reBoomerang.tw @@ -18,7 +18,7 @@ Your work is interrupted by $assistant.name with an alert from the entrance to t brings up the relevant feeds. There's a naked body crumpled pathetically against one wall of the entryway, beneath the communications panel. It's <<= SlaveFullName($activeSlave)>>, whom you sold _weeks weeks ago. $He's looking up into one of the cameras plaintively. "Plea<<s>>e take me back," $he whispers, not wanting to draw the attention of passersby, and knowing that $his faint words will be picked up and amplified for you. -<<set $activeSlave.collar = "none", $activeSlave.choosesOwnClothes = 0, $activeSlave.clothes = "no clothing", $activeSlave.buttplug = "none", $activeSlave.vaginalAccessory = "none", $activeSlave.dickAccessory = "none", $activeSlave.chastityAnus = 0, $activeSlave.chastityPenis = 0, $activeSlave.chastityVagina = 0>> +<<set $activeSlave.collar = "none", $activeSlave.faceAccessory = "none", $activeSlave.mouthAccessory = "none", $activeSlave.choosesOwnClothes = 0, $activeSlave.clothes = "no clothing", $activeSlave.buttplug = "none", $activeSlave.vaginalAccessory = "none", $activeSlave.dickAccessory = "none", $activeSlave.chastityAnus = 0, $activeSlave.chastityPenis = 0, $activeSlave.chastityVagina = 0>> <<run setHealth($activeSlave, jsRandom(-40, -25), $activeSlave.health.shortDamage + jsRandom(0, 10), $activeSlave.health.longDamage + jsRandom(0, 10))>> /* ------------------ pregnancy setup start here----------------- */ diff --git a/src/utility/descriptionWidgetsStyle.tw b/src/utility/descriptionWidgetsStyle.tw index 66c9faa27605e2950b953bd49ab01a52efdba21a..dc89add51c0cf72db20c5faa2458a671ae4fcc6c 100644 --- a/src/utility/descriptionWidgetsStyle.tw +++ b/src/utility/descriptionWidgetsStyle.tw @@ -3744,10 +3744,6 @@ $His <<switch $activeSlave.collar>> <<case "uncomfortable leather">> $He is wearing an uncomfortable leather collar with a useful steel ring in front. - <<case "dildo gag">> - $He is wearing a sturdy leather collar that continues up to restrict $his jaw as well. It holds a ring gag in $his mouth, into which slots a formidable inward-facing dildo that reaches down $his throat. It can be removed to facefuck $him. - <<case "massive dildo gag">> - $He is wearing a sturdy leather collar that continues up to restrict $his jaw as well. It acts as an anchor for an enormous inward-facing dildo that reaches deep down $his throat. The sheer size of the phallus forces $his mouth as wide as it will go and considerably bulges $his throat. Fortunately for $him, it is designed to allow $him to be able to breathe through $his nose; though when removed, the poor $girl finds $himself incapable of closing $his mouth for some time. <<case "preg biometrics">> <<if $activeSlave.pregSource > 0>> <<set _daddy = findFather($activeSlave.pregSource), _daddy = _daddy.slaveName>> @@ -3809,8 +3805,6 @@ $His $He is wearing a tight silk ribbon fitted to $his neck, it is oddly elegant. <<case "tight steel">> $He is wearing a tight steel collar whose restricting metal touch $he cannot escape. - <<case "porcelain mask">> - $He is wearing a beautiful porcelain mask to hide $his unsightly facial features. <<case "shock punishment">> $He is wearing a utilitarian collar with a punishment device at $his throat to administer agonizing shocks. <<case "neck corset">> @@ -3831,10 +3825,6 @@ $His $He is wearing the collar from a white formal shirt, and a black bowtie, though these conceal an actual collar that works perfectly well for restraint. <<case "ancient Egyptian">> $He is wearing a beautiful golden wesekh, a collar that spreads from $his neck out onto both shoulders and down $his front. - <<case "ball gag">> - $He is wearing a mouth filling, <<if $activeSlave.makeup == 3 || $activeSlave.makeup == 6 || $activeSlave.makeup == 8>>$activeSlave.hColor<<else>>red<</if>> ball-shaped gag that prevents $him from uttering a word while keeping $him uncomfortably aware of $his status. - <<case "bit gag">> - $He is wearing a jaw spreading, bar-shaped gag that prevents $him from speaking while keeping $him uncomfortably aware of $his status. <<case "cruel retirement counter" "nice retirement counter">> $He is wearing a <<if $activeSlave.collar == "cruel retirement counter">>heavy metal collar<<else>>nice collar, almost a necklace,<</if>> with a small numerical display reading <<if $activeSlave.indenture > -1>>