diff --git a/compile b/compile index 1a35d073a5aa5d040fc7e1bf53d69570c3ac3829..8a76f4a062438c59397aee1a1ec5207296886c24 100755 --- a/compile +++ b/compile @@ -23,24 +23,35 @@ then ./sanityCheck fi -ARCH="$(uname -m)" -if [ "$ARCH" = "x86_64" ] -then +case "$(uname -m)" in +x86_64|amd64) echo "x64 arch" - ./devTools/tweeGo/tweego_nix64 -o bin/FC_pregmod.html src/ || build_failed="true" -elif echo "$ARCH" | grep -Ee '86$' > /dev/null -then + if [ "$(uname -s)" = "Darwin" ]; then + TWEEGO_EXE="./devTools/tweeGo/tweego_osx64" + else + TWEEGO_EXE="./devTools/tweeGo/tweego_nix64" + fi + ;; +x86|i[3-6]86) echo "x86 arch" - ./devTools/tweeGo/tweego_nix86 -o bin/FC_pregmod.html src/ || build_failed="true" -elif echo "$ARCH" | grep -Ee '^arm' > /dev/null -then + if [ "$(uname -s)" = "Darwin" ]; then + TWEEGO_EXE="./devTools/tweeGo/tweego_osx86" + else + TWEEGO_EXE="./devTools/tweeGo/tweego_nix86" + fi + ;; +arm*) echo "arm arch" # tweego doesn't provide arm binaries so you have to build it yourself export TWEEGO_PATH=devTools/tweeGo/storyFormats - tweego -o bin/FC_pregmod.html src/ || build_failed="true" -else + TWEEGO_EXE="tweego" + ;; +*) + echo "unsupported architecture" exit 2 -fi +esac + +$TWEEGO_EXE -o "bin/FC_pregmod.html" src/ || build_failed="true" # Revert AlphaDisclaimer for next compilation git checkout -- src/gui/mainMenu/AlphaDisclaimer.tw diff --git a/compile-git b/compile-git index e7c06d2d80ed5f6175056d209c10b802010f823c..a50b484b4223b4300b34187ef2e4be4917faf1f6 100755 --- a/compile-git +++ b/compile-git @@ -4,24 +4,36 @@ ./sanityCheck HASH="$(git rev-list -n 1 --abbrev-commit HEAD)" -ARCH="$(uname -m)" -if [ "$ARCH" = "x86_64" ] -then + +case "$(uname -m)" in +x86_64|amd64) echo "x64 arch" - ./devTools/tweeGo/tweego_nix64 -o "bin/FC_pregmod_$HASH.html" src/ -elif echo "$ARCH" | grep -Ee '86$' > /dev/null -then + if [ "$(uname -s)" = "Darwin" ]; then + TWEEGO_EXE="./devTools/tweeGo/tweego_osx64" + else + TWEEGO_EXE="./devTools/tweeGo/tweego_nix64" + fi + ;; +x86|i[3-6]86) echo "x86 arch" - ./devTools/tweeGo/tweego_nix86 -o "bin/FC_pregmod_$HASH.html" src/ -elif echo "$ARCH" | grep -Ee '^arm' > /dev/null -then + if [ "$(uname -s)" = "Darwin" ]; then + TWEEGO_EXE="./devTools/tweeGo/tweego_osx86" + else + TWEEGO_EXE="./devTools/tweeGo/tweego_nix86" + fi + ;; +arm*) echo "arm arch" # tweego doesn't provide arm binaries so you have to build it yourself export TWEEGO_PATH=devTools/tweeGo/storyFormats - tweego -o "bin/FC_pregmod_$HASH.html" src/ -else + TWEEGO_EXE="tweego" + ;; +*) + echo "unsupported architecture" exit 2 -fi +esac + +$TWEEGO_EXE -o "bin/FC_pregmod_$HASH.html" src/ #Make the output prettier, replacing \t with a tab and \n with a newline sed -i -e '/^<div id="store-area".*$/s/\\t/\t/g' -e '/^<div id="store-area".*$/s/\\n/\n/g' "bin/FC_pregmod_$HASH.html" diff --git a/devNotes/VersionChangeLog-Premod+LoliMod.txt b/devNotes/VersionChangeLog-Premod+LoliMod.txt index 787ce37a2e9560d46836f378110f9269ac00978d..de7ab53cea5149135b343d761255142a95c24983 100644 --- a/devNotes/VersionChangeLog-Premod+LoliMod.txt +++ b/devNotes/VersionChangeLog-Premod+LoliMod.txt @@ -2,6 +2,18 @@ 0.10.7.1-1.4.x +12/28/2018 + + 4 + -sent cloning back to cheatmode for more testing + -fixes + +12/27/2018 + + 3 + -added cloning + -fixes + 12/23/2018 2 diff --git a/devNotes/twine JS.txt b/devNotes/twine JS.txt index 108014eed3ccbebec0f85edcd3bca046c9fcac0b..a5942d34da89d9b0209087d742f67d948e1843da 100644 --- a/devNotes/twine JS.txt +++ b/devNotes/twine JS.txt @@ -3635,6 +3635,92 @@ window.numberWithCommas = function(x) { return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ","); }; +window.numberToWords = function (x) { + if (x === 0) { + return "zero" + } else { + var ONE_TO_NINETEEN = [ + "one", "two", "three", "four", "five", + "six", "seven", "eight", "nine", "ten", + "eleven", "twelve", "thirteen", "fourteen", "fifteen", + "sixteen", "seventeen", "eighteen", "nineteen" + ]; + + var TENS = [ + "ten", "twenty", "thirty", "forty", "fifty", + "sixty", "seventy", "eighty", "ninety" + ]; + + var SCALES = ["thousand", "million", "billion", "trillion"]; + + // helper function for use with Array.filter + function isTruthy(item) { + return !!item; + } + + // convert a number into "chunks" of 0-999 + function chunk(number) { + var thousands = []; + + while (number > 0) { + thousands.push(number % 1000); + number = Math.floor(number / 1000); + } + + return thousands; + } + + // translate a number from 1-999 into English + function inEnglish(number) { + var thousands, hundreds, tens, ones, words = []; + + if (number < 20) { + return ONE_TO_NINETEEN[number - 1]; // may be undefined + } + + if (number < 100) { + ones = number % 10; + tens = number / 10 | 0; // equivalent to Math.floor(number / 10) + + words.push(TENS[tens - 1]); + words.push(inEnglish(ones)); + + return words.filter(isTruthy).join("-"); + } + + hundreds = number / 100 | 0; + words.push(inEnglish(hundreds)); + words.push("hundred"); + words.push(inEnglish(number % 100)); + + return words.filter(isTruthy).join(" "); + } + + // append the word for a scale. Made for use with Array.map + function appendScale(chunk, exp) { + var scale; + if (!chunk) { + return null; + } + scale = SCALES[exp - 1]; + return [chunk, scale].filter(isTruthy).join(" "); + } + + var string = chunk(x) + .map(inEnglish) + .map(appendScale) + .filter(isTruthy) + .reverse() + .join(" "); + + } + if (x > 0) { + return string; + } else { + return "negative " + string; + } +}; + window.jsRandom = function(min,max) { return Math.floor(Math.random()*(max-min+1)+min); }; @@ -7531,6 +7617,10 @@ window.newSlave = function newSlave(slave) { } else { slave.pregWeek = 0; } + + if (slave.clone !== 0) { + slave.canRecruit = 0; + } if (V.familyTesting === 1) { slave.sisters = 0; @@ -7653,6 +7743,10 @@ window.newChild = function newChild(child) { child.childSurname = 0; } + if (child.clone !== 0) { + child.canRecruit = 0; + } + if (child.fuckdoll > 0) { child.pronoun = "it"; child.possessivePronoun = "its"; @@ -10308,6 +10402,7 @@ window.generateGenetics = (function() { let dadSkinIndex = father !== 0 ? (skinToMelanin[father.origSkin] || 11) : 8; let skinIndex = Math.round(Math.random() * (dadSkinIndex - momSkinIndex) + momSkinIndex); return [ + 'pure white', 'pure white', 'extremely pale', 'pale', @@ -11360,7 +11455,6 @@ window.WombImpregnateClone = function(actor, fCount, mother, motherOriginal, age } } - MissingParentIDCorrection(actor); }; window.WombProgress = function(actor, ageToAdd) { @@ -13894,11 +13988,12 @@ window.buildFamilyTree = function(slaves = State.variables.slaves, filterID) { }; var node_lookup = {}; var preset_lookup = { - '-2': 'Social elite', - '-3': 'Client', - '-4': 'Former master', - '-5': 'An arcology owner', - '-6': 'A citizen' + '-2': 'A citizen', + '-3': 'Former master', + '-4': 'An arcology owner', + '-5': 'Client', + '-6': 'Social elite', + '-7': 'Gene lab' }; var outdads = {}; var outmoms = {}; @@ -21981,12 +22076,14 @@ window.SlaveSummaryUncached = (function(){ else short_legacy_family(slave); r += `</span>`; + short_clone(slave); short_rival(slave); } else if (V.abbreviateMental === 2) { if (V.familyTesting === 1) long_extended_family(slave); else long_legacy_family(slave); + long_clone(slave); long_rival(slave); } if (slave.fuckdoll === 0) { @@ -25597,6 +25694,12 @@ window.SlaveSummaryUncached = (function(){ } } + function short_clone(slave) { + if (slave.clone != 0) { + r += ` Clone`; + } + } + function short_rival(slave) { if (slave.rivalry !== 0) { r += ` `; @@ -25786,6 +25889,12 @@ window.SlaveSummaryUncached = (function(){ } } + function long_clone(slave) { + if (slave.clone != 0) { + r += ` <span class="skyblue">Clone of ${slave.clone}.</span>`; + } + } + function long_rival(slave) { if (slave.rivalry !== 0) { r += ` `; @@ -35693,6 +35802,10 @@ window.SFBC = function() { V.SF.Squad.Satellite = V.SF.Squad.Sat; delete V.SF.Squad.Sat; } } + if (V.SF.Squad != undefined && V.SF.Squad.Satellite.lv === undefined) { + V.SF.Squad.Sat = {lv:V.SF.Squad.Satellite, InOrbit:0}; + V.SF.Squad.Satellite = V.SF.Squad.Sat; delete V.SF.Squad.Sat; + } } } }; diff --git a/devTools/tweeGo/storyFormats/sugarcube-2/header.html b/devTools/tweeGo/storyFormats/sugarcube-2/header.html index e050930450fe4e68a9ae9a8e5c60e0de87abd90c..1b18c3f17cd1bb59a361b4ef4b524398cbf18240 100644 --- a/devTools/tweeGo/storyFormats/sugarcube-2/header.html +++ b/devTools/tweeGo/storyFormats/sugarcube-2/header.html @@ -102,6 +102,11 @@ var saveAs=saveAs||navigator.msSaveBlob&&navigator.msSaveBlob.bind(navigator)||f <style id="style-ui" type="text/css">#ui-dialog-body.settings [id|=setting-body]>div:first-child{display:table;width:100%}#ui-dialog-body.settings [id|=setting-label]{display:table-cell;padding:.4em 2em .4em 0}#ui-dialog-body.settings [id|=setting-label]+div{display:table-cell;min-width:8em;text-align:right;vertical-align:middle;white-space:nowrap}#ui-dialog-body.list{padding:0}#ui-dialog-body.list ul{margin:0;padding:0;list-style:none;border:1px solid transparent}#ui-dialog-body.list li{margin:0}#ui-dialog-body.list li:not(:first-child){border-top:1px solid #444}#ui-dialog-body.list li a{display:block;padding:.25em .75em;border:1px solid transparent;color:#eee;text-decoration:none}#ui-dialog-body.list li a:hover{background-color:#333;border-color:#eee}#ui-dialog-body.saves{padding:0 0 1px}#ui-dialog-body.saves>:not(:first-child){border-top:1px solid #444}#ui-dialog-body.saves table{border-spacing:0;width:100%}#ui-dialog-body.saves tr:not(:first-child){border-top:1px solid #444}#ui-dialog-body.saves td{padding:.33em .33em}#ui-dialog-body.saves td:first-child{min-width:1.5em;text-align:center}#ui-dialog-body.saves td:nth-child(3){line-height:1.2}#ui-dialog-body.saves td:last-child{text-align:right}#ui-dialog-body.saves .empty{color:#999;speak:none;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}#ui-dialog-body.saves .datestamp{font-size:75%;margin-left:1em}#ui-dialog-body.saves ul.buttons li{padding:.4em}#ui-dialog-body.saves ul.buttons>li+li>button{margin-left:.2em}#ui-dialog-body.saves ul.buttons li:last-child{float:right}#ui-dialog-body.settings div[id|=header-body]{margin:1em 0}#ui-dialog-body.settings div[id|=header-body]:first-child{margin-top:0}#ui-dialog-body.settings div[id|=header-body]:not(:first-child){border-top:1px solid #444;padding-top:1em}#ui-dialog-body.settings div[id|=header-body]>*{margin:0}#ui-dialog-body.settings h2[id|=header-heading]{font-size:1.375em}#ui-dialog-body.settings p[id|=header-desc],#ui-dialog-body.settings p[id|=setting-desc]{font-size:87.5%;margin:0 0 0 .5em}#ui-dialog-body.settings div[id|=setting-body]+div[id|=setting-body]{margin:1em 0}#ui-dialog-body.settings [id|=setting-control]{white-space:nowrap}#ui-dialog-body.settings button[id|=setting-control]{color:#eee;background-color:transparent;border:1px solid #444;padding:.4em}#ui-dialog-body.settings button[id|=setting-control]:hover{background-color:#333;border-color:#eee}#ui-dialog-body.settings button[id|=setting-control].enabled{background-color:#282;border-color:#4a4}#ui-dialog-body.settings button[id|=setting-control].enabled:hover{background-color:#4a4;border-color:#6c6}#ui-dialog-body.settings input[type=range][id|=setting-control]{max-width:35vw}#ui-dialog-body.list a,#ui-dialog-body.settings span[id|=setting-input]{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}#ui-dialog-body.saves button[id=saves-clear]:before,#ui-dialog-body.saves button[id=saves-export]:before,#ui-dialog-body.saves button[id=saves-import]:before,#ui-dialog-body.settings button[id|=setting-control].enabled:after,#ui-dialog-body.settings button[id|=setting-control]:after{font-family:tme-fa-icons;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;line-height:1;speak:none}#ui-dialog-body.saves button[id=saves-export]:before{content:"\e829\00a0"}#ui-dialog-body.saves button[id=saves-import]:before{content:"\e82a\00a0"}#ui-dialog-body.saves button[id=saves-clear]:before{content:"\e827\00a0"}#ui-dialog-body.settings button[id|=setting-control]:after{content:"\00a0\00a0\e830"}#ui-dialog-body.settings button[id|=setting-control].enabled:after{content:"\00a0\00a0\e831"}</style> <style id="style-ui-bar" type="text/css">#story{margin-left:20em}#ui-bar.stowed~#story{margin-left:4.5em}@media screen and (max-width:1136px){#story{margin-left:19em}#ui-bar.stowed~#story{margin-left:3.5em}}@media screen and (max-width:768px){#story{margin-left:3.5em}}#ui-bar{position:fixed;z-index:50;top:0;left:0;width:17.5em;height:100%;margin:0;padding:0;-o-transition:left .2s ease-in;transition:left .2s ease-in}#ui-bar.stowed{left:-15.5em}#ui-bar-body{height:90%;height:calc(100% - 2.5em);margin:2.5em 0;padding:0 1.5em}#ui-bar.stowed #ui-bar-body,#ui-bar.stowed #ui-bar-history{visibility:hidden;-o-transition:visibility .2s step-end;transition:visibility .2s step-end}#ui-bar{background-color:#222;border-right:1px solid #444;text-align:center}#ui-bar-tray{position:absolute;top:.2em;left:0;right:0}#ui-bar a{text-decoration:none}#ui-bar hr{border-color:#444}#ui-bar-history [id|=history],#ui-bar-toggle{font-size:1.2em;line-height:inherit;color:#eee;background-color:transparent;border:1px solid #444}#ui-bar-toggle{display:block;position:absolute;top:0;right:0;border-right:none;padding:.3em .45em .25em}#ui-bar.stowed #ui-bar-toggle{padding:.3em .35em .25em .55em}#ui-bar-toggle:hover{background-color:#444;border-color:#eee}#ui-bar-history{margin:0 auto}#ui-bar-history [id|=history]{padding:.2em .45em .35em}#ui-bar-history #history-jumpto{padding:.2em .665em .35em}#ui-bar-history [id|=history]:not(:first-child){margin-left:1.2em}#ui-bar-history [id|=history]:hover{background-color:#444;border-color:#eee}#ui-bar-history [id|=history]:disabled{color:#444;background-color:transparent;border-color:#444}#ui-bar-body{line-height:1.5;overflow:auto}#ui-bar-body>:not(:first-child){margin-top:2em}#story-title{margin:0;font-size:162.5%}#story-author{margin-top:2em;font-weight:700}#menu ul{margin:1em 0 0;padding:0;list-style:none;border:1px solid #444}#menu ul:empty{display:none}#menu li{margin:0}#menu li:not(:first-child){border-top:1px solid #444}#menu li a{display:block;padding:.25em .75em;border:1px solid transparent;color:#eee;text-transform:uppercase}#menu li a:hover{background-color:#444;border-color:#eee}#menu a,#ui-bar-history [id|=history],#ui-bar-toggle{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}#menu-core li[id|=menu-item] a:before,#ui-bar-history [id|=history],#ui-bar-toggle:before{font-family:tme-fa-icons;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;line-height:1;speak:none}#ui-bar-toggle:before{content:"\e81d"}#ui-bar.stowed #ui-bar-toggle:before{content:"\e81e"}#menu-item-saves a:before{content:"\e82b\00a0"}#menu-item-settings a:before{content:"\e82d\00a0"}#menu-item-restart a:before{content:"\e82c\00a0"}#menu-item-share a:before{content:"\e82f\00a0"}</style> <style id="style-ui-debug" type="text/css">#debug-bar{background-color:#222;border-left:1px solid #444;border-top:1px solid #444;bottom:0;margin:0;max-height:75%;padding:.5em;position:fixed;right:0;z-index:99900}#debug-bar>div:not([id])+div{margin-top:.5em}#debug-bar>div>label{margin-right:.5em}#debug-bar>div>input[type=text]{min-width:0;width:8em}#debug-bar>div>select{width:15em}#debug-bar-toggle{color:#eee;background-color:#222;border:1px solid #444;height:101%;height:calc(100% + 1px);left:-2em;left:calc(-2em - 1px);position:absolute;top:-1px;width:2em}#debug-bar-toggle:hover{background-color:#333;border-color:#eee}#debug-bar-hint{bottom:.175em;font-size:4.5em;opacity:.33;pointer-events:none;position:fixed;right:.6em;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;white-space:nowrap}#debug-bar-watch{background-color:#222;border-left:1px solid #444;border-top:1px solid #444;bottom:102%;bottom:calc(100% + 1px);font-size:.9em;left:-1px;max-height:650%;max-height:65vh;position:absolute;overflow-x:hidden;overflow-y:scroll;right:0;z-index:99800}#debug-bar-watch[hidden]{display:none}#debug-bar-watch div{color:#999;font-style:italic;margin:1em auto;text-align:center}#debug-bar-watch table{width:100%}#debug-bar-watch tr:nth-child(2n){background-color:rgba(127,127,127,.15)}#debug-bar-watch td{padding:.2em 0}#debug-bar-watch td:first-child+td{padding:.2em .3em .2em .1em}#debug-bar-watch .watch-delete{background-color:transparent;border:none;color:#c00}#debug-bar-watch-all,#debug-bar-watch-none{margin-left:.5em}#debug-bar-views-toggle,#debug-bar-watch-toggle{color:#eee;background-color:transparent;border:1px solid #444;margin-right:1em;padding:.4em}#debug-bar-views-toggle:hover,#debug-bar-watch-toggle:hover{background-color:#333;border-color:#eee}#debug-bar-watch:not([hidden])~div #debug-bar-watch-toggle,html[data-debug-view] #debug-bar-views-toggle{background-color:#282;border-color:#4a4}#debug-bar-watch:not([hidden])~div #debug-bar-watch-toggle:hover,html[data-debug-view] #debug-bar-views-toggle:hover{background-color:#4a4;border-color:#6c6}#debug-bar-hint:after,#debug-bar-toggle:before,#debug-bar-views-toggle:after,#debug-bar-watch .watch-delete:before,#debug-bar-watch-add:before,#debug-bar-watch-all:before,#debug-bar-watch-none:before,#debug-bar-watch-toggle:after{font-family:tme-fa-icons;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;line-height:1;speak:none}#debug-bar-toggle:before{content:"\e838"}#debug-bar-hint:after{content:"\e838\202f\e822"}#debug-bar-watch .watch-delete:before{content:"\e804"}#debug-bar-watch-add:before{content:"\e805"}#debug-bar-watch-all:before{content:"\e83a"}#debug-bar-watch-none:before{content:"\e827"}#debug-bar-views-toggle:after,#debug-bar-watch-toggle:after{content:"\00a0\00a0\e830"}#debug-bar-watch:not([hidden])~div #debug-bar-watch-toggle:after,html[data-debug-view] #debug-bar-views-toggle:after{content:"\00a0\00a0\e831"}html[data-debug-view] .debug{padding:.25em;background-color:#234}html[data-debug-view] .debug[title]{cursor:help}html[data-debug-view] .debug.block{display:inline-block;vertical-align:middle}html[data-debug-view] .debug.invalid{text-decoration:line-through}html[data-debug-view] .debug.hidden,html[data-debug-view] .debug.hidden .debug{background-color:#555}html:not([data-debug-view]) .debug.hidden{display:none}html[data-debug-view] .debug[data-name][data-type].nonvoid:after,html[data-debug-view] .debug[data-name][data-type]:before{background-color:rgba(0,0,0,.25);font-family:monospace,monospace;white-space:pre}html[data-debug-view] .debug[data-name][data-type]:before{content:attr(data-name)}html[data-debug-view] .debug[data-name][data-type|=macro]:before{content:"<<" attr(data-name) ">>"}html[data-debug-view] .debug[data-name][data-type|=macro].nonvoid:after{content:"<</" attr(data-name) ">>"}html[data-debug-view] .debug[data-name][data-type|=html]:before{content:"<" attr(data-name) ">"}html[data-debug-view] .debug[data-name][data-type|=html].nonvoid:after{content:"</" attr(data-name) ">"}html[data-debug-view] .debug[data-name][data-type]:not(:empty):before{margin-right:.25em}html[data-debug-view] .debug[data-name][data-type].nonvoid:not(:empty):after{margin-left:.25em}html[data-debug-view] .debug[data-name][data-type|=special],html[data-debug-view] .debug[data-name][data-type|=special]:before{display:block}</style> +<link rel="icon" type="image/png" sizes="144x144" href=""> +<link rel="icon" type="image/png" sizes="16x16" href=""> +<link rel="icon" type="image/png" sizes="310x310" href=""> +<link rel="icon" type="image/png" sizes="32x32" href=""> +<link rel="icon" type="image/x-icon" sizes="16x16 32x32 64x64" href=""> </head> <body> <div id="init-screen"> diff --git a/sanityCheck b/sanityCheck index e5a1ab62043bd990e33bcb363732700f81f5df2c..387055bf566a472b6309b4f03fcecb04fe9f787c 100755 --- a/sanityCheck +++ b/sanityCheck @@ -51,7 +51,7 @@ $GREP "<<[^<>]*[<>]\?[^<>]*>>>" -- "src/*.tw" | myprint "TooManyAngleBrackets" $GREP "<<<[^<>]*[<>]\?[^<>]*>>" -- "src/*.tw" | myprint "TooManyAngleBrackets" # Check for wrong capitalization on 'activeslave' and other common typos $GREP -e "\$act" --and --not -e "\$\(activeSlave\|activeChild\|activeArcology\|activeStandard\|activeOrgan\|activeLimbs\|activeUnits\|activeCanine\|activeHooved\|activeFeline\)" -- "src/*" | myprint "WrongCapitilization" -$GREP "\(csae\|[a-z] She \|attepmts\|youreslf\|advnaces\|canAcheive\|setBellySize\|SetbellySize\|setbellySize\|bellypreg\|pregBelly\|bellyimplant\|bellyfluid\|pronounCaps\|carress\|hormonebalance\)" -- 'src/*' | myprint "SpellCheck" +$GREP "\(csae\|[a-z] She \|attepmts\|youreslf\|advnaces\|canAcheive\|setBellySize\|SetbellySize\|setbellySize\|bellypreg\|pregBelly\|bellyimplant\|bellyfluid\|pronounCaps\|carress\|hormonebalance\|fetishknown\)" -- 'src/*' | myprint "SpellCheck" $GREP "\(recieve\|recieves\)" -- 'src/*' | myprint "PregmodderCannotSpellReceive" $GREP "\$slave\[" -- 'src/*' | myprint "ShouldBeSlaves" # Check for strange spaces e.g. $slaves[$i]. lips diff --git a/src/SecExp/attackOptions.tw b/src/SecExp/attackOptions.tw index ece4edc3ccfd006b21603bd2c989538017f43b98..ef91fc34e50effb4fa16bcbf0b7095333308c091 100644 --- a/src/SecExp/attackOptions.tw +++ b/src/SecExp/attackOptions.tw @@ -313,7 +313,7 @@ With your current readiness level you can <<if $deployedUnits > 0>>still send <s <br> <<mercUnitsDescription $mercUnits[_i]>> <br> - <<link "Deploy the unit "attackOptions"">> + <<link "Deploy the unit" "attackOptions">> <<set $mercUnits[_i].isDeployed = 1>> <<set $deployableUnits-->> <<set $deployedUnits++>> diff --git a/src/SpecialForce/JS.js b/src/SpecialForce/JS.js index 89fdd719287e10fe5658adc2e77a41bf7ba177b5..ca18e384ec5bdcee1280074a9a73cdd765632698 100644 --- a/src/SpecialForce/JS.js +++ b/src/SpecialForce/JS.js @@ -658,6 +658,10 @@ window.SFBC = function() { V.SF.Squad.Satellite = V.SF.Squad.Sat; delete V.SF.Squad.Sat; } } + if (V.SF.Squad != undefined && V.SF.Squad.Satellite.lv === undefined) { + V.SF.Squad.Sat = {lv:V.SF.Squad.Satellite, InOrbit:0}; + V.SF.Squad.Satellite = V.SF.Squad.Sat; delete V.SF.Squad.Sat; + } } } }; diff --git a/src/SpecialForce/Report.tw b/src/SpecialForce/Report.tw index 3989c9443b45088891e15f968e60b527d034a97c..a39116c7565604bfdf8514b0fb41198b4277b486 100644 --- a/src/SpecialForce/Report.tw +++ b/src/SpecialForce/Report.tw @@ -12,11 +12,11 @@ <<set $SF.Squad.Troops += Math.ceil(random(-2*$SF.Squad.Troops/100,-3*$SF.Squad.Troops/100))>> <</if>> <</if>> - <<set _SFIncome = 75000,_actionMultiplier = 1,_troopMultiplier = 1,_unitMultiplier = 1,_depravityMultiplier = 1,_SFupkeep = 0,_FNGs = 10,_Trade = 0.025>> + <<set _SFIncome = 75000,_actionMultiplier = 1,_troopMultiplier = 1,_unitMultiplier = 1,_depravityMultiplier = 1,_SFupkeep = 0,_FNGs = 10,_Trade = 0.025,$SFUC = 0>> <<if $SF.UC.Assign > 0>> - <<if $SF.UC.Assign === 1>> <<set $SFUC = Math.ceil($SF.Squad.Troops*.1),$SF.Squad.Troops-$SFUC>> - <<else>> <<set $SFUC = Math.ceil($SF.Squad.Troops*.25),$SF.Squad.Troops-$SFUC>> <</if>> - <</if>> + <<if $SF.UC.Assign < 2>> <<set $SFUC = Math.ceil($SF.Squad.Troops*.1)>> + <<else>> <<set $SFUC = Math.ceil($SF.Squad.Troops*.25)>> <</if>> + <</if>> <<set $SF.Squad.Troops-$SFUC>> <<if $SF.Squad.Troops > 200>> <<set _Trade += 0.05*(Math.ceil($SF.Squad.Troops/100))>> <<set _troopMultiplier = $SF.Squad.Troops/200, _SFupkeep += $SF.Squad.Troops*25>> <<if $secExp > 0>> diff --git a/src/cheats/PCCheatMenu.tw b/src/cheats/PCCheatMenu.tw index 0693f9c91473b1c67d88564d22fc3b78dbd1945b..e89ecc7f8c756c5115ca34dda7df7d661f8b9a01 100644 --- a/src/cheats/PCCheatMenu.tw +++ b/src/cheats/PCCheatMenu.tw @@ -7,9 +7,12 @@ <br><br> -Title: ''<<if $tempSlave.title == 0>>Master<<else>>Mistress<</if>>'' -<br><<radiobutton "$tempSlave.title" 0>> Master - <<radiobutton "$tempSlave.title" 1>> Mistress +Title: ''<<if $tempSlave.title == 1>>Master<<else>>Mistress<</if>>'' +<br><<radiobutton "$tempSlave.title" 1>> Master + <<radiobutton "$tempSlave.title" 0>> Mistress +Sex: ''$tempSlave.genes'' +<br><<radiobutton "$tempSlave.genes" "XY">> XY + <<radiobutton "$tempSlave.genes" "XX">> XX <br>''Name'': <<textbox "$tempSlave.name" $tempSlave.name>> <br>''Surname'': <<textbox "$tempSlave.surname" $tempSlave.surname>> <br>''Custom Title'': <<textbox "$tempSlave.customTitle" $tempSlave.customTitle>> diff --git a/src/facilities/farmyard/farmyardAnimals.tw b/src/facilities/farmyard/farmyardAnimals.tw index 797e364ecae092a183b0dfa2751e351f2c1d844c..b992a284e7b9a3d724ca76bc916aa6b2487e5f54 100644 --- a/src/facilities/farmyard/farmyardAnimals.tw +++ b/src/facilities/farmyard/farmyardAnimals.tw @@ -1,7 +1,7 @@ :: FarmyardAnimals [nobr] -/*TODO: add prices*/ -/*TODO: these prices will definitely need to be adjusted*/ +/* TODO: add prices */ +/* TODO: these prices will definitely need to be adjusted */ <<set $nextButton = "Back", $nextLink = "Farmyard", $returnTo = "FarmyardAnimals", $showEncyclopedia = 1, $encyclopedia = "Farmyard">> diff --git a/src/facilities/farmyard/farmyardLab.tw b/src/facilities/farmyard/farmyardLab.tw index 821ba34c44c60e39e116429b380f7d14eb79cd2e..9d0d431c6578f6fde5cdaf2b4f32e47537525ef6 100644 --- a/src/facilities/farmyard/farmyardLab.tw +++ b/src/facilities/farmyard/farmyardLab.tw @@ -2,8 +2,6 @@ <<set $nextButton = "Back", $nextLink = "Farmyard", $returnTo = "FarmyardLab", $showEncyclopedia = 1, $encyclopedia = "Farmyard">> -//This is currently under development.// - /* TODO: add plant types and research for them */ <br> diff --git a/src/facilities/nursery/nursery.tw b/src/facilities/nursery/nursery.tw index 7f1de38e324a24276936604e7fd64676304f02e1..422fe54f65539c6cf7741cd9cf4f7a57e0e0b096 100644 --- a/src/facilities/nursery/nursery.tw +++ b/src/facilities/nursery/nursery.tw @@ -377,10 +377,6 @@ Reserve an eligible mother-to-be's child to be placed in a room upon birth. Of $ <</link>> <</if>> -@@.hotpink;test@@. -@@.@@, -@@.@@; - <br><br> Target age for release: <<textbox "$targetAgeNursery" $targetAgeNursery "Nursery">> [[Minimum Legal Age|Nursery][$targetAgeNursery = $minimumSlaveAge]] diff --git a/src/facilities/nursery/nurseryReport.tw b/src/facilities/nursery/nurseryReport.tw index 45f3ad82b2b4ef4ea8fb4cc8a2d78fa9b31138e0..d5eca5141970e878784087269600eec182c3c4a0 100644 --- a/src/facilities/nursery/nurseryReport.tw +++ b/src/facilities/nursery/nurseryReport.tw @@ -2,7 +2,7 @@ /* TODO: This will most likely still need some rewriting */ <<SlaveSort $NurseryiIDs>> -<<set _DL = $NurseryiIDs.length, $nurserySlaves = _DL, _SL = $slaves.length, _bonusToggle = 0, _healthBonus = 0, _idleBonus = 0, _trustBonus = 0>> +<<set _NL = $NurseryiIDs.length, $nurserySlaves = _NL, _SL = $slaves.length, _bonusToggle = 0, _healthBonus = 0, _idleBonus = 0, _trustBonus = 0>> <<if $nurseryDecoration != "standard">> <<set _devBonus = 1>> @@ -79,151 +79,21 @@ $He has a natural mothering instinct and really makes $his girls feel at home. <<set _idleBonus++, _healthBonus++>> <</if>> - /* TODO: this will need to be reworked - <<set _attendantUsedCure = 0>> - <<for _dI = 0; _dI < _DL; _dI++>> - <<set $i = $slaveIndices[$NurseryiIDs[_dI]]>> - <<if ($slaves[$i].fetish == "mindbroken") && ($slaves[$i].health > 20) && (_attendantUsedCure == 0) && ($nurseryFix != 2)>> - <<set _attendantUsedCure = 1>> - <<if (random(1,100) > 90-$Matron.devotion)>> - <br> @@.green;Something almost miraculous has happened.@@ $Matron.slaveName has always refused to believe that $slaves[$i].slaveName could not be reached, and has lavished patient tenderness on $him in $nurseryName. $slaves[$i].slaveName has begun to respond, and is stirring from $him mental torpor. - <<set $slaves[$i].devotion = -3, $slaves[$i].sexualFlaw = "apathetic", $slaves[$i].behavioralFlaw = either("hates men", "odd"), $slaves[$i].fetish = "none", $slaves[$i].fetishKnown = 1>> - <<set _spr = $genePool.findIndex(function(s) { return s.ID == $slaves[$i].ID; })>> - <<if $genePool[_spr].intelligence > -3>> - <<set $slaves[$i].intelligence = $genePool[_spr].intelligence-1>> - <</if>> - <<if ($arcologies[0].FSPaternalist > 0)>> - Society @@.green;strongly approves@@ of $slaves[$i].slaveName being restored to sanity, which advances ideals about enlightened slaveownership. - <<set $repGain += 2*$FSSingleSlaveRep*($arcologies[0].FSPaternalist/$FSLockinLevel), $arcologies[0].FSPaternalist += 0.01*$FSSingleSlaveRep>> - <</if>> - <</if>> - <</if>> - <<set _seed = _bonusToggle * 10>> - <<if _bonusToggle == 1 && $slaves[$i].trust < 60>> - <<set $slaves[$i].trust++>> - <</if>> - <<if $Matron.rivalryTarget == $slaves[$i].ID>> - $He constantly harasses $him <<if $Matron.rivalry == 1>>growing rival<<elseif $Matron.rivalry == 2>>rival<<elseif $Matron.rivalry == 3>>bitter rival<</if>>, $slaves[$i].slaveName, preventing $him from getting comfortable and forcing $him to keep $him guard up. - <<set $slaves[$i].devotion -= 4, $slaves[$i].trust -= 4>> - <<if random(1,100) > 35>> - <<set $Matron.rivalry++, $slaves[_FLs].rivalry++, $slaves[$i].rivalry++>> - <</if>> - <<elseif $Matron.relationshipTarget == $slaves[$i].ID>> - $He dedicates most of $him attention to $him <<if $Matron.relationship == 1>>friend<<elseif $Matron.relationship == 2>>best friend<<elseif $Matron.relationship == 3>>friend with benefits<<elseif $Matron.relationship == 4>>lover<<elseif $Matron.relationship == 5>>slave wife<</if>>, $slaves[$i].slaveName, making $him stress, both physical and mental, wash away. - <<set $slaves[$i].devotion += 3, $slaves[$i].trust += 3>> - <<elseif $familyTesting == 1 && areRelated($Matron, $slaves[$i]) > 0>> - <<if $slaves[$i].mother == $Matron.ID || $slaves[$i].father == $Matron.ID>> - $He makes sure to spend extra time caring for $him daughter, $slaves[$i].slaveName. - <<set $slaves[$i].trust++, $slaves[$i].health++>> - <<elseif $slaves[$i].ID == $Matron.mother>> - $He makes sure to spend extra time caring for $him mother, $slaves[$i].slaveName. - <<set $slaves[$i].trust++, $slaves[$i].health++>> - <<elseif $slaves[$i].ID == $Matron.father>> - $He makes sure to spend extra time caring for $him father, $slaves[$i].slaveName. - <<set $slaves[$i].trust++, $slaves[$i].health++>> - <<else>> - <<switch areSisters($slaves[$i], $Matron)>> - <<case 1>> - $He makes sure to spend extra time caring for $him twin sister, $slaves[$i].slaveName. - <<set $slaves[$i].trust++, $slaves[$i].health++>> - <<case 2>> - $He makes sure to spend extra time caring for $him sister, $slaves[$i].slaveName. - <<set $slaves[$i].trust++, $slaves[$i].health++>> - <<case 3>> - $He makes sure to spend extra time caring for $him half-sister, $slaves[$i].slaveName. - <<set $slaves[$i].trust++, $slaves[$i].health++>> - <</switch>> - <</if>> - <<elseif $Matron.relationTarget == $slaves[$i].ID && $familyTesting == 0>> - $He makes sure to spend extra time caring for $him $slaves[$i].relation, $slaves[$i].slaveName. - <<set $slaves[$i].trust++>> - <</if>> - <<switch $slaves[$i].prestigeDesc>> - <<case "$He is a famed Free Cities whore, and commands top prices.">> - $He does $him best to relax the famous whore, $slaves[$i].slaveName, making sure to pay special attention to $him worn holes. - <<set $slaves[$i].devotion += 3, $slaves[$i].trust += 3>> - <<case "$He is a famed Free Cities slut, and can please anyone.">> - $He does $him best to soothe the famous entertainer, $slaves[$i].slaveName, letting $him relax in blissful peace. - <<set $slaves[$i].devotion += 3, $slaves[$i].trust += 3>> - <<case "$He is remembered for winning best in show as a cockmilker.">> - <<if ($slaves[$i].balls > 6) && ($slaves[$i].dick != 0)>> - <<if $Matron.fetish == "cumslut">> - $He can't keep $him hands off $slaves[$i].slaveName's cock and balls, but $he doesn't mind being milked constantly. Before long, strands of cum can be found floating all throughout the bath. - <<set $Matron.fetishStrength += 4, $slaves[_FLs].fetishStrength += 4>> - <<else>> - $He does $him best to accommodate $slaves[$i].slaveName's massive genitals and tends to $him whenever $he feels a need for release. - <<if random(1,100) > 65 && $Matron.fetish == "none">> - After taking several massive loads to the face, $Matron.slaveName begins to find satisfaction in being coated in cum. - <<set $Matron.fetish = "cumslut", $slaves[_FLs].fetish = "cumslut">> - <</if>> - <</if>> - <</if>> - <<set $slaves[$i].devotion += 3, $slaves[$i].trust += 3>> - <<case "$He is remembered for winning best in show as a dairy cow.">> - <<if ($slaves[$i].lactation > 0) && (($slaves[$i].boobs-$slaves[$i].boobsImplant) > 6000)>> - <<if $Matron.fetish == "boobs">> - $He can't keep $him hands off $slaves[$i].slaveName's huge breasts, but $he doesn't mind being milked constantly. Before long the bath gains a white tint. - <<set $Matron.fetishStrength += 4, $slaves[_FLs].fetishStrength += 4>> - <<else>> - $He does $him best to accommodate $slaves[$i].slaveName's massive breasts and tends to $him whenever $he feels a need for release. - <<if random(1,100) > 65 && $Matron.fetish == "none">> - After multiple milking sessions, $Matron.slaveName begins to find herself fantasizing about having giant milky breasts too. - <<set $Matron.fetish = "boobs", $slaves[_FLs].fetish = "boobs">> - <</if>> - <</if>> - <<set $slaves[$i].devotion += 3, $slaves[$i].trust += 3>> - <</if>> - <<case "$He is remembered for winning best in show as a breeder.">> - <<if $slaves[$i].bellyPreg >= 5000>> - <<if $Matron.fetish == "pregnancy">> - $He can't keep $his hands off $slaves[$i].slaveName's pregnancy, but $he doesn't mind $his full belly being fondled. - <<set $Matron.fetishStrength += 4, $slaves[_FLs].fetishStrength += 4>> - <<else>> - $He does $him best to accommodate $slaves[$i].slaveName's pregnancy and to make sure the mother-to-be is happy and comfortable. - <<if random(1,100) > 65 && $Matron.fetish == "none">> - After massaging $slaves[$i].slaveName's growing belly multiple times, $Matron.slaveName begins to find herself fantasizing about being swollen with life too. - <<set $Matron.fetish = "pregnancy", $slaves[_FLs].fetish = "pregnancy">> - <</if>> - <</if>> - <<set $slaves[$i].devotion += 3, $slaves[$i].trust += 3>> - <<else>> - <<if $Matron.fetish == "pregnancy">> - $He can't help but pester $slaves[$i].slaveName with questions about $him famous pregnancy, limiting $him ability to truly relax. - <<set $slaves[$i].devotion += 1, $slaves[$i].trust += 1>> - <<elseif canGetPregnant($slaves[$i])>> - $He does $him best to encourage $slaves[$i].slaveName's fertilization by performing any fertility boosting actions $he can. - <<set $slaves[$i].devotion += 3, $slaves[$i].trust += 3>> - <</if>> - <</if>> - <</switch>> - <<if ($Matron.intelligence > 0) && (_attendantUsedCure == 0) && random(1,100) > (100-($Matron.intelligence*10)-_seed) && ($nurseryFix == 0)>> - <<if $slaves[$i].behavioralFlaw != "none">> - <<run SoftenBehavioralFlaw($slaves[$i])>> - <<set _attendantUsedCure += 1>> - <br> $Matron.slaveName works carefully with $slaves[$i].slaveName, and successfully @@.green;softens $him behavioral flaw@@ into an appealing quirk. - <<elseif $slaves[$i].sexualFlaw != "none">> - <<run SoftenSexualFlaw($slaves[$i])>> - <<set _attendantUsedCure += 1>> - <br> $Matron.slaveName works carefully with $slaves[$i].slaveName, and successfully @@.green;softens $him sexual flaw@@ into an appealing quirk. - <</if>> - <</if>> - <</for>> - */ - <<if (_DL < $nursery)>> - <<set _seed = random(1,10)+(($nursery-_DL)*(random(150,170)+(_idleBonus*10)))>> + <<if (_NL < $nursery)>> + <<set _seed = random(1,10)+(($nursery-_NL)*(random(150,170)+(_idleBonus*10)))>> <<set $cash += _seed>> <br> Since $he doesn't have enough children to occupy all $him time, the nursery takes in citizens' children on a contract basis and $he cares for them too, earning @@.yellowgreen;<<print cashFormat(_seed)>>.@@ - <<if ($arcologies[0].FSRepopulationFocus > 0) && (_DL == 0)>> + <<if ($arcologies[0].FSRepopulationFocus > 0) && (_NL == 0)>> Society @@.green;loves@@ the way you are raising more children for $arcologies[0].name. <<= FSChange ("Repopulationist", 2)>> <</if>> <</if>> - <<if (_DL > 0)>><br><br><</if>> + <<if (_NL > 0)>><br><br><</if>> <</if>> -<<if (_DL > 0)>> - ''<<if (_DL > 1)>>There are _DL slaves<<else>>There is one slave<</if>> resting and recuperating in the nursery.'' - <<if ($arcologies[0].FSHedonisticDecadence > 0) && (_DL == 0)>> +<<if (_NL > 0)>> + ''<<if (_NL > 1)>>There are _NL slaves<<else>>There is one slave<</if>> resting and recuperating in the nursery.'' + <<if ($arcologies[0].FSHedonisticDecadence > 0) && (_NL == 0)>> Society @@.green;approves@@ of your slaves being pampered this way, greatly advancing your laid back culture. <<= FSChange("Hedonism", 1)>> <</if>> @@ -265,7 +135,7 @@ <<set $Matron = $slaves[_FLs]>> <</if>> -<<for _dI = 0; _dI < _DL; _dI++>> +<<for _dI = 0; _dI < _NL; _dI++>> <<set $i = $slaveIndices[$NurseryiIDs[_dI]]>> <<set $slaves[$i].devotion += _devBonus, $slaves[$i].trust += _trustBonus, $slaves[$i].health += _healthBonus>> <<if ($slaves[$i].devotion < 60) && ($slaves[$i].trust < 60)>> @@ -339,7 +209,7 @@ <</if>> <</if>> */ -<<if _DL > 0 || $Matron != 0>> +<<if _NL > 0 || $Matron != 0>> <br><br> <</if>> diff --git a/src/gui/Encyclopedia/encyclopedia.tw b/src/gui/Encyclopedia/encyclopedia.tw index 3e8a2a660f1018551e6262b69fa2b772616d5b77..22f6a67080b0d4d4d4bb3b441eb2622ebc629722 100644 --- a/src/gui/Encyclopedia/encyclopedia.tw +++ b/src/gui/Encyclopedia/encyclopedia.tw @@ -1683,13 +1683,13 @@ ARCOLOGY FACILITIES <<case "Nursery">> - The ''Nursery'' is used to raise children from birth naturally. Once a spot is reserved for the child, they will be placed in the Nursery upon birth and ejected once they are old enough. The Nursery can be furnished according to [[future society|Encyclopedia][$encyclopedia = "Future Societies"]] styles, and doing so will add a slight @@.hotpink;[[devotion|Encyclopedia][$encyclopedia = "From Rebellious to Devoted"]]@@ boost to slaves working there. /* TODO: verify that this is correct */ + The ''Nursery'' is used to raise children from birth naturally. Once a spot is reserved for the child, they will be placed in the Nursery upon birth and ejected once they are old enough. The Nursery can be furnished according to [[future society|Encyclopedia][$encyclopedia = "Future Societies"]] styles, and doing so can add a slight @@.hotpink;[[devotion|Encyclopedia][$encyclopedia = "From Rebellious to Devoted"]]@@ boost to slaves working there. /* TODO: verify that this is correct */ <br><br>''Extended family mode must be enabled.'' //This entry still needs work and will be updated with more information as it matures. If this message is still here, remind one of the devs to remove it.// <<case "Farmyard">> /* TODO: this will need more information */ - The ''Farmyard'' is where the majority of the [[food|Encyclopedia][$encyclopedia = "Food"]] in your arcology is grown, once it is built. It also allows you to house animals<<if $seeBestiality == 1>>, which you can have interact with your slaves<</if>>. The Farmyard can be furnished according to [[future society|Encyclopedia][$encyclopedia = "Future Societies"]] styles, and doing so will add a slight @@.hotpink;[[devotion|Encyclopedia][$encyclopedia = "From Rebellious to Devoted"]]@@ boost to slaves working there. /* TODO: this may need to be changed */ + The ''Farmyard'' is where the majority of the [[food|Encyclopedia][$encyclopedia = "Food"]] in your arcology is grown, once it is built. It also allows you to house animals<<if $seeBestiality == 1>>, which you can have interact with your slaves<</if>>. The Farmyard can be furnished according to [[future society|Encyclopedia][$encyclopedia = "Future Societies"]] styles, and doing so can add a slight @@.hotpink;[[devotion|Encyclopedia][$encyclopedia = "From Rebellious to Devoted"]]@@ boost to slaves working there. /* TODO: this may need to be changed */ <br>//This entry still needs work and will be updated with more information as it matures. If this message is still here, remind one of the devs to remove it.// diff --git a/src/init/storyInit.tw b/src/init/storyInit.tw index 3ae8bb7989f432f7ef0c0e94d27c965a95dd69e9..958da08e7379161238b6d880750ae1cc739bc036 100644 --- a/src/init/storyInit.tw +++ b/src/init/storyInit.tw @@ -388,6 +388,27 @@ You should have received a copy of the GNU General Public License along with thi <<initPC>> <<set $cheater = 0>> <<set $cash = 10000>> + <<for _i = 0; _i < _SL; _i++>> + <<if $familyTesting == 1>> + <<if $slaves[_i].mother == -1>> + <<set $slaves[_i].mother = $missingParentID+1200000>> + <</if>> + <<if $slaves[_i].father == -1>> + <<set $slaves[_i].father = $missingParentID+1200000>> + <</if>> + <<if $slaves[_i].pregSource == -1>> + <<set $slaves[_i].pregSource = 0>> + <</if>> + <<if $slaves[_i].cloneID == -1>> + <<set $slaves[_i].cloneID = 0>> + <</if>> + <</if>> + <<for _sInit = 0; _sInit < $slaves[_i].womb.length; _sInit++>> + <<if $slaves[_i].womb[_sInit].fatherID == -1>> + <<set $slaves[_i].womb[_sInit].fatherID = 0>> + <</if>> + <</for>> + <</for>> <</if>> <</if>> @@ -1013,6 +1034,9 @@ You should have received a copy of the GNU General Public License along with thi <<set $meshImplants = 0>> <<set $prostateImplants = 0>> <<set $youngerOvaries = 0>> +<<set $sympatheticOvaries = 0>> +<<set $fertilityImplant = 0>> +<<set $asexualReproduction = 0>> <<set $animalOvaries = 0>> /*{pigOvaries: 0, canineOvaries: 0, horseOvaries: 0, cowOvaries: 0} currently unused*/ <<set $animalTesticles = 0>> /*{pigTestes: 0, dogTestes: 0, horseTestes: 0, cowTestes: 0} currently unused*/ <<set $animalMpreg = 0>> /*{pigMpreg: 0, dogMpreg: 0, horseMpreg: 0, cowMpreg: 0} currently unused*/ diff --git a/src/js/DefaultRules.tw b/src/js/DefaultRules.tw index b5e7bd140cb63c722ba086158e153b745cc78abb..55f223212137ae4ff4fece7535ff48623d23a29c 100644 --- a/src/js/DefaultRules.tw +++ b/src/js/DefaultRules.tw @@ -189,7 +189,7 @@ window.DefaultRules = (function() { break; case "work as a farmhand": - if ((V.farmyardSlaves < V.farmyard && canWalk(slave))) //TODO: rework these requirements + if ((V.farmyardSlaves < V.farmyard)) //TODO: rework these requirements break; else { RAFacilityRemove(slave, rule); diff --git a/src/js/assayJS.tw b/src/js/assayJS.tw index 62175285b478fcff3b7d449e476e06111e37dab0..fd990ef0ddb901a475d2a301b151cef2d40c7fcb 100644 --- a/src/js/assayJS.tw +++ b/src/js/assayJS.tw @@ -290,6 +290,10 @@ window.newSlave = function newSlave(slave) { slave.pregWeek = 0; } + if (slave.clone !== 0) { + slave.canRecruit = 0; + } + if (V.familyTesting === 1) { slave.sisters = 0; slave.daughters = 0; @@ -411,6 +415,10 @@ window.newChild = function newChild(child) { child.childSurname = 0; } + if (child.clone !== 0) { + child.canRecruit = 0; + } + if (child.fuckdoll > 0) { child.pronoun = "it"; child.possessivePronoun = "its"; diff --git a/src/js/familyTree.tw b/src/js/familyTree.tw index 115c2eca26ecfab3f6c8cd63c552c63f7498c426..fd4461833e0b5bfe0012e49730538989403c60a6 100644 --- a/src/js/familyTree.tw +++ b/src/js/familyTree.tw @@ -213,11 +213,12 @@ window.buildFamilyTree = function(slaves = State.variables.slaves, filterID) { }; var node_lookup = {}; var preset_lookup = { - '-2': 'Social elite', - '-3': 'Client', - '-4': 'Former master', - '-5': 'An arcology owner', - '-6': 'A citizen' + '-2': 'A citizen', + '-3': 'Former master', + '-4': 'An arcology owner', + '-5': 'Client', + '-6': 'Social elite', + '-7': 'Gene lab' }; var outdads = {}; var outmoms = {}; diff --git a/src/js/generateGenetics.tw b/src/js/generateGenetics.tw index e692bfbaebe7662b6ca4122a1ca4d7525980cf4c..854d626824b17a48294d972467e6fb234221b01e 100644 --- a/src/js/generateGenetics.tw +++ b/src/js/generateGenetics.tw @@ -226,6 +226,7 @@ window.generateGenetics = (function() { let dadSkinIndex = father !== 0 ? (skinToMelanin[father.origSkin] || 11) : 8; let skinIndex = Math.round(Math.random() * (dadSkinIndex - momSkinIndex) + momSkinIndex); return [ + 'pure white', 'pure white', 'extremely pale', 'pale', diff --git a/src/js/slaveSummaryWidgets.tw b/src/js/slaveSummaryWidgets.tw index 44788270923ae3d3b72362e85fedd4f69b296427..1cb9a8bedf985eaf4066b5aba50651d79a9b2de5 100644 --- a/src/js/slaveSummaryWidgets.tw +++ b/src/js/slaveSummaryWidgets.tw @@ -232,12 +232,14 @@ window.SlaveSummaryUncached = (function(){ else short_legacy_family(slave); r += `</span>`; + short_clone(slave); short_rival(slave); } else if (V.abbreviateMental === 2) { if (V.familyTesting === 1) long_extended_family(slave); else long_legacy_family(slave); + long_clone(slave); long_rival(slave); } if (slave.fuckdoll === 0) { @@ -3848,6 +3850,12 @@ window.SlaveSummaryUncached = (function(){ } } + function short_clone(slave) { + if (slave.clone != 0) { + r += ` Clone`; + } + } + function short_rival(slave) { if (slave.rivalry !== 0) { r += ` `; @@ -4037,6 +4045,12 @@ window.SlaveSummaryUncached = (function(){ } } + function long_clone(slave) { + if (slave.clone != 0) { + r += ` <span class="skyblue">Clone of ${slave.clone}.</span>`; + } + } + function long_rival(slave) { if (slave.rivalry !== 0) { r += ` `; diff --git a/src/js/utilJS.tw b/src/js/utilJS.tw index 59655e0c63c72be8a6088be6b47f752ad7007acd..0c96b764552e3a383d033d4c6271d765a19abe5e 100644 --- a/src/js/utilJS.tw +++ b/src/js/utilJS.tw @@ -503,6 +503,91 @@ window.numberWithCommas = function(x) { return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ","); }; +window.numberToWords = function(x) { + if (x === 0) { + return "zero" + } else { + var ONE_TO_NINETEEN = [ + "one", "two", "three", "four", "five", + "six", "seven", "eight", "nine", "ten", + "eleven", "twelve", "thirteen", "fourteen", "fifteen", + "sixteen", "seventeen", "eighteen", "nineteen" + ]; + + var TENS = [ + "ten", "twenty", "thirty", "forty", "fifty", + "sixty", "seventy", "eighty", "ninety" + ]; + + var SCALES = ["thousand", "million", "billion", "trillion"]; + + // helper function for use with Array.filter + function isTruthy(item) { + return !!item; + } + + // convert a number into "chunks" of 0-999 + function chunk(number) { + var thousands = []; + + while (number > 0) { + thousands.push(number % 1000); + number = Math.floor(number / 1000); + } + + return thousands; + } + + // translate a number from 1-999 into English + function inEnglish(number) { + var thousands, hundreds, tens, ones, words = []; + + if (number < 20) { + return ONE_TO_NINETEEN[number - 1]; // may be undefined + } + + if (number < 100) { + ones = number % 10; + tens = number / 10 | 0; // equivalent to Math.floor(number / 10) + + words.push(TENS[tens - 1]); + words.push(inEnglish(ones)); + + return words.filter(isTruthy).join("-"); + } + + hundreds = number / 100 | 0; + words.push(inEnglish(hundreds)); + words.push("hundred"); + words.push(inEnglish(number % 100)); + + return words.filter(isTruthy).join(" "); + } + + // append the word for a scale. Made for use with Array.map + function appendScale(chunk, exp) { + var scale; + if (!chunk) { + return null; + } + scale = SCALES[exp - 1]; + return [chunk, scale].filter(isTruthy).join(" "); + } + + var string = chunk(x) + .map(inEnglish) + .map(appendScale) + .filter(isTruthy) + .reverse() + .join(" "); + + } if (x > 0) { + return string; + } else { + return "negative " + string; + } +}; + window.jsRandom = function(min,max) { return Math.floor(Math.random()*(max-min+1)+min); }; diff --git a/src/js/wombJS.tw b/src/js/wombJS.tw index 82549be1521f3a689132377ef395574fde6befb5..1795353978d119e125444fe3299f1d4eedfbd543 100644 --- a/src/js/wombJS.tw +++ b/src/js/wombJS.tw @@ -179,7 +179,6 @@ window.WombImpregnateClone = function(actor, fCount, mother, motherOriginal, age } } - MissingParentIDCorrection(actor); }; window.WombProgress = function(actor, ageToAdd) { diff --git a/src/pregmod/cloningWorkaround.tw b/src/pregmod/cloningWorkaround.tw index 8fa5af3e7fba9085ade5f343a020cabb7b8aa502..535a608fba3ad3495402bd86266f824f871cf3e3 100644 --- a/src/pregmod/cloningWorkaround.tw +++ b/src/pregmod/cloningWorkaround.tw @@ -1,29 +1,47 @@ :: Cloning Workaround [nobr] -<<set $nextButton = "Cancel", $receptrix = 0, _eligibility = 0>> +<<set $nextButton = "Cancel", $nextLink = "Gene Lab", _eligibility = 0>> +<<if $donatrix != "Undecided" && $donatrix.ID == -1>><<set _impreg = PlayerName()>><<elseif $donatrix != "Undecided">><<set _impreg = SlaveFullName($donatrix)>><<else>><<set _impreg = $donatrix>><</if>> +<<if $receptrix != "Undecided" && $receptrix.ID == -1>><<set _receive = PlayerName()>><<elseif $receptrix != "Undecided">><<set _receive = SlaveFullName($receptrix)>><<else>><<set _receive = $receptrix>><</if>> -//You've decided to clone <<if $donatrix.ID == -1>>yourself<<else>>$donatrix.slaveName<</if>>.// +//Blank ovum prepared, please select genetic source:// + +<br><br> +[[Yourself|Cloning Workaround][$donatrix = $PC]] +<<for _cw = 0; _cw < $slaves.length; _cw++>> +<<capture _cw>> + <<set _name = SlaveFullName($slaves[_cw])>> + <br><<print "[[_name|Cloning Workaround][$donatrix = $slaves[" + _cw + "]]]">> +<</capture>> +<</for>> <br><br> -__Select a slave to serve as the host for the clone__ +__Chosen surrogate: _receive __ <br> -<<for _cw = 0; _cw < $slaves.length; _cw++>> -<<capture _cw>> - <<if ($slaves[_cw].ovaries > 0 || $slaves[_cw].mpreg > 0) && isSlaveAvailable($slaves[_cw]) && $slaves[_cw].preg >= 0 && $slaves[_cw].preg < $slaves[_cw].pregData.normalBirth/10 && $slaves[_cw].pregWeek >= 0 && $slaves[_cw].pubertyXX == 1 && $slaves[_cw].pregType < 12 && $slaves[_cw].bellyImplant == -1 && $slaves[_cw].broodmother == 0 && $slaves[_cw].inflation <= 2 && $slaves[_cw].physicalAge < 70>> - <<set _name = SlaveFullName($slaves[_cw])>> - <br><<print "[[_name|Surrogacy][$receptrix = $slaves[" + _cw + "], $cash -= ($surgeryCost*2), $surgeryType = 'clone']]">> <<if $slaves[_cw].pregType >= 4>>//Using a slave carrying multiples is unadvisable//<</if>> +<<for _cw1 = 0; _cw1 < $slaves.length; _cw1++>> +<<capture _cw1>> + <<if ($slaves[_cw1].ovaries > 0 || $slaves[_cw1].mpreg > 0) && isSlaveAvailable($slaves[_cw1]) && $slaves[_cw1].preg >= 0 && $slaves[_cw1].preg < 4 && $slaves[_cw1].pregWeek >= 0 && $slaves[_cw1].pubertyXX == 1 && $slaves[_cw1].pregType < 12 && $slaves[_cw1].bellyImplant == -1 && $slaves[_cw1].broodmother == 0 && $slaves[_cw1].inflation <= 2 && $slaves[_cw1].physicalAge < 70>> + <<set _name2 = SlaveFullName($slaves[_cw1])>> + <br><<print "[[_name2|Cloning Workaround][$receptrix = $slaves[" + _cw1 + "]]]">> <<if $slaves[_cw1].pregType >= 4>>//Using a slave carrying multiples is unadvisable//<</if>> <<set _eligibility = 1>> <</if>> <</capture>> <</for>> <<if (_eligibility == 0)>> - <br>//You have no slaves capable of acting as an incubator.// + <br>//You have no slaves capable of acting as a surrogate.// <</if>> <<if $PC.vagina == 1 && $PC.preg >= 0 && $PC.preg < 4 && $PC.pregType < 8 && $PC.physicalAge < 70>> <br> - [[Use your own womb|Surrogacy][$receptrix = $PC, $cash -= ($surgeryCost*2), $surgeryType = 'clone']] + [[Use your own womb|Cloning Workaround][$receptrix = $PC]] <</if>> + +<br><br> + +_impreg will be cloned and _receive shall act as the incubator. +<<if _impreg != "Undecided" && _receive != "Undecided">> + [[Implant clone ovum|Surrogacy][$cash -= ($surgeryCost*2), $surgeryType = 'clone']] +<</if>> \ No newline at end of file diff --git a/src/pregmod/geneLab.tw b/src/pregmod/geneLab.tw index c5feb381bffc96af3f304fec35afa92994141c70..137017baa4b77c6164192399e4e1dd335f50727c 100644 --- a/src/pregmod/geneLab.tw +++ b/src/pregmod/geneLab.tw @@ -28,7 +28,7 @@ Genetic Harvesting <br> <</if>> <<elseif ($cloningSystem > 0)>> - The gene lab is capable of implanting a slave's genetic sequence into a blank embryo to produce a basic clone. + The gene lab is capable of implanting a slave's genetic sequence into a blank embryo to produce a basic clone. [[Make a clone|Cloning Workaround][$donatrix = "Undecided", $receptrix = "Undecided"]] <br> <</if>> <</if>> \ No newline at end of file diff --git a/src/pregmod/managePersonalAffairs.tw b/src/pregmod/managePersonalAffairs.tw index 872215cd269d8b959111b7d042daa3b471a3fefb..5d1c88018f801c1316afbd1b4f1e7548e4088c31 100644 --- a/src/pregmod/managePersonalAffairs.tw +++ b/src/pregmod/managePersonalAffairs.tw @@ -592,10 +592,6 @@ __Other Personal Business__ <br> You lack the reputation to be invited to the underground Black Market. <</if>> -<<if $cloningSystem == 1>> - <br> [[Clone yourself|Cloning Workaround][$returnTo = "Manage Personal Affairs", $donatrix = $PC]] -<</if>> - <<if $propOutcome == 1 && $arcologies[0].FSRestart != "unset">> <br><br> __Elite Breeder Qualifications__ diff --git a/src/pregmod/seHuskSlaveDelivery.tw b/src/pregmod/seHuskSlaveDelivery.tw index 8fa9a88016393577a076f19f4548efe415e030c5..e79e9b722924aa672512d10758116bc7c8e2a173 100644 --- a/src/pregmod/seHuskSlaveDelivery.tw +++ b/src/pregmod/seHuskSlaveDelivery.tw @@ -2,8 +2,8 @@ <<set $huskSlaveOrdered = 0, $nextButton = "Continue", $nextLink = "Scheduled Event", $returnTo = "Scheduled Event", $showEncyclopedia = 1, $encyclopedia = "Enslaving People">> -<<set $activeSlaveOneTimeMinAge = $huskSlave.age>> -<<set $activeSlaveOneTimeMaxAge = $huskSlave.age>> +<<set $activeSlaveOneTimeMinAge = parseInt($huskSlave.age)>> +<<set $activeSlaveOneTimeMaxAge = parseInt($huskSlave.age)>> <<set $one_time_age_overrides_pedo_mode = 1>> <<set $ageAdjustOverride = 1>> <<set $fixedNationality = $huskSlave.nationality>> diff --git a/src/pregmod/sePlayerBirth.tw b/src/pregmod/sePlayerBirth.tw index 975d82feeccc6e8a0406357deda72bc4b986acad..de6e15b568872d97a7284cd8715b496ea0dc14f1 100644 --- a/src/pregmod/sePlayerBirth.tw +++ b/src/pregmod/sePlayerBirth.tw @@ -444,7 +444,7 @@ You arrange yourself to give birth, relaxing until your body urges you to begin <<set $PC.birthOther += _others, $PC.birthSelf += _self, $PC.birthCitizen += _citizens, $PC.birthMaster += _oldMaster, $PC.birthArcOwner += _arcOwner, $PC.birthClient += _clients, $PC.birthElite += _elite, $PC.birthLab += _lab, $PC.birthDegenerate += _slavesLength>> <<if _curBabies == 1>> - + <<set _p = 0>> <<if $PC.curBabies[_p].genetics.race == $PC.origRace>> <<set _PCDegree++>> <</if>> diff --git a/src/pregmod/surrogacy.tw b/src/pregmod/surrogacy.tw index 96a203fc5e5d514c350419f75d2a70332925a064..19f79f6f502100ae879d3ee3686f514a4dc504eb 100644 --- a/src/pregmod/surrogacy.tw +++ b/src/pregmod/surrogacy.tw @@ -186,13 +186,13 @@ $He does not understand the realities of $his life as a slave at a core level, so $he's @@.mediumorchid;terrified and angry@@ that you have forced $him to bear <<if $receptrix.ID == $donatrix.ID>>$his own clone and potential replacement<<else>>this child, even more so as $he realizes $he doesn't know who the father is<</if>>. $He is @@.gold;sensibly fearful@@ of your total power over $his body and the future of the life $he now harbors within $him. <<set $receptrix.trust -= 15, $receptrix.devotion -= 15>> <</if>> - <<if $activeSlave.ID != $receptrix.ID>> - <<set _surr = $slaves.findIndex(function(s) { return s.ID == $receptrix.ID; })>> - <<set $slaves[_surr] = $receptrix>> - <<else>> - <<set $activeSlave = $receptrix>> - <</if>> + <<set _surr = $slaves.findIndex(function(s) { return s.ID == $receptrix.ID; })>> + <<set $slaves[_surr] = $receptrix>> <</if>> - <<set $receptrix = 0, $impregnatrix = 0, $donatrix = 0>> + <<if $donatrix.ID != -1>> + <<set _surr = $slaves.findIndex(function(s) { return s.ID == $donatrix.ID; })>> + <<set $slaves[_surr] = $donatrix>> + <</if>> + <<set $receptrix = 0, $donatrix = 0>> <</switch>> \ No newline at end of file diff --git a/src/pregmod/widgets/pregmodBirthWidgets.tw b/src/pregmod/widgets/pregmodBirthWidgets.tw index d93b6ca3349d583bbaeba026020e9d43c82ca0f0..874de7df3eb1662d59be1e8fac1605dc0431fd78 100644 --- a/src/pregmod/widgets/pregmodBirthWidgets.tw +++ b/src/pregmod/widgets/pregmodBirthWidgets.tw @@ -687,17 +687,17 @@ $He is helped to a private room in the back of the brothel by a group of eager patrons. Instinctively, $he begins to push out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby, indifferent to $his audience. $His child is promptly taken and, following a cleaning and fresh change of clothes, the audience is allowed to have their way with $his still very gravid body. <<else>> <<if (_birthScene > 80) && canDoVaginal($slaves[$i])>> - While riding a costumer's dick, $slaves[$i].slaveName's water breaks on him. Showing no signs of stopping, he shoves $his bulk off of him. Instinctively, $he begins to push out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby, indifferent to who may be watching $his naked crotch. $He draws $his child to $his breast before seeking out the next costumer's cock. + While riding a customer's dick, $slaves[$i].slaveName's water breaks on him. Showing no signs of stopping, he shoves $his bulk off of him. Instinctively, $he begins to push out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby, indifferent to who may be watching $his naked crotch. $He draws $his child to $his breast before seeking out the next customer's cock. <<elseif (_birthScene > 60) && canDoAnal($slaves[$i])>> - While taking a costumer's dick in $his ass, $slaves[$i].slaveName's water breaks. $He shows no signs of slowing down, so he allows $him to reposition and continue. Instinctively, $he begins to push out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby, indifferent to who may be watching $his naked crotch. He came strongly thanks to $him and gives $him a slap on the ass as $he struggles to reach $his child around $his still very gravid middle. Once $he has brought $his child to $his breast, $he seeks out the next costumer's cock. + While taking a customer's dick in $his ass, $slaves[$i].slaveName's water breaks. $He shows no signs of slowing down, so he allows $him to reposition and continue. Instinctively, $he begins to push out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby, indifferent to who may be watching $his naked crotch. He came strongly thanks to $him and gives $him a slap on the ass as $he struggles to reach $his child around $his still very gravid middle. Once $he has brought $his child to $his breast, $he seeks out the next customer's cock. <<elseif (_birthScene > 40)>> - While licking a costumer's cunt, $slaves[$i].slaveName's water breaks. $He shows no signs of slowing down, so she allows $him to reposition and continue. + While licking a customer's cunt, $slaves[$i].slaveName's water breaks. $He shows no signs of slowing down, so she allows $him to reposition and continue. <<ClothingBirth>> - The costumer splashes across $his face as $he struggles to reach <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> child around $his still very gravid middle. Once $he has brought $his child to $his breast, $he seeks out the next costumer's cunt. + The customer splashes across $his face as $he struggles to reach <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> child around $his still very gravid middle. Once $he has brought $his child to $his breast, $he seeks out the next customer's cunt. <<else>> - While sucking a costumer's dick, $slaves[$i].slaveName's water breaks. $He shows no signs of slowing down, so he allows $him to reposition and continue. + While sucking a customer's dick, $slaves[$i].slaveName's water breaks. $He shows no signs of slowing down, so he allows $him to reposition and continue. <<ClothingBirth>> - He cums down $his throat as $he struggles to reach <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> child around $his still very gravid middle. Once $he has brought $his child to $his breast, $he seeks out the next costumer's cock. + He cums down $his throat as $he struggles to reach <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> child around $his still very gravid middle. Once $he has brought $his child to $his breast, $he seeks out the next customer's cock. <</if>> <</if>> <<else>> @@ -712,18 +712,18 @@ <</if>> <<else>> <<if (_birthScene > 80) && canDoVaginal($slaves[$i])>> - While riding a costumer's dick, $slaves[$i].slaveName's water breaks on him. $He desperately tries to disengage but he grabs $his hips and slams $him back down. He thoroughly enjoys $his contracting cunt before pushing $him off and standing over $him, jacking off. Quickly $he spreads $his legs apart and begins pushing out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby. $He can't hide what's happening between $his legs, <<if $slaves[$i].fetish == "humiliation">>but that only makes it more exciting<<else>>so $he bears with it<</if>>. He cums over $his heaving, still very gravid body and moves on leaving $him to recover and collect $his child to be sent off. + While riding a customer's dick, $slaves[$i].slaveName's water breaks on him. $He desperately tries to disengage but he grabs $his hips and slams $him back down. He thoroughly enjoys $his contracting cunt before pushing $him off and standing over $him, jacking off. Quickly $he spreads $his legs apart and begins pushing out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby. $He can't hide what's happening between $his legs, <<if $slaves[$i].fetish == "humiliation">>but that only makes it more exciting<<else>>so $he bears with it<</if>>. He cums over $his heaving, still very gravid body and moves on leaving $him to recover and collect $his child to be sent off. <<set $humiliation = 1>> <<elseif (_birthScene > 60) && canDoAnal($slaves[$i])>> - While taking a costumer's dick in $his ass, $slaves[$i].slaveName's water breaks. $He desperately tries to disengage but he grabs $his hips and slams into $him hard. Quickly $he spreads $his legs apart and begins pushing out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby. $He can't hide what's happening between $his legs, <<if $slaves[$i].fetish == "humiliation">>but that only makes it more exciting<<else>>so $he bears with it<</if>>. He came strongly thanks to $him and gives $him a slap on the ass as $he collapses onto $his still very gravid belly and slips to $his side. $He quickly gathers $his child to be sent off. + While taking a customer's dick in $his ass, $slaves[$i].slaveName's water breaks. $He desperately tries to disengage but he grabs $his hips and slams into $him hard. Quickly $he spreads $his legs apart and begins pushing out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby. $He can't hide what's happening between $his legs, <<if $slaves[$i].fetish == "humiliation">>but that only makes it more exciting<<else>>so $he bears with it<</if>>. He came strongly thanks to $him and gives $him a slap on the ass as $he collapses onto $his still very gravid belly and slips to $his side. $He quickly gathers $his child to be sent off. <<set $humiliation = 1>> <<elseif (_birthScene > 40)>> - While licking a costumer's cunt, $slaves[$i].slaveName's water breaks. $He desperately tries to disengage but she grabs $his head and slams $him back into $his crotch. + While licking a customer's cunt, $slaves[$i].slaveName's water breaks. $He desperately tries to disengage but she grabs $his head and slams $him back into $his crotch. <<set $humiliation = 1>> <<ClothingBirth>> She cums across $his face before helping $his still very gravid body to the ground and leaving. When $he recovers, $he quickly gathers <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> child to be sent off. <<else>> - While sucking a costumer's dick, $slaves[$i].slaveName's water breaks. $He desperately tries to disengage but he grabs $his head and slams $him back into his crotch. + While sucking a customer's dick, $slaves[$i].slaveName's water breaks. $He desperately tries to disengage but he grabs $his head and slams $him back into his crotch. <<set $humiliation = 1>> <<ClothingBirth>> He cums down $his throat before letting $him collapse to the ground and leaving. When $he recovers and pushes $his still very gravid body upright, $he quickly gathers <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> child to be sent off. @@ -736,17 +736,17 @@ $He heads to a private room in the back of the brothel filled with eager patrons. Instinctively, $he begins to push out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby, indifferent to $his audience. $His child is promptly taken and, following a cleaning and fresh change of clothes, the audience is allowed to have their way with $his still very gravid body. <<else>> <<if (_birthScene > 80) && canDoVaginal($slaves[$i])>> - While riding a costumer's dick, $slaves[$i].slaveName's water breaks on him. Showing no signs of stopping, he shoves $his bulk off of him. Instinctively, $he begins to push out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby, indifferent to who may be watching $his naked crotch. $He draws $his child to $his breast before seeking out the next costumer's cock. + While riding a customer's dick, $slaves[$i].slaveName's water breaks on him. Showing no signs of stopping, he shoves $his bulk off of him. Instinctively, $he begins to push out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby, indifferent to who may be watching $his naked crotch. $He draws $his child to $his breast before seeking out the next customer's cock. <<elseif (_birthScene > 60) && canDoAnal($slaves[$i])>> - While taking a costumer's dick in $his ass, $slaves[$i].slaveName's water breaks. $He shows no signs of slowing down, so he allows $him to reposition and continue. Instinctively, $he begins to push out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby, indifferent to who may be watching $his naked crotch. He came strongly thanks to $him and gives $him a slap on the ass as $he struggles to reach $his child around $his still very gravid middle. Once $he has brought $his child to $his breast, $he seeks out the next costumer's cock. + While taking a customer's dick in $his ass, $slaves[$i].slaveName's water breaks. $He shows no signs of slowing down, so he allows $him to reposition and continue. Instinctively, $he begins to push out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby, indifferent to who may be watching $his naked crotch. He came strongly thanks to $him and gives $him a slap on the ass as $he struggles to reach $his child around $his still very gravid middle. Once $he has brought $his child to $his breast, $he seeks out the next customer's cock. <<elseif (_birthScene > 40)>> - While licking a costumer's cunt, $slaves[$i].slaveName's water breaks. $He shows no signs of slowing down, so she allows $him to reposition and continue. + While licking a customer's cunt, $slaves[$i].slaveName's water breaks. $He shows no signs of slowing down, so she allows $him to reposition and continue. <<ClothingBirth>> - The costumer splashes across $his face as $he struggles to reach $his child around $his still very gravid middle. Once $he has brought $his child to $his breast, $he seeks out the next costumer's cunt. + The customer splashes across $his face as $he struggles to reach $his child around $his still very gravid middle. Once $he has brought $his child to $his breast, $he seeks out the next customer's cunt. <<else>> - While sucking a costumer's dick, $slaves[$i].slaveName's water breaks. $He shows no signs of slowing down, so he allows $him to reposition and continue. + While sucking a customer's dick, $slaves[$i].slaveName's water breaks. $He shows no signs of slowing down, so he allows $him to reposition and continue. <<ClothingBirth>> - He cums down $his throat as $he struggles to reach $his child around $his still very gravid middle. Once $he has brought $his child to $his breast, $he seeks out the next costumer's cock. + He cums down $his throat as $he struggles to reach $his child around $his still very gravid middle. Once $he has brought $his child to $his breast, $he seeks out the next customer's cock. <</if>> <</if>> <<else>> @@ -761,18 +761,18 @@ <</if>> <<else>> <<if (_birthScene > 80) && canDoVaginal($slaves[$i])>> - While riding a costumer's dick, $slaves[$i].slaveName's water breaks on him. $He desperately tries to disengage but he grabs $his hips and slams $him back down. He thoroughly enjoys $his contracting cunt before pushing $him off and standing over $him, jacking off. Quickly $he spreads $his legs apart and begins pushing out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby. $He can't hide what's happening between $his legs, <<if $slaves[$i].fetish == "humiliation">>but that only makes it more exciting<<else>>so $he bears with it<</if>>. He cums over $his heaving, still very gravid body and moves on leaving $him to recover and collect $his child to be sent off. + While riding a customer's dick, $slaves[$i].slaveName's water breaks on him. $He desperately tries to disengage but he grabs $his hips and slams $him back down. He thoroughly enjoys $his contracting cunt before pushing $him off and standing over $him, jacking off. Quickly $he spreads $his legs apart and begins pushing out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby. $He can't hide what's happening between $his legs, <<if $slaves[$i].fetish == "humiliation">>but that only makes it more exciting<<else>>so $he bears with it<</if>>. He cums over $his heaving, still very gravid body and moves on leaving $him to recover and collect $his child to be sent off. <<set $humiliation = 1>> <<elseif (_birthScene > 60) && canDoAnal($slaves[$i])>> - While taking a costumer's dick in $his ass, $slaves[$i].slaveName's water breaks. $He desperately tries to disengage but he grabs $his hips and slams into $him hard. Quickly $he spreads $his legs apart and begins pushing out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby. $He can't hide what's happening between $his legs, <<if $slaves[$i].fetish == "humiliation">>but that only makes it more exciting<<else>>so $he bears with it<</if>>. He came strongly thanks to $him and gives $him a slap on the ass as $he collapses onto $his still very gravid belly and slips to $his side. $He quickly gathers $his child to be sent off. + While taking a customer's dick in $his ass, $slaves[$i].slaveName's water breaks. $He desperately tries to disengage but he grabs $his hips and slams into $him hard. Quickly $he spreads $his legs apart and begins pushing out <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> baby. $He can't hide what's happening between $his legs, <<if $slaves[$i].fetish == "humiliation">>but that only makes it more exciting<<else>>so $he bears with it<</if>>. He came strongly thanks to $him and gives $him a slap on the ass as $he collapses onto $his still very gravid belly and slips to $his side. $He quickly gathers $his child to be sent off. <<set $humiliation = 1>> <<elseif (_birthScene > 40)>> - While licking a costumer's cunt, $slaves[$i].slaveName's water breaks. $He desperately tries to disengage but she grabs $his head and slams $him back into her crotch. + While licking a customer's cunt, $slaves[$i].slaveName's water breaks. $He desperately tries to disengage but she grabs $his head and slams $him back into her crotch. <<set $humiliation = 1>> <<ClothingBirth>> She cums across $his face before helping $his still very gravid body to the ground and leaving. When $he recovers, $he quickly gathers <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> child to be sent off. <<else>> - While sucking a costumer's dick, $slaves[$i].slaveName's water breaks. $He desperately tries to disengage but he grabs $his head and slams $him back into his crotch. + While sucking a customer's dick, $slaves[$i].slaveName's water breaks. $He desperately tries to disengage but he grabs $his head and slams $him back into his crotch. <<set $humiliation = 1>> <<ClothingBirth>> He cums down $his throat before letting $him collapse to the ground and leaving. When $he recovers and pushes $his still very gravid body to its feet, $he quickly gathers <<if $slaves[$i].birthsTotal == 0>>$his first<<else>>this week's<</if>> child to be sent off. diff --git a/src/uncategorized/BackwardsCompatibility.tw b/src/uncategorized/BackwardsCompatibility.tw index a14223317825d291eb1210ab6e5c514ca5291198..215605a3d395be956c1f9c0c559e74c974835da5 100644 --- a/src/uncategorized/BackwardsCompatibility.tw +++ b/src/uncategorized/BackwardsCompatibility.tw @@ -728,7 +728,7 @@ <<if ndef $Matron>> <<set $Matron = 0>> <</if>> -<<if ndef $activeChild>> /* TODO: this might need to be moved to somewhere near the top */ +<<if ndef $activeChild>> <<set $activeChild = 0>> <</if>> <<if ndef $nannyInfluence>> @@ -2257,6 +2257,15 @@ Setting missing global variables: <<if ndef $prostateImplants>> <<set $prostateImplants = 0>> <</if>> +<<if ndef $sympatheticOvaries>> + <<set $sympatheticOvaries = 0>> +<</if>> +<<if ndef $fertilityImplant>> + <<set $fertilityImplant = 0>> +<</if>> +<<if ndef $asexualReproduction>> + <<set $asexualReproduction = 0>> +<</if>> <<if ndef $shelterSlaveGeneratedWeek || $shelterSlaveGeneratedWeek > $week>> <<set $shelterSlaveGeneratedWeek = 0>> <</if>> diff --git a/src/uncategorized/arcmgmt.tw b/src/uncategorized/arcmgmt.tw index 9be88137dca0349aad544fd3e631c6cb9c90acb4..e82f85585e68d588812ad69e3d5e52cad1ad1d57 100644 --- a/src/uncategorized/arcmgmt.tw +++ b/src/uncategorized/arcmgmt.tw @@ -110,7 +110,7 @@ _topClassP = 1>> _upperClassP *= 1 + Math.trunc(Math.min($arcologies[0].FSBodyPurist, 100) / 20) * -0.001, _topClass += Math.trunc(Math.min($arcologies[0].FSBodyPurist, 100) / 20) * -0.5, _topClassP *= 1 + Math.trunc(Math.min($arcologies[0].FSBodyPurist, 100) / 20) * -0.001>> - Body purist fashion standards comfort the poor stand as they stand out less from their more fortunate neighbors. + Body purist fashion standards comfort the poor as they stand out less from their more fortunate neighbors. <</if>> <<if $arcologies[0].FSTransformationFetishist != "unset">> <<set _FSScore += Math.min($arcologies[0].FSTransformationFetishist, 100), @@ -692,7 +692,12 @@ $menialBioreactors -= _expirationBR>> <<if $arcologies[0].honeymoon > 0>> <<set _honeymoon = 10 * $arcologies[0].honeymoon>> <</if>> -<<set $visitors = Math.trunc((($arcologies[0].prosperity + _FSScore * 5 + _honeymoon) * _transportHub * _terrain * _crime) * ($localEcon / 100))>> +<<set $oldVisitors = $visitors, +$visitors = Math.trunc((($arcologies[0].prosperity + _FSScore * 5 + _honeymoon) * _transportHub * _terrain * _crime) * ($localEcon / 100))>> +<<if isNaN($visitors)>> + <br>@@.red;Visitors is NaN, report this issue!@@ + <<set $visitors = $oldVisitors>> +<</if>> <br>@@.green;<<print $visitors>> traders and tourists@@ visited your arcology this week. /*slaves*/ @@ -719,7 +724,7 @@ $menialBioreactors -= _expirationBR>> <</if>> <<if _weeklyRetiredNPCMenials > 1>> <<set _weeklyRetiredNPCMenials = Math.trunc(_weeklyRetiredNPCMenials)>> - <<if _weeklyREtiredNPCMenials > 1>> + <<if _weeklyRetiredNPCMenials > 1>> <br>@@.red;<<print _weeklyRetiredNPCMenials>> menial slaves@@ were retired as free citizens by other slave owners in your arcology this week. <<else>> <br>@@.red;One menial slave@@ was retired as a free citizen by another slave owner in your arcology this week. @@ -742,60 +747,65 @@ $menialBioreactors -= _expirationBR>> <<set _LSCD = Math.trunc(($LSCBase * ($localEcon / 100)) + ($arcologies[0].prosperity * 4) + (($middleClass + $visitors * 0.6) * 1.5) + (($upperClass + $visitors * 0.2) * 3.5) + ($topClass * 18)), /*Demand for owning slaves*/ _SCD = Math.trunc(($upperClass * ($slaveDemandU + _slaveDemandU)) + ($topClass * ($slaveDemandT + _slaveDemandT)))>> -/*More slaves than they know what to do with*/ -<<if $NPCSlaves > _SCD * 1.6>> - <<set _NPCSlavesSold = $NPCSlaves - Math.trunc(_SCD * 1.6), - $menialDemandFactor -= _NPCSlavesSold, - $NPCSlaves = Math.trunc(_SCD * 1.6)>> - <<if _NPCSlavesSold > 1>> - <br>@@.red;<<print _NPCSlavesSold>> slaves@@ were sold by your inhabitants. They've got more than enough of them already. - <<elseif _NPCSlavesSold > 0>> - <br>@@.red;One slave@@ was sold by your inhabitants. They've got more than enough of them already. - <</if>> -/*More slaves than there is work*/ -<<elseif $NPCSlaves > (_LSCD / ($slaveProductivity + _slaveProductivity)) - $helots + _SCD>> - <<set _NPCSlavesSold = $NPCSlaves - Math.trunc(_LSCD / ($slaveProductivity + _slaveProductivity) - $helots + _SCD), - $menialDemandFactor -= _NPCSlavesSold, - $NPCSlaves = Math.trunc(_LSCD / ($slaveProductivity + _slaveProductivity))>> - <<if _NPCSlavesSold > 1>> - <br>@@.red;<<print _NPCSlavesSold>> slaves@@ were sold by your inhabitants. There was so little work that they failed to earn their keep. - <<elseif _NPCSlavesSold > 0>> - <br>@@.red;One slave was sold by your inhabitants. There was so little work that it failed to earn its keep. - <</if>> -/*Cutting back on slaves*/ -<<elseif $NPCSlaves > _SCD * 1.4>> - <<if $slaveCostFactor > 0.95>> - <<set _NPCSlavesSold = Math.trunc(($NPCSlaves - _SCD) * 0.4), +<<if isNaN(_LSCD)>> + <br>@@.red;LSCD is NaN, report this issue!@@ +<<elseif isNaN(_SCD)>> + <br>@@.red;SCD is NaN, report this issue!@@ +<<else>> /*More slaves than they know what to do with*/ + <<if $NPCSlaves > _SCD * 1.6>> + <<set _NPCSlavesSold = $NPCSlaves - Math.trunc(_SCD * 1.6), $menialDemandFactor -= _NPCSlavesSold, - $NPCSlaves -= _NPCSlavesSold>> + $NPCSlaves = Math.trunc(_SCD * 1.6)>> <<if _NPCSlavesSold > 1>> - <br>@@.red;<<print _NPCSlavesSold>> slaves were sold by your inhabitants. They've got more than enough of them already. + <br>@@.red;<<print _NPCSlavesSold>> slaves@@ were sold by your inhabitants. They've got more than enough of them already. <<elseif _NPCSlavesSold > 0>> - <br>@@.red;One slave was sold by your inhabitants. They've got more than enough of them already. + <br>@@.red;One slave@@ was sold by your inhabitants. They've got more than enough of them already. <</if>> - <</if>> -/*Selling excess slaves for profit*/ -<<elseif $NPCSlaves > _SCD * 1.2>> - <<if $slaveCostFactor > 1.1>> - <<set _NPCSlavesSold = Math.trunc(($NPCSlaves - _SCD) * 0.4), + /*More slaves than there is work*/ + <<elseif $NPCSlaves > (_LSCD / ($slaveProductivity + _slaveProductivity)) - $helots + _SCD>> + <<set _NPCSlavesSold = $NPCSlaves - Math.trunc(_LSCD / ($slaveProductivity + _slaveProductivity) - $helots + _SCD), $menialDemandFactor -= _NPCSlavesSold, - $NPCSlaves -= _NPCSlavesSold>> + $NPCSlaves = Math.trunc(_LSCD / ($slaveProductivity + _slaveProductivity))>> <<if _NPCSlavesSold > 1>> - <br>@@.red;<<print _NPCSlavesSold>> slaves were sold by your inhabitants. They saw an opportunity for profit. + <br>@@.red;<<print _NPCSlavesSold>> slaves@@ were sold by your inhabitants. There was so little work that they failed to earn their keep. <<elseif _NPCSlavesSold > 0>> - <br>@@.red;One slave was sold by your inhabitants. They saw an opportunity for profit. + <br>@@.red;One slave@@ was sold by your inhabitants. There was so little work that it failed to earn its keep. + <</if>> + /*Cutting back on slaves*/ + <<elseif $NPCSlaves > _SCD * 1.4>> + <<if $slaveCostFactor > 0.95>> + <<set _NPCSlavesSold = Math.trunc(($NPCSlaves - _SCD) * 0.4), + $menialDemandFactor -= _NPCSlavesSold, + $NPCSlaves -= _NPCSlavesSold>> + <<if _NPCSlavesSold > 1>> + <br>@@.red;<<print _NPCSlavesSold>> slaves@@ were sold by your inhabitants. They've got more than enough of them already. + <<elseif _NPCSlavesSold > 0>> + <br>@@.red;One slave@@ was sold by your inhabitants. They've got more than enough of them already. + <</if>> + <</if>> + /*Selling excess slaves for profit*/ + <<elseif $NPCSlaves > _SCD * 1.2>> + <<if $slaveCostFactor > 1.1>> + <<set _NPCSlavesSold = Math.trunc(($NPCSlaves - _SCD) * 0.4), + $menialDemandFactor -= _NPCSlavesSold, + $NPCSlaves -= _NPCSlavesSold>> + <<if _NPCSlavesSold > 1>> + <br>@@.red;<<print _NPCSlavesSold>> slaves@@ were sold by your inhabitants. They saw an opportunity for profit. + <<elseif _NPCSlavesSold > 0>> + <br>@@.red;One slave@@ was sold by your inhabitants. They saw an opportunity for profit. + <</if>> <</if>> <</if>> -<</if>> -/*Buying slaves because they are really cheap*/ -<<if $slaveCostFactor < 0.8>> - <<if $NPCSlaves < _SCD * 1.5>> - <<set _NPCSlavesBought = Math.trunc(_SCD * 0.05), - $menialSupplyFactor -= _NPCSlavesBought, - $NPCSlaves += _NPCSlavesBought>> - <<if _NPCSlavesBought > 1>> - <br>@@.green;<<print _NPCSlavesBought>> slaves were bought by your inhabitants. They were too cheap to pass up on. - <</if>> /*there's no way this ever ends up needing a 1 slave version*/ + /*Buying slaves because they are really cheap*/ + <<if $slaveCostFactor < 0.8>> + <<if $NPCSlaves < _SCD * 1.5>> + <<set _NPCSlavesBought = Math.trunc(_SCD * 0.05), + $menialSupplyFactor -= _NPCSlavesBought, + $NPCSlaves += _NPCSlavesBought>> + <<if _NPCSlavesBought > 1>> + <br>@@.green;<<print _NPCSlavesBought>> slaves@@ were bought by your inhabitants. They were too cheap to pass up on. + <</if>> /*there's no way this ever ends up needing a 1 slave version*/ + <</if>> <</if>> <</if>> @@ -805,107 +815,116 @@ _SCD = Math.trunc(($upperClass * ($slaveDemandU + _slaveDemandU)) + ($topClass * <<if _LCD < 0>> <<set _LCD = 0>> <</if>> -/*Changing population depending on work available*/ -<<if $lowerClass < _LCD>> - <<set _LCImmigration = Math.trunc((_LCD - $lowerClass) * (0.3 * _terrain)) + 1, - $lowerClass += _LCImmigration>> - <<if _LCImmigration > 1>> - <br>@@.green;<<print _LCImmigration>> lower class citizens@@ moved to your arcology. - <<elseif _LCImmigration > 0>> - <br>@@.green;One lower class citizen@@ moved to your arcology. - <</if>> -<<elseif $lowerClass > _LCD>> - <<set _LCEmigration = Math.trunc(($lowerClass - _LCD) * 0.6) + 1>> - <<if $citizenRetirementMenials == 1>> - <<set _enslavedEmigrants = Math.trunc((($lowerClass - _LCD) * 0.6) * $enslaveChance * (0.05 + _banishedRatio))>> - <<else>> - <<set _enslavedEmigrants = Math.trunc((($lowerClass - _LCD) * 0.6) * $enslaveChance)>> - <</if>> - <<set $lowerClass -= _LCEmigration, - _enslaved += _enslavedEmigrants>> - <<if _LCEmigration > 1>> - <br>@@.red;<<print _LCEmigration>> lower class citizens@@ had no work and tried to leave your arcology. - <<if _enslavedEmigrants > 1>> - @@.green;<<print _enslavedEmigrants>> of them were enslaved instead.@@ - <<elseif _enslavedEmigrants > 0>> - @@.green;One of them was enslaved instead.@@ +<<if isNaN(_LCD)>> + <br>@@.red;LCD is NaN, report this issue!@@ +<<else>>/*Changing population depending on work available*/ + <<if $lowerClass < _LCD>> + <<set _LCImmigration = Math.trunc((_LCD - $lowerClass) * (0.3 * _terrain)) + 1, + $lowerClass += _LCImmigration>> + <<if _LCImmigration > 1>> + <br>@@.green;<<print _LCImmigration>> lower class citizens@@ moved to your arcology. + <<elseif _LCImmigration > 0>> + <br>@@.green;One lower class citizen@@ moved to your arcology. + <</if>> + <<elseif $lowerClass > _LCD>> + <<set _LCEmigration = Math.trunc(($lowerClass - _LCD) * 0.6) + 1>> + <<if $citizenRetirementMenials == 1>> + <<set _enslavedEmigrants = Math.trunc((($lowerClass - _LCD) * 0.6) * $enslaveChance * (0.05 + _banishedRatio))>> + <<else>> + <<set _enslavedEmigrants = Math.trunc((($lowerClass - _LCD) * 0.6) * $enslaveChance)>> + <</if>> + <<set $lowerClass -= _LCEmigration, + _enslaved += _enslavedEmigrants>> + <<if _LCEmigration > 1>> + <br>@@.red;<<print _LCEmigration>> lower class citizens@@ had no work and tried to leave your arcology. + <<if _enslavedEmigrants > 1>> + @@.green;<<print _enslavedEmigrants>> of them were enslaved instead.@@ + <<elseif _enslavedEmigrants > 0>> + @@.green;One of them was enslaved instead.@@ + <</if>> + <<elseif _LCEmigration > 0>> + <br>@@.red;One lower class citizen@@ left your arcology due to a lack of work. <</if>> - <<elseif _LCEmigration > 0>> - <br>@@.red;One lower class citizen@@ left your arcology due to a lack of work. <</if>> -<</if>> -<<if _enslaved > 0>> - <<if _enslaved < 4>> - <<set _enslavedPC = 1, - _enslavedNPC = _enslaved - 1>> - <<else>> - <<set _enslavedPC = Math.trunc(_enslaved / 4), - _enslavedNPC = _enslaved - _enslavedPC>> + <<if _enslaved > 0>> + <<if _enslaved < 4>> + <<set _enslavedPC = 1, + _enslavedNPC = _enslaved - 1>> + <<else>> + <<set _enslavedPC = Math.trunc(_enslaved / 4), + _enslavedNPC = _enslaved - _enslavedPC>> + <</if>> + <<set $helots += _enslavedPC, + $NPCSlaves += _enslavedNPC>> <</if>> - <<set $helots += _enslavedPC, - $NPCSlaves += _enslavedNPC>> -<</if>> -<<if _enslaved > 1>> - <br>In total @@.green;<<print _enslaved>> lower class citizens@@ were enslaved for failing to pay their debts. - <br>@@.green;You enslaved <<print _enslavedPC>>@@ of them while other debtholders in the arcology enslaved the remaining <<print _enslavedNPC>>. -<<elseif _enslaved > 0>> - <br>@@.green;As arcology owner you claimed the slave.@@ -<</if>> -/*Need more slaves still*/ -<<if $NPCSlaves < _SCD>> - <<set _NPCSlavesBought = Math.trunc((_SCD - $NPCSlaves) * 0.75) + 1, - $menialSupplyFactor -= _NPCSlavesBought, - $NPCSlaves += _NPCSlavesBought>> - <<if _NPCSlavesBought > 1>> - <br>@@.green;<<print _NPCSlavesBought>> slaves@@ were bought by your inhabitants. They did not have enough of them to satisfy their needs. - <<elseif _NPCSlavesBought > 0>> - <br>@@.green;One slave@@ was bought by your inhabitants. They did not quite have enough of them to satisfy their needs. + <<if _enslaved > 1>> + <br>In total @@.green;<<print _enslaved>> lower class citizens@@ were enslaved for failing to pay their debts. + <br>@@.green;You enslaved <<print _enslavedPC>>@@ of them while other debtholders in the arcology enslaved the remaining <<print _enslavedNPC>>. + <<elseif _enslaved > 0>> + <br>@@.green;As arcology owner you claimed the slave.@@ + <</if>> + /*Need more slaves still*/ + <<if $NPCSlaves < _SCD>> + <<set _NPCSlavesBought = Math.trunc((_SCD - $NPCSlaves) * 0.75) + 1, + $menialSupplyFactor -= _NPCSlavesBought, + $NPCSlaves += _NPCSlavesBought>> + <<if _NPCSlavesBought > 1>> + <br>@@.green;<<print _NPCSlavesBought>> slaves@@ were bought by your inhabitants. They did not have enough of them to satisfy their needs. + <<elseif _NPCSlavesBought > 0>> + <br>@@.green;One slave@@ was bought by your inhabitants. They did not quite have enough of them to satisfy their needs. + <</if>> <</if>> <</if>> /*Middle Class Citizens*/ /*Demand for Middle Class*/ <<set _MCD = Math.trunc((($MCBase * ($localEcon / 100)) + $arcologies[0].prosperity + _middleClass + ($NPCSlaves * 0.15) + ($lowerClass * 0.1) + (($upperClass + $visitors * 0.2) * 0.5) + ($topClass * 2.5)) * $rentEffectM * _middleClassP)>> -/*Middle Class Citizens immigrating*/ -<<if $middleClass < _MCD>> - <<set _MCImmigration = Math.trunc((_MCD - $middleClass) * (0.3 * _terrain)) + 1, - $middleClass += _MCImmigration>> - <<if _MCImmigration > 1>> - <br>@@.green;<<print _MCImmigration>> middle class citizens@@ moved to your arcology. - <<elseif _MCImmigration > 0>> - <br>@@.green;One middle class citizen@@ moved to your arcology. - <</if>> -/*Middle Class Citizens emigrating*/ -<<elseif $middleClass > _MCD>> - <<set _MCEmigration = Math.trunc(($middleClass - _MCD) * 0.6), - $middleClass -= _MCEmigration>> - <<if _MCEmigration > 1>> - <br>@@.red;<<print _MCEmigration>> middle class citizens@@ left your arcology. - <<elseif _MCEmigration > 0>> - <br>@@.red;One middle class citizen@@ left your arcology. +<<if isNaN(_MCD)>> + <br>@@.red;MCD is NaN, report this issue!@@ +<<else>> /*Middle Class Citizens immigrating*/ + <<if $middleClass < _MCD>> + <<set _MCImmigration = Math.trunc((_MCD - $middleClass) * (0.3 * _terrain)) + 1, + $middleClass += _MCImmigration>> + <<if _MCImmigration > 1>> + <br>@@.green;<<print _MCImmigration>> middle class citizens@@ moved to your arcology. + <<elseif _MCImmigration > 0>> + <br>@@.green;One middle class citizen@@ moved to your arcology. + <</if>> + /*Middle Class Citizens emigrating*/ + <<elseif $middleClass > _MCD>> + <<set _MCEmigration = Math.trunc(($middleClass - _MCD) * 0.6), + $middleClass -= _MCEmigration>> + <<if _MCEmigration > 1>> + <br>@@.red;<<print _MCEmigration>> middle class citizens@@ left your arcology. + <<elseif _MCEmigration > 0>> + <br>@@.red;One middle class citizen@@ left your arcology. + <</if>> <</if>> <</if>> /*Upper Class Citizens*/ /*Demand for Upper Class*/ <<set _UCD = Math.trunc((($UCBase * ($localEcon / 100)) + ($arcologies[0].prosperity * 0.2) + _upperClass + ($NPCSlaves * 0.02) + ($lowerClass * 0.025) + (($middleClass + $visitors * 0.6) * 0.05) + ($topClass * 0.3)) * $rentEffectU * _upperClassP)>> -/*Upper Class Citizens immigrating*/ -<<if $upperClass < _UCD>> - <<set _UCImmigration = Math.trunc((_UCD - $upperClass) * (0.3 * _terrain)) + 1, - $upperClass += _UCImmigration>> - <<if _UCImmigration > 1>> - <br>@@.green;<<print _UCImmigration>> upper class citizens@@ moved to your arcology. - <<elseif _UCImmigration > 0>> - <br>@@.green;One upper class citizen@@ moved to your arcology. - <</if>> -/*Upper Class Citizens Emigrating*/ -<<elseif $upperClass > _UCD>> - <<set _UCEmigration = Math.trunc(($upperClass - _UCD) * 0.6), - $upperClass -= _UCEmigration>> - <<if _UCEmigration > 1>> - <br>@@.red;<<print _UCEmigration>> upper class citizens@@ left your arcology. - <<elseif _UCEmigration > 0>> - <br>@@.red;One upper class citizen@@ left your arcology. +<<if isNaN(_UCD)>> + <br>@@.red;UCD is NaN, report this issue!@@ +<<else>> /*Upper Class Citizens immigrating*/ + <<if $upperClass < _UCD>> + <<set _UCImmigration = Math.trunc((_UCD - $upperClass) * (0.3 * _terrain)) + 1, + $upperClass += _UCImmigration>> + <<if _UCImmigration > 1>> + <br>@@.green;<<print _UCImmigration>> upper class citizens@@ moved to your arcology. + <<elseif _UCImmigration > 0>> + <br>@@.green;One upper class citizen@@ moved to your arcology. + <</if>> + /*Upper Class Citizens Emigrating*/ + <<elseif $upperClass > _UCD>> + <<set _UCEmigration = Math.trunc(($upperClass - _UCD) * 0.6), + $upperClass -= _UCEmigration>> + <<if _UCEmigration > 1>> + <br>@@.red;<<print _UCEmigration>> upper class citizens@@ left your arcology. + <<elseif _UCEmigration > 0>> + <br>@@.red;One upper class citizen@@ left your arcology. + <</if>> <</if>> <</if>> @@ -922,26 +941,31 @@ _SCD = Math.trunc(($upperClass * ($slaveDemandU + _slaveDemandU)) + ($topClass * <<if _TCD < 15>> <<set _TCD = 15>> <</if>> -/*Top Class Citizens immigrating*/ -<<if $topClass < _TCD>> - <<set _TCImmigration = Math.trunc((_TCD - $topClass) * (0.3 * _terrain)) + 1, - $topClass += _TCImmigration>> - <<if _TCImmigration > 1>> - <br>@@.green;<<print _TCImmigration>> millionaires@@ moved to your arcology. /*Fat Cat? One-Percenter?*/ - <<elseif _TCImmigration > 0>> - <br>@@.green;One millionaire@@ moved to your arcology. - <</if>> -/*Top Class Citizens emigrating*/ -<<elseif $topClass > _TCD>> - <<set _TCEmigration = Math.trunc(($topClass - _TCD) * 0.6) + 1, - $topClass -= _TCEmigration>> - <<if _TCEmigration > 1>> - <br>@@.red;<<print _TCEmigration>> millionaires@@ left your arcology. - <<elseif _TCEmigration > 0>> - <br>@@.red;One millionaire@@ left your arcology. +<<if isNaN(_TCD)>> + <br>@@.red;TCD is NaN, report this issue!@@ +<<else>> /*Top Class Citizens immigrating*/ + <<if $topClass < _TCD>> + <<set _TCImmigration = Math.trunc((_TCD - $topClass) * (0.3 * _terrain)) + 1, + $topClass += _TCImmigration>> + <<if _TCImmigration > 1>> + <br>@@.green;<<print _TCImmigration>> millionaires@@ moved to your arcology. /*Fat Cat? One-Percenter?*/ + <<elseif _TCImmigration > 0>> + <br>@@.green;One millionaire@@ moved to your arcology. + <</if>> + /*Top Class Citizens emigrating*/ + <<elseif $topClass > _TCD>> + <<set _TCEmigration = Math.trunc(($topClass - _TCD) * 0.6) + 1, + $topClass -= _TCEmigration>> + <<if _TCEmigration > 1>> + <br>@@.red;<<print _TCEmigration>> millionaires@@ left your arcology. + <<elseif _TCEmigration > 0>> + <br>@@.red;One millionaire@@ left your arcology. + <</if>> <</if>> <</if>> + <</if>> /*ends _weatherFreeze*/ + <<if $secExp == 1>> <<set $ASlaves = $NPCSlaves + $helots + $fuckdolls + $menialBioreactors + $secHelots + $slavesEmployedManpower>> <<else>> diff --git a/src/uncategorized/costsReport.tw b/src/uncategorized/costsReport.tw index d39996755c3453cab53aabb53afc1ccfac57bf5c..2139a14fc2127424ae31d092649afe3e6801ff05 100644 --- a/src/uncategorized/costsReport.tw +++ b/src/uncategorized/costsReport.tw @@ -380,11 +380,13 @@ $nursery > 0 || $masterSuiteUpgradePregnancy > 0 || $incubator > 0 || <<else>> <<set _livingExpense = $rulesCost>> <</if>> - <<case "work as a farmhand">> /* TODO: this may need tweaking */ - <<if $slaves[$i].livingRules == "normal">> - <<set _livingExpense = ($rulesCost*1.5)>> + <<case "work as a farmhand">> + <<if $slaves[$i].livingRules == "luxurious">> + <<set _livingExpense = ($rulesCost)>> + <<elseif $slaves[$i].livingRules == "normal">> + <<set _livingExpense = ($rulesCost*2)>> <<else>> - <<set _livingExpense = $rulesCost>> + <<set _livingExpense = ($rulesCost*.9)>> <</if>> <<case "work in the brothel">> <<if $slaves[$i].livingRules == "normal">> diff --git a/src/uncategorized/fsDevelopments.tw b/src/uncategorized/fsDevelopments.tw index 180e041b78d71bac7d8d87a4c357b15164e5abb2..ff77a8ef68b358ae63b523b074456d37bdc3e9ac 100644 --- a/src/uncategorized/fsDevelopments.tw +++ b/src/uncategorized/fsDevelopments.tw @@ -94,9 +94,9 @@ /* Spending, terrain, rep effects */ <<set _broadProgress = 0>> -<<if $SF.Toggle && $SF.Active >= 1 && $SF.UC.Assign > 0>> +<<if $SF.Toggle && $SF.Active >= 1 && $SF.UC.Assign > 0 && $SFUC > 0>> Assigning a <<if $SF.UC.Assign === 1>>small<<else>>large<</if>> portion of $SF.Lower to undercover work helps forward your goals for your arcology's future. - <<set _broadProgress += $SFUC/10>> <br> + <<set _broadProgress += $SFUC/100>> <br> <</if>> <<if $FSSpending > 1>> Your @@.yellowgreen;societal spending@@ helps forward your goals for the arcology's future. diff --git a/src/uncategorized/lawCompliance.tw b/src/uncategorized/lawCompliance.tw index 5f9d806230d5f7881ca5714bbbaf06da73cdc060..6a1e30b8e1ce4880e5765b1a2320d701e6369620 100644 --- a/src/uncategorized/lawCompliance.tw +++ b/src/uncategorized/lawCompliance.tw @@ -55,10 +55,15 @@ <<set $activeSlave.health = random(50,90)>> <<set $activeSlave.weight = random(-20,0)>> <<elseif $arcologies[0].FSHedonisticDecadenceSMR == 1>> - <<set $activeSlave.muscles = random(-80,0)>> <<set $activeSlave.weight = random(50,200)>> - <<set $activeSlave.health = random(-30,10)>> - Much of $his time before sale was spent being fattened up and lying around. + <<if $arcologies[0].FSHedonisticDecadenceStrongFat == 1>> + <<set $activeSlave.muscles = random(10,60)>> + <<set $activeSlave.health = random(10,40)>> + <<else>> + <<set $activeSlave.muscles = random(-80,0)>> + <<set $activeSlave.health = random(-30,10)>> + <</if>> + Much of $his time before sale was spent being fattened up and <<if $arcologies[0].FSHedonisticDecadenceStrongFat == 1>>pumping iron<<else>>lying around<</if>>. <<if $activeSlave.devotion <= 20>> $He had to be forcefed massive amounts of slave food while bound to meet requirements, filling $him with @@.gold;fear@@ and @@.mediumorchid;disgust.@@ <<set $activeSlave.trust -= 5>> diff --git a/src/uncategorized/masterSuiteReport.tw b/src/uncategorized/masterSuiteReport.tw index 9e9035c41c3e340eafb7a3a911769cab805dba28..c46c110d67296cb3a6436e1d100e7d7042b4440e 100644 --- a/src/uncategorized/masterSuiteReport.tw +++ b/src/uncategorized/masterSuiteReport.tw @@ -383,7 +383,7 @@ <<silently>> <<include "SA chooses own job">> <<include "SA please you">> - <<if $servantMilkers == 1 && $slaves[$i].lactation > 0 && $slaves[$i].fuckdoll == 0 && $slaves[$i].fetish != "mindroken" && $slaves[$i].amp != 1 && $slaves[$i].intelligence+$slaves[$i].intelligenceImplant >= -90>><<set $servantMilkersMultiplier = 0.25>><<silently>><<include "SA get milked">><</silently>><<set $servantMilkersMultiplier = 1>><</if>> + <<if $servantMilkers == 1 && $slaves[$i].lactation > 0 && $slaves[$i].fuckdoll == 0 && $slaves[$i].fetish != "mindbroken" && $slaves[$i].amp != 1 && $slaves[$i].intelligence+$slaves[$i].intelligenceImplant >= -90>><<set $servantMilkersMultiplier = 0.25>><<silently>><<include "SA get milked">><</silently>><<set $servantMilkersMultiplier = 1>><</if>> <<set _chosenClothes = saChoosesOwnClothes($slaves[$i])>> <<include "SA rules">> <<include "SA diet">> diff --git a/src/uncategorized/reRelativeRecruiter.tw b/src/uncategorized/reRelativeRecruiter.tw index 74c05df0b232fa43ff7932451950b066011c9b4d..5d94bbe06b41d0de4f468c023477de68612d5a2a 100644 --- a/src/uncategorized/reRelativeRecruiter.tw +++ b/src/uncategorized/reRelativeRecruiter.tw @@ -137,6 +137,8 @@ <<set $activeSlave.pregKnown = 0>> <<set WombFlush($activeSlave)>> <<run SetBellySize($activeSlave)>> + <<set $activeSlave.clone = 0>> + <<set $activeSlave.cloneID = 0>> /*<<set _relativeSeed = random(1,100)>> To be used if additional variants are added. Since there currently is one each, checking a seed for a 100% chance is pointless. */ @@ -152,6 +154,7 @@ <<set $activeSlave.preg = random(5,39)>> <<set $activeSlave.pregType = 1>> <<set $activeSlave.pregKnown = 1>> + <<set $activeSlave.pregSource = 0>> <<set $activeSlave.pregWeek = $activeSlave.preg>> <<run SetBellySize($activeSlave)>> <</if>> diff --git a/src/uncategorized/saRules.tw b/src/uncategorized/saRules.tw index b83e5921782102f3c625cdc39a1b93e06549f82c..d7148fab546a49a02999c1f6583b091b5db16e83 100644 --- a/src/uncategorized/saRules.tw +++ b/src/uncategorized/saRules.tw @@ -2153,7 +2153,7 @@ <<set $slaves[$i].trust -= _punishments>> <</switch>> <</if>> - <<case "be the Matron">> /*TODO: this needs major work*/ + <<case "be the Matron">> <<set $slaves[$i].need -= ($NurseryiIDs.length*3)>> <<if $slaves[$i].energy <= 20>> is frigid and has little interest in getting off<<if ($slaves[$i].releaseRules != "permissive")>>, making the rule restricting $his sexual outlets superfluous<</if>>. @@ -2477,7 +2477,7 @@ <<set $slaves[$i].trust += 1>> <</switch>> <<else>> - <<switch $nurseryDecoration>> /* TODO: these may need to be rewritten - I'm not much of a writer */ + <<switch $nurseryDecoration>> <<case "Chinese Revivalist">> The Oriental artwork in $his personal room reminds $him of $his position and @@.hotpink;renders $him even more submissive.@@ <<set $slaves[$i].devotion += 1>> @@ -4191,8 +4191,8 @@ <</switch>> <</if>> <</if>> - <<case "be the Farmer">> /*TODO: this will need a rewrite*/ - <<set $slaves[$i].need -= $DairyiIDs.length*5>> + <<case "be the Farmer">> + <<set $slaves[$i].need -= $FarmyardiIDs.length*5>> <<if $slaves[$i].energy <= 20>> is frigid and has little interest in getting off<<if ($slaves[$i].releaseRules != "permissive")>>, making the rule restricting $his sexual outlets superfluous<</if>>. <<set $slaves[$i].need = 0>> @@ -4208,7 +4208,7 @@ <<if ($slaves[$i].releaseRules == "restrictive")>> willingly begs you to <<saRulesPlayerFetishPlay>> - whenever you inspect $dairyName. + whenever you inspect $farmyardName. <<saRulesPlayerEnergy>> <<saRulesPlayerDiscoversFetish>> <<saRulesPlayerDrugEffects>> @@ -4242,28 +4242,28 @@ <</if>> /* closes releaseRules not restrictive */ <</if>> - $He is @@.hotpink;very happy@@ with $his private room in $dairyName and @@.mediumaquamarine;trusts@@ you a bit more for placing $him in charge of it. + $He is @@.hotpink;very happy@@ with $his private room in $farmyardName and @@.mediumaquamarine;trusts@@ you a bit more for placing $him in charge of it. <<set $slaves[$i].devotion += 1, $slaves[$i].trust += 1>> <<if ($universalRulesConsent == 0)>> <<if ($slaves[$i].releaseRules != "restrictive")>> <<if ($slaves[$i].energy > 95)>> - <<if $DairyiIDs.length > 2>> + <<if $FarmyardiIDs.length > 2>> Under the rules, $he's allowed to demand that other slaves get $him off, and $he @@.hotpink;adores@@ you for leaving plentiful outlets for $his nymphomania under $his charge. <<else>> - Under the rules, $he's allowed to demand that other slaves get $him off, and $he @@.hotpink;eagerly awaits@@ the day you assign more cows to $dairyName. + Under the rules, $he's allowed to demand that other slaves get $him off, and $he @@.hotpink;eagerly awaits@@ the day you assign more cows to $farmyardName. <</if>> <<set $slaves[$i].devotion += 1>> <<elseif ($slaves[$i].fetishKnown == 1) && ($slaves[$i].fetishStrength > 60)>> <<if ($slaves[$i].fetish == "sadist")>> - <<if $DairyiIDs.length > 2>> + <<if $FarmyardiIDs.length > 2>> Under the rules, $he's allowed to sexually abuse other slaves, and $he @@.hotpink;adores@@ you for providing so many cows for $him to rape. <<else>> - Under the rules, $he's allowed to sexually abuse other slaves, and $he @@.hotpink;eagerly awaits@@ the day you assign more cows to $dairyName for $him to rape. + Under the rules, $he's allowed to sexually abuse other slaves, and $he @@.hotpink;eagerly awaits@@ the day you assign more cows to $farmyardName for $him to rape. <</if>> <<set $slaves[$i].devotion += 1>> <<elseif ($slaves[$i].fetish == "dom")>> - <<if $DairyiIDs.length > 2>> + <<if $FarmyardiIDs.length > 2>> Under the rules, $he's allowed to force other slaves to have sex with $him, and $he @@.hotpink;adores@@ you for allowing $him so many cows to dominate. <<else>> Under the rules, $he's allowed to force other slaves to have sex with $him, and $he @@.hotpink;eagerly awaits@@ the day you assign more cows to $his domain. @@ -4311,7 +4311,7 @@ <<if $spa != 0>> usually spends in $spaName<<if $Attendant != 0>> enjoying $Attendant.slaveName's care<</if>>. <<else>> - usually spends relaxing in $his room<<if $DairyiIDs.length > 1>> with the softest cow available<</if>>. + usually spends relaxing in $his room<<if $FarmyardiIDs.length > 1>> with the softest cow available<</if>>. <</if>> <<if $slaves[$i].relationship > 0>> $He often asks to save these breaks so $he can spend them with $his <<if $slaves[$i].relationship == 1>>friend<<elseif $slaves[$i].relationship == 2>>best friend<<elseif $slaves[$i].relationship == 3>>friend with benefits<<elseif $slaves[$i].relationship == 4>>sweetheart<<else>>wife<</if>>. @@ -4508,6 +4508,9 @@ <<case "Aztec Revivalist" "Chinese Revivalist" "Chattel Religionist" "Edo Revivalist" "Arabian Revivalist" "Egyptian Revivalist">> The spare living conditions and daily tasks @@.hotpink;get $him used@@ to the routine of slavery. <<set $slaves[$i].devotion += 1>> + <<case "Roman Revivalist">> + $He is + <<set $slaves[$i].devotion += 2, $slaves[$i].trust += 2>> <<default>> The reasonable living conditions allow $him to relax after the days work. <<if $slaves[$i].pregKnown && $farmyardPregSetting >= 1 && $slaves[$i].bellyPreg >= 1500>> @@ -4560,6 +4563,9 @@ <</if>> <<case "Aztec Revivalist" "Chinese Revivalist" "Chattel Religionist" "Edo Revivalist" "Arabian Revivalist" "Egyptian Revivalist">> The living conditions of $farmyardName might be spare, but they are no means meant to be uncomfortable. + <<case "Roman Revivalist">> + $He is @@.hotpink;very happy@@ about $his cushy living arrangements, and @@.mediumaquamarine;trusts you all the more@@ for it. + <<set $slaves[$i].devotion += 2, $slaves[$i].trust += 2>> <<default>> $He likes $his personal space in $farmyardName's dormitory, even if it's just a small room. <</switch>> diff --git a/src/uncategorized/saWorkTheFarm.tw b/src/uncategorized/saWorkTheFarm.tw index 04a107fd05befbf391b5576644aa6d073b00dd0b..0f6b72fb4772410b8467f13c87b31faf57a45e87 100644 --- a/src/uncategorized/saWorkTheFarm.tw +++ b/src/uncategorized/saWorkTheFarm.tw @@ -1,4 +1,4 @@ -:: SA work the farm [nobr] /* TODO: This entire passage will need to be reworked */ +:: SA Work the Farm [nobr] /* TODO: This entire passage will need to be reworked */ <!-- Statistics gathering --> <<set _incomeStats = getSlaveStatisticData($slaves[$i], $slaves[$i].assignment === Job.DAIRY ? $facility.farmyard : undefined)>> diff --git a/src/uncategorized/salon.tw b/src/uncategorized/salon.tw index 7fc2de4a680c796fbc600e472405f46be13e2817..0343685a4a307b5f47d19ab9f6556000d2106d8f 100644 --- a/src/uncategorized/salon.tw +++ b/src/uncategorized/salon.tw @@ -4,6 +4,8 @@ <<set $showEncyclopedia = 1>><<set $encyclopedia = "The Auto Salon">> +<<set _oldHLength = $activeSlave.hLength, _newHLength = 0>> + <h1>The Auto Salon</h1> //$activeSlave.slaveName is seated in the auto salon. $He is awaiting your artistic pleasure.// @@ -334,6 +336,14 @@ <<elseif $activeSlave.hLength < 150>> | [[Apply extensions|Salon][$activeSlave.hLength += 10,$cash -= $modCost]] <</if>> + /* FIXME: get this to work + | Custom length: <<textbox "_newHLength" _oldHLength "Salon">> + <<if (_newHLength < _oldHLength) && (_newHLength > 0)>> + <<set $activeSlave.hLength = _newHLength>> + <<else>> + <<set $activeSlave.hLength = _oldHLength>> + <</if>> + */ <br> Have $his hair carefully maintained at its current length: diff --git a/src/uncategorized/seNonlethalPit.tw b/src/uncategorized/seNonlethalPit.tw index dfda8561560ed8786f444cfb29d500a504dd45cf..2b3f3934e2dbb146a70072f287b47d11b47b209c 100644 --- a/src/uncategorized/seNonlethalPit.tw +++ b/src/uncategorized/seNonlethalPit.tw @@ -1060,8 +1060,8 @@ <</if>> <<else>> <<set _minutesLasted = random(1,5)>> - <<if _canRun == 1>> /* FIXME: clean this mess up */ - $activeSlave.slaveName is quick, but not quick enough. $He manages to last almost <<if _minutesLasted == 1>>a full minute<<else>><<if _minutesLasted == 2>>two<<elseif _minutesLasted == 3>>three<<elseif _minutesLasted == 4>>four<<elseif _minutesLasted == 5>>five<</if>> full minutes<</if>> before the _animal.species finally catches $him. + <<if _canRun == 1>> + $activeSlave.slaveName is quick, but not quick enough. $He manages to last almost <<= numberToWords(_minutesLasted)>> full minutes before the _animal.species finally catches $him. <<elseif _canRun == 0>> $activeSlave.slaveName isn't quick enough to avoid the beast, and $he only manages to last a pitiful thirty seconds before the _animal.species catches $him. <</if>> diff --git a/src/uncategorized/slaveInteract.tw b/src/uncategorized/slaveInteract.tw index be69cfee20581a06a1c9aea0ae484bee9d6cf6b0..14323798393dd088c6805c6814b8c2426d91a5f8 100644 --- a/src/uncategorized/slaveInteract.tw +++ b/src/uncategorized/slaveInteract.tw @@ -1452,10 +1452,6 @@ Aphrodisiacs: <span id="aphrodisiacs"><strong><<if $activeSlave.aphrodisiacs > 1 <</if>> <</if>> -<<if $cloningSystem == 1>> - <br> - <<link "Clone $him" "Cloning Workaround">><<set $returnTo = "Slave Interact", $donatrix = $activeSlave>><</link>> -<</if>> <<if $propOutcome == 1 && $arcologies[0].FSRestart != "unset">> <<if $activeSlave.breedingMark == 0 && $activeSlave.fuckdoll == 0 && $activeSlave.eggType == "human" && isFertile($activeSlave)>> <br> @@ -1605,7 +1601,7 @@ Hormones: <strong><span id="hormones"> <<if setup.facilityHeads.includes($activeSlave.assignment)>> <<if $activeSlave.lactation != 2>> - <br>Lactation maintenance for facility heads: ''<span id="releaseRules">$activeSlave.lactationRules</span>.'' + <br>Lactation maintenance for facility heads: ''<span id="lactationRules">$activeSlave.lactationRules</span>.'' <<link "Left alone">><<set $activeSlave.lactationRules = "none">><<replace "#lactationRules">>$activeSlave.lactationRules<</replace>><</link>> | <<if $activeSlave.lactation == 0>> <<link "Induce lactation">><<set $activeSlave.lactationRules = "induce">><<replace "#lactationRules">>$activeSlave.lactationRules<</replace>><</link>> diff --git a/src/uncategorized/slaveSummary.tw b/src/uncategorized/slaveSummary.tw index bc15b20ce76fe8b8f881bb2f910b46b4ab5be77e..61c5817982e93ef49dd3162fcdf5423965570f74 100644 --- a/src/uncategorized/slaveSummary.tw +++ b/src/uncategorized/slaveSummary.tw @@ -36,8 +36,8 @@ || ($Flag == 1 && s.assignment == "get treatment in the clinic") || ($Flag != 0 && $Flag != 1 && s.ID == $Nurse.ID))), "Nurse Select": s => (s.assignmentVisible == 1 && s.fuckdoll == 0 && s.devotion > 50 && canWalk(s) && canSee(s)), - "Schoolroom": s => (s.assignmentVisible == 1 && s.fuckdoll <= 0 && s.fetish != "mindbroken" && ( - ($Flag == 0 && s.assignment != "learn in the schoolroom") + "Schoolroom": s => (s.assignmentVisible == 1 && s.fuckdoll <= 0 && ( + ($Flag == 0 && s.fetish != "mindbroken" && s.assignment != "learn in the schoolroom") || ($Flag == 1 && s.assignment == "learn in the schoolroom") || ($Flag != 0 && $Flag != 1 && s.ID == $Schoolteacher.ID))), "Schoolteacher Select": s => (s.assignmentVisible == 1 && s.fuckdoll == 0 && s.devotion > 50 && canTalk(s) && canWalk(s) && canSee(s)), diff --git a/src/uncategorized/surgeryDegradation.tw b/src/uncategorized/surgeryDegradation.tw index ece6ce8a24461b531ca30910c9e541c95fddb72a..aa363beeb8c35b8e93a174915d58841cc1ccd59a 100644 --- a/src/uncategorized/surgeryDegradation.tw +++ b/src/uncategorized/surgeryDegradation.tw @@ -1302,13 +1302,13 @@ As the remote surgery's long recovery cycle completes, <<if ($activeSlave.devotion > 50) && ($activeSlave.sexualFlaw == "self hating")>> Strong emotions play out on $his face as $he experiences a watershed in $his life of sexual slavery, perhaps the most radical one $he'll ever experience. $He loves you with all $his being, and truly hates $himself. $He finds $himself in an emotional place where $he's willing to accept having had you cut $his dick off. $He knows $he's a worthless piece of trash, and realizes that if you feel like trimming useless bits off $him, that's your prerogative. In moments, $he's confirmed in @@.hotpink;total, final, fanatical submission to your will.@@ It's almost frightening. <<set $activeSlave.devotion += 50>> - <<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishknown == 1) && ($activeSlave.fetishStrength > 95) && ($activeSlave.fetish == "buttslut")>> + <<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishKnown == 1) && ($activeSlave.fetishStrength > 95) && ($activeSlave.fetish == "buttslut")>> $He's such a complete buttslut, though, that $he finds $he doesn't really care. $He never really paid much attention to $his own dick; for $him, sex is about the phalli that get rammed up $his ass. And you didn't take that from $him. If anything, $he's @@.mediumaquamarine;reassured@@ by the implicit promise that $he'll never be anything but a butthole slut, and of course is forced even further into @@.hotpink;submission to your will.@@ <<set $activeSlave.devotion += 8, $activeSlave.trust += 8>> - <<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishknown == 1) && ($activeSlave.fetishStrength > 95) && ($activeSlave.fetish == "cumslut")>> + <<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishKnown == 1) && ($activeSlave.fetishStrength > 95) && ($activeSlave.fetish == "cumslut")>> $He's such an oral slut, though, that $he finds $he doesn't really care. $He never really paid much attention to $his dick; for $him, sex is about what $he gets to suck. As far as $he's concerned, you've simply confirmed that $his most important hole is the one in $his face. If anything, $he's @@.mediumaquamarine;reassured@@ by the implicit promise that $he'll never be anything more than a nice inviting facepussy, and of course, $he's forced even further into @@.hotpink;submission to your will.@@ <<set $activeSlave.devotion += 8, $activeSlave.trust += 8>> - <<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishknown == 1) && ($activeSlave.fetishStrength > 95) && ($activeSlave.fetish == "submissive")>> + <<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishKnown == 1) && ($activeSlave.fetishStrength > 95) && ($activeSlave.fetish == "submissive")>> $He's such a total submissive, though, that $he accepts even this. Having $his cock removed, reducing $him to a sexually helpless place where $he can only receive pleasure by being penetrated, is perhaps the final step in sexual slavery, and $he's a little awed by it. If anything, $he's @@.mediumaquamarine;reassured@@ by the implicit promise that $his body exists for the sexual gratification of others, and of course, $he's forced even further into @@.hotpink;submission to your will.@@ <<set $activeSlave.devotion += 8, $activeSlave.trust += 8>> <<elseif $activeSlave.devotion > 95>> @@ -1374,13 +1374,13 @@ As the remote surgery's long recovery cycle completes, <<if ($activeSlave.devotion > 50) && ($activeSlave.sexualFlaw == "self hating")>> Strong emotions play out on $his face as $he experiences a watershed in $his life of sexual slavery, perhaps the most radical one $he'll ever experience. $He loves you with all $his being, and truly hates $himself. $He finds $himself in an emotional place where $he's willing to accept having $his womanhood torn out. $He knows $he's a worthless piece of trash, and realizes that if you feel like removing the parts of $his body that can feel sexual pleasure, that's your prerogative. In moments, $he's confirmed in @@.hotpink;total, final, fanatical submission to your will.@@ It's almost frightening. <<set $activeSlave.devotion += 50>> - <<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishknown == 1) && ($activeSlave.fetishStrength > 95) && ($activeSlave.fetish == "buttslut")>> + <<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishKnown == 1) && ($activeSlave.fetishStrength > 95) && ($activeSlave.fetish == "buttslut")>> $He's such a complete buttslut, though, that $he finds $he doesn't really care. $He never really paid much attention to $his front hole; it got wet when $he got buttfucked, but that was mostly useful to provide a little lube for phalli that fucked it before switching to $his ass. If anything, $he's @@.mediumaquamarine;reassured@@ by the implication that $his asshole is all that matters about $him, and of course is forced even further into @@.hotpink;submission to your will.@@ <<set $activeSlave.devotion += 8, $activeSlave.trust += 8>> - <<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishknown == 1) && ($activeSlave.fetishStrength > 95) && ($activeSlave.fetish == "cumslut")>> + <<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishKnown == 1) && ($activeSlave.fetishStrength > 95) && ($activeSlave.fetish == "cumslut")>> $He's such an oral slut, though, that $he finds $he doesn't really care. $He viewed $his pussy as a nice place for stimulation while $he licked, blew, and sucked; if $he has to learn to get off from throat stimulation $he will. As far as $he's concerned, you've simply confirmed that $his most important hole is the one in $his face. If anything, $he's @@.mediumaquamarine;reassured@@ by the implication that $his real pussy has always been the one in the middle of $his face, and of course, $he's forced even further into @@.hotpink;submission to your will.@@ <<set $activeSlave.devotion += 8, $activeSlave.trust += 8>> - <<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishknown == 1) && ($activeSlave.fetishStrength > 95) && ($activeSlave.fetish == "submissive")>> + <<elseif ($activeSlave.devotion > 20) && ($activeSlave.fetishKnown == 1) && ($activeSlave.fetishStrength > 95) && ($activeSlave.fetish == "submissive")>> $He's such a total submissive, though, that $he accepts even this. Having $his womanhood torn out, greatly curtailing $his physical ability to enjoy sex, is perhaps the final step in sexual slavery, and $he's a little awed by it. If anything, $he's @@.mediumaquamarine;reassured@@ by the implicit promise that $his body exists for the degrading sexual gratification of others, and of course, $he's forced even further into @@.hotpink;submission to your will.@@ <<set $activeSlave.devotion += 8, $activeSlave.trust += 8>> <<elseif $activeSlave.devotion > 95>> diff --git a/src/utility/extendedFamilyWidgets.tw b/src/utility/extendedFamilyWidgets.tw index 3d9c6baa868d4981a2c820cb4f21cee8b0e6ce54..50458f06585562dc14ff44069ecf858a804471a0 100644 --- a/src/utility/extendedFamilyWidgets.tw +++ b/src/utility/extendedFamilyWidgets.tw @@ -699,6 +699,15 @@ @@.lightgreen;_children[0].slaveName is a half-brother to $him.@@ <</if>> +<<if $activeSlave.clone != 0>> + $He is + <<if $activeSlave.cloneID == -1>> + your clone. + <<else>> + a clone of $activeSlave.clone. + <</if>> +<</if>> + <<if $cheatMode == 1>> $activeSlave.sisters sisters, $activeSlave.daughters daughters. <</if>> @@ -866,6 +875,17 @@ <</if>> <<set $children = []>> +/* +<<if $PC.clone != 0>> + <br>You are a clone of + <<if $activeSlave.cloneID == -1>> + yourself. + <<else>> + $PC.clone. + <</if>> +<</if>> +*/ + /*Player is Father, lists children you fathered*/ <<for $i = 0; $i < $slaves.length; $i++>> <<if $PC.ID == $slaves[$i].father>>