diff --git a/README.md b/README.md new file mode 100644 index 0000000000000000000000000000000000000000..6b0142578ab74f54513f927d96de91b33d2996c9 --- /dev/null +++ b/README.md @@ -0,0 +1,77 @@ +Common problems: + +How do I start the game? +-Run the compile file, go to folder "bin", click the "FC_Pregmod" and play. (Recommendation: Drag it into incognito mode) + +I get an error on gamestart reading "Apologies! A fatal error has occurred. Aborting. Error: Unexpected token @ in JSON at position 0. Stack Trace: SyntaxError: Unexpected token @ in JSON at position 0 at JSON.parse (<anonymous>) at JSON.value" or some variant +-clear cookies + +Everything is broken! +-Do not copy over your existing download as it may leave old files behind, replace it entirely + +I can't save more than once or twice. +-Known issue caused by sugarcube level changes. Save to file doesn't have this problem and will likely avoid the first problem as well. +-It is possible to increase the memory utilized by your browser to delay this + +I wish to report a sanityCheck issue. +-Great, however a large majority of the results are false positives coming from those specific sections being split over several lines in the name of readability and git grep's intentionally (http://git.661346.n2.nabble.com/bug-git-grep-P-and-multiline-mode-td7613900.html ) lacking support for multiline. An Attempt to add -Pzl (https://gitgud.io/pregmodfan/fc-pregmod/merge_requests/2108 ) created a sub condition black hole. What follows are examples of common false positives that can safely be ignored; + + [MissingClosingAngleBracket]src/art/vector/Generate_Stylesheet.tw:11:<<print "<style>."+_art_display_class+" { + <<print "<style>."+_art_display_class+" { + position: absolute; + height: 100%; + margin-left: auto; + margin-right: auto; + left: 0; + right: 0; + } + +How to mod (basic doc): + +1. All sources now in the src subdir, in separate files. 1 passage = 1 file. + +2. Special files and dir's: + - src/config - configuration of the story is here. + - src/config/start.tw - contains list of .tw passage files, regenerated automatic, by building scripts. Do not change by hands. (original passage Start from pregmod renamed and moved to src/events/intro/introSummary.tw) + - src/js/storyJS.tw - special passage with [script] tag - contain all native JavaScript from pregmod. + - devTools/tweeGo/targets/sugarcube-2/userlib.js - on original FC JS moved here (I deleted it after moving JS to storyJS.tw). Compare to storyJS.tw but do not copy file here. May conflict with src/js/storyJS.tw if copied. + - src/pregmod - I put all pregmod-only passages here. + - .gitignore - special file for git - to ignore some files. For example - compilation results. + +3. Compilation: + + Windows: + Run compile.bat - result will be file bin/FC_pregmod.html + Second run of compile.but will overwrite bin/FC_pregmod.html without prompt. + + Linux: + Ensure executable permission on file "devTools/tweeGo/tweego" (not tweego.exe!) + Ensure executable permission on file "compile" + In the root dir of sources (where you see src, devTools, bin...) run command "./compile" from console + compile-git will produce the same result file but with current commit hash in filename. + + Mac: + Not supported directly (I don't have access to Mac for testing). + But you can use linux compilation script if you download tweego for mac from here: https://bitbucket.org/tmedwards/tweego/downloads/ and replace linux executable with mac executable in ./devTools/tweeGo/ folder. This is not tested though, so be warned. + +4. Simple comparing and merging with original FC: + + Use meld tool. Place folder FreeCities (original FC sources tree) near FreeCitiesPregmod (this sources tree) and use command: + meld FreeCities FreeCitiesPregmod + or just select these folders in meld's GUI. + +5. All modders will be very grateful if anyone who makes some changes to game with .html file also post his/her resulting src folder tree. + +6. For contributors to pregmod: if you don't use git, then you need to post your version of src folder tree, not just produced FC_pregmod.html file!!! This html file can't be reverted to proper sources, and useless as contribution! + +7. Git workflow: + - Master branch is pregmod-master. Only Pregmodder can add something to it directly. Always contain his last public changes. + - pregmod-dev - branch with experimental code mainly by pregmodfan. + - Any contributions will be placed in separate branches like pregmod-mod-<something> (if it's ready to merge with master complete feature/mod) or pregmod-contrib-<something> if it's partial work until contributions is reviewed. + + Typical cycle with git: + 1. Make account on gitgud if you don't have usable one. + 2. Fork main repository through gitgud interface. (Or pull changes from main repo if you already have fork.) + 3. Clone your fork to local machine with git client (Or pull changes if already cloned.) + 4. Make you changes as you like, commit, and push result into your forked repository (with git client). + 5. Make merge request through gitgud interface. diff --git a/README.txt b/README.txt new file mode 100644 index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 diff --git a/devNotes/AnatomyOfAFreeCitiesEvent.txt b/devNotes/AnatomyOfAFreeCitiesEvent.txt index 3bd915117c8100bae6a7d87206daceb1d65972e1..5a6ac0cba79470c0cda7124c4bfa60431d7118fa 100644 --- a/devNotes/AnatomyOfAFreeCitiesEvent.txt +++ b/devNotes/AnatomyOfAFreeCitiesEvent.txt @@ -30,7 +30,7 @@ Immediate effects Every event can have immediate effects, which happen when the event gets chosen. For most events, those are what should happen if the player ignores the event (by hitting "Continue" or the space bar on the keyboard). Choice effects (see below) can override or roll back those. - reRecuit (4-19) + reRecuit (4-19) <<if Array.isArray($recruit)>> <<if $cheatMode == 1>> <<set $nextButton = "Back", $nextLink = "Nonrandom Event", $returnTo = "Nonrandom Event">> /* if user just clicks spacebar */ @@ -71,17 +71,17 @@ Choices should also be hidden when they run against the game rules, like for exa diary (313-325) <<if $dairyFeedersUpgrade == 1>> - The milking machines can hold feeders in slaves' mouths and inject drugs into their bodies, ensuring ideal nutrition and production. - <br> The feeders are - <<if $dairyFeedersSetting == 2>> - ''industrial.'' [[Moderate|Dairy][$dairyFeedersSetting = 1, $dairyFeedersSettingChanged = -1]] - <<elseif $dairyFeedersSetting == 1>> - ''active.'' [[Inactive|Dairy][$dairyFeedersSetting = 0]]<<if ($seeExtreme != 0) && ($dairyRestraintsSetting == 2)>> | [[Industrial|Dairy][$dairyFeedersSetting = 2, $dairyFeedersSettingChanged = 1]]<</if>> - <<else>> - ''inactive.'' [[Active|Dairy][$dairyFeedersSetting = 1]] - <</if>> + The milking machines can hold feeders in slaves' mouths and inject drugs into their bodies, ensuring ideal nutrition and production. + <br> The feeders are + <<if $dairyFeedersSetting == 2>> + ''industrial.'' [[Moderate|Dairy][$dairyFeedersSetting = 1, $dairyFeedersSettingChanged = -1]] + <<elseif $dairyFeedersSetting == 1>> + ''active.'' [[Inactive|Dairy][$dairyFeedersSetting = 0]]<<if ($seeExtreme != 0) && ($dairyRestraintsSetting == 2)>> | [[Industrial|Dairy][$dairyFeedersSetting = 2, $dairyFeedersSettingChanged = 1]]<</if>> + <<else>> + ''inactive.'' [[Active|Dairy][$dairyFeedersSetting = 1]] + <</if>> <<else>> - $dairyNameCaps is equipped to feed and clean slaves normally. [[Upgrade the milking machines with intubators|Dairy][$cash -= _Tmult1, $dairyFeedersUpgrade = 1]] //Costs ¤_Tmult1 and will increase upkeep costs// + $dairyNameCaps is equipped to feed and clean slaves normally. [[Upgrade the milking machines with intubators|Dairy][$cash -= _Tmult1, $dairyFeedersUpgrade = 1]] //Costs ¤_Tmult1 and will increase upkeep costs// <</if>> In order to enable the industrial feeder option both any of the see extreme content options has be enabled and the restraint's have to be already set to industrial. @@ -115,10 +115,10 @@ A choice doesn't need to have a specific effect. If your event has an immediate <</replace>> <</link>> <<if $cash >= 2000>> - <br><<link "Take the poor slave girl into your custody">> - <<replace "#result">> - Confronting the citizen is simplicity in itself; he would not dare defy you under threat of arrest by your security drones and is unlikely to garner any sympathy from the public for his degradationist behaviors. As such, you are able to take civil ownership over the poor slave girl and take her into your care with only minimal compensation to the citizen. As you stride away from her former owner with the girl in your arms, she leans over to plant a chaste kiss of thanks on your cheek. - <<set $cash -= 2000>> + <br><<link "Take the poor slave girl into your custody">> + <<replace "#result">> + Confronting the citizen is simplicity in itself; he would not dare defy you under threat of arrest by your security drones and is unlikely to garner any sympathy from the public for his degradationist behaviors. As such, you are able to take civil ownership over the poor slave girl and take her into your care with only minimal compensation to the citizen. As you stride away from her former owner with the girl in your arms, she leans over to plant a chaste kiss of thanks on your cheek. + <<set $cash -= 2000>> <<set $activeSlaveOneTimeMaxAge = 22>> <<include "Generate New Slave">> <<set $activeSlave.origin = "She was taken into your custody from an abusive owner.">> @@ -130,8 +130,8 @@ A choice doesn't need to have a specific effect. If your event has an immediate <<set $activeSlave.health = random(10,20)>> <<include "New Slave Intro">> <<set $nextLink = "AS Dump", $returnTo = "RIE Eligibility Check">> - <</replace>> - <</link>> // Taking custody of the girl will cost ¤2000. // + <</replace>> + <</link>> // Taking custody of the girl will cost ¤2000. // <</if>> <br><<link "Publicly confront the citizen">> <<replace "#result">> diff --git a/devNotes/VersionChangeLog-Premod+LoliMod.txt b/devNotes/VersionChangeLog-Premod+LoliMod.txt index 2bba8eff3f242644d648f60cd483f89f4274e316..7f42f3edd8fd35eefed4b70076da2f003849be7e 100644 --- a/devNotes/VersionChangeLog-Premod+LoliMod.txt +++ b/devNotes/VersionChangeLog-Premod+LoliMod.txt @@ -1,4 +1,25 @@ -Pregmod +Pregmod + +0.10.7.1-2.1.x + +02/02/2019 + + 3 + -enabled "well hung" genetic quirk + -fixes + +02/01/2019 + + 2 + -fixes + + 1 + -fixes + + 0 + -added ear surgery (elf) + -groundwork for multiple marriage + -fixes and cleaning 0.10.7.1-2.0.x diff --git a/devTools/embed_favicon.py b/devTools/embed_favicon.py index 4b59bb93be8597b5a4bdcd45d58dc8d43a00d7f9..79d82ab4ff1c9801d1d0b136c6fa20043c06ae46 100755 --- a/devTools/embed_favicon.py +++ b/devTools/embed_favicon.py @@ -1,14 +1,14 @@ #!/usr/bin/env python3 ''' -Script for embedding favicons into the SugarCube Header. +Script for embedding favicons into a HTML Header. Script file is expected to reside in devTools directory. Note: This does not actually check the image file's contents for size detection. Usage: -python3 embed_favicon.py +python3 embed_favicon.py [FC_pregmod.html] ''' import sys @@ -22,22 +22,28 @@ ext2mimetype = { '.ico': 'image/x-icon' } + # reads a file, turns it into a data uri def data_uri_from_file(filename, mimetype): - data = open(filename,'rb').read() + data = open(filename, 'rb').read() base64data = base64.b64encode(data).decode('ascii') - out = 'data:%s;base64,%s'%(mimetype, base64data) + out = 'data:%s;base64,%s' % (mimetype, base64data) return out + if __name__ == "__main__": # find project root directory path # (script file is expected to reside in devTools) project_root_path = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) - # path to SugarCube's header.html - header_html_path = os.path.join( - project_root_path, - 'devTools/tweeGo/storyFormats/sugarcube-2/header.html' - ) + html_path = '' + if (len(sys.argv) > 1): + html_path = sys.argv[1] + else: + # path to bin/FC_pregmod.html + html_path = os.path.join( + project_root_path, + 'bin/FC_pregmod.html' + ) # path to directory containing all favicons to embed favicons_source_path = os.path.join( project_root_path, @@ -45,18 +51,19 @@ if __name__ == "__main__": ) # walk directory for all files favicons_paths = [ - os.path.join(dirpath, filename) - for dirpath, dirnames, filenames in os.walk(favicons_source_path) - for filename in filenames + os.path.join(dirpath, filename) + for dirpath, dirnames, filenames in os.walk(favicons_source_path) + for filename in filenames ] # ignore files with unknown extensions - favicons_paths = [f for f in favicons_paths if f[-4:] in ext2mimetype.keys()] - + favicons_paths = [f for f in favicons_paths + if f[-4:] in ext2mimetype.keys()] + # prepare embedded data size_from_filename = re.compile(r'([0-9]+)\....$') favicons_html = [] for fp in favicons_paths: - print('Found favicon source file "%s".'%(fp)) + print('Found favicon source file "%s".' % (fp)) # get mimetype by file extension mimetype = ext2mimetype[fp[-4:]] if (mimetype == 'image/x-icon'): @@ -65,19 +72,19 @@ if __name__ == "__main__": else: # guess icon size from file name size = size_from_filename.search(fp).group(1) - sizes = '%sx%s'%(size, size) + sizes = '%sx%s' % (size, size) data = data_uri_from_file(fp, mimetype) favicons_html.append( # prepare html with favicon data embedded - '<link rel="icon" type="%s" sizes="%s" href="%s">\n'%( + '<link rel="icon" type="%s" sizes="%s" href="%s">\n' % ( mimetype, sizes, data ) ) # modify header file - with open(header_html_path,'r+',encoding='utf-8') as hf: - print('Rewriting "%s"...'%(header_html_path)) - lines_in = hf.readlines() # read whole file + with open(html_path, 'r+', encoding='utf-8') as hf: + print('Rewriting "%s"...' % (html_path)) + lines_in = hf.readlines() # read whole file lines_out = [] for line in lines_in: # embed favicons into head @@ -86,8 +93,8 @@ if __name__ == "__main__": # remove all currently embedded favicons if (not (line.startswith('<link') and 'icon' in line)): lines_out.append(line) - hf.seek(0) # move to beginning of file - hf.write(''.join(lines_out)) # overwrite with new data - hf.truncate() # remove trailing old data - + hf.seek(0) # move to beginning of file + hf.write(''.join(lines_out)) # overwrite with new data + hf.truncate() # remove trailing old data + print('Finished.') diff --git a/player variables documentation - Pregmod.txt b/player variables documentation - Pregmod.txt index 0a50e92112c526d59ab80cdd1f079bbbd0ad6a30..59e431ad146679893de9b2adb5dcadacc8be4cf9 100644 --- a/player variables documentation - Pregmod.txt +++ b/player variables documentation - Pregmod.txt @@ -333,10 +333,14 @@ accepts string father: your father +Accepts ID +Values between 0 and -20 are reserved. mother: your mother +Accepts ID +Values between 0 and -20 are reserved. sisters: diff --git a/readme.txt b/readme.txt index e6806595ec54353d87c29945ef5e28e47f53ca8a..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 100644 --- a/readme.txt +++ b/readme.txt @@ -1,73 +0,0 @@ -Common problems: - -How do I start the game? --Run the compile file, go to folder "bin", click the "FC_Pregmod" and play. (Recommendation: Drag it into incognito mode) - -I get an error on gamestart. --clear cookies - -I can't save more than once or twice. --Known issue caused by sugarcube level changes. Save to file doesn't have this problem and will likely avoid the first problem as well. - -I wish to report a sanityCheck issue. --Great, however a large majority of the results are false positives coming from those specific sections being split over several lines in the name of readability and git grep's intentionally (http://git.661346.n2.nabble.com/bug-git-grep-P-and-multiline-mode-td7613900.html ) lacking support for multiline. An Attempt to add -Pzl (https://gitgud.io/pregmodfan/fc-pregmod/merge_requests/2108 ) created a sub condition black hole. What follows are examples of common false positives that can safely be ignored; - - [MissingClosingAngleBracket]src/art/vector/Generate_Stylesheet.tw:11:<<print "<style>."+_art_display_class+" { - <<print "<style>."+_art_display_class+" { - position: absolute; - height: 100%; - margin-left: auto; - margin-right: auto; - left: 0; - right: 0; - } - -How to mod (basic doc): - -1. All sources now in the src subdir, in separate files. 1 passage = 1 file. - -2. Special files and dir's: - - src/config - configuration of the story is here. - - src/config/start.tw - contains list of .tw passage files, regenerated automatic, by building scripts. Do not change by hands. (original passage Start from pregmod renamed and moved to src/events/intro/introSummary.tw) - - src/js/storyJS.tw - special passage with [script] tag - contain all native JavaScript from pregmod. - - devTools/tweeGo/targets/sugarcube-2/userlib.js - on original FC JS moved here (I deleted it after moving JS to storyJS.tw). Compare to storyJS.tw but do not copy file here. May conflict with src/js/storyJS.tw if copied. - - src/pregmod - I put all pregmod-only passages here. - - .gitignore - special file for git - to ignore some files. For example - compilation results. - -3. Compilation: - - Windows: - Run compile.bat - result will be file bin/FC_pregmod.html - Second run of compile.but will overwrite bin/FC_pregmod.html without prompt. - - Linux: - Ensure executable permission on file "devTools/tweeGo/tweego" (not tweego.exe!) - Ensure executable permission on file "compile" - In the root dir of sources (where you see src, devTools, bin...) run command "./compile" from console - compile-git will produce the same result file but with current commit hash in filename. - - Mac: - Not supported directly (I don't have access to Mac for testing). - But you can use linux compilation script if you download tweego for mac from here: https://bitbucket.org/tmedwards/tweego/downloads/ and replace linux executable with mac executable in ./devTools/tweeGo/ folder. This is not tested though, so be warned. - -4. Simple comparing and merging with original FC: - - Use meld tool. Place folder FreeCities (original FC sources tree) near FreeCitiesPregmod (this sources tree) and use command: - meld FreeCities FreeCitiesPregmod - or just select these folders in meld's GUI. - -5. All modders will be very grateful if anyone who makes some changes to game with .html file also post his/her resulting src folder tree. - -6. For contributors to pregmod: if you don't use git, then you need to post your version of src folder tree, not just produced FC_pregmod.html file!!! This html file can't be reverted to proper sources, and useless as contribution! - -7. Git workflow: - - Master branch is pregmod-master. Only Pregmodder can add something to it directly. Always contain his last public changes. - - pregmod-dev - branch with experimental code mainly by pregmodfan. - - Any contributions will be placed in separate branches like pregmod-mod-<something> (if it's ready to merge with master complete feature/mod) or pregmod-contrib-<something> if it's partial work until contributions is reviewed. - - Typical cycle with git: - 1. Make account on gitgud if you don't have usable one. - 2. Fork main repository through gitgud interface. (Or pull changes from main repo if you already have fork.) - 3. Clone your fork to local machine with git client (Or pull changes if already cloned.) - 4. Make you changes as you like, commit, and push result into your forked repository (with git client). - 5. Make merge request through gitgud interface. diff --git a/slave variables documentation - Pregmod.txt b/slave variables documentation - Pregmod.txt index aefeb7daa54ab81fbdb9587926c9fd7a6f2783c2..24945f24566baea7407f9ed8148eeb38a3a7a924 100644 --- a/slave variables documentation - Pregmod.txt +++ b/slave variables documentation - Pregmod.txt @@ -2682,28 +2682,28 @@ is fetish known to player behavioralFlaw: "none" -"arrogant" - clings to her dignity, thinks slavery is beneath her -"bitchy" - can't keep her opinions to herself -"odd" - says and does odd things -"hates men" - hates men -"hates women" - hates women -"gluttonous" - likes eating, gains weight -"anorexic" - dislikes eating and being forced to eat, loses weight -"devout" - resistance through religious faith -"liberated" - believes slavery is wrong +"arrogant" - clings to her dignity, thinks slavery is beneath her +"bitchy" - can't keep her opinions to herself +"odd" - says and does odd things +"hates men" - hates men +"hates women" - hates women +"gluttonous" - likes eating, gains weight +"anorexic" - dislikes eating and being forced to eat, loses weight +"devout" - resistance through religious faith +"liberated" - believes slavery is wrong behavioralQuirk: "none" -"confident" - believes she has value as a slave -"cutting" - often has as witty or cunning remark ready, knows when to say it -"funny" - is funny -"fitness" - loves working out -"adores women" - likes spending time with women -"adores men" - likes spending time with men -"insecure" - defines herself on the thoughts of others -"sinful" - breaks cultural norms -"advocate" - advocates slavery +"confident" - believes she has value as a slave +"cutting" - often has as witty or cunning remark ready, knows when to say it +"funny" - is funny +"fitness" - loves working out +"adores women" - likes spending time with women +"adores men" - likes spending time with men +"insecure" - defines herself on the thoughts of others +"sinful" - breaks cultural norms +"advocate" - advocates slavery sexualFlaw: @@ -3136,13 +3136,16 @@ mother: Slave's mother's ID Accepts ID +Values between 0 and -20 are reserved. -1 - player father: Slave's father's ID Accepts ID +Values between 0 and -20 are reserved. -1 - player +-3 - player's former master sisters: @@ -3506,19 +3509,19 @@ To test if your slave is functioning, start up a normal game, swap to cheat mode @@.hotpink; - devotion gain @@.mediumorchid; - devotion loss @@.mediumaquamarine; - trust gain -@@.gold; - trust loss -@@.coral; - notable change and fetish loss -@@.lightcoral; - fetish strength gain, fetish acquisition and fetish discovery -@@.lime; - growth/improvement to a body part (reversed in some cases) -@@.orange; - shrinking/degradation of a body part (reversed in some cases) -@@.lightsalmon; - rivalry -@@.lightgreen; - relationship +@@.gold; - trust loss +@@.coral; - notable change and fetish loss +@@.lightcoral; - fetish strength gain, fetish acquisition and fetish discovery +@@.lime; - growth/improvement to a body part (reversed in some cases) +@@.orange; - shrinking/degradation of a body part (reversed in some cases) +@@.lightsalmon; - rivalry +@@.lightgreen; - relationship wombJS.tw subsystem: -This is womb processor/simulator script. It's take care about calculation of belly sizes based on individual fetus sizes, -with full support of broodmothers implant random turning on and off possibility. Also this can be expanded to store more parents' data in each individual fetus in future. Should be initialized for all slaves not female only. Currently it's not affect pregnancy mechanic in game directly - it's addon for better sizes calculation, and optional mechanics for future usage. +This is a womb processor/simulator script. It takes care of calculation of belly sizes based on individual fetus sizes, with full support of broodmothers implant random turning on and off possibility. Also this can be expanded to store more parents data in each individual fetus in future. +Should be initialized for all slaves not female only. Currently it's not affect pregnancy mechanic in game directly - it's addon for better sizes calculation, and optional mechanics for future usage. Design limitations: - Mother can't gestate children with different speeds at same time. All speed changes apply to all fetuses. - Sizes of individual fetuses updated only on call of WombGetVolume - not every time as called WombProgress. This is for better overall code speed. diff --git a/src/SecExp/attackGenerator.tw b/src/SecExp/attackGenerator.tw index 4a0a2fefabf01d6a63126d7a05f9f10165465347..be593a973cacd16d11330ea703ef6e0744e125a4 100644 --- a/src/SecExp/attackGenerator.tw +++ b/src/SecExp/attackGenerator.tw @@ -115,15 +115,15 @@ /* terrain */ <<if $terrain == "urban">> - <<set $battleTerrain = either("outskirts","urban","wasteland")>> + <<set $battleTerrain = either("outskirts", "urban", "wasteland")>> <<elseif $terrain == "rural">> - <<set $battleTerrain = either("hills","outskirts","rural","wasteland")>> + <<set $battleTerrain = either("hills", "outskirts", "rural", "wasteland")>> <<elseif $terrain == "ravine">> - <<set $battleTerrain = either("mountains","outskirts","hills","wasteland")>> + <<set $battleTerrain = either("hills", "mountains", "outskirts", "wasteland")>> <<elseif $terrain == "marine">> - <<set $battleTerrain = either("coast","outskirts","hills","wasteland")>> + <<set $battleTerrain = either("coast", "hills", "outskirts", "wasteland")>> <<elseif $terrain == "oceanic">> - <<set $battleTerrain = either("coast","outskirts","hills","wasteland")>> + <<set $battleTerrain = either("coast", "hills", "outskirts", "wasteland")>> <<else>> <<set $battleTerrain = "error">> <</if>> diff --git a/src/SecExp/attackHandler.tw b/src/SecExp/attackHandler.tw index a196d0af7409b655ce67ed41b341e7bb471a599b..05714e0fcf94d78ac44b31270bbf8ba78204126c 100644 --- a/src/SecExp/attackHandler.tw +++ b/src/SecExp/attackHandler.tw @@ -61,33 +61,33 @@ <<else>> -/*Init*/ -<<if $majorBattle == 0>> - <<set _turns = $maxTurns>> -<</if>> -<<set _turn = 0>> -<<set _attack = 0>> -<<set _defense = 0>> -<<set _morale = 0>> -<<set _hp = 0>> -<<set _baseHp = 0>> -<<set _enemyAttack = 0>> -<<set _enemyDefense = 0>> -<<set _enemyMorale = 0>> -<<set _enemyHp = 0>> -<<set _enemyBaseHp = 0>> -<<set _woundChance = 5>> /* leader has a base chance of 5% to get wounded */ -<<set _tacChance = 0.5>> /* by default tactics have a 50% chance of succeeding */ -<<set _atkMod = 1>> -<<set _defMod = 1>> -<<set _militiaMod = 1>> -<<set _slaveMod = 1>> -<<set _mercMod = 1>> -<<set _enemyMod = 1>> -<<set _SFMod = 1>> -<<set _expBonus = 0>> -<<set _loyaltyBonus = 0>> -<<set _armyMod = 0>> + /*Init*/ + <<if $majorBattle == 0>> + <<set _turns = $maxTurns>> + <</if>> + <<set _turn = 0>> + <<set _attack = 0>> + <<set _defense = 0>> + <<set _morale = 0>> + <<set _hp = 0>> + <<set _baseHp = 0>> + <<set _enemyAttack = 0>> + <<set _enemyDefense = 0>> + <<set _enemyMorale = 0>> + <<set _enemyHp = 0>> + <<set _enemyBaseHp = 0>> + <<set _woundChance = 5>> /* leader has a base chance of 5% to get wounded */ + <<set _tacChance = 0.5>> /* by default tactics have a 50% chance of succeeding */ + <<set _atkMod = 1>> + <<set _defMod = 1>> + <<set _militiaMod = 1>> + <<set _slaveMod = 1>> + <<set _mercMod = 1>> + <<set _enemyMod = 1>> + <<set _SFMod = 1>> + <<set _expBonus = 0>> + <<set _loyaltyBonus = 0>> + <<set _armyMod = 0>> /* major battle */ <<if $majorBattle == 1>> @@ -501,40 +501,7 @@ <<set _mercMod -= 0.10>> <<set _SFMod -= 0.10>> <</if>> - <<set _atkMod += either(-1,1) * random(10) * 0.1>> - <<set _defMod += either(-1,1) * random(10) * 0.1>> - <<set _tacChance += either(-1,1) * random(20) * 0.1>> -<<elseif $leadingTroops == "mercenary">> - <<set _mercMod += 0.10>> - <<set _SFMod += 0.10>> - <<if $arcologies[0].FSRomanRevivalist != "unset">> - <<set _militiaMod += 0.10>> - <<else>> - <<set _militiaMod -= 0.10>> - <</if>> - <<if $arcologies[0].FSDegradationist != "unset">> - <<set _slaveMod -= 0.35>> - <</if>> - <<set _atkMod += random(15) * 0.1>> - <<set _defMod += random(15) * 0.1>> - <<set _tacChance += random(30) * 0.1>> -<<elseif $leadingTroops == "colonel">> - <<set _mercMod += 0.10>> - <<set _SFMod += 0.15>> - <<if $arcologies[0].FSRomanRevivalist != "unset">> - <<set _militiaMod += 0.10>> - <<else>> - <<set _militiaMod -= 0.10>> - <</if>> - <<if $arcologies[0].FSDegradationist != "unset">> - <<set _slaveMod -= 0.35>> - <</if>> - <<set _atkMod += random(30) * 0.1>> - <<set _defMod += random(30) * 0.1>> - <<set _tacChance += random(40) * 0.1>> -<</if>> -/* Terrain and Tactics */ -<<if $battleTerrain == "urban">> + <<if $chosenTactic == "Bait and Bleed">> <<set _atkMod += 0.15>> <<set _defMod += 0.10>> @@ -568,73 +535,137 @@ <<set _defMod -= 0.15>> <<set _tacChance -= 0.30>> <</if>> -<<elseif $battleTerrain == "rural">> - <<if $chosenTactic == "Bait and Bleed">> - <<set _atkMod -= 0.05>> - <<set _defMod -= 0.10>> - <<set _tacChance -= 0.15>> - <<elseif $chosenTactic == "Guerrilla">> - <<set _atkMod -= 0.10>> - <<set _defMod -= 0.10>> - <<set _tacChance -= 0.20>> - <<elseif $chosenTactic == "Choke Points">> - <<set _atkMod -= 0.10>> - <<set _defMod -= 0.15>> - <<set _tacChance -= 0.25>> - <<elseif $chosenTactic == "Interior Lines">> - <<set _atkMod += 0.10>> - <<set _defMod += 0.15>> - <<set _tacChance += 0.25>> - <<elseif $chosenTactic == "Pincer Maneuver">> - <<set _atkMod += 0.15>> - <<set _defMod += 0.10>> - <<set _tacChance += 0.25>> - <<elseif $chosenTactic == "Defense In Depth">> - <<set _atkMod += 0.15>> - <<set _defMod += 0.15>> - <<set _tacChance += 0.30>> - <<elseif $chosenTactic == "Blitzkrieg">> - <<set _atkMod += 0.15>> - <<set _defMod += 0.10>> - <<set _tacChance += 0.25>> - <<elseif $chosenTactic == "Human Wave">> - <<set _atkMod += 0.20>> - <<set _defMod += 0.05>> - <<set _tacChance += 0.25>> - <</if>> -<<elseif $battleTerrain == "hills">> - <<if $chosenTactic == "Bait and Bleed">> - <<set _atkMod += 0.05>> - <<set _defMod += 0.05>> - <<set _tacChance += 0.10>> - <<elseif $chosenTactic == "Guerrilla">> - <<set _atkMod += 0.05>> - <<set _defMod += 0.10>> - <<set _tacChance += 0.15>> - <<elseif $chosenTactic == "Choke Points">> + + /* Calculates if tactics are successful */ + /* minimum chance is 10% */ + <<if _tacChance <= 0>> + <<set _tacChance = 0.1>> + <</if>> + <<if random(1,100) <= _tacChance * 100>> + <<set _enemyMod -= 0.30>> + <<set _militiaMod += 0.20>> + <<set _slaveMod += 0.20>> + <<set _mercMod += 0.20>> <<set _atkMod += 0.10>> <<set _defMod += 0.10>> - <<set _tacChance += 0.20>> - <<elseif $chosenTactic == "Interior Lines">> - <<set _atkMod -= 0.05>> - <<set _defMod -= 0.05>> - <<set _tacChance -= 0.10>> - <<elseif $chosenTactic == "Pincer Maneuver">> - <<set _atkMod += 0.10>> - <<set _defMod += 0.05>> - <<set _tacChance += 0.15>> - <<elseif $chosenTactic == "Defense In Depth">> - <<set _atkMod -= 0.10>> - <<set _defMod -= 0.05>> - <<set _tacChance -= 0.15>> - <<elseif $chosenTactic == "Blitzkrieg">> + <<set $tacticsSuccessful = 1>> + <<else>> + <<set _enemyMod += 0.20>> + <<set _militiaMod -= 0.20>> + <<set _slaveMod -= 0.20>> + <<set _mercMod -= 0.20>> <<set _atkMod -= 0.10>> - <<set _defMod -= 0.15>> - <<set _tacChance += 0.25>> - <<elseif $chosenTactic == "Human Wave">> - <<set _atkMod -= 0.15>> - <<set _defMod -= 0.15>> - <<set _tacChance -= 0.30>> + <<set _defMod -= 0.10>> + <<set $tacticsSuccessful = 0>> + <</if>> + + /* enemy morale mods */ + <<if $week < 30>> + <<set _enemyMod += 0.15>> + <<elseif $week < 60>> + <<set _enemyMod += 0.30>> + <<elseif $week < 90>> + <<set _enemyMod += 0.45>> + <<elseif $week < 120>> + <<set _enemyMod += 0.60>> + <<else>> + <<set _enemyMod += 0.75>> + <</if>> + + /* calculates PC army stats */ + <<if $secBots.isDeployed == 1>> + <<set _attack += ($secBotsBaseAttack + $secBotsBaseAttack * $secBots.equip * $equipMod) * _atkMod>> + <<set _defense += ($secBotsBaseDefense + $secBotsBaseDefense * $secBots.equip * $equipMod) * _defMod>> + <<set _hp += $secBotsBaseHp * $secBots.troops>> + <</if>> + <<for _i = 0; _i < $militiaUnits.length; _i++>> + <<if $militiaUnits[_i].isDeployed == 1>> + <<if $militiaUnits[_i].training <= 10>> + <<set _expBonus = 0>> + <<elseif $militiaUnits[_i].training <= 33>> + <<set _expBonus = 0.10>> + <<elseif $militiaUnits[_i].training <= 66>> + <<set _expBonus = 0.25>> + <<else>> + <<set _expBonus = 0.50>> + <</if>> + <<if $militiaUnits[_i].loyalty <= 10>> + <<set _loyaltyBonus = 0>> + <<elseif $militiaUnits[_i].loyalty <= 33>> + <<set _loyaltyBonus = 0.10>> + <<elseif $militiaUnits[_i].loyalty <= 66>> + <<set _loyaltyBonus = 0.20>> + <<else>> + <<set _loyaltyBonus = 0.30>> + <</if>> + <<set _attack += ($militiaBaseAttack + $militiaBaseAttack * $militiaUnits[_i].equip * $equipMod + $militiaBaseAttack * _expBonus + $militiaBaseAttack * _loyaltyBonus + $militiaBaseAttack * $militiaUnits[_i].SF * 0.20 + $militiaUnits[_i].cyber) * _atkMod>> + <<set _defense += ($militiaBaseDefense + $militiaBaseDefense * $militiaUnits[_i].equip * $equipMod + $militiaBaseDefense * _expBonus + $militiaBaseDefense * _loyaltyBonus + $militiaBaseDefense * $militiaUnits[_i].SF * 0.20 + $militiaUnits[_i].cyber) * _defMod>> + <<set _hp += ($militiaBaseHp + $militiaUnits[_i].cyber + $militiaBaseHp * $militiaUnits[_i].medics * 0.25) * $militiaUnits[_i].troops>> + <</if>> + <</for>> + <<for _i = 0; _i < $slaveUnits.length; _i++>> + <<if $slaveUnits[_i].isDeployed == 1>> + <<if $slaveUnits[_i].training <= 33>> + <<set _expBonus = 0>> + <<elseif $slaveUnits[_i].training <= 66>> + <<set _expBonus = 0.25>> + <<else>> + <<set _expBonus = 0.50>> + <</if>> + <<if $slaveUnits[_i].loyalty <= 10>> + <<set _loyaltyBonus = 0>> + <<elseif $slaveUnits[_i].loyalty <= 33>> + <<set _loyaltyBonus = 0.10>> + <<elseif $slaveUnits[_i].loyalty <= 66>> + <<set _loyaltyBonus = 0.20>> + <<else>> + <<set _loyaltyBonus = 0.30>> + <</if>> + <<set _attack += ($slaveBaseAttack + $slaveBaseAttack * $slaveUnits[_i].equip * $equipMod + $slaveBaseAttack * _expBonus + $slaveBaseAttack * _loyaltyBonus + $slaveBaseAttack * $slaveUnits[_i].SF * 0.20 + $slaveUnits[_i].cyber) * _atkMod>> + <<set _defense += ($slaveBaseDefense + $slaveBaseDefense * $slaveUnits[_i].equip * $equipMod + $slaveBaseDefense * _expBonus + $slaveBaseDefense * _loyaltyBonus + $slaveBaseDefense * $slaveUnits[_i].SF * 0.20 + $slaveUnits[_i].cyber) * _defMod>> + <<set _hp += ($slaveBaseHp + $slaveUnits[_i].cyber + $slaveBaseHp * $slaveUnits[_i].medics * 0.25) * $slaveUnits[_i].troops>> + <</if>> + <</for>> + <<for _i = 0; _i < $mercUnits.length; _i++>> + <<if $mercUnits[_i].isDeployed == 1>> + <<if $mercUnits[_i].training <= 33>> + <<set _expBonus = 0>> + <<elseif $mercUnits[_i].training <= 66>> + <<set _expBonus = 0.25>> + <<else>> + <<set _expBonus = 0.50>> + <</if>> + <<if $mercUnits[_i].loyalty <= 10>> + <<set _loyaltyBonus = 0>> + <<elseif $mercUnits[_i].loyalty <= 33>> + <<set _loyaltyBonus = 0.10>> + <<elseif $mercUnits[_i].loyalty <= 66>> + <<set _loyaltyBonus = 0.20>> + <<else>> + <<set _loyaltyBonus = 0.30>> + <</if>> + <<set _attack += ($mercBaseAttack + $mercBaseAttack * $mercUnits[_i].equip * $equipMod + $mercBaseAttack * _expBonus + $mercBaseAttack * _loyaltyBonus + $mercBaseAttack * $mercUnits[_i].SF * 0.20 + $mercUnits[_i].cyber) * _atkMod>> + <<set _defense += ($mercBaseDefense + $mercBaseDefense * $mercUnits[_i].equip * $equipMod + $mercBaseDefense * _expBonus + $mercBaseDefense * _loyaltyBonus + $mercBaseDefense * $mercUnits[_i].SF * 0.20 + $mercUnits[_i].cyber) * _defMod>> + <<set _hp += ($mercBaseHp + $mercUnits[_i].cyber + $mercBaseHp * $mercUnits[_i].medics * 0.25) * $mercUnits[_i].troops>> + <</if>> + <</for>> + + <<if $SF.Toggle && $SF.Active >= 1 && $SFIntervention>> + <<set $SFatk = 0>> + <<set $SFdef = 0>> + <<set $SFhp = 0>> + <<calcSFStatistics>> + <<set _attack += $SFatk>> + <<set _defense += $SFdef>> + <<set _hp += $SFhp>> + <</if>> + + /* morale and baseHp calculation */ + /* minimum modifier is -50%, maximum is +50% */ + <<if _militiaMod < 0.5>> + <<set _militiaMod = 0.5>> + <<elseif _militiaMod > 1.5>> + <<set _militiaMod = 1.5>> <</if>> <<elseif $battleTerrain == "coast">> <<if $chosenTactic == "Bait and Bleed">> @@ -736,39 +767,27 @@ <<set _defMod -= 0.10>> <<set _tacChance -= 0.20>> <</if>> -<<elseif $battleTerrain == "wasteland">> - <<if $chosenTactic == "Bait and Bleed">> - <<set _atkMod += 0.05>> - <<set _defMod += 0.05>> - <<set _tacChance += 0.10>> - <<elseif $chosenTactic == "Guerrilla">> - <<set _atkMod += 0.10>> - <<set _defMod += 0.05>> - <<set _tacChance += 0.15>> - <<elseif $chosenTactic == "Choke Points">> - <<set _atkMod -= 0.10>> - <<set _defMod += 0.05>> - <<set _tacChance -= 0.05>> - <<elseif $chosenTactic == "Interior Lines">> - <<set _atkMod += 0.10>> - <<set _defMod += 0.15>> - <<set _tacChance += 0.25>> - <<elseif $chosenTactic == "Pincer Maneuver">> - <<set _atkMod += 0.15>> - <<set _defMod += 0.10>> - <<set _tacChance += 0.25>> - <<elseif $chosenTactic == "Defense In Depth">> - <<set _atkMod += 0.05>> - <<set _defMod += 0.10>> - <<set _tacChance += 0.15>> - <<elseif $chosenTactic == "Blitzkrieg">> - <<set _atkMod += 0.15>> - <<set _defMod += 0.15>> - <<set _tacChance += 0.30>> - <<elseif $chosenTactic == "Human Wave">> - <<set _atkMod += 0.20>> - <<set _defMod += 0.05>> - <<set _tacChance += 0.25>> + + <<set $troopCount = 0>> + <<calcTroopCount>> + <<set _moraleTroopMod = Math.clamp($troopCount / 100,1,5)>> + + <<set _morale = ($secBotsMorale * $deployingBots + $militiaBaseMorale * _militiaMod * $deployingMilitia + $slaveBaseMorale * _slaveMod * $deployingSlaves + $mercBaseMorale * _mercMod * $deployingMercs + $SFBaseMorale * $SFIntervention * _SFMod) / ($deployingBots + $deployingMilitia +$deployingSlaves + $deployingMercs + $SFIntervention)>> + <<set _morale = _morale + _morale * $secBarracksUpgrades.luxury * 0.05>> /* barracks bonus */ + <<set _morale *= _moraleTroopMod>> + <<set _baseHp = ($secBotsBaseHp * $deployingBots + $militiaBaseHp * $deployingMilitia + $slaveBaseHp * $deployingSlaves + $mercBaseHp * $deployingMercs + $SFBaseHp * $SFIntervention) / ($deployingBots + $deployingMilitia +$deployingSlaves + $deployingMercs + $SFIntervention)>> + + /* calculates enemy army stats */ + <<if $week <= 30>> + <<set _armyMod = $attackTroops / 80>> + <<elseif $week <= 60>> + <<set _armyMod = $attackTroops / 75>> + <<elseif $week <= 90>> + <<set _armyMod = $attackTroops / 70>> + <<elseif $week <= 120>> + <<set _armyMod = $attackTroops / 65>> + <<else>> + <<set _armyMod = $attackTroops / 60>> <</if>> <</if>> @@ -792,7 +811,9 @@ <<elseif $attackType == "freedom fighters">> <<set _tacChance -= 0.25>> <</if>> -<<elseif $chosenTactic == "Choke Points">> + + <<set _enemyMoraleTroopMod = Math.clamp($attackTroops / 100,1,5)>> + <<if $attackType == "raiders">> <<set _tacChance += 0.25>> <<elseif $attackType == "free city">> @@ -802,15 +823,16 @@ <<elseif $attackType == "freedom fighters">> <<set _tacChance += 0.05>> <</if>> -<<elseif $chosenTactic == "Interior Lines">> - <<if $attackType == "raiders">> - <<set _tacChance -= 0.15>> - <<elseif $attackType == "free city">> - <<set _tacChance += 0.15>> - <<elseif $attackType == "old world">> - <<set _tacChance += 0.20>> - <<elseif $attackType == "freedom fighters">> - <<set _tacChance -= 0.10>> + + /* difficulty */ + <<set _enemyAttack *= $difficulty>> + <<set _enemyDefense *= $difficulty>> + <<set _enemyMorale *= $difficulty>> + <<set _enemyHp *= $difficulty>> + <<set _enemyBaseHp *= $difficulty>> + + <<if isNaN(_attack)>> + <br>@@.red;Error: attack value reported NaN@@ <</if>> <<elseif $chosenTactic == "Pincer Maneuver">> <<if $attackType == "raiders">> @@ -966,208 +988,22 @@ <<set _defense += ($mercBaseDefense + $mercBaseDefense * $mercUnits[_i].equip * $equipMod + $mercBaseDefense * _expBonus + $mercBaseDefense * _loyaltyBonus + $mercBaseDefense * $mercUnits[_i].SF * 0.20 + $mercUnits[_i].cyber) * _defMod>> <<set _hp += ($mercBaseHp + $mercUnits[_i].cyber + $mercBaseHp * $mercUnits[_i].medics * 0.25) * $mercUnits[_i].troops>> <</if>> -<</for>> - -<<if $SF.Toggle && $SF.Active >= 1 && $SFIntervention>> - <<set $SFatk = 0>> - <<set $SFdef = 0>> - <<set $SFhp = 0>> - <<calcSFStatistics>> - <<set _attack += $SFatk>> - <<set _defense += $SFdef>> - <<set _hp += $SFhp>> -<</if>> - -/* morale and baseHp calculation */ -/* minimum modifier is -50%, maximum is +50% */ -<<if _militiaMod < 0.5>> - <<set _militiaMod = 0.5>> -<<elseif _militiaMod > 1.5>> - <<set _militiaMod = 1.5>> -<</if>> -<<if _slaveMod < 0.5>> - <<set _slaveMod = 0.5>> -<<elseif _slaveMod > 1.5>> - <<set _slaveMod = 1.5>> -<</if>> -<<if _mercMod < 0.5>> - <<set _mercMod = 0.5>> -<<elseif _mercMod > 1.5>> - <<set _mercMod = 1.5>> -<</if>> -<<if _SFMod < 0.5>> - <<set _SFMod = 0.5>> -<<elseif _SFMod > 1.5>> - <<set _SFMod = 1.5>> -<</if>> - -<<set $troopCount = 0>> -<<calcTroopCount>> -<<set _moraleTroopMod = Math.clamp($troopCount / 100,1,5)>> - -<<set _morale = ($secBotsMorale * $deployingBots + $militiaBaseMorale * _militiaMod * $deployingMilitia + $slaveBaseMorale * _slaveMod * $deployingSlaves + $mercBaseMorale * _mercMod * $deployingMercs + $SFBaseMorale * $SFIntervention * _SFMod) / ($deployingBots + $deployingMilitia +$deployingSlaves + $deployingMercs + $SFIntervention)>> -<<set _morale = _morale + _morale * $secBarracksUpgrades.luxury * 0.05>> /* barracks bonus */ -<<set _morale *= _moraleTroopMod>> -<<set _baseHp = ($secBotsBaseHp * $deployingBots + $militiaBaseHp * $deployingMilitia + $slaveBaseHp * $deployingSlaves + $mercBaseHp * $deployingMercs + $SFBaseHp * $SFIntervention) / ($deployingBots + $deployingMilitia +$deployingSlaves + $deployingMercs + $SFIntervention)>> - -/* calculates enemy army stats */ -<<if $week <= 30>> - <<set _armyMod = $attackTroops / 80>> -<<elseif $week <= 60>> - <<set _armyMod = $attackTroops / 75>> -<<elseif $week <= 90>> - <<set _armyMod = $attackTroops / 70>> -<<elseif $week <= 120>> - <<set _armyMod = $attackTroops / 65>> -<<else>> - <<set _armyMod = $attackTroops / 60>> -<</if>> -<<set _armyMod = Math.trunc(_armyMod)>> -<<if $majorBattle == 1>> - <<set _armyMod *= 2>> -<</if>> -<<if _armyMod <= 0>> - <<set _armyMod = 1>> -<</if>> - -<<set _enemyMoraleTroopMod = Math.clamp($attackTroops / 100,1,5)>> - -<<if $attackType == "raiders">> - <<set _enemyAttack = ($raBaseAttack + $weapManu * $sellTo.raiders + $raBaseAttack * $attackEquip * $equipMod) * _armyMod>> - <<set _enemyDefense = ($raBaseDefense + $weapManu * $sellTo.raiders + $raBaseDefense * $attackEquip * $equipMod) * _armyMod>> - <<set _enemyMorale = $raBaseMorale * _enemyMod * _enemyMoraleTroopMod>> - <<set _enemyHp = $raBaseHp * $attackTroops>> - <<set _enemyBaseHp = $raBaseHp>> -<<elseif $attackType == "free city">> - <<set _enemyAttack = ($fcBaseAttack + $weapManu * $sellTo.FC + $fcBaseAttack * $attackEquip * $equipMod) * _armyMod>> - <<set _enemyDefense = ($fcBaseDefense + $weapManu * $sellTo.FC + $fcBaseDefense * $attackEquip * $equipMod) * _armyMod>> - <<set _enemyMorale = $fcBaseMorale * _enemyMod * _enemyMoraleTroopMod>> - <<set _enemyHp = $fcBaseHp * $attackTroops>> - <<set _enemyBaseHp = $fcBaseHp>> -<<elseif $attackType == "old world">> - <<set _enemyAttack = ($owBaseAttack + $weapManu * $sellTo.oldWorld + $owBaseAttack * $attackEquip * $equipMod) * _armyMod>> - <<set _enemyDefense = ($owBaseDefense + $weapManu * $sellTo.oldWorld + $owBaseDefense * $attackEquip * $equipMod) * _armyMod>> - <<set _enemyMorale = $owBaseMorale * _enemyMod * _enemyMoraleTroopMod>> - <<set _enemyHp = $owBaseHp * $attackTroops>> - <<set _enemyBaseHp = $owBaseHp>> -<<elseif $attackType == "freedom fighters">> - <<set _enemyAttack = ($ffBaseAttack + $weapManu * $sellTo.oldWorld + $ffBaseAttack * $attackEquip * $equipMod) * _armyMod>> - <<set _enemyDefense = ($ffBaseDefense + $weapManu * $sellTo.oldWorld + $ffBaseDefense * $attackEquip * $equipMod) * _armyMod>> - <<set _enemyMorale = $ffBaseMorale * _enemyMod * _enemyMoraleTroopMod>> - <<set _enemyHp = $ffBaseHp * $attackTroops>> - <<set _enemyBaseHp = $ffBaseHp>> -<</if>> - -/* difficulty */ -<<set _enemyAttack *= $difficulty>> -<<set _enemyDefense *= $difficulty>> -<<set _enemyMorale *= $difficulty>> -<<set _enemyHp *= $difficulty>> -<<set _enemyBaseHp *= $difficulty>> - -<<if isNaN(_attack)>> - <br>@@.red;Error: attack value reported NaN@@ -<</if>> -<<if isNaN(_defense)>> - <br>@@.red;Error: defense value reported NaN@@ -<</if>> -<<if isNaN(_hp)>> - <br>@@.red;Error: hp value reported NaN@@ -<</if>> -<<if isNaN(_morale)>> - <br>@@.red;Error: morale value reported NaN@@ -<</if>> -<<if isNaN(_enemyAttack)>> - <br>@@.red;Error: enemy attack value reported NaN@@ -<</if>> -<<if isNaN(_enemyDefense)>> - <br>@@.red;Error: enemy defense value reported NaN@@ -<</if>> -<<if isNaN(_enemyHp)>> - <br>@@.red;Error: enemy hp value reported NaN@@ -<</if>> -<<if isNaN(_enemyMorale)>> - <br>@@.red;Error: enemy morale value reported NaN@@ -<</if>> - -<<if $showBattleStatistics == 1>> -<<set _atkMod -= 1, _defMod -= 1, _militiaMod -= 1, _mercMod -= 1, _slaveMod -= 1, _SFMod -= 1, _enemyMod -= 1, _moraleTroopMod -= 1, _enemyMoraleTroopMod -= 1, _difficulty = $difficulty -1>> -<<set _atkMod = Math.round(_atkMod * 100)>> -<<set _defMod = Math.round(_defMod * 100)>> -<<set _militiaMod = Math.round(_militiaMod * 100)>> -<<set _mercMod = Math.round(_mercMod * 100)>> -<<set _slaveMod = Math.round(_slaveMod * 100)>> -<<set _SFMod = Math.round(_SFMod * 100)>> -<<set _enemyMod = Math.round(_enemyMod * 100)>> -<<set _barracksBonus = $secBarracksUpgrades.luxury * 5>> -<<set _moraleTroopMod = Math.round(_moraleTroopMod * 100)>> -<<set _enemyMoraleTroopMod = Math.round(_enemyMoraleTroopMod * 100)>> -<<set _difficulty *= 100>> - -__Difficulty__: -<br> -<<if $difficulty == 0.5>> - Very easy -<<elseif $difficulty == 0.75>> - Easy -<<elseif $difficulty == 1>> - Normal -<<elseif $difficulty == 1.25>> - Hard -<<else>> - Very hard -<</if>> -<br> -<br> -__Army__: -<br>troops: <<print commaNum(Math.round($troopCount))>> -<br>attack: <<print commaNum(Math.round(_attack))>> -<br>defense: <<print commaNum(Math.round(_defense))>> -<br>hp: <<print commaNum(Math.round(_hp))>> -<br>morale: <<print commaNum(Math.round(_morale))>> -<br>attack modifier: <<if _atkMod > 0>>+<</if>>_atkMod% -<br>defense modifier: <<if _defMod > 0>>+<</if>>_defMod% -<br>average base HP: <<print commaNum(Math.round(_baseHp))>> -<br>militia morale modifier: <<if _militiaMod > 0>>+<</if>>_militiaMod% -<br>slaves morale modifier: <<if _slaveMod > 0>>+<</if>>_slaveMod% -<br>mercenaries morale modifier: <<if _mercMod > 0>>+<</if>>_mercMod% -<<if $SF.Toggle && $SF.Active >= 1 && $SFIntervention>> -<br>special force morale modifier: <<if _SFMod > 0>>+<</if>>_SFMod% -<</if>> -<<if $secBarracksUpgrades.luxury >= 1>> -<br>Barracks bonus morale modifier: +<<print _barracksBonus>>% -<</if>> -<<if _moraleTroopMod>> - <br>morale increase due to troop numbers: +<<print _moraleTroopMod>>% -<</if>> -<br> -<br> -__Tactics__: -<br>tactic chance of success: <<print commaNum(Math.round(_tacChance * 100))>>% -<br>was tactic chosen successful?: <<if $tacticsSuccessful == 1>> yes <<else>> no<</if>> -<br> -<br> -__Enemy__: -<br>enemy troops: <<print commaNum(Math.round($attackTroops))>> -<br>enemy attack: <<print commaNum(Math.round(_enemyAttack))>> -<br>enemy defense: <<print commaNum(Math.round(_enemyDefense))>> -<br>enemy Hp: <<print commaNum(Math.round(_enemyHp))>> -<br>enemy morale: <<print commaNum(Math.round(_enemyMorale))>> -<br>enemy base Hp: <<print commaNum(Math.round(_enemyBaseHp))>> -<br>enemy morale modifier: <<if _enemyMod > 0>>+<</if>>_enemyMod% -<<if _enemyMoraleTroopMod > 0>> - <br>enemy morale increase due to troop numbers: +<<print _enemyMoraleTroopMod>>% -<</if>> -<br>Difficulty modifier: <<if _difficulty > 0>>+<</if>><<print _difficulty>>% -<</if>> + <<if $showBattleStatistics == 1>> + <<set _atkMod -= 1, _defMod -= 1, _militiaMod -= 1, _mercMod -= 1, _slaveMod -= 1, _SFMod -= 1, _enemyMod -= 1, _moraleTroopMod -= 1, _enemyMoraleTroopMod -= 1, _difficulty = $difficulty -1>> + <<set _atkMod = Math.round(_atkMod * 100)>> + <<set _defMod = Math.round(_defMod * 100)>> + <<set _militiaMod = Math.round(_militiaMod * 100)>> + <<set _mercMod = Math.round(_mercMod * 100)>> + <<set _slaveMod = Math.round(_slaveMod * 100)>> + <<set _SFMod = Math.round(_SFMod * 100)>> + <<set _enemyMod = Math.round(_enemyMod * 100)>> + <<set _barracksBonus = $secBarracksUpgrades.luxury * 5>> + <<set _moraleTroopMod = Math.round(_moraleTroopMod * 100)>> + <<set _enemyMoraleTroopMod = Math.round(_enemyMoraleTroopMod * 100)>> + <<set _difficulty *= 100>> -/* simulates the combat by pitting attk against def */ -<<for _i = 0; _i < _turns; _i++>> - <br><br> - <<if $showBattleStatistics == 1>> turn: <<print _i + 1>><</if>> - /* player army attacks */ - <<set _damage = Math.clamp(_attack - _enemyDefense,_attack * 0.1,_attack)>> + __Difficulty__: <br> <<if $showBattleStatistics == 1>> player damage: <<print commaNum(Math.round(_damage))>><</if>> <<set _enemyHp -= _damage>> @@ -1200,39 +1036,95 @@ __Enemy__: <<set _moraleDamage = Math.clamp(_damage / 2 + _damage / _baseHp,0,_damage*1.5)>> <<set _morale -= _moraleDamage>> <br> - <<if $showBattleStatistics == 1>> remaining morale: <<print Math.round(_morale)>><</if>> - <<if _hp <= 0 || _morale <= 0>> - <br> - <<if $showBattleStatistics == 1>> <br>Defeat!<</if>> - <<set $battleResult = -3>> - <<set $battleTurns = _i>> - <<break>> + __Enemy__: + <br>enemy troops: <<print commaNum(Math.round($attackTroops))>> + <br>enemy attack: <<print commaNum(Math.round(_enemyAttack))>> + <br>enemy defense: <<print commaNum(Math.round(_enemyDefense))>> + <br>enemy Hp: <<print commaNum(Math.round(_enemyHp))>> + <br>enemy morale: <<print commaNum(Math.round(_enemyMorale))>> + <br>enemy base Hp: <<print commaNum(Math.round(_enemyBaseHp))>> + <br>enemy morale modifier: <<if _enemyMod > 0>>+<</if>>_enemyMod% + <<if _enemyMoraleTroopMod > 0>> + <br>enemy morale increase due to troop numbers: +<<print _enemyMoraleTroopMod>>% + <</if>> + <br>Difficulty modifier: <<if _difficulty > 0>>+<</if>><<print _difficulty>>% <</if>> -<</for>> -<<if $battleResult != 3 && $battleResult != -3>> - <br> - <<if _morale > _enemyMorale>> - <<if $showBattleStatistics == 1>> <br>Partial victory!<</if>> - <<set $battleResult = 2>> - <<elseif _morale < _enemyMorale>> - <<if $showBattleStatistics == 1>> <br>Partial defeat!<</if>> - <<set $battleResult = -2>> + + /* simulates the combat by pitting attk against def */ + <<for _i = 0; _i < _turns; _i++>> + <br><br> + <<if $showBattleStatistics == 1>> turn: <<print _i + 1>><</if>> + /* player army attacks */ + <<set _damage = Math.clamp(_attack - _enemyDefense,_attack * 0.1,_attack)>> + <br> + <<if $showBattleStatistics == 1>> player damage: <<print commaNum(Math.round(_damage))>><</if>> + <<set _enemyHp -= _damage>> + <br> + <<if $showBattleStatistics == 1>> remaining enemy Hp: <<print commaNum(Math.round(_enemyHp))>><</if>> + <<set $enemyLosses += _damage / _enemyBaseHp>> + <<set _moraleDamage = Math.clamp(_damage / 2 + _damage / _enemyBaseHp,0,_damage*1.5)>> + <<set _enemyMorale -= _moraleDamage>> + <br> + <<if $showBattleStatistics == 1>> remaining enemy morale: <<print commaNum(Math.round(_enemyMorale))>><</if>> + <<if _enemyHp <= 0 || _enemyMorale <= 0>> + <br> + <<if $showBattleStatistics == 1>> <br>Victory!<</if>> + <<set $battleResult = 3>> + <<set $battleTurns = _i>> + <<break>> + <</if>> + + /* attacker army attacks */ + <<set _damage = _enemyAttack - _defense>> + <<if _damage < _enemyAttack * 0.1>> + <<set _damage = _enemyAttack * 0.1>> + <</if>> + <br> + <<if $showBattleStatistics == 1>> enemy damage: <<print commaNum(Math.round(_damage))>><</if>> + <<set _hp -= _damage>> + <br> + <<if $showBattleStatistics == 1>> remaining hp: <<print commaNum(Math.round(_hp))>><</if>> + <<set $losses += _damage / _baseHp>> + <<set _moraleDamage = Math.clamp(_damage / 2 + _damage / _baseHp,0,_damage*1.5)>> + <<set _morale -= _moraleDamage>> + <br> + <<if $showBattleStatistics == 1>> remaining morale: <<print Math.round(_morale)>><</if>> + <<if _hp <= 0 || _morale <= 0>> + <br> + <<if $showBattleStatistics == 1>> <br>Defeat!<</if>> + <<set $battleResult = -3>> + <<set $battleTurns = _i>> + <<break>> + <</if>> + <</for>> + <<if $battleResult != 3 && $battleResult != -3>> + <br> + <<if _morale > _enemyMorale>> + <<if $showBattleStatistics == 1>> <br>Partial victory!<</if>> + <<set $battleResult = 2>> + <<elseif _morale < _enemyMorale>> + <<if $showBattleStatistics == 1>> <br>Partial defeat!<</if>> + <<set $battleResult = -2>> + <</if>> <</if>> -<</if>> -<<if $showBattleStatistics == 1>> - <br> - <br>Losses: <<print commaNum(Math.trunc($losses))>> - <br>Enemy losses: <<print commaNum(Math.trunc($enemyLosses))>> -<</if>> + <<if $showBattleStatistics == 1>> + <br> + <br>Losses: <<print commaNum(Math.trunc($losses))>> + <br>Enemy losses: <<print commaNum(Math.trunc($enemyLosses))>> + <</if>> -<<if $battleResult > 3 || $battleResult < -3>> - <br><br>@@.red;Error: failed to determine battle result@@ -<</if>> + <<if $battleResult > 3 || $battleResult < -3>> + <br><br>@@.red;Error: failed to determine battle result@@ + <</if>> -<<if $showBattleStatistics == 1 && $majorBattle == 1 && $majorBattleGameOver == 1 && $battleResult == -3>> - <br><br> - <<link "Proceed">> + <<if $showBattleStatistics == 1 && $majorBattle == 1 && $majorBattleGameOver == 1 && $battleResult == -3>> + <br><br> + <<link "Proceed">> + <<set $gameover = "major battle defeat">> + <<goto "Gameover">> + <</link>> + <<elseif $majorBattle == 1 && $majorBattleGameOver == 1 && $battleResult == -3>> <<set $gameover = "major battle defeat">> <<goto "Gameover">> <</link>> diff --git a/src/SecExp/unitsRebellionReport.tw b/src/SecExp/unitsRebellionReport.tw index 3d362d09c22a42c9371dd08c3e0eca3edc58b3ba..fb3230c27ba8515cc145178f6f9c0b844e77ba98 100644 --- a/src/SecExp/unitsRebellionReport.tw +++ b/src/SecExp/unitsRebellionReport.tw @@ -104,8 +104,7 @@ /* slaves */ <<set _slaveRebelledID = []>> <<set _slaveManpower = 0>> - <br> - <br> + <br><br> <<for _j = 0; _j < $slaveUnits.length; _j++>> <<if $slaveUnits[_j].active == 1 && $rebellingID.includes($slaveUnits[_j].ID)>> $slaveUnits[_j].platoonName, @@ -158,8 +157,7 @@ /* mercs */ <<set _mercRebelledID = []>> <<set _mercManpower = 0>> - <br> - <br> + <br><br> <<for _j = 0; _j < $mercUnits.length; _j++>> <<if $mercUnits[_j].active == 1 && $rebellingID.includes($mercUnits[_j].ID)>> $mercUnits[_j].platoonName, @@ -297,8 +295,7 @@ /* assigns the losses and notify the player */ <<if $irregulars > 0>> - <br> - <br> + <br><br> <<set _loss = _lossesList.pluck()>> <<if _loss > $ACitizens * 0.95>> <<set _loss = Math.trunc($ACitizens * 0.95)>> /* this is unlikely to happen, but might as well be safe*/ @@ -341,8 +338,7 @@ <</if>> <</if>> <<if $secBots.active == 1>> - <br> - <br> + <br><br> <<set _loss = _lossesList.pluck()>> <<set _loss = Math.clamp(_loss,0,$secBots.troops)>> <<set $secBots.troops -= _loss>> @@ -367,8 +363,7 @@ <</if>> <</if>> <<if $SF.Toggle && $SF.Active >= 1>> - <br> - <br> + <br><br> <<set _loss = _lossesList.pluck()>> <<set _loss = Math.clamp(_loss,0,$SF.Squad.Troops)>> $SF.Lower, $SF.Squad.Troops strong, is called to join the battle: @@ -389,8 +384,7 @@ <<if $deployingMilitia == 1>> <<for _j = 0; _j < $militiaUnits.length; _j++>> <<if $militiaUnits[_j].active == 1 && $loyalID.includes($militiaUnits[_j].ID)>> - <br> - <br> + <br><br> <<set $militiaUnits[_j].battlesFought++>> <<set _loss = _lossesList.pluck()>> <<set _loss = Math.clamp(_loss,0,$militiaUnits[_j].troops)>> @@ -434,8 +428,7 @@ <<set _med = 0>> <<for _j = 0; _j < $slaveUnits.length; _j++>> <<if $slaveUnits[_j].active == 1 && $loyalID.includes($slaveUnits[_j].ID)>> - <br> - <br> + <br><br> <<set $slaveUnits[_j].battlesFought++>> <<set _loss = _lossesList.pluck()>> <<if !(Number.isInteger(_loss))>> @@ -482,8 +475,7 @@ <<if $deployingMercs == 1>> <<for _j = 0; _j < $mercUnits.length; _j++>> <<if $mercUnits[_j].active == 1 && $loyalID.includes($mercUnits[_j].ID)>> - <br> - <br> + <br><br> <<set $mercUnits[_j].battlesFought++>> <<set _loss = _lossesList.pluck()>> <<set _loss = Math.clamp(_loss,0,$mercUnits[_j].troops)>> @@ -523,8 +515,7 @@ <</if>> <</for>> <</if>> - <br> - <br> + <br><br> <<if $rebellingID.length > 0 && $battleResult >= 2>> /* win */ /* militia */ diff --git a/src/SpecialForce/Upgrades.tw b/src/SpecialForce/Upgrades.tw index 1fe617a441ff48d8fb447c11c227e5a9e67fd441..11c560502b55d7704572b42cf3c75743da294481 100644 --- a/src/SpecialForce/Upgrades.tw +++ b/src/SpecialForce/Upgrades.tw @@ -116,7 +116,7 @@ <<else>>//Cannot afford to upgrade Transport Vehicle Fleet.//<</if>> - //Costs @@.yellowgreen;<<print cashFormat(_cTV)>>@@//<span style="float:right;"><<print progress($SF.Squad.TV)>> </span> + //Costs @@.yellowgreen;<<print cashFormat(_cTV)>>@@//<span style="float:right;"><<print progress($SF.Squad.TV)>> </span> <<elseif $SF.Squad.TV == _TVU>>//The Transport Vehicle Fleet has been fully upgraded.//<span style="float:right;"><<print progress($SF.Squad.TV)>></span> diff --git a/src/art/artJS.js b/src/art/artJS.js index eec18a632ece6b05ae0ed0be9eba33191fec8d55..30a25baec93a307b6b6549b2984ec07759fdb9c9 100644 --- a/src/art/artJS.js +++ b/src/art/artJS.js @@ -72,12 +72,11 @@ window.ArtControlRendered = function ArtControlRendered(slave, sizePlacement) { /* This takes a textual hair color description and tries to guess the appropriate HTML compliant color code. - -color should be a color name, but can also be a string describing hair color. +Color should be a color name, but can also be a string describing hair color. eyes can be nearly anything, it only indicates that the function is being used for eye color instead of hair color. - This code's working is described to the user in the Encyclopedia, chapter "Lore", section "Dyes". */ + window.extractColor = function (color, eyes) { /* these are color names known and used in FreeCities diff --git a/src/art/assistantArt.js b/src/art/assistantArt.js index b441c2fb827b246662cdf479524409867ac45260..5b8130f2031086c0f84ce7fa9ba2991542877e5a 100644 --- a/src/art/assistantArt.js +++ b/src/art/assistantArt.js @@ -12,7 +12,7 @@ window.assistantArt = function assistantArt(sizePlacement) { if (V.imageChoice === 0 || V.imageChoice === 1) { if (V.imageChoice === 1) { - switch (V.assistantAppearance) { + switch (V.assistantAppearance) { case "monstergirl": fileName = "''"; break; @@ -63,7 +63,7 @@ window.assistantArt = function assistantArt(sizePlacement) { break; default: fileName = "''"; - } + } } else /* V.imageChoice === 0*/ { fileName += "'resources/renders/assistant "; switch (V.assistantAppearance) { diff --git a/src/cheats/mod_EditSlaveCheat.tw b/src/cheats/mod_EditSlaveCheat.tw index c39aa26fd17b8b3426bb0120c16375186412c0f9..bb9a18a01e782b80889f8e07caac2dac2c1f6f76 100644 --- a/src/cheats/mod_EditSlaveCheat.tw +++ b/src/cheats/mod_EditSlaveCheat.tw @@ -1353,7 +1353,7 @@ Paraphilias: <<radiobutton "$tempSlave.sexualQuirk" "unflinching">> Unflinching <<radiobutton "$tempSlave.sexualQuirk" "size queen">> Size Queen <<if $tempSlave.sexualQuirk != "none">> - <<if !["cum addict", "anal addict", "attention whore", "breast growth", "abusive", "malicious", "self hating", "neglectful", "breeder"].includes($tempSlave.sexualFlaw)>> + <<if !["abusive", "anal addict", "attention whore", "breast growth", "breeder", "cum addict", "malicious", "neglectful", "self hating"].includes($tempSlave.sexualFlaw)>> <<set $tempSlave.sexualFlaw = "none">> <</if>> <</if>> diff --git a/src/debugging/debugWidgets.tw b/src/debugging/debugWidgets.tw index b4d13efc7b22536bd3b063747a4c3eaadd47dab3..ef640d1eacc76f2dc5ba350918d032cc65dc3032 100644 --- a/src/debugging/debugWidgets.tw +++ b/src/debugging/debugWidgets.tw @@ -22,7 +22,7 @@ The included "Go Back" link is intended to replace the usual NextButton. <br> Differences: <<if _diffArrayFromNew.length > 0>> - <<for _i = 0; _i < _diffArrayFromNew.length; _i++>> /* Print variable names, and changed values. Will output the new values correctly, may not output old values correctly */ + <<for _i = 0; _i < _diffArrayFromNew.length; _i++>> /* Print variable names, and changed values. Will output the new values correctly, may not output old values correctly */ <<if _diffArrayFromNew[_i].variable != "nextButton" && _diffArrayFromNew[_i].variable != "nextLink" && _diffArrayFromNew[_i].variable != "args">> <br> Variable: <<print _diffArrayFromNew[_i].variable>>, Original Value: <<print _diffArrayFromNew[_i].oldVal>>, New Value: <<print _diffArrayFromNew[_i].newVal>> <</if>> diff --git a/src/facilities/farmyard/farmyardReport.tw b/src/facilities/farmyard/farmyardReport.tw index 8786c347863cf4e07299d79de9084df3ad81cf88..cea2e129407c815f373af384b51dc7e8d09a932e 100644 --- a/src/facilities/farmyard/farmyardReport.tw +++ b/src/facilities/farmyard/farmyardReport.tw @@ -95,7 +95,7 @@ $His turgid dick helps $him manage $his workers. <<set $FarmerCashBonus += 0.05>> <</if>> - + <<for _dI = 0; _dI < _DL; _dI++>> <<set $i = $slaveIndices[$FarmyardiIDs[_dI]]>> <<if $Farmer.rivalryTarget == $slaves[$i].ID>> @@ -128,7 +128,7 @@ <<set $slaves[$i].trust++, $FarmerCashBonus += 0.05>> <</if>> <</for>> - + <<set _oldCash = $cash>> <<if (_DL < 5)>> /* TODO: will we need this block? @@ -317,7 +317,7 @@ <<set $food += _foodWeek>> <<if $farmyardDecoration != "standard">> - <br>$farmyardNameCaps's customers enjoyed + <br>$farmyardNameCaps's customers enjoyed <<if $seeBestiality == 1 && $farmyardBreeding > 0 && ($canines.length > 0 || $hooved.length > 0 || $felines.length > 0)>> @@.green;watching farmhands fuck animals in $farmyardDecoration surroundings.@@ <<elseif $farmyardShows == 1>> diff --git a/src/facilities/nursery/childSummary.tw b/src/facilities/nursery/childSummary.tw index 2d9a62cdeb043b03ab2caacab269138510bf5d96..1f0742ab1b2fbdba2e0fbb67d719a83806728dad 100644 --- a/src/facilities/nursery/childSummary.tw +++ b/src/facilities/nursery/childSummary.tw @@ -5,7 +5,7 @@ "Nursery" c => (c.assignmentVisible == 1 && c.fuckdoll == 0), "Personal Attention Select": c => (c.assignmentVisible == 1 && c.fuckdoll <= 0) && ( ($Flag == 0 && c.assignment != "be a child") - || ($Flag == 1 && c.assignment == "be a child") + || ($Flag == 1 && c.assignment == "be a child") ), "New Game Plus": c => (($Flag == 0 && c.assignment != "be imported") || ($Flag != 0 && c.assignment == "be imported")), "Rules Slave Select": c => (($Flag == 0 && !ruleSlaveSelected(c, $currentRule)) || ($Flag != 0 && ruleSlaveSelected(c, $currentRule))), diff --git a/src/facilities/nursery/longChildDescription.tw b/src/facilities/nursery/longChildDescription.tw index 3ccf1f25fb50f678201b0ffa013b2456102e413c..fc748c7fdb35ae4cb02ba0dd84f14437e6b93fc5 100644 --- a/src/facilities/nursery/longChildDescription.tw +++ b/src/facilities/nursery/longChildDescription.tw @@ -788,7 +788,7 @@ $he's <<if $activeChild.fuckdoll == 0>> <<if $showBodyMods == 1>> - <<if ["neck", "left cheek", "right cheek", "cheeks", "left ears", "right ears", "ears"].includes($activeChild.brandLocation)>> + <<if ["cheeks", "ears", "left cheek", "left ears", "neck", "right cheek", "right ears"].includes($activeChild.brandLocation)>> <<brandDescription>> <</if>> <</if>> @@ -1272,7 +1272,7 @@ $He is <<if $activeChild.fuckdoll == 0>> <<if $showBodyMods == 1>> /* Check it's not a facial brand: */ - <<if ["back", "lower back", "chest", "right shoulder", "left shoulder", "shoulders", "right upper arm", "left upper arm", "upper arms", "right lower arm", "left lower arm", "lower arms", "right wrist", "left wrist", "wrists", "right hand", "left hand", "hands", "left ankle", "right ankle", "ankles", "right calf", "left calf", "calves", "right foot", "left foot", "feet"].includes($activeChild.brandLocation)>> + <<if ["ankles", "back", "calves", "chest", "feet", "hands", "left ankle", "left calf", "left foot", "left hand", "left lower arm", "left shoulder", "left upper arm", "left wrist", "lower arms", "lower back", "right ankle", "right calf", "right foot", "right hand", "right lower arm", "right shoulder", "right upper arm", "right wrist", "shoulders", "upper arms", "wrists"].includes($activeChild.brandLocation)>> <<brandDescription>> <</if>> <</if>> diff --git a/src/facilities/nursery/nursery.tw b/src/facilities/nursery/nursery.tw index 78098219fb314c8c2d417af2e628745801c4b9d7..1b9d83f97065287a7859050d1a751ed7adba7df0 100644 --- a/src/facilities/nursery/nursery.tw +++ b/src/facilities/nursery/nursery.tw @@ -407,7 +407,7 @@ Target age for release: <<textbox "$targetAgeNursery" $targetAgeNursery "Nursery Children are purposefully getting more exercise than recommended; excessive muscle gain likely. [[Limit exercise|Nursery][$nurseryMusclesSetting = 1]] | [[Disable|Nursery][$nurseryMusclesSetting = 0]] <<elseif $nurseryMusclesSetting == 1>> - Excercise is being carefully managed; children will be raised with average strength. + Exercise is being carefully managed; children will be raised with average strength. [[More exercise|Nursery][$nurseryMusclesSetting = 2]] | [[Disable|Nursery][$nurseryMusclesSetting = 0]] <<elseif $nurseryMusclesSetting == 0>> Children are no getting any exercise; they will likely be extremely weak. @@ -592,7 +592,7 @@ Filter by assignment: | | <<print "[[Abuse her|FAbuse][$activeSlave = $cribs["+$i+"], $childSex = 1, $nextButton = _j,$nextLink = _k,$returnTo = _l]]">> <<else>> all of her holes equally, but for now:// - <br> <<print "[[Use her mouth|FLips][$activeSlave = $cribs["+$i+"], $childSex = 1, $nextButton = _j, $nextLink = _k, $returnTo = _l]]">> | <<print "[[Play with her tits|FBoobs][$activeSlave = $cribs["+$i+"], $childSex = 1, $nextButton = _j, $nextLink = _k, $returnTo = _l]]">> + <br> <<print "[[Use her mouth|FLips][$activeSlave = $cribs["+$i+"], $childSex = 1, $nextButton = _j, $nextLink = _k, $returnTo = _l]]">> | <<print "[[Play with her tits|FBoobs][$activeSlave = $cribs["+$i+"], $childSex = 1, $nextButton = _j, $nextLink = _k, $returnTo = _l]]">> <<if canDoVaginal($cribs[$i])>> | <<print "[[Fuck her|FVagina][$activeSlave = $cribs["+$i+"], $childSex = 1, $nextButton = _j, $nextLink = _k, $returnTo = _l]]">> <<if canDoAnal($cribs[$i])>> diff --git a/src/init/storyInit.tw b/src/init/storyInit.tw index af26bbead9f30613808645ed2055c2d5ee551029..f48636c0d322a9198dbe402fe5151a3d2657e8e9 100644 --- a/src/init/storyInit.tw +++ b/src/init/storyInit.tw @@ -15,8 +15,8 @@ You should have received a copy of the GNU General Public License along with thi <<set $returnTo = "init", $nextButton = "Continue", $nextLink = "Alpha disclaimer">> <<unset $releaseID>> -<<set $ver = "0.10.7", $pmodVer = "2.0.X", $releaseID = 1040>> -<<if ndef $pmodVer>><<set $pmodVer = "2.0.X">><</if>> +<<set $ver = "0.10.7", $pmodVer = "2.1.X", $releaseID = 1041>> +<<if ndef $pmodVer>><<set $pmodVer = "2.1.X">><</if>> /* This needs to be broken down into individual files that can be added to StoryInit instead. */ @@ -216,7 +216,6 @@ You should have received a copy of the GNU General Public License along with thi <<set $saveImported = 0>> <</if>> - <<if $saveImported == 0>> /* new game (not NG+) */ <<initPC>> @@ -358,7 +357,7 @@ You should have received a copy of the GNU General Public License along with thi <<set $minimumSlaveAge = 18>> <<set $fertilityAge = 13>> <<silently>> - FertilityAge($fertilityAge) + FertilityAge($fertilityAge) <</silently>> <<set $potencyAge = 13>> <<set $AgePenalty = 1>> @@ -494,7 +493,7 @@ You should have received a copy of the GNU General Public License along with thi <<set $dairyRestraintsUpgrade = 0>> <<set $dairyRestraintsSetting = 0>> <<silently>> -DairyRestraintsSetting($dairyRestraintsSetting) + DairyRestraintsSetting($dairyRestraintsSetting) <</silently>> <<set $dairySlimMaintainUpgrade = 0>> <<set $dairySlimMaintain = 0>> @@ -878,7 +877,7 @@ DairyRestraintsSetting($dairyRestraintsSetting) <<set $clinicInflateBelly = 0>> <<set $playerBred = 0>> <<set $propOutcome = 0>> -<<set $EliteSires = ["moves", "quick", "crazy", "virgin", "futa", "preggo"]>> +<<set $EliteSires = ["crazy", "futa", "moves", "preggo", "quick", "virgin"]>> <<set $startingPoint = -1>> <<set $PhysicalRetirementAgePolicy = 0>> <<set $raped = -1>> @@ -1465,8 +1464,8 @@ electrolarynx: 0, erectileImplant: 0 } >> -<<set $merchantFSWares = ["GenderRadicalistResearch", "TransformationFetishistResearch", "AssetExpansionistResearch", "SlimnessEnthusiastResearch", "YouthPreferentialistResearch", "HedonisticDecadenceResearch"]>> -<<set $merchantIllegalWares = ["childhoodFertilityInducedNCS", "UterineRestraintMesh", "RapidCellGrowthFormula", "PGHack", "sympatheticOvaries", "asexualReproduction"]>> /* "AnimalOrgans" for future use */ +<<set $merchantFSWares = ["AssetExpansionistResearch", "GenderRadicalistResearch", "HedonisticDecadenceResearch", "SlimnessEnthusiastResearch", "TransformationFetishistResearch", "YouthPreferentialistResearch"]>> +<<set $merchantIllegalWares = ["asexualReproduction", "childhoodFertilityInducedNCS", "PGHack", "RapidCellGrowthFormula", "sympatheticOvaries", "UterineRestraintMesh"]>> /* "AnimalOrgans" for future use */ <<set $RapidCellGrowthFormula = 0>> <<set $UterineRestraintMesh = 0>> <<set $PGHack = 0>> diff --git a/src/js/SetBellySize.js b/src/js/SetBellySize.js index 6b9cc142ca3a00412b617c93d04cb89f31f16376..cc164d372eaac91885b57e1079896b982eaf171d 100644 --- a/src/js/SetBellySize.js +++ b/src/js/SetBellySize.js @@ -1,6 +1,7 @@ window.SetBellySize = function SetBellySize(slave) { + let _implantSize; - WombNormalizePreg(slave); /*now with support for legacy code that advance pregnancy by setting .preg++ */ + WombNormalizePreg(slave); /* now with support for legacy code that advances pregnancy by setting .preg++ */ if (slave.bellyImplant > 0) _implantSize = slave.bellyImplant; diff --git a/src/js/assayJS.js b/src/js/assayJS.js index 47e539a8d80c0f0ae37083a0a02f648bc00a0f89..f778ef1d8e78c1d3ccdc56ac821477b0de3f5c40 100644 --- a/src/js/assayJS.js +++ b/src/js/assayJS.js @@ -1813,7 +1813,7 @@ window.DegradingName = function DegradingName(slave) { } else if (slave.intelligence+slave.intelligenceImplant < -50) { names.push("Cretin", "Dumb", "Retarded", "Stupid"); } - if (slave.vagina === 1 && slave.vaginaSkill <= 10) { + if (slave.vagina === 1 && slave.vaginalSkill <= 10) { names.push("Fresh", "New", "Tight"); } if (slave.devotion < -75) { diff --git a/src/js/birthJS.js b/src/js/birthJS.js index 6f38f46a463014ca1475368f0ea9a45df5e9f7b4..87cdbf48095cbdc775475aba8cf8fd04487cdcdc 100644 --- a/src/js/birthJS.js +++ b/src/js/birthJS.js @@ -38,7 +38,7 @@ window.BirthDestinationText = function(choice,slave) { } break; case "Orphanage": - if (V.slave.burst < 1) { + if (slave.burst < 1) { if (slave.fetish == "mindbroken" || slave.fuckdoll > 0) { r += `has few thoughts about the matter.`; } else if (slave.devotion > 95) { @@ -59,7 +59,7 @@ window.BirthDestinationText = function(choice,slave) { if (T.call !== 1) { r += `citizen schools, to be brought up coequal with the arcology's other young people.`; } - if (V.slave.burst < 1) { + if (slave.burst < 1) { r += ` ${sn} `; if (slave.fetish === "mindbroken" || slave.fuckdoll > 0) { r += `has few thoughts about the matter.`; @@ -76,7 +76,7 @@ window.BirthDestinationText = function(choice,slave) { break; case "Private": if (T.call !== 1) r += `${child} ${T.count > 1 ? ' are':' is'} sent to be privately raised, to be brought up as a future high class citizen.`; - if (V.slave.burst < 1) { + if (slave.burst < 1) { r += ` ${sn} `; if (slave.fetish === "mindbroken" || slave.fuckdoll > 0) { r += `has few thoughts about the matter.`; @@ -107,7 +107,7 @@ window.BirthDestinationText = function(choice,slave) { } const cash = cashFormat(T.count*(50+T.babyCost));r += ` <span class='yellowgreen'>${cash}.</span>`; if (slave.prematureBirth > 0) r += ` A low price due to the added costs of caring for ${T.count > 1 ? 'them':'it'}.`; - if (V.slave.burst < 1) { + if (slave.burst < 1) { r += ` ${sn} `; if (slave.fetish === "mindbroken" || slave.fuckdoll > 0) { r += `has few thoughts about the matter.`; diff --git a/src/js/datatypeCleanupJS.js b/src/js/datatypeCleanupJS.js index fa9fa3b048dfdf5d4ebedeb90cc9d3c4ff001ec2..419284878d70ba628235d22ffbdb5559b649b8c9 100644 --- a/src/js/datatypeCleanupJS.js +++ b/src/js/datatypeCleanupJS.js @@ -1253,7 +1253,7 @@ window.EconomyDatatypeCleanup = function EconomyDatatypeCleanup() { V.lowerClass = Math.max(+V.lowerClass, 0) || 3120; } if (V.LCRent !== 0) { - V.LCRent = Math.max(+V.LCRent, 0) || 20; + V.LCRent = Math.max(+V.LCRent, 0) || 20; } V.MCBase = Math.max(+V.MCBase, 0) || 200; /* nowhere modified */ @@ -1262,7 +1262,7 @@ window.EconomyDatatypeCleanup = function EconomyDatatypeCleanup() { V.middleClass = Math.max(+V.middleClass, 0) || 890; } if (V.MCRent !== 0) { - V.MCRent = Math.max(+V.MCRent, 0) || 50; + V.MCRent = Math.max(+V.MCRent, 0) || 50; } V.UCBase = Math.max(+V.UCBase, 0) || 40; /* nowhere modified */ @@ -1271,7 +1271,7 @@ window.EconomyDatatypeCleanup = function EconomyDatatypeCleanup() { V.upperClass = Math.max(+V.upperClass, 0) || 200; } if (V.UCRent !== 0) { - V.UCRent = Math.max(+V.UCRent, 0) || 175; + V.UCRent = Math.max(+V.UCRent, 0) || 175; } V.TCBase = Math.max(+V.TCBase, 0) || 20; /* nowhere modified */ @@ -1280,7 +1280,7 @@ window.EconomyDatatypeCleanup = function EconomyDatatypeCleanup() { V.topClass = Math.max(+V.topClass, 0) || 38; } if (V.TCRent !== 0) { - V.TCRent = Math.max(+V.TCRent, 0) || 650; + V.TCRent = Math.max(+V.TCRent, 0) || 650; } }; diff --git a/src/js/generateGenetics.js b/src/js/generateGenetics.js index 98ab81f15c7f4c6123432e818ac86feb9061cba4..79b546d30414d49c527120bdb5c02afaaa96e786 100644 --- a/src/js/generateGenetics.js +++ b/src/js/generateGenetics.js @@ -593,6 +593,35 @@ window.generateGenetics = (function() { } } + // well hung + if (father !== 0) { + if (mother.geneticQuirks.wellHung + father.geneticQuirks.wellHung >= 3) { + if (sex === "XY") { + quirks.wellHung = 2; + } else { + quirks.wellHung = 1; + } + } else if (mother.geneticQuirks.wellHung + father.geneticQuirks.wellHung >= 1) { + chance = jsRandom(0, 1000); + if (chance > 750) { + quirks.wellHung = 1; + } + } + } else if (mother.geneticQuirks.wellHung === 2) { + chance = jsRandom(0, 1000); + if (sex === "XY") { + if (chance > 900) { + quirks.wellHung = 2; + } else if (chance > 200) { + quirks.wellHung = 1; + } + } else { + if (chance > 500) { + quirks.wellHung = 1; + } + } + } + return clone(quirks); } diff --git a/src/js/generateNewSlaveJS.js b/src/js/generateNewSlaveJS.js index 65880d2c4b34a4de8cadd08412facc96b6ff0479..9a2bb25283f7049f97bc4e2890a4dadf32a114d0 100644 --- a/src/js/generateNewSlaveJS.js +++ b/src/js/generateNewSlaveJS.js @@ -70,6 +70,7 @@ window.GenerateNewSlave = (function(){ slave.pubertyXY = 0; slave.energy = jsRandom(1,85); + generateXXGeneticQuirks(); generateXXBodyProportions(); generateVagina(); generateXXPreferences(); @@ -82,7 +83,6 @@ window.GenerateNewSlave = (function(){ generateXXMods(); generateXXBodyHair(); generateXXPuberty(); - generateXXGeneticQuirks(); } function GenerateXYSlave() { @@ -92,6 +92,7 @@ window.GenerateNewSlave = (function(){ slave.pubertyXX = 0; slave.energy = jsRandom(15,90); + generateXYGeneticQuirks(); generateXYBodyProportions(); generateDick(); generateCircumcision(); @@ -105,7 +106,6 @@ window.GenerateNewSlave = (function(){ generateXYMods(); generateXYBodyHair(); generateXYPuberty(); - generateXYGeneticQuirks(); } function generateXXBodyProportions() { @@ -222,7 +222,15 @@ window.GenerateNewSlave = (function(){ slave.preg = 0; if (slave.physicalAge <= 13) { - slave.dick = jsEither([1, 1, 1, 1, 2, 2, 2, 3]); + if (slave.geneticQuirks.wellHung == 2) { + if (slave.physicalAge >= 8) { + slave.dick = jsEither([2, 2, 3, 3, 4]); + } else { + slave.dick = jsEither([1, 2, 2, 3]); + } + } else { + slave.dick = jsEither([1, 1, 1, 1, 2, 2, 2, 3]); + } if (V.seeExtreme === 1) { slave.balls = jsEither([0, 0, 1, 1, 1, 2, 2, 2, 2, 3, 3]); } else { @@ -230,7 +238,11 @@ window.GenerateNewSlave = (function(){ } slave.scrotum = slave.balls; } else if (slave.physicalAge <= 15) { - slave.dick = jsEither([1, 1, 1, 2, 2, 2, 3]); + if (slave.geneticQuirks.wellHung == 2) { + slave.dick = jsEither([3, 3, 4, 4, 5]); + } else { + slave.dick = jsEither([1, 1, 1, 2, 2, 2, 3]); + } if (V.seeExtreme === 1) { slave.balls = jsEither([0, 1, 1, 1, 2, 2, 2, 2, 3, 3, 4]); } else { @@ -238,7 +250,11 @@ window.GenerateNewSlave = (function(){ } slave.scrotum = slave.balls; } else if (slave.physicalAge <= 17) { - slave.dick = jsEither([1, 1, 2, 2, 3, 3]); + if (slave.geneticQuirks.wellHung == 2) { + slave.dick = jsEither([4, 4, 5, 5, 6]); + } else { + slave.dick = jsEither([1, 1, 2, 2, 3, 3]); + } if (V.seeExtreme === 1) { slave.balls = jsEither([0, 1, 1, 2, 2, 2, 3, 3, 3, 4, 5]); } else { @@ -246,13 +262,20 @@ window.GenerateNewSlave = (function(){ } slave.scrotum = slave.balls; } else { - slave.dick = jsEither([1, 2, 2, 2, 3, 3, 3, 4, 4, 5]); + if (slave.geneticQuirks.wellHung == 2) { + slave.dick = jsEither([5, 5, 6]); + } else { + slave.dick = jsEither([1, 2, 2, 2, 3, 3, 3, 4, 4, 5]); + } if (V.seeExtreme === 1) { slave.balls = jsEither([0, 1, 2, 2, 2, 3, 3, 3, 4, 4, 5]); } else { slave.balls = jsEither([1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 5]); } if (slave.balls !== 0) { + if (slave.geneticQuirks.wellHung == 2) { + slave.balls++; + } slave.scrotum = slave.balls + jsEither([0, 0, 1]); } else { slave.scrotum = 0; @@ -1061,6 +1084,12 @@ window.GenerateNewSlave = (function(){ } function generateXYGeneticQuirks() { + chance = jsRandom(1,10000); + if (chance >= 9750) { + slave.geneticQuirks.wellHung = 2; + } else if (chance >= 9500) { + slave.geneticQuirks.wellHung = 1; + } chance = jsRandom(1,1000); if (chance >= 950) { slave.geneticQuirks.fertility = 1; diff --git a/src/js/quickListJS.js b/src/js/quickListJS.js index 0a57d7c224c6c72047b6ae9260542e85dcebcccc..0d844d95609ccbf785fae474868d97aa98b26499 100644 --- a/src/js/quickListJS.js +++ b/src/js/quickListJS.js @@ -67,21 +67,14 @@ window.sortIncubatorPossiblesByReservedSpots = function () { window.sortIncubatorPossiblesByPreviousSort = function () { var sort = State.variables.sortIncubatorList; - console.log(State.variables); - console.log('sort', sort); if ('unsorted' !== sort) { - console.log("sort isn't unsorted", sort); if ('Name' === sort) { - console.log("sort is name", sort); sortIncubatorPossiblesByName(); } else if ('Reserved Incubator Spots' === sort) { - console.log("sort is spots", sort); sortIncubatorPossiblesByReservedSpots(); } else if ('Pregnancy Week' === sort) { - console.log("sort is week", sort); sortIncubatorPossiblesByPregnancyWeek(); } else if ('Number of Children' === sort) { - console.log("sort is count", sort); sortIncubatorPossiblesByPregnancyCount(); } } @@ -113,21 +106,14 @@ window.sortNurseryPossiblesByReservedSpots = function () { window.sortNurseryPossiblesByPreviousSort = function () { var sort = State.variables.sortNurseryList; - console.log(State.variables); - console.log('sort', sort); if ('unsorted' !== sort) { - console.log("sort isn't unsorted", sort); if ('Name' === sort) { - console.log("sort is name", sort); sortNurseryPossiblesByName(); } else if ('Reserved Nursery Spots' === sort) { - console.log("sort is spots", sort); sortNurseryPossiblesByReservedSpots(); } else if ('Pregnancy Week' === sort) { - console.log("sort is week", sort); sortNurseryPossiblesByPregnancyWeek(); } else if ('Number of Children' === sort) { - console.log("sort is count", sort); sortNurseryPossiblesByPregnancyCount(); } } diff --git a/src/js/sexActsJS.js b/src/js/sexActsJS.js index b6307e9e08fb227f01fbb25a20ff809bf43348b0..5276ff697a8eb07e10236580fbef2b4bec43b3f6 100644 --- a/src/js/sexActsJS.js +++ b/src/js/sexActsJS.js @@ -296,6 +296,7 @@ window.PartnerVCheck = function PartnerVCheck(analTimes, bothTimes) { let He = capFirstChar(he); let His = capFirstChar(his); let r = ``; + if (V.partner < 0 || V.partner >= V.slaves.length) { r += `@@.red;PartnerVCheck called with invalid partner '$partner' from passage ${passage()}.@@`; } else if (canDoVaginal(partner)) { diff --git a/src/js/wombJS.js b/src/js/wombJS.js index a4f88a287b44901131a43e2faacc341811bb2f9b..a5db8aec38f3edbc66428c2abff6cc3c2cef0fb3 100644 --- a/src/js/wombJS.js +++ b/src/js/wombJS.js @@ -1,5 +1,5 @@ /* -This is womb processor/simulator script. It takes care about calculation of belly sizes based on individual fetus sizes, with full support of broodmothers implant random turning on and off possibility. Also this can be expanded to store more parents data in each individual fetus in future. +This is a womb processor/simulator script. It takes care of calculation of belly sizes based on individual fetus sizes, with full support of broodmothers implant random turning on and off possibility. Also this can be expanded to store more parents data in each individual fetus in future. Design limitations: - Mother can't gestate children with different speeds at same time. All speed changes apply to all fetuses. - Sizes of individual fetuses updated only on call of WombGetVolume - not every time as called WombProgress. This is for better overall code speed. diff --git a/src/npc/databases/customSlavesDatabase.tw b/src/npc/databases/customSlavesDatabase.tw index 880400bdba2ed24c6bd1167c8742a4a842ee7c63..099827349cf72452035b94ec3da74b6d6b66b482 100644 --- a/src/npc/databases/customSlavesDatabase.tw +++ b/src/npc/databases/customSlavesDatabase.tw @@ -1,3 +1,3 @@ :: custom Slaves Database -<<set _i = 1000000>> \ No newline at end of file +<<set _i = 1000000>> diff --git a/src/npc/rgASDump.tw b/src/npc/rgASDump.tw index db756d9a91da6ed9e98b2dd04fe60517e92e5847..6d06a2f25fca2fd488aa77fb0c90ff36c9580be9 100644 --- a/src/npc/rgASDump.tw +++ b/src/npc/rgASDump.tw @@ -23,17 +23,17 @@ <<else>> <<if ($activeSlave.relation == 0)>> -<<if random(1,100) <= 5>> - <<set $activeSlave.recruiter = "twin">> -<<elseif ($activeSlave.actualAge > 32) && (random(1,100) <= 41)>> - <<set $activeSlave.recruiter = "mother">> -<<elseif ($activeSlave.actualAge < 24) && (random(1,100) <= 40)>> - <<set $activeSlave.recruiter = "daughter">> -<<elseif ($activeSlave.actualAge < 43) && (random(1,100) <= 20)>> - <<set $activeSlave.recruiter = "older sister">> -<<elseif ($activeSlave.actualAge < 25) && ($activeSlave.actualAge > 18) && (random(1,100) <= 20)>> - <<set $activeSlave.recruiter = "young sister">> -<</if>> + <<if random(1,100) <= 5>> + <<set $activeSlave.recruiter = "twin">> + <<elseif ($activeSlave.actualAge > 32) && (random(1,100) <= 41)>> + <<set $activeSlave.recruiter = "mother">> + <<elseif ($activeSlave.actualAge < 24) && (random(1,100) <= 40)>> + <<set $activeSlave.recruiter = "daughter">> + <<elseif ($activeSlave.actualAge < 43) && (random(1,100) <= 20)>> + <<set $activeSlave.recruiter = "older sister">> + <<elseif ($activeSlave.actualAge < 25) && ($activeSlave.actualAge > 18) && (random(1,100) <= 20)>> + <<set $activeSlave.recruiter = "young sister">> + <</if>> <</if>> <</if>> diff --git a/src/pregmod/birthStorm.tw b/src/pregmod/birthStorm.tw index 2f12ac7e002b8312c32780536508d8e4cf9c7636..a5c0360ca54e487685bdfda64f898697ff855df4 100644 --- a/src/pregmod/birthStorm.tw +++ b/src/pregmod/birthStorm.tw @@ -64,8 +64,13 @@ The remote surgery allows the removal of the pregnancy generator through convent <<set $activeSlave.births += _curBabies>> <<set $activeSlave.birthsTotal += _curBabies>> <<set $birthsTotal += _curBabies>> - -<<set $activeSlave.pregWeek = -4>> +<<if $activeSlave.geneticQuirks.fertility+$activeSlave.geneticQuirks.hyperFertility >= 4>> + <<set $activeSlave.pregWeek = -2>> +<<elseif $activeSlave.geneticQuirks.hyperFertility > 1>> + <<set $activeSlave.pregWeek = -3>> +<<else>> + <<set $activeSlave.pregWeek = -4>> +<</if>> <<set $activeSlave.pregType = 0>> <<set $activeSlave.pregSource = 0>> <<set $activeSlave.pregKnown = 0>> diff --git a/src/pregmod/csec.tw b/src/pregmod/csec.tw index 1ec5dffb8da99abf5bc4d0969c727563c9b9bf2d..ef305e0e503a091a90837cf55f8a2769e9f4b71b 100644 --- a/src/pregmod/csec.tw +++ b/src/pregmod/csec.tw @@ -358,7 +358,13 @@ Since $his <<if $activeSlave.mpreg == 1>>ass<<else>>vagina<</if>> was spared fro <<set $activeSlave.pregType = 0>> <<set $activeSlave.pregSource = 0>> <<set $activeSlave.pregKnown = 0>> - <<set $activeSlave.pregWeek = -4>> + <<if $activeSlave.geneticQuirks.fertility+$activeSlave.geneticQuirks.hyperFertility >= 4>> + <<set $activeSlave.pregWeek = -2>> + <<elseif $activeSlave.geneticQuirks.hyperFertility > 1>> + <<set $activeSlave.pregWeek = -3>> + <<else>> + <<set $activeSlave.pregWeek = -4>> + <</if>> <<set $activeSlave.labor = 0>> <<if $activeSlave.broodmother == 0 && $bellyImplants == 1>> <br><br> diff --git a/src/pregmod/fSlaveSlaveVag.tw b/src/pregmod/fSlaveSlaveVag.tw index ae584a4152d20a1b701983e198ef004dea3bf0ee..a2da70af1f7963f607c336fc6d17fccc9091294e 100644 --- a/src/pregmod/fSlaveSlaveVag.tw +++ b/src/pregmod/fSlaveSlaveVag.tw @@ -1,6 +1,5 @@ :: FSlaveSlaveVag [nobr] - <<set $nextButton = "Back", $nextLink = "Slave Interact">> <<set $slaverapistx = 0, $eligibility = 0>> diff --git a/src/pregmod/physicalDevelopment.tw b/src/pregmod/physicalDevelopment.tw index 65c3d7e85e8f39e5e2f27a6d2edaa07a921dd1aa..9475937353900c1541a9d78a4baf8cc03d519026 100644 --- a/src/pregmod/physicalDevelopment.tw +++ b/src/pregmod/physicalDevelopment.tw @@ -1366,6 +1366,12 @@ <<elseif $args[0].genes == "XY">> +<<if $args[0].geneticQuirks.wellHung == 2>> + <<set _dickMod = 2>> +<<else>> + <<set _dickMod = 1>> +<</if>> + <<switch $args[0].physicalAge>> <<case 3>> <<if $args[0].hormoneBalance >= 200>> @@ -1594,7 +1600,7 @@ <</if>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 70>> + <<if random(1,100) > 70/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -1626,7 +1632,7 @@ <</if>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 90>> + <<if random(1,100) > 90/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -1700,18 +1706,42 @@ <<elseif $args[0].height <= 144>> <<set $args[0].height += 3>> <</if>> + <<if $args[0].dick > 0 && $args[0].dick < 6 && _dickMod == 2>> + <<if random(1,100) > 70>> + <<set $args[0].dick += 1>> + <<if $args[0].foreskin > 0>> + <<set $args[0].foreskin += 1>> + <</if>> + <</if>> + <</if>> <<elseif $args[0].hormoneBalance <= -100>> <<if $args[0].height <= 137>> <<set $args[0].height += either(4,5,5,5,6)>> <<elseif $args[0].height <= 144>> <<set $args[0].height += 3>> <</if>> + <<if $args[0].dick > 0 && $args[0].dick < 6 && _dickMod == 2>> + <<if random(1,100) > 70>> + <<set $args[0].dick += 1>> + <<if $args[0].foreskin > 0>> + <<set $args[0].foreskin += 1>> + <</if>> + <</if>> + <</if>> <<else>> <<if $args[0].height <= 137>> <<set $args[0].height += either(4,4,5,5,5,6)>> <<elseif $args[0].height <= 144>> <<set $args[0].height += 3>> <</if>> + <<if $args[0].dick > 0 && $args[0].dick < 6 && _dickMod == 2>> + <<if random(1,100) > 70>> + <<set $args[0].dick += 1>> + <<if $args[0].foreskin > 0>> + <<set $args[0].foreskin += 1>> + <</if>> + <</if>> + <</if>> <</if>> <<if $args[0].pregAdaptation < 8>> <<set $args[0].pregAdaptation++>> @@ -1758,7 +1788,7 @@ <<set $args[0].height += 3>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 70>> + <<if random(1,100) > 70/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -1780,7 +1810,7 @@ <<set $args[0].height += 3>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 90>> + <<if random(1,100) > 90/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -1801,6 +1831,14 @@ <<elseif $args[0].height <= 156>> <<set $args[0].height += 4>> <</if>> + <<if $args[0].dick > 0 && $args[0].dick < 6 && _dickMod == 2>> + <<if random(1,100) > 70>> + <<set $args[0].dick += 1>> + <<if $args[0].foreskin > 0>> + <<set $args[0].foreskin += 1>> + <</if>> + <</if>> + <</if>> <</if>> <<if $args[0].pregAdaptation < 9>> <<set $args[0].pregAdaptation++>> @@ -1850,7 +1888,7 @@ <<set $args[0].boobs -= 100>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 70>> + <<if random(1,100) > 70/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -1875,7 +1913,7 @@ <<set $args[0].boobs -= 50>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 90>> + <<if random(1,100) > 90/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -1896,6 +1934,14 @@ <<elseif $args[0].height <= 163>> <<set $args[0].height += 3>> <</if>> + <<if $args[0].dick > 0 && $args[0].dick < 6 && _dickMod == 2>> + <<if random(1,100) > 70>> + <<set $args[0].dick += 1>> + <<if $args[0].foreskin > 0>> + <<set $args[0].foreskin += 1>> + <</if>> + <</if>> + <</if>> <</if>> <<if $args[0].pregAdaptation < 10>> <<set $args[0].pregAdaptation++>> @@ -1955,7 +2001,7 @@ <<set $args[0].boobs -= 100>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 70>> + <<if random(1,100) > 70/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -1985,7 +2031,7 @@ <<set $args[0].boobs -= 50>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 90>> + <<if random(1,100) > 90/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2016,6 +2062,14 @@ <<set $args[0].waist += 5>> <</if>> <</if>> + <<if $args[0].dick > 0 && $args[0].dick < 6 && _dickMod == 2>> + <<if random(1,100) > 70>> + <<set $args[0].dick += 1>> + <<if $args[0].foreskin > 0>> + <<set $args[0].foreskin += 1>> + <</if>> + <</if>> + <</if>> <</if>> <<if $args[0].pregAdaptation < 12>> <<set $args[0].pregAdaptation += 2>> @@ -2114,7 +2168,7 @@ <<set $args[0].boobs -= 50>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 50>> + <<if random(1,100) > 50/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2149,7 +2203,7 @@ <<set $args[0].boobs -= 50>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 70>> + <<if random(1,100) > 70/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2181,7 +2235,7 @@ <</if>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 50>> + <<if random(1,100) > 50/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2260,7 +2314,7 @@ <<set $args[0].boobs -= 100>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 20>> + <<if random(1,100) > 20/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2290,7 +2344,7 @@ <<set $args[0].boobs -= 50>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 40>> + <<if random(1,100) > 40/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2322,7 +2376,7 @@ <</if>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 50>> + <<if random(1,100) > 50/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2395,7 +2449,7 @@ <<set $args[0].boobs -= 100>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 20>> + <<if random(1,100) > 20/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2423,7 +2477,7 @@ <<set $args[0].boobs -= 50>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 40>> + <<if random(1,100) > 40/_dickMod>> <<set $args[0].dick += 1>> <</if>> <</if>> @@ -2445,7 +2499,7 @@ <<set $args[0].height += either(0,0,1,1,1,2)>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 50>> + <<if random(1,100) > 50/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2518,7 +2572,7 @@ <<set $args[0].boobs -= 100>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 70>> + <<if random(1,100) > 70/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2546,7 +2600,7 @@ <<set $args[0].boobs -= 50>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 90>> + <<if random(1,100) > 90/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2628,7 +2682,7 @@ <<set $args[0].boobs -= 100>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 70>> + <<if random(1,100) > 70/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2656,7 +2710,7 @@ <<set $args[0].boobs -= 50>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 90>> + <<if random(1,100) > 90/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2738,7 +2792,7 @@ <<set $args[0].boobs -= 100>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 70>> + <<if random(1,100) > 70/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> @@ -2766,7 +2820,7 @@ <<set $args[0].boobs -= 50>> <</if>> <<if $args[0].dick > 0 && $args[0].dick < 6>> - <<if random(1,100) > 90>> + <<if random(1,100) > 90/_dickMod>> <<set $args[0].dick += 1>> <<if $args[0].foreskin > 0>> <<set $args[0].foreskin += 1>> diff --git a/src/pregmod/rePregInventor.tw b/src/pregmod/rePregInventor.tw index a468df343e31c6a786453ccf862723eacfda0845..f8451baa1d2171f0d2b23866ae8d816092ca1189 100644 --- a/src/pregmod/rePregInventor.tw +++ b/src/pregmod/rePregInventor.tw @@ -356,7 +356,7 @@ <<set $pregInventions = 1>> <<set $activeSlave.trust += 4, $activeSlave.devotion += 10>> <</replace>> - <</link>> // This will cost <<= cashFormat(10000)>>// + <</link>> //This will cost <<= cashFormat(10000)>>// <</if>> </span> <</replace>> @@ -820,7 +820,7 @@ <<set $arcologies[_i].FSRestart -= 20>> <</if>> <</for>> - <<set _pregmag = "a cut out magazine cover of your renowned hyperbroodmother inventor, " + $activeSlave.slaveName + ", and her myriad toys">> + <<set _pregmag = "a cut out magazine cover of your renowned hyperbroodmother inventor, " + $activeSlave.slaveName + ", and " + $his + " myriad toys">> <<set $trinkets.push(_pregmag)>> <</replace>> <</link>> @@ -850,7 +850,7 @@ <<set $arcologies[_i].FSRestart -= 20>> <</if>> <</for>> - <<set _pregmag = "a cut out magazine cover of your renowned hyperbroodmother inventor, " + $activeSlave.slaveName + ", and her myriad toys">> + <<set _pregmag = "a cut out magazine cover of your renowned hyperbroodmother inventor, " + $activeSlave.slaveName + ", and " + $his + " myriad toys">> <<set $trinkets.push(_pregmag)>> <</replace>> <</link>> @@ -908,7 +908,7 @@ <<set _pregmag = "a cut out magazine cover of your renowned hyperbroodmother inventor, " + $activeSlave.slaveName + ", and her myriad toys">> <<set $trinkets.push(_pregmag)>> <<elseif $activeSlave.pornPrestige >= 3 && random(1,100) > 15>> - You turn your FCTV screen off satisifed that your slave has done a satisfactory job. Over the course of the next several weeks, it becomes clear that $activeSlave.slaveName's appearance on "Husbandry With Milly" has had a @@.green;significant impact@@ on public opinion, though only at a local level. + You turn your FCTV screen off satisfied that your slave has done a satisfactory job. Over the course of the next several weeks, it becomes clear that $activeSlave.slaveName's appearance on "Husbandry With Milly" has had a @@.green;significant impact@@ on public opinion, though only at a local level. <<if $activeSlave.prestige < 1>> <<set $activeSlave.prestige = 1>> <<set $activeSlave.prestigeDesc = "She is a locally respected inventor of hyperpregnant sex accessories and toys.">> @@ -966,7 +966,7 @@ <<set _pregmag = "a cut out magazine cover of your renowned hyperbroodmother inventor, " + $activeSlave.slaveName + ", and her myriad toys">> <<set $trinkets.push(_pregmag)>> <<elseif $activeSlave.pornPrestige >= 2 && random(1,100) > 30>> - You turn your FCTV screen off satisifed that your slave has done a satisfactory job. Over the course of the next several weeks, it becomes clear that $activeSlave.slaveName's appearance on "Husbandry With Milly" has had a @@.green;significant impact@@ on public opinion, though only at a local level. + You turn your FCTV screen off satisfied that your slave has done a satisfactory job. Over the course of the next several weeks, it becomes clear that $activeSlave.slaveName's appearance on "Husbandry With Milly" has had a @@.green;significant impact@@ on public opinion, though only at a local level. <<if $activeSlave.prestige < 1>> <<set $activeSlave.prestige = 1>> <<set $activeSlave.prestigeDesc = "She is a locally respected inventor of hyperpregnant sex accessories and toys.">> @@ -1024,7 +1024,7 @@ <<set _pregmag = "a cut out magazine cover of your renowned hyperbroodmother inventor, " + $activeSlave.slaveName + ", and her myriad toys">> <<set $trinkets.push(_pregmag)>> <<elseif random(1,100) > 50>> - You turn your FCTV screen off satisifed that your slave has done a satisfactory job. Over the course of the next several weeks, it becomes clear that $activeSlave.slaveName's appearance on "Husbandry With Milly" has had a @@.green;significant impact@@ on public opinion, though only at a local level. + You turn your FCTV screen off satisfied that your slave has done a satisfactory job. Over the course of the next several weeks, it becomes clear that $activeSlave.slaveName's appearance on "Husbandry With Milly" has had a @@.green;significant impact@@ on public opinion, though only at a local level. <<if $activeSlave.prestige < 1>> <<set $activeSlave.prestige = 1>> <<set $activeSlave.prestigeDesc = "She is a locally respected inventor of hyperpregnant sex accessories and toys.">> diff --git a/src/pregmod/saAgent.tw b/src/pregmod/saAgent.tw index 0c93aca9771c115cf4000b8a5a0395fe105c2977..4f3098bb71c3f51e643e9f0cbb89560df4fabb36 100644 --- a/src/pregmod/saAgent.tw +++ b/src/pregmod/saAgent.tw @@ -423,9 +423,23 @@ <</if>> <<if ($slaves[$i].preg > $slaves[$i].pregData.minLiveBirth) && ($slaves[$i].broodmother == 0) && (random(1,100) < 90)>> - <<set $slaves[$i].birthsTotal += WombBirthReady($slaves[$i], $slaves[$i].pregData.minLiveBirth), WombBirth($slaves[$i], $slaves[$i].pregData.minLiveBirth), WombFlush($slaves[$i]), $slaves[$i].preg = 0, $slaves[$i].pregWeek = -4, $slaves[$i].pregSource = 0, $slaves[$i].pregType = 0, $slaves[$i].pregKnown = 0 >> + <<set $slaves[$i].birthsTotal += WombBirthReady($slaves[$i], $slaves[$i].pregData.minLiveBirth), WombBirth($slaves[$i], $slaves[$i].pregData.minLiveBirth), WombFlush($slaves[$i]), $slaves[$i].preg = 0, $slaves[$i].pregSource = 0, $slaves[$i].pregType = 0, $slaves[$i].pregKnown = 0 >> + <<if $slaves[$i].geneticQuirks.fertility+$slaves[$i].geneticQuirks.hyperFertility >= 4>> + <<set $slaves[$i].pregWeek = -2>> + <<elseif $slaves[$i].geneticQuirks.hyperFertility > 1>> + <<set $slaves[$i].pregWeek = -3>> + <<else>> + <<set $slaves[$i].pregWeek = -4>> + <</if>> <<elseif ($slaves[$i].preg > $slaves[$i].pregData.normalBirth) && ($slaves[$i].broodmother == 0)>> - <<set $slaves[$i].birthsTotal += WombBirthReady($slaves[$i], $slaves[$i].pregData.minLiveBirth), WombBirth($slaves[$i], $slaves[$i].pregData.minLiveBirth), WombFlush($slaves[$i]), $slaves[$i].preg = 0, $slaves[$i].pregWeek = -4, $slaves[$i].pregSource = 0, $slaves[$i].pregType = 0, $slaves[$i].pregKnown = 0>> + <<set $slaves[$i].birthsTotal += WombBirthReady($slaves[$i], $slaves[$i].pregData.minLiveBirth), WombBirth($slaves[$i], $slaves[$i].pregData.minLiveBirth), WombFlush($slaves[$i]), $slaves[$i].preg = 0, $slaves[$i].pregSource = 0, $slaves[$i].pregType = 0, $slaves[$i].pregKnown = 0>> + <<if $slaves[$i].geneticQuirks.fertility+$slaves[$i].geneticQuirks.hyperFertility >= 4>> + <<set $slaves[$i].pregWeek = -2>> + <<elseif $slaves[$i].geneticQuirks.hyperFertility > 1>> + <<set $slaves[$i].pregWeek = -3>> + <<else>> + <<set $slaves[$i].pregWeek = -4>> + <</if>> <<elseif ($slaves[$i].preg > 37) && ($slaves[$i].broodmother > 0)>> <<if $slaves[$i].broodmother > 0>> <<set $slaves[$i].birthsTotal += WombBirthReady($slaves[$i], 37), WombBirth($slaves[$i], 37), $slaves[$i].preg = WombMaxPreg($slaves[$i])>> diff --git a/src/pregmod/saClothes.tw b/src/pregmod/saClothes.tw index db30132e92cc3b562ed50f875f0bb2e5f40e6f71..09c0d8520a3881ff95c0f785bcd7e31563c8ad98 100644 --- a/src/pregmod/saClothes.tw +++ b/src/pregmod/saClothes.tw @@ -431,7 +431,14 @@ The tight corseting has @@.orange;caused $him to miscarry,@@ which @@.red;damages $his health.@@ <<set $slaves[$i].health -= 20>> <<if lastPregRule($slaves[$i],$defaultRules)>><<set $slaves[$i].preg = -1>><<else>><<set $slaves[$i].preg = 0>><</if>> - <<set $slaves[$i].pregType = 0, WombFlush($slaves[$i]), $slaves[$i].pregKnown = 0, $slaves[$i].pregWeek = -4>> + <<set $slaves[$i].pregType = 0, WombFlush($slaves[$i]), $slaves[$i].pregKnown = 0>> + <<if $slaves[$i].geneticQuirks.fertility+$slaves[$i].geneticQuirks.hyperFertility >= 4>> + <<set $slaves[$i].pregWeek = -2>> + <<elseif $slaves[$i].geneticQuirks.hyperFertility > 1>> + <<set $slaves[$i].pregWeek = -3>> + <<else>> + <<set $slaves[$i].pregWeek = -4>> + <</if>> <<run SetBellySize($slaves[$i])>> <<if $slaves[$i].fuckdoll == 0 && $slaves[$i].fetish != "mindbroken">> <<if $slaves[$i].devotion < -50>> @@ -774,7 +781,14 @@ The dildo penetrating $his womb @@.orange;caused $him to miscarry,@@ which @@.red;damages $his health.@@ <<set $slaves[$i].health -= 20>> <<if lastPregRule($slaves[$i],$defaultRules)>><<set $slaves[$i].preg = -1>><<else>><<set $slaves[$i].preg = 0>><</if>> - <<set $slaves[$i].pregType = 0, WombFlush($slaves[$i]), $slaves[$i].pregKnown = 0, $slaves[$i].pregWeek = -4>> + <<set $slaves[$i].pregType = 0, WombFlush($slaves[$i]), $slaves[$i].pregKnown = 0>> + <<if $slaves[$i].geneticQuirks.fertility+$slaves[$i].geneticQuirks.hyperFertility >= 4>> + <<set $slaves[$i].pregWeek = -2>> + <<elseif $slaves[$i].geneticQuirks.hyperFertility > 1>> + <<set $slaves[$i].pregWeek = -3>> + <<else>> + <<set $slaves[$i].pregWeek = -4>> + <</if>> <<run SetBellySize($slaves[$i])>> $He is <<if $slaves[$i].devotion < -50>> diff --git a/src/pregmod/seBurst.tw b/src/pregmod/seBurst.tw index 2fa8b90bfec60d8d0d6ba6ad1c5a0eac22241488..cb37324eea64a412190d0abf2bdd13a631c7b7de 100644 --- a/src/pregmod/seBurst.tw +++ b/src/pregmod/seBurst.tw @@ -6,12 +6,12 @@ <<if $slaves[_b].burst == 1>> <<if (($slaves[_b].belly > ($slaves[_b].pregAdaptation*3200)) || $slaves[_b].bellyPreg > 600000)>> - + <<set $slaves[_b].curBabies = WombBirth($slaves[_b], $slaves[_b].pregData.minLiveBirth)>> <<set $slaves[_b].curStillBirth = 0 >> <<set _curBabies = $slaves[_b].curBabies.length>> /*just to improve speed and usability here.*/ <<set $birthsTotal += _curBabies>> - + <<set _others = 0, _PC = 0, _citizens = 0, _oldMaster = 0, _arcOwner = 0, _lab = 0, _fathers = [], _babyFatherLink = []>> <<for _cb = 0; _cb < $slaves[_b].curBabies.length; _cb++>> <<if $slaves[_b].curBabies[_cb].fatherID == 0 || $slaves[_b].curBabies[_cb].fatherID == -5>> @@ -129,7 +129,7 @@ /* ------------------------------------------------ */ $slaves[_b].slaveName's straining womb finally gave out and burst, taking $his - + <<if _curBabies > 0>> life, but not <<if _curBabies <= 1>>that of $his child<<else>>those of all $his children<</if>>; <<if _fathersReduced.length > 2>> @@ -273,7 +273,7 @@ <<set $reservedChildren = FetusGlobalReserveCount("incubator")>> <<set $reservedChildrenNursery = FetusGlobalReserveCount("nursery")>> - + <<elseif $slaves[_b].inflation != 0>> <<pop $slaves[_b]>> <</if>> diff --git a/src/pregmod/seFCTVshows.tw b/src/pregmod/seFCTVshows.tw index c132d3324087886ae3e513099cb3216070e29ddf..2439602d80748bb9dfc66837846f6aaf927352fd 100644 --- a/src/pregmod/seFCTVshows.tw +++ b/src/pregmod/seFCTVshows.tw @@ -359,6 +359,7 @@ Tired after a long day, you tell <<if $Concubine != 0>>@@.pink;$Concubine.slaveN <br><br>The woman helping to display the slaves shows her hand to the camera; it's coated in a sticky layer of precum from handling the cum cow's equipment. <</if>> <<slaveCost $activeSlave>> +<<setLocalPronouns $activeSlave>> <<if $randShow < 3>> <<set $slaveCost *= 1.3>> <<elseif $randShow == 6>> @@ -370,7 +371,12 @@ Tired after a long day, you tell <<if $Concubine != 0>>@@.pink;$Concubine.slaveN The offered price is <<print cashFormat($slaveCost)>>. <<if $cash >= $slaveCost>> - <br>[[Buy her slave contract|New Slave Intro][cashX(forceNeg($slaveCost), "slaveTransfer", $activeSlave), $nextLink = "Scheduled Event", $returnTo = "Scheduled Event"]] + <br> + <<link "Buy $his slave contract">> + <<run cashX(forceNeg($slaveCost), "slaveTransfer", $activeSlave)>> + <<set $nextLink = "Scheduled Event", $returnTo = "Scheduled Event">> + <<goto "New Slave Intro">> + <</link>> <<else>> //@@.red;You lack the necessary funds to buy this slave.@@// <</if>> diff --git a/src/pregmod/sePlayerBirth.tw b/src/pregmod/sePlayerBirth.tw index b25d38376b104933bfd80a46799dd6d3bae61394..c89e9ad5b885804b91ebc7b338516fab3f234648 100644 --- a/src/pregmod/sePlayerBirth.tw +++ b/src/pregmod/sePlayerBirth.tw @@ -637,7 +637,9 @@ You arrange yourself to give birth, relaxing until your body urges you to begin <</if>> /*closes SE*/ <<set _badBirth = 0, $PC.pregSource = 0, $PC.pregType = 0, $PC.belly = 2000, WombFlush($PC)>> -<<if $PC.geneticQuirks.fertility == 2>> +<<if $PC.geneticQuirks.fertility+$PC.geneticQuirks.hyperFertility >= 4>> + <<set $PC.pregWeek = -2>> +<<elseif $PC.geneticQuirks.hyperFertility == 2>> <<set $PC.pregWeek = -3>> <<else>> <<set $PC.pregWeek = -4>> diff --git a/src/pregmod/widgets/economyWidgets.tw b/src/pregmod/widgets/economyWidgets.tw index 841e1c9e2b1a2c9f06f1e94162078ec0cd3bc084..99e69b2ec2bfeb7c9fc696b3d437e454ac375eb8 100644 --- a/src/pregmod/widgets/economyWidgets.tw +++ b/src/pregmod/widgets/economyWidgets.tw @@ -459,7 +459,7 @@ <</if>> <</widget>> -/* Call with <<CorpDevBuySell "asset" "Numasset">> TODO: replace eval parse with appropriate functions */ +/* Call with <<CorpDevBuySell "asset" "Numasset">> TODO: replace eval parse with appropriate functions */ <<widget "CorpDevBuySell">> <<set _textboxMLArg = '_'+$args[1]>> | Trade Qty diff --git a/src/pregmod/widgets/seBirthWidgets.tw b/src/pregmod/widgets/seBirthWidgets.tw index 92b2a224f39cd10e28fa8f0f6abe41d25f61d8dc..3ea7a74c4fbb24ceebbb3bbc02de08ace2701fa4 100644 --- a/src/pregmod/widgets/seBirthWidgets.tw +++ b/src/pregmod/widgets/seBirthWidgets.tw @@ -324,7 +324,7 @@ /* Here support for partial birth cases but if slaves still NOT have broodmother implant. Right now remaining babies will be lost, need to add research option for selective births. It should control labor and stop it after ready to birth babies out. Should be Repopulation FS research before broodmothers (their implant obviously have it as a part of functional). */ <<if $slaves[$i].broodmother == 0>> - <<if $slaves[$i].prematureBirth == 1>> /* emergency birth, anything less than 23 weeks of age is not making it through this */ + <<if $slaves[$i].prematureBirth == 1>> /* emergency birth, anything less than 23 weeks of age is not making it through this */ <<set $slaves[$i].curStillBirth = $slaves[$i].womb.length>> <<set WombFlush($slaves[$i])>> <<elseif $surgeryUpgrade == 1>> @@ -997,7 +997,13 @@ All in all, <<set $slaves[$i].pregType = 0>> <<set $slaves[$i].pregSource = 0>> <<set $slaves[$i].pregKnown = 0>> - <<set $slaves[$i].pregWeek = -4>> + <<if $slaves[$i].geneticQuirks.fertility+$slaves[$i].geneticQuirks.hyperFertility >= 4>> + <<set $slaves[$i].pregWeek = -2>> + <<elseif $slaves[$i].geneticQuirks.hyperFertility > 1>> + <<set $slaves[$i].pregWeek = -3>> + <<else>> + <<set $slaves[$i].pregWeek = -4>> + <</if>> <</if>> <<set $csec = 0>> diff --git a/src/uncategorized/BackwardsCompatibility.tw b/src/uncategorized/BackwardsCompatibility.tw index 94b3f45d306c1645193a7c6e7799852e05a45d1b..fb4fbecc0b55c04621e5a24acd67a310a94b6e02 100644 --- a/src/uncategorized/BackwardsCompatibility.tw +++ b/src/uncategorized/BackwardsCompatibility.tw @@ -543,7 +543,7 @@ <<set $propOutcome = 0>> <</if>> <<if ndef $EliteSires>> - <<set $EliteSires = ["moves", "quick", "crazy", "virgin", "futa", "preggo"]>> + <<set $EliteSires = ["crazy", "futa", "moves", "preggo", "quick", "virgin"]>> <</if>> <<if ndef $startingPoint>> <<set $startingPoint = -1>> @@ -1046,10 +1046,10 @@ <<set $eugenicsFullControl = 0>> <</if>> <<if ndef $merchantFSWares>> - <<set $merchantFSWares = ["GenderRadicalistResearch", "TransformationFetishistResearch", "AssetExpansionistResearch", "SlimnessEnthusiastResearch", "YouthPreferentialistResearch", "HedonisticDecadenceResearch"]>> + <<set $merchantFSWares = ["AssetExpansionistResearch", "GenderRadicalistResearch", "HedonisticDecadenceResearch", "SlimnessEnthusiastResearch", "TransformationFetishistResearch", "YouthPreferentialistResearch"]>> <</if>> <<if ndef $merchantIllegalWares>> - <<set $merchantIllegalWares = ["childhoodFertilityInducedNCS", "UterineRestraintMesh", "RapidCellGrowthFormula", "PGHack", "sympatheticOvaries", "asexualReproduction"]>> + <<set $merchantIllegalWares = ["asexualReproduction", "childhoodFertilityInducedNCS", "PGHack", "RapidCellGrowthFormula", "sympatheticOvaries", "UterineRestraintMesh"]>> <<elseif $merchantIllegalWares.length == 0>> <<set $merchantIllegalWares.push("childhoodFertilityInducedNCS")>> <<set $merchantIllegalWares.push("UterineRestraintMesh")>> @@ -1255,19 +1255,18 @@ <<if ndef $month>> -<<set $month = either("January","February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December")>> + <<set $month = either("April", "August", "December", "February", "January", "July", "June", "March", "May", "November", "October", "September")>> <</if>> <<if ndef $day>> -<<set $day = random(1,28)>> + <<set $day = random(1,28)>> <</if>> <<if ndef $year>> <<set $year = (2037+Math.floor($week/52))>> <</if>> <<if ndef $arcologies>> -<<set $arcologies = []>> - -<<set $arcologies[0] = {name: "Arcology X-", direction: 0, government: 1, honeymoon: 0, prosperity: 50, FSSupremacist: "unset", FSSupremacistRace: 0, FSSubjugationist: "unset", FSSubjugationistRace: 0, FSGenderRadicalist: "unset", FSGenderFundamentalist: "unset", FSPaternalist: "unset", FSDegradationist: "unset", FSBodyPurist: "unset", FSTransformationFetishist: "unset", FSYouthPreferentialist: "unset", FSMaturityPreferentialist: "unset", FSSlimnessEnthusiast: "unset", FSAssetExpansionist: "unset", FSPastoralist: "unset", FSPhysicalIdealist: "unset", FSChattelReligionist: "unset", FSRomanRevivalist: "unset", FSEgyptianRevivalist: "unset", FSEdoRevivalist: "unset", FSArabianRevivalist: "unset", FSChineseRevivalist: "unset", FSNull: "unset", FSRepopulationFocus: "unset", FSRestart: "unset", FSHedonisticDecadence: "unset", embargo: 1, embargoTarget: -1, influenceTarget: -1, influenceBonus: 0, rival: 0}>> + <<set $arcologies = []>> + <<set $arcologies[0] = {name: "Arcology X-", direction: 0, government: 1, honeymoon: 0, prosperity: 50, FSSupremacist: "unset", FSSupremacistRace: 0, FSSubjugationist: "unset", FSSubjugationistRace: 0, FSGenderRadicalist: "unset", FSGenderFundamentalist: "unset", FSPaternalist: "unset", FSDegradationist: "unset", FSBodyPurist: "unset", FSTransformationFetishist: "unset", FSYouthPreferentialist: "unset", FSMaturityPreferentialist: "unset", FSSlimnessEnthusiast: "unset", FSAssetExpansionist: "unset", FSPastoralist: "unset", FSPhysicalIdealist: "unset", FSChattelReligionist: "unset", FSRomanRevivalist: "unset", FSEgyptianRevivalist: "unset", FSEdoRevivalist: "unset", FSArabianRevivalist: "unset", FSChineseRevivalist: "unset", FSNull: "unset", FSRepopulationFocus: "unset", FSRestart: "unset", FSHedonisticDecadence: "unset", embargo: 1, embargoTarget: -1, influenceTarget: -1, influenceBonus: 0, rival: 0}>> <</if>> <<if def $arcologyName>> @@ -2372,7 +2371,7 @@ Setting missing global variables: <</if>> <<if ndef $justiceEvents>> - <<set $justiceEvents = ["slave deal", "slave training", "majority deal", "indenture deal", "virginity deal"]>> + <<set $justiceEvents = ["indenture deal", "majority deal", "slave deal", "slave training", "virginity deal"]>> <</if>> <<if (($ver.startsWith("0.6") && !$ver.startsWith("10.6")) || ($ver.startsWith("0.7")) || ($ver.startsWith("0.8")) || ($ver == "0.9"))>> @@ -2753,23 +2752,32 @@ Setting missing slave variables: <<if ndef _backwardsCompatibility>><<set _Slave.relation = 0, _Slave.relationTarget = 0>><</if>> <</if>> -<<if _Slave.race == "surgically altered to look white">> - <<set _Slave.race = "white">> +<<if _Slave.race == "surgically altered to look amerindian">> + <<set _Slave.race = "amerindian">> +<</if>> +<<if _Slave.race == "surgically altered to look asian">> + <<set _Slave.race = "asian">> <</if>> <<if _Slave.race == "surgically altered to look black">> <<set _Slave.race = "black">> <</if>> +<<if _Slave.race == "surgically altered to look indo-aryan">> + <<set _Slave.race = "indo-aryan">> +<</if>> <<if _Slave.race == "surgically altered to look latina">> <<set _Slave.race = "latina">> <</if>> -<<if _Slave.race == "surgically altered to look asian">> - <<set _Slave.race = "asian">> +<<if _Slave.race == "surgically altered to look malay">> + <<set _Slave.race = "malay">> <</if>> <<if _Slave.race == "surgically altered to look middle eastern">> <<set _Slave.race = "middle eastern">> <</if>> -<<if _Slave.race == "surgically altered to look amerindian">> - <<set _Slave.race = "amerindian">> +<<if (_Slave.race == "surgically altered to look mixed race") || (_Slave.race == "surgically altered to look mixed")>> + <<set _Slave.race = "mixed race">> +<</if>> +<<if (_Slave.race == "surgically altered to look pacific islander") || (_Slave.race == "surgically altered to look like a pacific islander")>> + <<set _Slave.race = "pacific islander">> <</if>> <<if (_Slave.race == "surgically altered to look southern european") || (_Slave.race == "southern European")>> <<set _Slave.race = "southern european">> @@ -2777,17 +2785,8 @@ Setting missing slave variables: <<if _Slave.race == "surgically altered to look semitic">> <<set _Slave.race = "semitic">> <</if>> -<<if _Slave.race == "surgically altered to look malay">> - <<set _Slave.race = "malay">> -<</if>> -<<if _Slave.race == "surgically altered to look indo-aryan">> - <<set _Slave.race = "indo-aryan">> -<</if>> -<<if (_Slave.race == "surgically altered to look pacific islander") || (_Slave.race == "surgically altered to look like a pacific islander")>> - <<set _Slave.race = "pacific islander">> -<</if>> -<<if (_Slave.race == "surgically altered to look mixed race") || (_Slave.race == "surgically altered to look mixed")>> - <<set _Slave.race = "mixed race">> +<<if _Slave.race == "surgically altered to look white">> + <<set _Slave.race = "white">> <</if>> <<if ndef _Slave.override_Race>> @@ -3053,49 +3052,49 @@ Setting missing slave variables: <<if (($ver.startsWith("0.6") && !$ver.startsWith("10.6")) || ($ver.startsWith("0.7")) || ($ver.startsWith("0.8")) || ($ver.startsWith("0.9"))) && (!$ver.startsWith("0.9.5")) && (!$ver.startsWith("0.9.6")) && (!$ver.startsWith("0.9.7")) && (!$ver.startsWith("0.9.8")) && (!$ver.startsWith("0.9.9")) && (!$ver.startsWith("0.9.10"))>> <<if _Slave.oralSkill > 0>> - <<if _Slave.oralSkill == 3>> - <<set _Slave.oralSkill = 100>> - <<elseif _Slave.oralSkill == 2>> - <<set _Slave.oralSkill = 65>> - <<else>> - <<set _Slave.oralSkill = 35>> - <</if>> + <<if _Slave.oralSkill == 3>> + <<set _Slave.oralSkill = 100>> + <<elseif _Slave.oralSkill == 2>> + <<set _Slave.oralSkill = 65>> + <<else>> + <<set _Slave.oralSkill = 35>> + <</if>> <</if>> <<if _Slave.vaginalSkill > 0>> - <<if _Slave.vaginalSkill == 3>> - <<set _Slave.vaginalSkill = 100>> - <<elseif _Slave.vaginalSkill == 2>> - <<set _Slave.vaginalSkill = 65>> - <<else>> - <<set _Slave.vaginalSkill = 35>> - <</if>> + <<if _Slave.vaginalSkill == 3>> + <<set _Slave.vaginalSkill = 100>> + <<elseif _Slave.vaginalSkill == 2>> + <<set _Slave.vaginalSkill = 65>> + <<else>> + <<set _Slave.vaginalSkill = 35>> + <</if>> <</if>> <<if _Slave.analSkill > 0>> - <<if _Slave.analSkill == 3>> - <<set _Slave.analSkill = 100>> - <<elseif _Slave.analSkill == 2>> - <<set _Slave.analSkill = 65>> - <<else>> - <<set _Slave.analSkill = 35>> - <</if>> + <<if _Slave.analSkill == 3>> + <<set _Slave.analSkill = 100>> + <<elseif _Slave.analSkill == 2>> + <<set _Slave.analSkill = 65>> + <<else>> + <<set _Slave.analSkill = 35>> + <</if>> <</if>> <<if _Slave.whoreSkill > 0>> - <<if _Slave.whoreSkill == 3>> - <<set _Slave.whoreSkill = 100>> - <<elseif _Slave.whoreSkill == 2>> - <<set _Slave.whoreSkill = 65>> - <<else>> - <<set _Slave.whoreSkill = 35>> - <</if>> + <<if _Slave.whoreSkill == 3>> + <<set _Slave.whoreSkill = 100>> + <<elseif _Slave.whoreSkill == 2>> + <<set _Slave.whoreSkill = 65>> + <<else>> + <<set _Slave.whoreSkill = 35>> + <</if>> <</if>> <<if _Slave.entertainSkill > 0>> - <<if _Slave.entertainSkill == 3>> - <<set _Slave.entertainSkill = 100>> - <<elseif _Slave.entertainSkill == 2>> - <<set _Slave.entertainSkill = 65>> - <<else>> - <<set _Slave.entertainSkill = 35>> - <</if>> + <<if _Slave.entertainSkill == 3>> + <<set _Slave.entertainSkill = 100>> + <<elseif _Slave.entertainSkill == 2>> + <<set _Slave.entertainSkill = 65>> + <<else>> + <<set _Slave.entertainSkill = 35>> + <</if>> <</if>> <<if ($ver != "0.9.4")>> <<set _Slave.aphrodisiacs = 0>> @@ -3339,7 +3338,7 @@ Setting missing slave variables: <<set _Slave = $genePool[_bci]>> <<PMODinit _Slave>> - + <<if $genePool.map(function(s) { return s.ID; }).count(_Slave.ID) > 1>> /* first check for duplicate IDs, keep the first entry and delete the others */ <<for _bci2 = _bci + 1; _bci2 < $genePool.length; _bci2++>> <<if $genePool[_bci2].ID == _Slave.ID>> @@ -3449,8 +3448,8 @@ Done! /* Sec Exp */ <<if $secExp == 1>> -<br> -<<include "SecExpBackwardCompatibility">> + <br> + <<include "SecExpBackwardCompatibility">> <<else>> <<set $crime = 0, $security = 0>> <</if>> diff --git a/src/uncategorized/PESS.tw b/src/uncategorized/PESS.tw index b0ac09113c329e1249fafd9a8cc2fb1210200678..563a26bad4913aa98200aa7069e867589f166ad9 100644 --- a/src/uncategorized/PESS.tw +++ b/src/uncategorized/PESS.tw @@ -137,7 +137,7 @@ When you've finished your task, you raise your eyes to examine $him. $He's stand $He's nude, making it obvious that $his poor soft member has done its duty today. It even looks a little moist, as though it bred a fertile slave's pussy only a few minutes ago. <<elseif ["body oil", "chains", "clubslut netting", "restrictive latex", "shibari ropes", "uncomfortable straps"].indexOf($activeSlave.clothes) != -1>> $His clothes don't cover $his dick, making it obvious that $his poor soft member has done its duty today. It even looks a little moist, as though it bred a fertile slave's pussy only a few minutes ago. -<<elseif ["a burkini", "a comfortable bodysuit", "a fallen nuns habit", "a latex catsuit", "a leotard", "a monokini", "a cybersuit", "a scalemail bikini", "shimapan panties", "a string bikini", "attractive lingerie for a pregnant woman", "attractive lingerie", "harem gauze", "kitty lingerie", "restrictive latex", "slutty jewelry", "spats and a tank top", "stretch pants and a crop-top"].indexOf($activeSlave.clothes) != -1>> +<<elseif ["a burkini", "a comfortable bodysuit", "a cybersuit", "a fallen nuns habit", "a latex catsuit", "a leotard", "a monokini", "a scalemail bikini", "a string bikini", "attractive lingerie for a pregnant woman", "attractive lingerie", "harem gauze", "kitty lingerie", "restrictive latex", "shimapan panties", "slutty jewelry", "spats and a tank top", "stretch pants and a crop-top"].indexOf($activeSlave.clothes) != -1>> $His clothes cover $his groin, but they're pretty tight, making it clear that $his poor soft member has done its duty today. <<else>> $His clothes are relatively modest, so you can't see it, but it's clear that $his poor soft member has done its duty today. diff --git a/src/uncategorized/RESS.tw b/src/uncategorized/RESS.tw index 832151f04aca051c3f071fb2a09e5aa383e5a41c..073d9d570810342392b8b9275d855b3c0ac334ff 100644 --- a/src/uncategorized/RESS.tw +++ b/src/uncategorized/RESS.tw @@ -325,7 +325,7 @@ clings to you in $his sleep as the warmth of your body begins to move away from <<case "confident tanning">> It's an unusually nice day, with mild sunshine, light breezes, and nothing offensive or dangerous in the atmosphere. In the middle of the afternoon, you take a break from your busy schedule of sex and business and stroll out onto one of your penthouse balconies. It seems <<EventNameLink $activeSlave>> was struck by a similar impulse. <<if $activeSlave.assignment == "rest">>$He's assigned to do little but rest<<else>>This is one of $his rest periods<</if>>, so $he's come out here to lay naked on a towel and enjoy the sun. -<<if ["dark olive", "dark", "brown", "dark brown", "black", "ebony", "pure black"].includes($activeSlave.skin)>> +<<if ["black", "brown", "dark brown", "dark olive", "dark", "ebony", "pure black"].includes($activeSlave.skin)>> $His $activeSlave.skin doesn't tan much, so $he's just out here to bask in its warmth. $His body shines with lotion from a bottle lying next to $him, but it's just general-purpose stuff. <<elseif ($activeSlave.skin == "tanned")>> $His tanned skin shines with lotion from a bottle lying next to $him. @@ -3117,7 +3117,7 @@ and flirting with passersby. Or $he would be, if $he weren't surrounded by a hos <br><br> "Why the fuck did you say that shit? We're not lesbians," says one. <br><br> -"You're fucking //gross,//" says another. "Like, ew. Even if it's free, why the fuck would we let you touch us?" +"You're fucking //gross//," says another. "Like, ew. Even if it's free, why the fuck would we let you touch us?" <br><br> <<if $activeSlave.bellyPreg >= 750000>> "Holy shit, $he's gonna blow! Bitch'll keep fucking till $his belly pops open and keep on fucking still," @@ -3517,7 +3517,7 @@ $He shrieks, backpedaling, and then falls backward, $his <<if $activeSlave.butt There are sturdy leather seats placed strategically throughout your penthouse. They offer something convenient to bend your slaves over, wherever you happen to encounter them, and they're comfortable, too. At the moment, you're sitting on one, using a tablet to take care of some business that caught you away from your office, but isn't worth heading back to your desk for. Slaves move by your impromptu throne as you work, mostly <<if $averageTrust > 50>>greeting you cheerfully<<elseif $averageTrust > 20>>greeting you properly<<elseif $averageTrust > -20>>doing their best to greet you properly<<elseif $averageTrust > -50>>greeting you fearfully<<else>>struggling to greet you through their terror<</if>> as they pass. Busy, you spare few of them more than a glance. <br><br> -One of them slows as $he goes by, however. Looking up, you see that it's <<EventNameLink $activeSlave>>. <<if canTalk($activeSlave)>>"Hi <<Master>>," $he <<say>>s flirtily<<if $activeSlave.belly >= 1500>> rubbing a hand across $his _belly <<if $activeSlave.bellyPreg > 0>> pregnancy<<else>>belly<</if>><</if>>. "That look<<s>> like a really comfortable <<s>>eat. Can I <<s>>it down and re<<s>>t <<if $activeSlave.belly >= 10000>>my tired leg<<s>> <</if>>for a little while?"<<else>>$He greets you properly, but adds a flirtiness to $his gestures, and asks if $he can sit down and rest <<if $activeSlave.belly >= 10000>> $his <<if $activeSlave.bellyPreg > 0>>gravid<<else>>_belly<</if>> bulk <</if>>on the comfortable seat for a little while.<</if>> $He is not pointing at the soft leather cushion next to you: $he's pointing at your crotch. +One of them slows as $he goes by, however. Looking up, you see that it's <<EventNameLink $activeSlave>>. <<if canTalk($activeSlave)>>"Hi <<Master>>," $he <<say>>s flirtatiously<<if $activeSlave.belly >= 1500>> rubbing a hand across $his _belly <<if $activeSlave.bellyPreg > 0>> pregnancy<<else>>belly<</if>><</if>>. "That look<<s>> like a really comfortable <<s>>eat. Can I <<s>>it down and re<<s>>t <<if $activeSlave.belly >= 10000>>my tired leg<<s>> <</if>>for a little while?"<<else>>$He greets you properly, but adds a flirtiness to $his gestures, and asks if $he can sit down and rest <<if $activeSlave.belly >= 10000>> $his <<if $activeSlave.bellyPreg > 0>>gravid<<else>>_belly<</if>> bulk <</if>>on the comfortable seat for a little while.<</if>> $He is not pointing at the soft leather cushion next to you: $he's pointing at your crotch. <br><br> You're nude, a consequence of <<if $Concubine != 0 && $Concubine.ID != $activeSlave.ID>>recent activities involving $Concubine.slaveName<<else>>recent unrelated activities<</if>>. <<if $PC.dick == 1>>Your formidable dick is three quarters hard,<<else>>Nude, that is, all except for the strap-on you were just using and haven't taken off yet,<</if>> and $activeSlave.slaveName is pointing right at it. $He knows exactly what $he's asking for and gives $his <<if $activeSlave.hips > 0>>broad<<elseif $activeSlave.hips > -1>>trim<<else>>narrow<</if>> hips a little wiggle to make it even more abundantly clear. <<if ["chastity", "combined chastity"].includes($activeSlave.dickAccessory)>> @@ -3893,7 +3893,7 @@ and flirting with passersby. Or $he would be, if $he weren't surrounded by a gro <<elseif $activeSlave.belly >= 150000>> "Oh my god, I didn't know a $girl could get //that// pregnant," <<elseif $activeSlave.dick > 6>> - "I didn't even know <<= $girl>>s could have dicks that bid," + "I didn't even know <<= $girl>>s could have dicks that big," <<elseif $activeSlave.weight > 130>> "$He looks so soft and pillowy," <<elseif $activeSlave.belly >= 1500>> @@ -4317,7 +4317,7 @@ You are working late tonight, poring over some particularly troublesome business <<elseif $PC.refreshmentType == 6>> tab of $PC.refreshment <</if>> -brought in to you. This time <<EventNameLink $activeSlave>> has been sent to deliver it. $He loves you, but fears you simultaneously. Such relationships were not uncommon before the advent of modern slavery, but they are especially prevalent in its wake, as fear has proven a highly effective control method for those slaveowners with the inclination and relative lack of conscience to utilize it as such. You hurriedly put the finishing touches on your work, eager to be done, and reach for your $PC.refreshment. $activeSlave.slaveName flinches at your sudden movement, taking a few frightened steps back, nearly dropping the serving tray and leaving you grasping at thin air. It was a simple fear response; $he didn't realize you were ready for your treat and instinctively thought you were reaching out to strike $him. Tears swell up in $his eyes as $he apologizes profusely. +brought in to you. This time <<EventNameLink $activeSlave>> has been sent to deliver it. $He loves you, but fears you simultaneously. Such relationships were not uncommon before the advent of modern slavery, but they are especially prevalent in its wake, as fear has proven a highly effective control method for those slaveowners with the inclination and relative lack of conscience to utilize it as such. You hurriedly put the finishing touches on your work, eager to be done, and then reach for your $PC.refreshment. $activeSlave.slaveName flinches at your sudden movement, taking a few frightened steps back, nearly dropping the serving tray and leaving you grasping at thin air. It was a simple fear response; $he didn't realize you were ready for your treat and instinctively thought you were reaching out to strike $him. Tears swell up in $his eyes as $he apologizes profusely. <<default>> <br>ERROR: bad RESS event $RESSevent @@ -4387,7 +4387,7 @@ brought in to you. This time <<EventNameLink $activeSlave>> has been sent to del <<else>> "You don't want me to get pregnant <<Master>>?" <</if>> - You bring $his over to the couch, set $him on your lap, and teasingly call $him a buttslut. Every so often you graze a finger around $his chastity belt, noting how much $his body wants you in $him, but you only make it the center of attention once the poor over-aroused slave + You bring $him over to the couch, set $him on your lap, and teasingly call $him a buttslut. Every so often you graze a finger around $his chastity belt, noting how much $his body wants you in $him, but you only make it the center of attention once the poor over-aroused slave <<if !canTalk($activeSlave)>> begins to use piteous gestures to beg you abjectly to penetrate $him. <<else>> @@ -4422,9 +4422,9 @@ brought in to you. This time <<EventNameLink $activeSlave>> has been sent to del <<if !canTalk($activeSlave)>> $His expression shifts to confusion. <<else>> - "What<<s>> that mean <<Master>>?" + "What doe<<s>> that mean <<Master>>?" <</if>> - You quickly approach and catch $him, forcing $his <<if $activeSlave.belly >= 1500>><<if $activeSlave.bellyPreg >= 1500>>gravid <<else>>distended <</if>><</if>>body face up onto the couch. $He <<if canSee($activeSlave)>>watches you carefully<<else>>listens to your movements<</if>> as you size up $his fully erect + You quickly approach and catch $him, forcing $his <<if $activeSlave.belly >= 1500>><<if $activeSlave.bellyPreg >= 1500>>gravid <<else>>distended <</if>><</if>>body face up onto the couch. $He <<if canSee($activeSlave)>>watches you carefully<<elseif canHear($activeSlave)>>listens to your movements<<else>>waits with trepidation<</if>> as you size up $his fully erect <<if $activeSlave.dick == 1>> tiny dick. <<elseif $activeSlave.dick == 2>> @@ -4466,9 +4466,9 @@ brought in to you. This time <<EventNameLink $activeSlave>> has been sent to del <<if !canTalk($activeSlave)>> $His expression shifts to confusion. <<else>> - "What<<s>> that mean <<Master>>?" + "What doe<<s>> that mean <<Master>>?" <</if>> - You quickly approach and catch $him, forcing $him <<if $activeSlave.belly >= 1500>><<if $activeSlave.bellyPreg >= 1500>>gravid <<else>>distended <</if>><</if>>body face down onto the couch<<if $activeSlave.belly >= 100000>> as best you can<</if>>. $He <<if canSee($activeSlave)>>watches you carefully<<else>>listens to your movements<</if>> as you size up $his fully erect + You quickly approach and catch $him, forcing $his <<if $activeSlave.belly >= 1500>><<if $activeSlave.bellyPreg >= 1500>>gravid <<else>>distended <</if>><</if>>body face down onto the couch<<if $activeSlave.belly >= 100000>> as best you can<</if>>. $He <<if canSee($activeSlave)>>watches you carefully<<else>>listens to your movements<</if>> as you size up $his fully erect <<if $activeSlave.dick == 1>> tiny dick. <<elseif $activeSlave.dick == 2>> @@ -4525,7 +4525,7 @@ brought in to you. This time <<EventNameLink $activeSlave>> has been sent to del <<else>> "What<<s>> that mean <<Master>>?" <</if>> - You quickly approach and catch $him, forcing $his <<if $activeSlave.belly >= 1500>><<if $activeSlave.bellyPreg >= 1500>>gravid <<else>>distended <</if>><</if>>body face up onto the couch. $He <<if canSee($activeSlave)>>watches you carefully<<else>>listens to your movements<</if>> as you size up $his fully erect + You quickly approach and catch $him, forcing $his <<if $activeSlave.belly >= 1500>><<if $activeSlave.bellyPreg >= 1500>>gravid <<else>>distended <</if>><</if>>body face up onto the couch. $He <<if canSee($activeSlave)>>watches you carefully<<elseif canHear($activeSlave)>>listens to your movements<<else>>waits with trepidation<</if>> as you size up $his fully erect <<if $activeSlave.dick == 1>> tiny dick. <<elseif $activeSlave.dick == 2>> @@ -4581,7 +4581,7 @@ brought in to you. This time <<EventNameLink $activeSlave>> has been sent to del <</replace>> <</link>><<if ($activeSlave.anus == 0)>> //This option will take anal virginity//<</if>> <<if $seeExtreme == 1 && $activeSlave.indentureRestrictions <= 0>> -<br><<link "Geld $him to render $his impotent again">> +<br><<link "Geld $him to render $him impotent again">> <<set $activeSlave.balls = 0, $activeSlave.health -= 10, $activeSlave.trust -= 20>> <<EventNameDelink $activeSlave>> <<replace "#result">> @@ -4939,7 +4939,7 @@ brought in to you. This time <<EventNameLink $activeSlave>> has been sent to del <br><<link "Fake playing along">> <<EventNameDelink $activeSlave>> <<replace "#result">> - You start removing your top and putting on a show of seducing your slave, dropping to your knees while looking doe-eyed at $him. By sucking $him off, you'll probably get $him to lower their guard enough to get the upper hand. You take $his + You start removing your top and putting on a show of seducing your slave, dropping to your knees while looking doe-eyed at $him. By sucking $him off, you'll probably get $him to lower $his guard enough to get the upper hand. You take $his <<if $activeSlave.dick == 1>> pathetic <<elseif $activeSlave.dick == 2>> @@ -5924,9 +5924,9 @@ brought in to you. This time <<EventNameLink $activeSlave>> has been sent to del <<replace "#result">> Wordlessly, you fetch a towel of your own. $He raises $his head a little to see if $he's needed, but as soon as $he <<if canSee($activeSlave)>>sees<<else>>realizes<</if>> what you're doing, $he smiles with simple satisfaction and closes $his eyes again. You strip and lie down next to $him. $He made a good decision <<if $activeSlave.assignment == "rest">>about how to spend $his rest<<else>>about what to do with $his rest period<</if>>. The sun is warm and gentle, and the interminable demands of leadership and your harem suddenly seem very far away. You drop off for a short while, only waking when your apologetic personal assistant breaks in with notice of an upcoming meeting. As you get your senses back, you notice that $activeSlave.slaveName's hand is right next to yours, flattened out against the decking. $His eyes remain closed, and $his breath is steady; $he's fast asleep. It seems $he did not want to wake you, but @@.hotpink;wanted very much to be a little closer to you.@@ You consider canceling the meeting and waking the sun-warmed <<if $activeSlave.physicalAge > 30>> - woman, + $woman, <<elseif $activeSlave.physicalAge > 17>> - girl, + $girl, <<elseif $activeSlave.physicalAge > 12>> teen, <<else>> @@ -5936,7 +5936,7 @@ brought in to you. This time <<EventNameLink $activeSlave>> has been sent to del <<set $activeSlave.devotion += 4>> <</replace>> <</link>> -<br><<link "Bring your good girls out for a day at the beach">> +<br><<link "Bring your good slaves out for a day at the beach">> <<EventNameDelink $activeSlave>> <<replace "#result">> You direct $assistantName to bring your girls who deserve it out for a day at the beach. There might be little sand out on the balcony, but there's plenty of warm sun. And beaches are overrated these days anyway, with the ocean becoming so unpredictable. <<if $assistantName == "your personal assistant">>Your personal assistant<<else>>$assistantName<</if>> advises them to get naked, and bring towels and sun lotion appropriate for their individual skin types, so they know they're going to get some sunshine, but they're surprised when they get outside. They're obviously expecting an orgy of some kind, but all they see is you and $activeSlave.slaveName luxuriating on the decking. As they arrive, they take the cue and line up with you one by one. After a long sunbathing session, you send a couple of them inside to bring out cool drinks, a beach ball, and other essentials. The hornier girls are doubtful for a while, but eventually they all relax and @@.mediumaquamarine;gain confidence@@ from the simple, nonsexual pleasure of a little time in the sun. @@ -8387,7 +8387,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<set $activeSlave.devotion -= 5>> <</replace>> <</link>> -<br><<link "Sissy slave girls don't need to climax to serve">> +<br><<link "Sissy slave <<= $girl>>s don't need to climax to serve">> <<EventNameDelink $activeSlave>> <<replace "#result">> You explain patiently that $he needs to stop focusing on getting off. $He's a sex slave, and what matters is that $he pleasures others. If $he doesn't climax $himself, that's unfortunate but not really significant. $He looks terribly forlorn, so to drive home the point you push $him down to the floor, give $him a rough facefuck, and send $him away with tousled hair, <<if $PC.dick == 0>>a tired tongue<<else>>a mouthful of ejaculate<</if>>, and the same limp dick as before. @@.mediumorchid;It's frustrating for $him.@@ @@ -9141,7 +9141,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<else>> You finger fuck $him for a while, the sting of the soap on $him sensitive insides making $him gasp. <</if>> - As $he moans down on the shower floor, you lie down behind $him, spooning $him helpless body<<if $activeSlave.belly >= 5000>>, your hands encircling $him _belly <<if $activeSlave.bellyPreg >= 3000>>pregnancy<<else>>middle<</if>><</if>>. + As $he moans down on the shower floor, you lie down behind $him, spooning $his helpless body<<if $activeSlave.belly >= 5000>>, your hands encircling $his _belly <<if $activeSlave.bellyPreg >= 3000>>pregnancy<<else>>middle<</if>><</if>>. <<if $PC.dick == 1>> Your cock slides into $him with ease <<elseif $PC.boobs == 1>> @@ -9245,10 +9245,10 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<case "obedient bitchy">> -<<link "Beg $his pardon and offer to loan the bitch to $him">> +<<link "Beg her pardon and offer to loan the bitch to her">> <<EventNameDelink $activeSlave>> <<replace "#result">> - The businesswoman's anger turns to malicious anticipation as you call $activeSlave.slaveName over and inform $him that you and the businesswoman have decided $activeSlave.slaveName will be spending the night with $him. Now that you look at your business partner, she has certain signs of a sadist. $activeSlave.slaveName notices too, and begins to cry<<if $activeSlave.bellyPreg >= 1500>> and shield $his pregnancy<</if>> as the businesswoman promises that there will be "no permanent damage." $activeSlave.slaveName is unceremoniously returned in the early hours of the morning. $His back and buttocks have been meticulously flogged right up to the very edge of damage, leaving angry marks across $his $activeSlave.skin skin. $His mouth lolls open, as though $he's been doing little but give cunnilingus. <<if $activeSlave.vagina != -1>>$His pussy,<<elseif $activeSlave.dick == 0>>$His shamefully featureless groin with its tiny little hole,<<else>>$His dick,<</if>> anus,<<if $activeSlave.belly >= 10001>> popped navel,<</if>> and even $his nipples show signs of torture. Whenever $he thinks of a sharp remark in the future, @@.hotpink;$he'll remember the pain and keep $his mouth shut.@@ + The businesswoman's anger turns to malicious anticipation as you call $activeSlave.slaveName over and inform $him that you and the businesswoman have decided $activeSlave.slaveName will be spending the night with her. Now that you look at your business partner, she has certain signs of a sadist. $activeSlave.slaveName notices too, and begins to cry<<if $activeSlave.bellyPreg >= 1500>> and shield $his pregnancy<</if>> as the businesswoman promises that there will be "no permanent damage." $activeSlave.slaveName is unceremoniously returned in the early hours of the morning. $His back and buttocks have been meticulously flogged right up to the very edge of damage, leaving angry marks across $his $activeSlave.skin skin. $His mouth lolls open, as though $he's been doing little but give cunnilingus. <<if $activeSlave.vagina != -1>>$His pussy,<<elseif $activeSlave.dick == 0>>$His shamefully featureless groin with its tiny little hole,<<else>>$His dick,<</if>> anus,<<if $activeSlave.belly >= 10001>> popped navel,<</if>> and even $his nipples show signs of torture. Whenever $he thinks of a sharp remark in the future, @@.hotpink;$he'll remember the pain and keep $his mouth shut.@@ <<set $activeSlave.behavioralFlaw = "none", $activeSlave.oralCount += 5, $oralTotal += 5>> <</replace>> <</link>> @@ -9891,7 +9891,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <</link>><<if ($activeSlave.anus == 0 && canDoAnal($activeSlave)) || ($activeSlave.vagina == 0 && canDoVaginal($activeSlave))>> //This option will take virginity//<</if>> <</if>> <<if canDoAnal($activeSlave)>> -<br><<link "Assrape $his">> +<br><<link "Assrape $him">> <<EventNameDelink $activeSlave>> <<replace "#result">> You order $him to kneel. $He looks hopeful and complies, but $his anticipation of enjoyable sex vanishes with a pathetic little gasp when you<<if $PC.dick == 0>> don a strap-on and<</if>> <<if $PC.vagina == 1>>use a couple of fingers to collect some of your pussyjuice for improvised lube<<else>>spit on $his butthole<</if>>. With only a little saliva as lubrication, you brutally sodomize $him, fucking $his <<if $seeRace == 1>>$activeSlave.race <</if>>ass to the limit of what you can get away with without damaging $him. @@ -10118,7 +10118,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<set $activeSlave.devotion += 4>> <</replace>> <</link>> -<br><<link "Share some refreshments with $his">> +<br><<link "Share some refreshments with $him">> <<EventNameDelink $activeSlave>> <<replace "#result">> You reach into the back of your desk, where your private reserves are, and wordlessly offer $him a @@ -10450,11 +10450,11 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<replace "#artFrame">> /* 000-250-006 */ <<if $seeImages == 1>> - <<if $imageChoice == 1>> - <div class="imageRef lrgVector"><<SlaveArt $activeSlave 2 0>></div> - <<else>> - <div class="imageRef lrgRender"><<SlaveArt $activeSlave 2 0>></div> - <</if>> + <<if $imageChoice == 1>> + <div class="imageRef lrgVector"><<SlaveArt $activeSlave 2 0>></div> + <<else>> + <div class="imageRef lrgRender"><<SlaveArt $activeSlave 2 0>></div> + <</if>> <</if>> /* 000-250-006 */ <</replace>> @@ -10835,7 +10835,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address $He almost cries with relief when you tell $him to <<switch $activeSlave.fetish>> <<case "submissive">> - lie down on your desk on $his side in the fetal position. $He clambers up hurriedly and hugs $his knees<<if $activeSlave.belly >= 10000>> as best $he can with $his _belly <<if $activeSlave.bellyPreg >= 3000>>pregnancy <</if>>in the way<</if>>, spinning $himself around on the smooth surface so $his rear is pointing right at you. You stand up and pull $his over, $his $activeSlave.skin skin sliding across the cool glass desktop, until $his + lie down on your desk on $his side in the fetal position. $He clambers up hurriedly and hugs $his knees<<if $activeSlave.belly >= 10000>> as best $he can with $his _belly <<if $activeSlave.bellyPreg >= 3000>>pregnancy <</if>>in the way<</if>>, spinning $himself around on the smooth surface so $his rear is pointing right at you. You stand up and pull $him over, $his $activeSlave.skin skin sliding across the cool glass desktop, until $his <<if canDoAnal($activeSlave) && canDoVaginal($activeSlave)>> butt is right at the edge of the desk. You warm yourself up with a pussy fuck before shifting your attention to $his neglected asshole. <<= BothVCheck(3)>> @@ -11213,7 +11213,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address @@.lightcoral;$His enjoyment of pain has increased.@@ <<elseif random(1,100) > 50>> <<set $activeSlave.fetishStrength = 65, $activeSlave.fetish = "masochist", $activeSlave.fetishKnown = 1>> - Before $he realizes what's happening, @@.lightcoral;$he's getting aroused at the thought of <<= WrittenMaster()>> beating $him.@@ + Before $he realizes what's happening, @@.lightcoral;$he's getting aroused at the thought of $his <<= WrittenMaster()>> beating $him.@@ <</if>> <</replace>> <</link>> @@ -14173,10 +14173,10 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<set $activeSlave.trust -= 4, $activeSlave.devotion += 4>> <</replace>> <</link>><<if (($activeSlave.anus == 0) || ($activeSlave.vagina == 0)) && ($PC.dick == 1)>> //This option will take virginity//<</if>> -<br><<link "Get the truth out of $his">> +<br><<link "Get the truth out of $him">> <<EventNameDelink $activeSlave>> <<replace "#result">> - You ask $him why $he's really here, with devastating directness and in a tone that will brook no disobedience. $He quails, $him shoulders slumping as $he + You ask $him why $he's really here, with devastating directness and in a tone that will brook no disobedience. $He quails, $his shoulders slumping as $he <<if $activeSlave.belly >= 1500>> <<if $activeSlave.pregKnown == 1>> hugs $his pregnancy @@ -16095,11 +16095,11 @@ You tell $him kindly that you understand, and that $he'll be trained to address <</if>> $He spreads $his legs as wide as they'll go, and reaches down to spread $his buttocks even wider, offering you $his <<if canDoVaginal($activeSlave) && canDoAnal($activeSlave)>> - $his holes. + holes. <<elseif canDoVaginal($activeSlave)>> - $his pussy. + pussy. <<else>> - $his asshole. + asshole. <</if>> $He <<if $activeSlave.voice == 0>>tries to groan<<else>>groans<</if>> with anticipation of the coming relief as you slide <<if $PC.dick == 1>>your cock<<else>>a strap-on<</if>> past $his <<if canDoVaginal($activeSlave)>> @@ -16148,7 +16148,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <</if>> $His cock is so long that it drags along the floor as you pound <<if $activeSlave.belly >= 300000>> - $his against $his _belly dome of a stomach. + $him against $his _belly dome of a stomach. <<elseif $activeSlave.boobs > 12000>> $him, $his enormous tits serving as a cushion for $his torso to rest against. <<elseif $activeSlave.boobs > 7000>> @@ -16177,7 +16177,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<set $activeSlave.analCount++, $analTotal++>> <</if>> <</if>> - The cum pressurization brought $his almost to half-hardness, and as this effect diminishes, $his dick slides out again, releasing a lewd torrent of cum. $He cries with overstimulation, relief, pain, and humiliation, @@.hotpink;groveling below you@@ in utter subjugation. + The cum pressurization brought $him almost to half-hardness, and as this effect diminishes, $his dick slides out again, releasing a lewd torrent of cum. $He cries with overstimulation, relief, pain, and humiliation, @@.hotpink;groveling below you@@ in utter subjugation. <<set $activeSlave.devotion += 4>> <</replace>> <</link>><<if canDoVaginal($activeSlave) && ($activeSlave.vagina == 0)>>//This option will take virginity//<<elseif !canDoVaginal($activeSlave) && ($activeSlave.anus == 0)>> //This option will take anal virginity//<</if>> @@ -16223,7 +16223,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<elseif $activeSlave.fetish == "pregnancy" && $activeSlave.pregKnown == 1>> Being on the bottom for some missionary lovemaking is very much to $his tastes, even though $he is already pregnant. $He builds to orgasm slowly, reveling in the feeling of being your woman. <<elseif $activeSlave.fetish == "pregnancy">> - Being on the bottom for some missionary lovemaking is very much to $his tastes, even though the encounter isn't particularly likely to get $him pregnant. $He builds to orgasm slowly, reveling in the feeling of being your woman. + Being on the bottom for some missionary lovemaking is very much to $his tastes, even though the encounter isn't particularly likely to get $him pregnant. $He builds to orgasm slowly, reveling in the feeling of being your $woman. <</if>> As you made love to $him, the gentle motions, feminine sighs, and delicate aroma of pleasure woke the other girls in bed with you, and they began their own intimacy with each other. As you go back to sleep, you're surrounded with something very like Sapphic paradise. $activeSlave.slaveName nestles up to you once more, embracing you with @@.mediumaquamarine;trust born of love.@@ <<set $activeSlave.trust += 4, $activeSlave.vaginalCount++, $vaginalTotal++>> @@ -16234,7 +16234,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<replace "#result">> You feel your libido building, building, building within you, an endless cycle that mounts rapidly to an inevitable explosion. It comes, and you perform a catlike glide around until your head is at $his feet. As you did, you infiltrated one of your legs between $hers from its convenient starting point. $He wakes suddenly to the feeling of being manhandled, and then comes fully awake to the shockingly intimate sensation of your pussies pressed together as closely as physically possible. <br><br> - Holding $his upper thighs with your hands to pull $him against you, you grind into $him, fucking $him about as comprehensively as it's possible for someone without a cock to fuck a woman. $He's most definitely up for it, and you see $his eyes fly wide in the gloom as the full weight of the pleasure crashes into $him. It's not exactly a position for lovemaking, since your faces are about as far apart as they can possibly be during sex, but kissing be damned, you're here to fuck. Naturally, this evolution wakes everyone else up too, and before long, there's a regular lesbian orgy going on. When it's over, $activeSlave.slaveName finds $himself returning exhaustedly to sleep, one of your arms curled + Holding $his upper thighs with your hands to pull $him against you, you grind into $him, fucking $him about as comprehensively as it's possible for someone without a cock to fuck a $woman. $He's most definitely up for it, and you see $his eyes fly wide in the gloom as the full weight of the pleasure crashes into $him. It's not exactly a position for lovemaking, since your faces are about as far apart as they can possibly be during sex, but kissing be damned, you're here to fuck. Naturally, this evolution wakes everyone else up too, and before long, there's a regular lesbian orgy going on. When it's over, $activeSlave.slaveName finds $himself returning exhaustedly to sleep, one of your arms curled <<if $activeSlave.belly >= 5000>> under $his _belly <<if $activeSlave.bellyPreg >= 3000>>pregnancy<<else>>belly<</if>> <<else>> @@ -16276,7 +16276,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<if $activeSlave.fetish == "boobs">> $He orgasms strongly soon after the first jet of milk, producing an especially thick squirt. <</if>> - After you're satisfied, you move your hands to $his nipples and milk $him like a cow, getting the last drops of milk out of $his + After you're satisfied, you move your hands to $his nipples and milk $him like a cow, getting the last drops of milk out of $him <<if $activeSlave.fetish == "boobs">> and producing a shuddering series of aftershocks. <<else>> @@ -16293,9 +16293,9 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<replace "#result">> You ask $him if $he really wants to be treated like a cow. $He nods, a bit hesitantly, sensing a certain danger but not really knowing what else to do. You lead $him to the utility area of the penthouse, where the milkers are, but stop $him when $he starts for one. Instead, you <<if $activeSlave.belly >= 300000>> - pull $his over $his _belly belly with $his udders hanging beneath $his<<if $activeSlave.boobs > 5000>>, the twin masses of female flesh almost reaching the floor<</if>>. + pull $him over $his _belly belly with $his udders hanging beneath $his<<if $activeSlave.boobs > 5000>>, the twin masses of female flesh almost reaching the floor<</if>>. <<else>> - fetch a pair of low stools, make $his kneel on one, and put $his hands on the other, so $he's on all fours with $his udders hanging beneath $his<<if $activeSlave.boobs > 5000>>, the twin masses of female flesh almost reaching the floor<</if>>. + fetch a pair of low stools, make $him kneel on one, and put $his hands on the other, so $he's on all fours with $his udders hanging beneath $his<<if $activeSlave.boobs > 5000>>, the twin masses of female flesh almost reaching the floor<</if>>. <</if>> <br><br> You swing a bucket under $his nipples and milk $him by hand, as though $he were a cow. This isn't exactly what $he had in mind, but the feeling of your hands on $his nipples, tugging the streams of milk out of $him and into the bucket beneath <<if $activeSlave.fetish == "boobs">>brings $his very close to orgasm<<else>>eventually relaxes $his<</if>>. Seeing this, you muse aloud, as though to yourself, that a little farmyard bestiality wouldn't hurt, since there's no one here but you and a dairy cow. Pawing the cow's behind possessively, you finger $him aggressively before deciding on @@ -16989,7 +16989,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<set $activeSlave.trust += 4, $activeSlave.oralCount++, $oralTotal++>> <</replace>> <</link>> -<br><<link "Dance along with $his">> +<br><<link "Dance along with $him">> <<EventNameDelink $activeSlave>> <<replace "#result">> $He doesn't <<if canSee($activeSlave)>>see<<else>>notice<</if>> you advance on $him; $he's facing away from you, and in any case, $he's lost in $his own little world. At the same moment, however, $he begins to hear the track $he's humming, in perfect synchrony with the way $he's humming it, and senses a presence at $his side. You timed it perfectly, directing the sound system here to play the right track, match it to $him, and fade it in as you approached and began to dance beside $him. @@ -17233,7 +17233,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <</if>> <<set $fixedNationality = "American">> <<include "Generate New Slave">> - <<set _origin = "You enslaved her for abusing " + $eventSlave.slaveName + " while $he was serving the public.">> + <<set _origin = "You enslaved her for abusing " + $eventSlave.slaveName + " while " + $he + " was serving the public.">> <<set $activeSlave.origin = _origin>> <<set $activeSlave.career = "a student">> <<set $activeSlave.markings = "none", $activeSlave.weight = -20>> @@ -17255,7 +17255,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<set $activeSlave.health = random(30,50)>> <<set $activeSlave.attrXY = random(60,90)>> <<set $activeSlave.attrXX = random(10,20)>> - <<set $activeSlave.behavioralFlaw = either("bitchy", "arrogant")>> + <<set $activeSlave.behavioralFlaw = either("arrogant", "bitchy")>> <<run newSlave($activeSlave)>> /* skip New Slave Intro */ <<run cashX(-8333, "slaveTransfer", $activeSlave)>> <</for>> @@ -17331,7 +17331,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<link "Give them a surprise massage">> <<EventNameDelink $activeSlave>> <<replace "#result">> - You move stealthily up behind $him in a predatory crouch, your arms forward and your fingers spread. When $he reaches up to <<if $activeSlave.makeup != 0>>do $his eyes<<else>>massage $his forehead<</if>>, you take advantage of $his newly vulnerable flanks and reach around $him to take $his torpedo tits in hand. $He <<if $activeSlave.voice != 0>>howls<<else>>makes the raspy noise that mute slaves make when<</if>> in shock, writhing away from the grasping digits. Your hands aren't particularly cold, but $he's deliciously warm from the shower and you're holding onto $his firmly. $His + You move stealthily up behind $him in a predatory crouch, your arms forward and your fingers spread. When $he reaches up to <<if $activeSlave.makeup != 0>>do $his eyes<<else>>massage $his forehead<</if>>, you take advantage of $his newly vulnerable flanks and reach around $him to take $his torpedo tits in hand. $He <<if $activeSlave.voice != 0>>howls<<else>>makes the raspy noise that mute slaves make when<</if>> in shock, writhing away from the grasping digits. Your hands aren't particularly cold, but $he's deliciously warm from the shower and you're holding onto $him firmly. $His <<if $activeSlave.butt > 12>> titanic ass <<elseif $activeSlave.butt > 5>> @@ -17478,12 +17478,12 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<set $activeSlave.health -= 20>> <<if ($arcologies[0].FSSubjugationistRace == "white")>> <<set $activeSlave.race = "white">> - <<set $activeSlave.skin = either("pale", "light", "fair")>> + <<set $activeSlave.skin = either("fair", "light", "pale")>> <<set $activeSlave.eyeColor = either("blue", "brown", "green")>> - <<set $activeSlave.hColor = either("black", "blonde", "red", "brown")>> + <<set $activeSlave.hColor = either("black", "blonde", "brown", "red")>> <<elseif ($arcologies[0].FSSubjugationistRace == "latina")>> <<set $activeSlave.race = "latina">> - <<set $activeSlave.skin = either("light olive", "brown", "dark brown", "tanned", "dark olive")>> + <<set $activeSlave.skin = either("brown", "dark brown", "dark olive", "light olive", "tanned")>> <<set $activeSlave.hColor = either("black", "black", "brown", "brown")>> <<elseif ($arcologies[0].FSSubjugationistRace == "black")>> <<set $activeSlave.race = "black">> @@ -17491,11 +17491,11 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<set $activeSlave.hColor = either("black", "black", "black", "brown")>> <<elseif ($arcologies[0].FSSubjugationistRace == "asian")>> <<set $activeSlave.race = "asian">> - <<set $activeSlave.skin = either("light olive", "dark olive", "light")>> + <<set $activeSlave.skin = either("dark olive", "light olive", "light")>> <<set $activeSlave.hColor = either("black")>> <<elseif ($arcologies[0].FSSubjugationistRace == "middle eastern")>> <<set $activeSlave.race = "middle eastern">> - <<set $activeSlave.skin = either("tanned", "dark olive", "light olive")>> + <<set $activeSlave.skin = either("dark olive", "light olive", "tanned")>> <<set $activeSlave.hColor = "black">> <<elseif ($arcologies[0].FSSubjugationistRace == "indo-aryan")>> <<set $activeSlave.race = "indo-aryan">> @@ -17503,7 +17503,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<set $activeSlave.hColor = "black">> <<elseif ($arcologies[0].FSSubjugationistRace == "amerindian")>> <<set $activeSlave.race = "amerindian">> - <<set $activeSlave.skin = either("tanned", "dark", "light")>> + <<set $activeSlave.skin = either("dark", "light", "tanned")>> <<set $activeSlave.hColor = either("black")>> <<elseif ($arcologies[0].FSSubjugationistRace == "pacific islander")>> <<set $activeSlave.race = "pacific islander">> @@ -17511,15 +17511,15 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<set $activeSlave.hColor = either("black")>> <<elseif ($arcologies[0].FSSubjugationistRace == "malay")>> <<set $activeSlave.race = "malay">> - <<set $activeSlave.skin = either("light", "light olive", "dark olive")>> + <<set $activeSlave.skin = either("dark olive", "light olive", "light")>> <<set $activeSlave.hColor = either("black")>> <<elseif ($arcologies[0].FSSubjugationistRace == "southern european")>> <<set $activeSlave.race = "southern european">> - <<set $activeSlave.skin = either("light", "dark olive", "light olive")>> + <<set $activeSlave.skin = either("dark olive", "light olive", "light")>> <<set $activeSlave.hColor = either("black")>> <<elseif ($arcologies[0].FSSubjugationistRace == "semitic")>> <<set $activeSlave.race = "semitic">> - <<set $activeSlave.skin = either("tanned", "dark olive", "light olive")>> + <<set $activeSlave.skin = either("dark olive", "light olive", "tanned")>> <<set $activeSlave.hColor = either("black")>> <<elseif ($arcologies[0].FSSubjugationistRace == "mixed race")>> <<set $activeSlave.race = "mixed race">> @@ -19291,7 +19291,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<replace "#result">> You linger in the hallway a while with $activeSlave.slaveName and enjoy a brief but verbose discussion. It's clear $he hasn't had the chance to engage in any meaningful conversations in a while, so $he relishes the opportunity energetically. <br><br> - Though the two of you only touch upon a handful of sophisticated topics, by the time you leave $him to tend to other matters, $activeSlave.slaveName is beaming happily as $he continues on to $his duties for the day. $He @@.mediumaquamarine;trusts you more@@ for taking the time to engage with $his intellectually. + Though the two of you only touch upon a handful of sophisticated topics, by the time you leave $him to tend to other matters, $activeSlave.slaveName is beaming happily as $he continues on to $his duties for the day. $He @@.mediumaquamarine;trusts you more@@ for taking the time to engage with $him intellectually. <<set $activeSlave.trust += 4>> <</replace>> <</link>> @@ -19883,7 +19883,7 @@ You tell $him kindly that you understand, and that $he'll be trained to address <<if canDoVaginal($activeSlave) && canDoAnal($activeSlave)>> Even a switch to $his ass does little to slow your thrusts, and so $his breasts continue to rest impassively on $his chest as their owner is buttfucked senseless. <</if>> - You finish with a particularly hard thrust <<if $PC.dick == 0>>and shake with climax<<else>>to spill your seed deep inside $his<</if>>, ramming forward hard enough to knock $him down to the floor. As you rise, $his discomfited form is a pretty sight, with $his perfectly rounded breasts + You finish with a particularly hard thrust <<if $PC.dick == 0>>and shake with climax<<else>>to spill your seed deep inside $him<</if>>, ramming forward hard enough to knock $him down to the floor. As you rise, $his discomfited form is a pretty sight, with $his perfectly rounded breasts <<if $activeSlave.belly >= 300000>> neatly stack on top each other <<else>> diff --git a/src/uncategorized/RESSTR.tw b/src/uncategorized/RESSTR.tw index 75b19232503d838d288a73c05ca57f54fdc35975..796b9e90c7d1bfaad2ed005195570cd15d87221b 100644 --- a/src/uncategorized/RESSTR.tw +++ b/src/uncategorized/RESSTR.tw @@ -39,7 +39,7 @@ <</if>> <<else>> -<<set $nextButton = "Continue", $nextLink = "AS Dump", $returnTo = "Next Week">> + <<set $nextButton = "Continue", $nextLink = "AS Dump", $returnTo = "Next Week">> /* 000-250-006 */ <<if $seeImages == 1>> @@ -51,27 +51,27 @@ <</if>> /* 000-250-006 */ -<<set $desc = SlaveTitle($activeSlave)>> -<<run Enunciate($activeSlave)>> + <<set $desc = SlaveTitle($activeSlave)>> + <<run Enunciate($activeSlave)>> -<<switch $RESSTRevent>> + <<switch $RESSTRevent>> -<<default>> - <br>ERROR: bad RESSTR event $RESSTRevent -<</switch>> + <<default>> + <br>ERROR: bad RESSTR event $RESSTRevent + <</switch>> -<br><br> -<span id="result"> -<<switch $RESSTRevent>> + <br><br> + <span id="result"> + <<switch $RESSTRevent>> -<<default>> - <br>ERROR: bad RESSTR event $RESSTRevent -<</switch>> + <<default>> + <br>ERROR: bad RESSTR event $RESSTRevent + <</switch>> -<<if $cheatMode == 1>> - <br><br>DEBUG: [[Go back to Nonrandom Event|Nonrandom Event][$activeSlave = 0, $eventSlave = 0]] -<</if>> + <<if $cheatMode == 1>> + <br><br>DEBUG: [[Go back to Nonrandom Event|Nonrandom Event][$activeSlave = 0, $eventSlave = 0]] + <</if>> -</span> + </span> <</if>> /* CLOSES EVENT SELECTION */ diff --git a/src/uncategorized/assign.tw b/src/uncategorized/assign.tw index 964791f95e4766d7027dcc0c5353a15710773f1c..9fb35d058a7c6fff5f76faa31fb1b3c4d9f0df69 100644 --- a/src/uncategorized/assign.tw +++ b/src/uncategorized/assign.tw @@ -16,7 +16,7 @@ <<case "Coursing Association">> <<set $Lurcher = $activeSlave>> <<goto $returnTo>> - + <<default>> <<= assignJob($activeSlave, $assignTo)>> diff --git a/src/uncategorized/bodyModification.tw b/src/uncategorized/bodyModification.tw index 04aa173a28b88cabbab7ced8278b41baa164e4c0..1657019c159371749fa4933b1ed670bed65a26b4 100644 --- a/src/uncategorized/bodyModification.tw +++ b/src/uncategorized/bodyModification.tw @@ -21,47 +21,67 @@ <<unset $brandApplied>> <</if>> <<if $activeSlave.fetish != "mindbroken" && $activeSlave.fuckdoll == 0>> - <<if $degradation > 1>> - <<if $degradation > 5>> - <<if $activeSlave.devotion <= 50 && $activeSlave.trust < -50>> - $He is appalled by the whorish spectacle you have made of $him. $He @@.gold;fears@@ you all the more for this but is so terrified of you it does not affect $his submission. - <<set $activeSlave.trust -= 10>> - <<elseif $activeSlave.devotion <= 50>> - $He is appalled by the whorish spectacle you have made of $him. $He @@.mediumorchid;hates@@ and @@.gold;fears@@ you for this. - <<set $activeSlave.devotion -= 10, $activeSlave.trust -= 10>> - <<else>> - $He is shocked by the whorish spectacle you have made of $him. However, $he is so submissive to your will that $he @@.hotpink;accepts@@ that the slave <<if canSee($activeSlave)>>in the mirror<<else>>$he pictures<</if>> is who $he is now. - <<set $activeSlave.devotion += 4>> - <</if>> - <br><br> - <<else>> - <<if $activeSlave.devotion < -20 && $activeSlave.trust < 20>> - $He is @@.gold;afraid@@ that $he has been permanently altered against $his will, but is also scared of your reaction to any objection and suppresses $his disgust. - <<set $activeSlave.trust -= 5>> - <<elseif $activeSlave.devotion < -20>> - $He is @@.mediumorchid;angry@@ and @@.gold;afraid@@ that $he has been permanently altered against $his will. - <<set $activeSlave.devotion -= 5, $activeSlave.trust -= 5>> + <<if $degradation > 1>> + <<if $degradation > 5>> + <<if $activeSlave.devotion <= 50 && $activeSlave.trust < -50>> + $He is appalled by the whorish spectacle you have made of $him. $He @@.gold;fears@@ you all the more for this but is so terrified of you it does not affect $his submission. + <<set $activeSlave.trust -= 10>> + <<elseif $activeSlave.devotion <= 50>> + $He is appalled by the whorish spectacle you have made of $him. $He @@.mediumorchid;hates@@ and @@.gold;fears@@ you for this. + <<set $activeSlave.devotion -= 10, $activeSlave.trust -= 10>> + <<else>> + $He is shocked by the whorish spectacle you have made of $him. However, $he is so submissive to your will that $he @@.hotpink;accepts@@ that the slave <<if canSee($activeSlave)>>in the mirror<<else>>$he pictures<</if>> is who $he is now. + <<set $activeSlave.devotion += 4>> + <</if>> + <br><br> <<else>> - $He is saddened to have been altered against $his will. However, $he realizes that $he is a slave, so $he @@.hotpink;accepts@@ your work. - <<set $activeSlave.devotion += 4>> + <<if $activeSlave.devotion < -20 && $activeSlave.trust < 20>> + $He is @@.gold;afraid@@ that $he has been permanently altered against $his will, but is also scared of your reaction to any objection and suppresses $his disgust. + <<set $activeSlave.trust -= 5>> + <<elseif $activeSlave.devotion < -20>> + $He is @@.mediumorchid;angry@@ and @@.gold;afraid@@ that $he has been permanently altered against $his will. + <<set $activeSlave.devotion -= 5, $activeSlave.trust -= 5>> + <<else>> + $He is saddened to have been altered against $his will. However, $he realizes that $he is a slave, so $he @@.hotpink;accepts@@ your work. + <<set $activeSlave.devotion += 4>> + <</if>> <</if>> + <<set $degradation = 0>> <</if>> - <<set $degradation = 0>> - <</if>> - <<set _slaveBeforeSession = getSlave($activeSlave.ID)>> - <<if $activeSlave.tonguePiercing != _slaveBeforeSession.tonguePiercing>> - <<if $activeSlave.fetishKnown>> - <<if $activeSlave.fetishStrength > 10>> - <<if $activeSlave.fetish == "cumslut">> - Since $he's an oral whore, $he's - <<if $activeSlave.tonguePiercing > _slaveBeforeSession.tonguePiercing>> - <<if $activeSlave.tonguePiercing > 1>>@@.hotpink;very happy@@ you took the time to personally pierce $his tongue so heavily<<else>>@@.hotpink;happy@@ to get a tongue piercing from you personally<</if>>. After all, $he's pretty sure it's a sign there will be plenty of <<if $PC.dick>>dick for $him to suck<<else>>pussy for $him to eat<</if>> in the future. - <<set $activeSlave.devotion += ($activeSlave.tonguePiercing-_slaveBeforeSession.tonguePiercing)*2>> - <<elseif $activeSlave.devotion <= 95>> - @@.mediumorchid;saddened@@ you decided to take out $his tongue piercings yourself. $He's afraid this means something about $his future as a suck slut. - <<set $activeSlave.devotion += ($activeSlave.tonguePiercing-_slaveBeforeSession.tonguePiercing)*2>> + <<set _slaveBeforeSession = getSlave($activeSlave.ID)>> + <<if $activeSlave.tonguePiercing != _slaveBeforeSession.tonguePiercing>> + <<if $activeSlave.fetishKnown>> + <<if $activeSlave.fetishStrength > 10>> + <<if $activeSlave.fetish == "cumslut">> + Since $he's an oral whore, $he's + <<if $activeSlave.tonguePiercing > _slaveBeforeSession.tonguePiercing>> + <<if $activeSlave.tonguePiercing > 1>>@@.hotpink;very happy@@ you took the time to personally pierce $his tongue so heavily<<else>>@@.hotpink;happy@@ to get a tongue piercing from you personally<</if>>. After all, $he's pretty sure it's a sign there will be plenty of <<if $PC.dick>>dick for $him to suck<<else>>pussy for $him to eat<</if>> in the future. + <<set $activeSlave.devotion += ($activeSlave.tonguePiercing-_slaveBeforeSession.tonguePiercing)*2>> + <<elseif $activeSlave.devotion <= 95>> + @@.mediumorchid;saddened@@ you decided to take out $his tongue piercings yourself. $He's afraid this means something about $his future as a suck slut. + <<set $activeSlave.devotion += ($activeSlave.tonguePiercing-_slaveBeforeSession.tonguePiercing)*2>> + <</if>> + <</if>> + <</if>> + <<if $activeSlave.sexualFlaw == "hates oral">> + $He has trouble thinking of $his mouth as a warm, wet, playful hole, so $his new piercings will be therapeutic. Having something to suck on at all times should force $him past $his hangups. <</if>> <</if>> + <</if>> + <<if $activeSlave.nipplesPiercing+$activeSlave.areolaePiercing != _slaveBeforeSession.nipplesPiercing+_slaveBeforeSession.areolaePiercing>> + <<if $activeSlave.fetishKnown>> + <<if $activeSlave.fetishStrength > 10>> + <<if $activeSlave.fetish == "boobs">> + Since $he's fixated on $his boobs, $he's + <<if $activeSlave.nipplesPiercing+$activeSlave.areolaePiercing > _slaveBeforeSession.nipplesPiercing+_slaveBeforeSession.areolaePiercing>> + <<if $activeSlave.nipplesPiercing+$activeSlave.areolaePiercing > 2>>@@.hotpink;very happy@@ you took the time to personally pierce them so heavily<<else>>@@.hotpink;happy@@ to get nipple piercings from you personally<</if>>. As far as $he's concerned, more attention on $his tits is always good. + <<set $activeSlave.devotion += ($activeSlave.nipplesPiercing+$activeSlave.areolaePiercing-_slaveBeforeSession.nipplesPiercing-_slaveBeforeSession.areolaePiercing)*2>> + <<elseif $activeSlave.devotion <= 95>> + @@.mediumorchid;saddened@@ you decided to take out $his nipple piercings yourself. $He doesn't like anything that makes $his tits less distinctive. + <<set $activeSlave.devotion += ($activeSlave.tonguePiercing-_slaveBeforeSession.tonguePiercing)*2>> + <</if>> + <</if>> + <</if>> <</if>> <<if $activeSlave.sexualFlaw == "hates oral">> $He has trouble thinking of $his mouth as a warm, wet, playful hole, so $his new piercings will be therapeutic. Having something to suck on at all times should force $him past $his hang-ups. @@ -118,206 +138,213 @@ $He has trouble thinking of $his vagina as a fuckhole rather than something special to protect and cherish, so $his new piercings will be therapeutic. The constant, inescapable stimulation of $his labia should force $him past $his hang-ups. <</if>> <</if>> - <</if>> - <<if $activeSlave.dickPiercing != _slaveBeforeSession.dickPiercing>> - <<if $activeSlave.fetishKnown>> - <<if $activeSlave.fetishStrength > 10>> - <<if $activeSlave.fetish == "pregnancy">> - Since $he's fixated on using $his cock to impregnate other slaves, $he's - <<if $activeSlave.dickPiercing > _slaveBeforeSession.dickPiercing>> - <<if $activeSlave.dickPiercing > 1>>@@.hotpink;very happy@@ you took the time to personally stick so much metal into $his dick<<if $activeSlave.scrotum>> and ballsack<</if>><<else>>@@.hotpink;happy@@ to get penis piercings from you personally<</if>>. $He's extremely proud of $his newly decorated member. - <<set $activeSlave.devotion += ($activeSlave.dickPiercing-_slaveBeforeSession.dickPiercing)*2>> - <<elseif $activeSlave.devotion <= 95>> - @@.mediumorchid;saddened@@ you decided to take out $his dick<<if $activeSlave.scrotum>> and ballsack<</if>> piercings yourself. $He passionately loves using $his penis, and $he's concerned you're planning to let $him do less of that. - <<set $activeSlave.devotion += ($activeSlave.dickPiercing-_slaveBeforeSession.dickPiercing)*2>> + <<if $activeSlave.anusPiercing != _slaveBeforeSession.anusPiercing>> + <<if $activeSlave.fetishKnown>> + <<if $activeSlave.fetishStrength > 10>> + <<if $activeSlave.fetish == "buttslut">> + Since $he's an anal slut, $he's + <<if $activeSlave.anusPiercing > _slaveBeforeSession.anusPiercing>> + <<if $activeSlave.anusPiercing > 1>>@@.hotpink;very happy@@ you took the time to personally pierce the entire area around $his whorish asspussy<<else>>@@.hotpink;happy@@ to get a piercing next to $his favorite hole from you personally<</if>>. $He can't wait to find out how the metal will feel against $his butthole when $he moves around. + <<set $activeSlave.devotion += ($activeSlave.anusPiercing-_slaveBeforeSession.anusPiercing)*2>> + <<elseif $activeSlave.devotion <= 95>> + @@.mediumorchid;saddened@@ you decided to take out $his backdoor piercings yourself. $He will miss the constant anal titillation, and $he's worried this means you're becoming less interested in $his butthole. + <<set $activeSlave.devotion += ($activeSlave.anusPiercing-_slaveBeforeSession.anusPiercing)*2>> + <</if>> + <</if>> + <</if>> + <<if $activeSlave.sexualFlaw == "hates anal">> + $He has trouble thinking of $his asshole as a sexy, fuckable hole, so $his new piercings will be therapeutic. The constant tickling back there should force $him past $his hangups. + <</if>> <</if>> <</if>> - <</if>> - <</if>> - <</if>> - <<if $activeSlave.anusPiercing != _slaveBeforeSession.anusPiercing>> - <<if $activeSlave.fetishKnown>> - <<if $activeSlave.fetishStrength > 10>> - <<if $activeSlave.fetish == "buttslut">> - Since $he's an anal slut, $he's - <<if $activeSlave.anusPiercing > _slaveBeforeSession.anusPiercing>> - <<if $activeSlave.anusPiercing > 1>>@@.hotpink;very happy@@ you took the time to personally pierce the entire area around $his whorish asspussy<<else>>@@.hotpink;happy@@ to get a piercing next to $his favorite hole from you personally<</if>>. $He can't wait to find out how the metal will feel against $his butthole when $he moves around. - <<set $activeSlave.devotion += ($activeSlave.anusPiercing-_slaveBeforeSession.anusPiercing)*2>> - <<elseif $activeSlave.devotion <= 95>> - @@.mediumorchid;saddened@@ you decided to take out $his backdoor piercings yourself. $He will miss the constant anal titillation, and $he's worried this means you're becoming less interested in $his butthole. - <<set $activeSlave.devotion += ($activeSlave.anusPiercing-_slaveBeforeSession.anusPiercing)*2>> + <<if $activeSlave.genes == "XY">> + <<if $activeSlave.attrXY <= 35>> + <<if $activeSlave.earPiercing+$activeSlave.nosePiercing+$activeSlave.eyebrowPiercing+$activeSlave.lipsPiercing+$activeSlave.navelPiercing > _slaveBeforeSession.earPiercing+_slaveBeforeSession.nosePiercing+_slaveBeforeSession.eyebrowPiercing+_slaveBeforeSession.lipsPiercing+_slaveBeforeSession.navelPiercing>> + $His girly new + <<if $activeSlave.nosePiercing == 1 && _slaveBeforeSession.nosePiercing == 0>> + pierced ears should help $him a little with $his issues about $his self-image as a fuckable slave girl. + <<elseif $activeSlave.nosePiercing == 1 && _slaveBeforeSession.nosePiercing == 0>> + nose piercing should make $his reflection in the mirror seem just a bit more fuckably feminine to $him. + <<elseif $activeSlave.eyebrowPiercing == 1 && _slaveBeforeSession.eyebrowPiercing == 0>> + facial piercing should help destroy $his vestiges of sexual identity outside of $his life as a hole for cocks. + <<elseif $activeSlave.lipsPiercing == 1 && _slaveBeforeSession.lipsPiercing == 0>> + facial piercing, just below $his pretty mouth, should help $him get used to the idea of it being a warm, wet hole for cocks. + <<elseif $activeSlave.navelPiercing == 1 && _slaveBeforeSession.navelPiercing == 0>> + navel piercing should help $his see $his naked body in a submissively sexual way, especially as $him turns to hide it and present $his asspussy. + <<else>> + new set of slutty facial piercings should help $him get used to the idea of being a girly slave meant to please dicks. + <</if>> + <<if $activeSlave.devotion < -20>>Unfortunately, that positive effect will have to wait until $he's a little less resistant to the idea of being a sex slave.<</if>> <</if>> <</if>> - <</if>> <<if $activeSlave.sexualFlaw == "hates anal">> $He has trouble thinking of $his asshole as a sexy, fuckable hole, so $his new piercings will be therapeutic. The constant tickling back there should force $him past $his hang-ups. <</if>> <</if>> <</if>> <<if $activeSlave.genes == "XY">> - <<if $activeSlave.attrXY <= 35>> - <<if $activeSlave.earPiercing+$activeSlave.nosePiercing+$activeSlave.eyebrowPiercing+$activeSlave.lipsPiercing+$activeSlave.navelPiercing > _slaveBeforeSession.earPiercing+_slaveBeforeSession.nosePiercing+_slaveBeforeSession.eyebrowPiercing+_slaveBeforeSession.lipsPiercing+_slaveBeforeSession.navelPiercing>> - $His girly new - <<if $activeSlave.nosePiercing == 1 && _slaveBeforeSession.nosePiercing == 0>> - pierced ears should help $him a little with $his issues about $his self-image as a fuckable slave girl. - <<elseif $activeSlave.nosePiercing == 1 && _slaveBeforeSession.nosePiercing == 0>> - nose piercing should make $his reflection in the mirror seem just a bit more fuckably feminine to $him. - <<elseif $activeSlave.eyebrowPiercing == 1 && _slaveBeforeSession.eyebrowPiercing == 0>> - facial piercing should help destroy $his vestiges of sexual identity outside of $his life as a hole for cocks. - <<elseif $activeSlave.lipsPiercing == 1 && _slaveBeforeSession.lipsPiercing == 0>> - facial piercing, just below $his pretty mouth, should help $him get used to the idea of it being a warm, wet hole for cocks. - <<elseif $activeSlave.navelPiercing == 1 && _slaveBeforeSession.navelPiercing == 0>> - navel piercing should help $his see $his naked body in a submissively sexual way, especially as $him turns to hide it and present $his asspussy. - <<else>> - new set of slutty facial piercings should help $him get used to the idea of being a girly slave meant to please dicks. - <</if>> - <<if $activeSlave.devotion < -20>>Unfortunately, that positive effect will have to wait until $he's a little less resistant to the idea of being a sex slave.<</if>> - <</if>> - <</if>> - <</if>> - <<if $activeSlave.anusTat != _slaveBeforeSession.anusTat>> - <<if canSee($activeSlave)>> - <<if canTalk($activeSlave)>> - <<if $activeSlave.anus > 3>> - <<set _anus = "anal gape">> - <<elseif $activeSlave.anus == 3>> - <<set _anus = "relaxed asspussy">> - <<elseif $activeSlave.anus == 2>> - <<set _anus = "soft butthole">> - <<else>> - <<set _anus = "tight butthole">> - <</if>> - <<if $activeSlave.anusTat == "bleached">> - $He knew $he was getting $his ass bleached, of course. The stinging sensation was hard to miss. Even so, $he cranes $his neck around as soon as possible to look at $his _anus in the mirror. - <<else>> - $He knew $he was getting $his asshole tattooed, of course. $He cranes $his neck around as soon as possible to look at $his _anus in the mirror. - <<if $activeSlave.butt > 5>>$His huge buttocks are still held apart by the spreaders used to give the tattooing actuators access to $his most intimate area, giving $him a good view.<</if>> - <</if>> - <<if $activeSlave.fetishKnown && $activeSlave.fetish == "buttslut">> - <<switch $activeSlave.anusTat>> - <<case "bleached">> - $He giggles at $his crinkled fuckhole's clean, fuckable appearance, and starts squeezing $his sphincter muscles experimentally. "Thank you, <<Master>>," $he gasps, flushing. - <<case "flowers" "tribal patterns">> - $He gasps at the beautiful design and then suddenly bursts into tears. "T-thank you, <<Master>>," $he blubbers. "I'm <<s>>-<<s>>uch an anal whore." - <<case "advertisements">> - $He stares, $his mouth working as $he spells out - <<if ($activeSlave.vagina > -1)>> - 'Second Pussy.' $He smiles naughtily. "<<Master>>, it'<<s>> my //favorite// pu<<ss>>y," + <<if $activeSlave.attrXY <= 35>> + <<if $activeSlave.earPiercing+$activeSlave.nosePiercing+$activeSlave.eyebrowPiercing+$activeSlave.lipsPiercing+$activeSlave.navelPiercing > _slaveBeforeSession.earPiercing+_slaveBeforeSession.nosePiercing+_slaveBeforeSession.eyebrowPiercing+_slaveBeforeSession.lipsPiercing+_slaveBeforeSession.navelPiercing>> + $His girly new + <<if $activeSlave.nosePiercing == 1 && _slaveBeforeSession.nosePiercing == 0>> + pierced ears should help $him a little with $his issues about $his self-image as a fuckable slave girl. + <<elseif $activeSlave.nosePiercing == 1 && _slaveBeforeSession.nosePiercing == 0>> + nose piercing should make $his reflection in the mirror seem just a bit more fuckably feminine to $him. + <<elseif $activeSlave.eyebrowPiercing == 1 && _slaveBeforeSession.eyebrowPiercing == 0>> + facial piercing should help destroy $his vestiges of sexual identity outside of $his life as a hole for cocks. + <<elseif $activeSlave.lipsPiercing == 1 && _slaveBeforeSession.lipsPiercing == 0>> + facial piercing, just below $his pretty mouth, should help $him get used to the idea of it being a warm, wet hole for cocks. + <<elseif $activeSlave.navelPiercing == 1 && _slaveBeforeSession.navelPiercing == 0>> + navel piercing should help $his see $his naked body in a submissively sexual way, especially as $him turns to hide it and present $his asspussy. <<else>> - 'Spit First.' $He smiles naughtily. "<<Master>>, that work<<s>> for me. Lube'<<s>> good too. Or, um, dry'<<s>> fine too," + new set of slutty facial piercings should help $him get used to the idea of being a girly slave meant to please dicks. <</if>> - $he giggles. - <<case "rude words">> - $He stares, $his mouth working as $he spells out - <<if ($activeSlave.vagina > -1)>> - 'Fucktoy's Favorite Fuckhole.' $He smiles naughtily. "<<Master>>, it sure i<<s>>," + <<if $activeSlave.devotion < -20>>Unfortunately, that positive effect will have to wait until $he's a little less resistant to the idea of being a sex slave.<</if>> + <</if>> + <</if>> + <</if>> + <<if $activeSlave.anusTat != _slaveBeforeSession.anusTat>> + <<if canSee($activeSlave)>> + <<if canTalk($activeSlave)>> + <<if $activeSlave.anus > 3>> + <<set _anus = "anal gape">> + <<elseif $activeSlave.anus == 3>> + <<set _anus = "relaxed asspussy">> + <<elseif $activeSlave.anus == 2>> + <<set _anus = "soft butthole">> <<else>> - 'Sissy Slut's Sodomy Slit.' $He smiles naughtily. "<<Master>>, I love it when you fuck my lewd butt <<s>>lit," + <<set _anus = "tight butthole">> <</if>> - $he giggles. - <<case "sacrilege">> - $He stares, $his mouth working as $he reads the ring of Aramaic blasphemy around $his hole. Getting it, $he smiles naughtily. "<<Master>>, I'm a horrible little butthole <<s>>uccubu<<s>>. Plea<<s>>e, <<Master>>, feed me. I need cum in my a<<ss>> to <<s>>urvive." - <<case "sacrament">> - $He stares, $his mouth working as $he reads the ring of Aramaic around $his hole. Getting it, $he smiles beatifically. "<<Master>>, I alway<<s>> knew butt<<s>>e<<x>> was a <<s>>acrament." - <<case "degradation">> - $He stares, $his mouth working as $he spells out '<<= WrittenMaster($activeSlave)>> Made Me An Anal Slut.' $He smiles naughtily. "Oh <<Master>>, you did," $he <<say>>s gratefully. "And I love you for it." - <<case "counting">> - $He stares, realizing that the markings denote how many times $he's been sodomized. "<<Master>>, thank you, and, and, I hope I'll have to come back in here a lot," $he <<say>>s. "Um, becau<<s>>e I have to have that updated. Because I'm being fucked in the butt a lot," $he adds, wanting to be completely clear. - <<case "bovine patterns">> - $He stares at $his new cow's anus. Finally, $he focuses on the upsides of being permanently transformed like this. "<<Master>>, I hope thi<<s>> mean<<s>> I'll have to be fed up the butt a lot," $he <<say>>s, referencing the milking systems' anal feeders. - <<case "possessive">> - $He stares, realizing that the ring of numbers around $his anus give the date $he was enslaved by you. "Be<<s>t place for that date, <<Master>>," $he <<say>>s. "Being a butt <<s>>lut i<<s>> my life now." - <<case "paternalist">> - $He stares, $his mouth working as $he spells out '<<= WrittenMaster($activeSlave)>> Helped Me Love Anal.' "Oh <<Master>>, you did," $he coos. "You did! Thank you <<s>>o much for helping me become the anal <<s>>lut I wa<<s>> alway<<s>> meant to be!" - <</switch>> - <<elseif $activeSlave.devotion > 50>> - <<switch $activeSlave.anusTat>> - <<case "bleached">> - $He gasps at how closely the crinkled skin around $his anal opening matches the rest of $his $activeSlave.skin body. "Oh, it'<<s>> <<s>>o beautiful! Thank you, <<Master>>, thank you," $he exclaims lovingly. - <<case "flowers" "tribal patterns">> - $He gasps at the beautiful design. "It'<<s>> <<s>>o pretty, <<Master>>," $he <<say>>s. "Thank you. I love you <<s>>o much!" - <<case "advertisements" "rude words" "sacrilege" "sacrament" "degradation" "possessive" "paternalist">> - $He stares, $his mouth working as $he spells out the words tattooed in a ring around $his asshole. "Thank you, <<Master>>," $he <<say>>s devotedly. "I love you and I'll <<s>>erve you with my butthole a<<s>> be<<s>>t I can." - <<default>> - $He smiles, pleased at the mark of your attention to $his body. "Thank you, <<Master>>," $he <<say>>s devotedly. "I love you and I'll <<s>>erve you with my butthole a<<s>> be<<s>>t I can." - <</switch>> - <<elseif $activeSlave.sexualFlaw == "hates anal">> - $He stares, - <<switch $activeSlave.anusTat>> - <<case "bleached">> - horrified, and then shudders convulsively, but can't look away. - <<case "flowers" "tribal patterns">> - torn between fascination at the intricate design and horror at having $his anus permanently tattooed. - <<case "advertisements" "rude words" "sacrilege" "sacrament" "degradation" "possessive" "paternalist">> - $his mouth working as $he spells out the words tattooed in a ring around $his asshole. $He starts to cry as their meaning sinks in. - <<default>> - lower lip quivering. - <</switch>> - $He hates being assraped, and knows that this means there's lots of it in store for $him. "<<Master>>, p-plea<<s>>e," $he moans halfheartedly. "I d-don't like being b-butt f-fucked." - <<elseif $activeSlave.devotion > 20>> - $He stares, - <<switch $activeSlave.anusTat>> - <<case "bleached">> - fascinated. $He doesn't seem sure what to make of this. - <<case "flowers" "tribal patterns">> - torn between admiration of the pretty design and realization that $his anus has been permanently tattooed. - <<case "advertisements" "rude words" "sacrilege" "sacrament" "degradation" "possessive" "paternalist">> - $his mouth working as $he spells out the words tattooed in a ring around $his asshole. $He shudders a little as they sink in and $he internalizes what they say about $him and $his asshole. - <<default>> - realizing that $his anus has been permanently tattooed. It's yet another proof that $he's permanently a sex slave, and $his anus is for fucking. - <</switch>> - "Thank you, <<Master>>," $he <<say>>s, taking refuge in propriety. "Um, d-doe<<s>> thi<<s>> mean I'm going to be more of a, um, b-butt<<s>>lut?" $he asks hesitantly, not sounding very enthusiastic. - <<elseif $activeSlave.trust < -20>> - $He stares, - <<switch $activeSlave.anusTat>> - <<case "bleached">> - trying to process the appearance of what must seem like an unnaturally clean-looking hole. - <<case "flowers" "tribal patterns">> - struggling to process the fact that one of $his most intimate areas has been tattooed. Beautifully tattooed, but still. - <<case "advertisements" "rude words" "sacrilege" "sacrament" "degradation" "possessive" "paternalist">> - $his mouth working as $he spells out the words tattooed in a ring around $his asshole. $He shudders as $he does $his best to conceal $his feelings about such a permanent display of $his status as an anal slave. - <<default>> - looking sad as the meaning of a permanent display of $his status as an anal slave sinks in. - <</switch>> - After a short pause $he remembers $his duties and stammers, "T-thank you, <<Master>>." After a while longer $he turns $his head away, clearly not wanting to dwell on how $his anus is obviously being beautified to attract sexual attention. - <<else>> - <<switch $activeSlave.anusTat>> - <<case "bleached">> - $His face darkens as $he sees $his crinkled fuckhole's clean, fuckable appearance. "Don't you dare fucking a<<ss>>rape me!" $he bursts out. - <<case "flowers" "tribal patterns">> - $He's momentarily surprised by the pretty design, but then $his face darkens. "That'<<s>> permanent!" $he bursts out. "My a<<ss>>hole i<<s>> going to look like that forever!" - <<case "advertisements">> - $He stares, $his mouth working as $he spells out - <<if ($activeSlave.vagina > -1)>> - 'Second Pussy.' $His face darkens. "No it'<<s>> not," $he bursts out. "Anal is dirty." + <<if $activeSlave.anusTat == "bleached">> + $He knew $he was getting $his ass bleached, of course. The stinging sensation was hard to miss. Even so, $he cranes $his neck around as soon as possible to look at $his _anus in the mirror. <<else>> - 'Spit First.' $His face darkens. "Gro<<ss>>," $he bursts out. "Gro<<ss>> and wrong!" + $He knew $he was getting $his asshole tattooed, of course. $He cranes $his neck around as soon as possible to look at $his _anus in the mirror. + <<if $activeSlave.butt > 5>>$His huge buttocks are still held apart by the spreaders used to give the tattooing actuators access to $his most intimate area, giving $him a good view.<</if>> <</if>> - <<case "rude words">> - $He stares, $his mouth working as $he spells out - <<if ($activeSlave.vagina > -1)>> - 'Fucktoy's Favorite Fuckhole.' $His face darkens. "No it'<<s>> not," $he bursts out. "It'<<s>> my a<<ss>>!" + <<if $activeSlave.fetishKnown && $activeSlave.fetish == "buttslut">> + <<switch $activeSlave.anusTat>> + <<case "bleached">> + $He giggles at $his crinkled fuckhole's clean, fuckable appearance, and starts squeezing $his sphincter muscles experimentally. "Thank you, <<Master>>," $he gasps, flushing. + <<case "flowers" "tribal patterns">> + $He gasps at the beautiful design and then suddenly bursts into tears. "T-thank you, <<Master>>," $he blubbers. "I'm <<s>>-<<s>>uch an anal whore." + <<case "advertisements">> + $He stares, $his mouth working as $he spells out + <<if ($activeSlave.vagina > -1)>> + 'Second Pussy.' $He smiles naughtily. "<<Master>>, it'<<s>> my //favorite// pu<<ss>>y," + <<else>> + 'Spit First.' $He smiles naughtily. "<<Master>>, that work<<s>> for me. Lube'<<s>> good too. Or, um, dry'<<s>> fine too," + <</if>> + $he giggles. + <<case "rude words">> + $He stares, $his mouth working as $he spells out + <<if ($activeSlave.vagina > -1)>> + 'Fucktoy's Favorite Fuckhole.' $He smiles naughtily. "<<Master>>, it sure i<<s>>," + <<else>> + 'Sissy Slut's Sodomy Slit.' $He smiles naughtily. "<<Master>>, I love it when you fuck my lewd butt <<s>>lit," + <</if>> + $he giggles. + <<case "sacrilege">> + $He stares, $his mouth working as $he reads the ring of Aramaic blasphemy around $his hole. Getting it, $he smiles naughtily. "<<Master>>, I'm a horrible little butthole <<s>>uccubu<<s>>. Plea<<s>>e, <<Master>>, feed me. I need cum in my a<<ss>> to <<s>>urvive." + <<case "sacrament">> + $He stares, $his mouth working as $he reads the ring of Aramaic around $his hole. Getting it, $he smiles beatifically. "<<Master>>, I alway<<s>> knew butt<<s>>e<<x>> was a <<s>>acrament." + <<case "degradation">> + $He stares, $his mouth working as $he spells out '<<= WrittenMaster($activeSlave)>> Made Me An Anal Slut.' $He smiles naughtily. "Oh <<Master>>, you did," $he <<say>>s gratefully. "And I love you for it." + <<case "counting">> + $He stares, realizing that the markings denote how many times $he's been sodomized. "<<Master>>, thank you, and, and, I hope I'll have to come back in here a lot," $he <<say>>s. "Um, becau<<s>>e I have to have that updated. Because I'm being fucked in the butt a lot," $he adds, wanting to be completely clear. + <<case "bovine patterns">> + $He stares at $his new cow's anus. Finally, $he focuses on the upsides of being permanently transformed like this. "<<Master>>, I hope thi<<s>> mean<<s>> I'll have to be fed up the butt a lot," $he <<say>>s, referencing the milking systems' anal feeders. + <<case "possessive">> + $He stares, realizing that the ring of numbers around $his anus give the date $he was enslaved by you. "Be<<s>t place for that date, <<Master>>," $he <<say>>s. "Being a butt <<s>>lut i<<s>> my life now." + <<case "paternalist">> + $He stares, $his mouth working as $he spells out '<<= WrittenMaster($activeSlave)>> Helped Me Love Anal.' "Oh <<Master>>, you did," $he coos. "You did! Thank you <<s>>o much for helping me become the anal <<s>>lut I wa<<s>> alway<<s>> meant to be!" + <</switch>> + <<elseif $activeSlave.devotion > 50>> + <<switch $activeSlave.anusTat>> + <<case "bleached">> + $He gasps at how closely the crinkled skin around $his anal opening matches the rest of $his $activeSlave.skin body. "Oh, it'<<s>> <<s>>o beautiful! Thank you, <<Master>>, thank you," $he exclaims lovingly. + <<case "flowers" "tribal patterns">> + $He gasps at the beautiful design. "It'<<s>> <<s>>o pretty, <<Master>>," $he <<say>>s. "Thank you. I love you <<s>>o much!" + <<case "advertisements" "rude words" "sacrilege" "sacrament" "degradation" "possessive" "paternalist">> + $He stares, $his mouth working as $he spells out the words tattooed in a ring around $his asshole. "Thank you, <<Master>>," $he <<say>>s devotedly. "I love you and I'll <<s>>erve you with my butthole a<<s>> be<<s>>t I can." + <<default>> + $He smiles, pleased at the mark of your attention to $his body. "Thank you, <<Master>>," $he <<say>>s devotedly. "I love you and I'll <<s>>erve you with my butthole a<<s>> be<<s>>t I can." + <</switch>> + <<elseif $activeSlave.sexualFlaw == "hates anal">> + $He stares, + <<switch $activeSlave.anusTat>> + <<case "bleached">> + horrified, and then shudders convulsively, but can't look away. + <<case "flowers" "tribal patterns">> + torn between fascination at the intricate design and horror at having $his anus permanently tattooed. + <<case "advertisements" "rude words" "sacrilege" "sacrament" "degradation" "possessive" "paternalist">> + $his mouth working as $he spells out the words tattooed in a ring around $his asshole. $He starts to cry as their meaning sinks in. + <<default>> + lower lip quivering. + <</switch>> + $He hates being assraped, and knows that this means there's lots of it in store for $him. "<<Master>>, p-plea<<s>>e," $he moans halfheartedly. "I d-don't like being b-butt f-fucked." + <<elseif $activeSlave.devotion > 20>> + $He stares, + <<switch $activeSlave.anusTat>> + <<case "bleached">> + fascinated. $He doesn't seem sure what to make of this. + <<case "flowers" "tribal patterns">> + torn between admiration of the pretty design and realization that $his anus has been permanently tattooed. + <<case "advertisements" "rude words" "sacrilege" "sacrament" "degradation" "possessive" "paternalist">> + $his mouth working as $he spells out the words tattooed in a ring around $his asshole. $He shudders a little as they sink in and $he internalizes what they say about $him and $his asshole. + <<default>> + realizing that $his anus has been permanently tattooed. It's yet another proof that $he's permanently a sex slave, and $his anus is for fucking. + <</switch>> + "Thank you, <<Master>>," $he <<say>>s, taking refuge in propriety. "Um, d-doe<<s>> thi<<s>> mean I'm going to be more of a, um, b-butt<<s>>lut?" $he asks hesitantly, not sounding very enthusiastic. + <<elseif $activeSlave.trust < -20>> + $He stares, + <<switch $activeSlave.anusTat>> + <<case "bleached">> + trying to process the appearance of what must seem like an unnaturally clean-looking hole. + <<case "flowers" "tribal patterns">> + struggling to process the fact that one of $his most intimate areas has been tattooed. Beautifully tattooed, but still. + <<case "advertisements" "rude words" "sacrilege" "sacrament" "degradation" "possessive" "paternalist">> + $his mouth working as $he spells out the words tattooed in a ring around $his asshole. $He shudders as $he does $his best to conceal $his feelings about such a permanent display of $his status as an anal slave. + <<default>> + looking sad as the meaning of a permanent display of $his status as an anal slave sinks in. + <</switch>> + After a short pause $he remembers $his duties and stammers, "T-thank you, <<Master>>." After a while longer $he turns $his head away, clearly not wanting to dwell on how $his anus is obviously being beautified to attract sexual attention. <<else>> - 'Sissy Slut's Sodomy Slit.' $His face darkens. "No it'<<s>> not," $he bursts out. "I'm not a <<s>>i<<ss>>y! Or a <<s>>lut! And it'<<s>> not a slit!" Those are debatable, but they can all change, of course. + <<switch $activeSlave.anusTat>> + <<case "bleached">> + $His face darkens as $he sees $his crinkled fuckhole's clean, fuckable appearance. "Don't you dare fucking a<<ss>>rape me!" $he bursts out. + <<case "flowers" "tribal patterns">> + $He's momentarily surprised by the pretty design, but then $his face darkens. "That'<<s>> permanent!" $he bursts out. "My a<<ss>>hole i<<s>> going to look like that forever!" + <<case "advertisements">> + $He stares, $his mouth working as $he spells out + <<if ($activeSlave.vagina > -1)>> + 'Second Pussy.' $His face darkens. "No it'<<s>> not," $he bursts out. "Anal is dirty." + <<else>> + 'Spit First.' $His face darkens. "Gro<<ss>>," $he bursts out. "Gro<<ss>> and wrong!" + <</if>> + <<case "rude words">> + $He stares, $his mouth working as $he spells out + <<if ($activeSlave.vagina > -1)>> + 'Fucktoy's Favorite Fuckhole.' $His face darkens. "No it'<<s>> not," $he bursts out. "It'<<s>> my a<<ss>>!" + <<else>> + 'Sissy Slut's Sodomy Slit.' $His face darkens. "No it'<<s>> not," $he bursts out. "I'm not a <<s>>i<<ss>>y! Or a <<s>>lut! And it'<<s>> not a slit!" Those are debatable, but they can all change, of course. + <</if>> + <<case "sacrilege" "sacrament">> + $He stares, $his mouth working as $he reads the ring of Aramaic around $his hole. $He doesn't understand it, but $he's not happy about having stuff permanently inscribed around $his ass. + <<case "degradation">> + $He stares, $his mouth working as $he spells out '<<= WrittenMaster($activeSlave)>> Made Me An Anal Slut.' $His face darkens. "No I'm not," $he bursts out. That remains to be seen. + <<case "counting">> + $He stares, realizing that the markings denote how many times $he's been sodomized. $His face darkens. "I <<s>>ee there'<<s>> room for more," $he bursts out. "Fucking gro<<ss>>." + <<case "bovine patterns">> + $He stares at $his new cow's anus. "Fucking gro<<ss>>," $he bursts out. "I'm not an animal." That remains to be seen. + <<case "possessive">> + $He stares, realizing that the ring of numbers around $his anus give the date $he was enslaved by you. $His face darkens. "Wor<<s>>t day of my life," $he bursts out. + <<case "paternalist">> + $He stares, $his mouth working as $he spells out '<<= WrittenMaster($activeSlave)>> Helped Me Love Anal.' "I don't," $he bursts out. "It'<<s>> fucking gro<<ss>>." + <</switch>> <</if>> - <<case "sacrilege" "sacrament">> - $He stares, $his mouth working as $he reads the ring of Aramaic around $his hole. $He doesn't understand it, but $he's not happy about having stuff permanently inscribed around $his ass. - <<case "degradation">> - $He stares, $his mouth working as $he spells out '<<= WrittenMaster($activeSlave)>> Made Me An Anal Slut.' $His face darkens. "No I'm not," $he bursts out. That remains to be seen. - <<case "counting">> - $He stares, realizing that the markings denote how many times $he's been sodomized. $His face darkens. "I <<s>>ee there'<<s>> room for more," $he bursts out. "Fucking gro<<ss>>." - <<case "bovine patterns">> - $He stares at $his new cow's anus. "Fucking gro<<ss>>," $he bursts out. "I'm not an animal." That remains to be seen. - <<case "possessive">> - $He stares, realizing that the ring of numbers around $his anus give the date $he was enslaved by you. $His face darkens. "Wor<<s>>t day of my life," $he bursts out. - <<case "paternalist">> - $He stares, $his mouth working as $he spells out '<<= WrittenMaster($activeSlave)>> Helped Me Love Anal.' "I don't," $he bursts out. "It'<<s>> fucking gro<<ss>>." - <</switch>> + <</if>> <</if>> <</if>> - <</if>> - <</if>> - <</if>> <</if>> /* 000-250-006 */ diff --git a/src/uncategorized/brothel.tw b/src/uncategorized/brothel.tw index e808b0c15da5e64ea8e5ff9320e9c71bf7314b35..8efe26db319872fe67c36952cc6970bf06b43a92 100644 --- a/src/uncategorized/brothel.tw +++ b/src/uncategorized/brothel.tw @@ -195,7 +195,7 @@ Last week this <<set $lastWeeksCashProfits.brothelAds = $lastWeeksCashIncome.brothelAds + $lastWeeksCashExpenses.brothelAds>> <<if $lastWeeksCashProfits.brothelAds > 0>> made you an extra @@.green;<<print cashFormat($lastWeeksCashProfits.brothelAds)>>@@,<<if $brothelSlaves > 1>> as well as increasing business for your whores.<</if>> -<<elseif $lastWeeksCashProfits.brothelAds < 0>> +<<elseif $lastWeeksCashProfits.brothelAds < 0>> cost you @@.red;<<print cashFormat($lastWeeksCashProfits.brothelAds)>>@@,<<if $brothelSlaves > 1>> but still increased business for your whores.<</if>> <</if>> <<link "Manage brothel advertisements" "Brothel Advertisement">><<set $nextLink = passage(), $nextButton = "Back">><</link>> diff --git a/src/uncategorized/economics.tw b/src/uncategorized/economics.tw index d1180127fd9a5c94b2affe56bc34190cd563f942..da15571c75a1370a4df644a08d97643bcd39fa63 100644 --- a/src/uncategorized/economics.tw +++ b/src/uncategorized/economics.tw @@ -83,56 +83,56 @@ </div> <div id="Management" class="tabcontent"> -<div class="content"> -<<include "Arcology Management">> -</div> + <div class="content"> + <<include "Arcology Management">> + </div> </div> <<if $FSAnnounced > 0>> <div id="Societies" class="tabcontent"> - <div class="content"> - <<include "FS Developments">> - </div> + <div class="content"> + <<include "FS Developments">> + </div> </div> <</if>> <<if $corpIncorporated == 1>> <div id="Corporation" class="tabcontent"> - <div class="content"> - <<include "Corporation Developments">> - </div> + <div class="content"> + <<include "Corporation Developments">> + </div> </div> <</if>> <div id="Authority" class="tabcontent"> -<div class="content"> -<<include "authorityReport">> -</div> + <div class="content"> + <<include "authorityReport">> + </div> </div> <div id="securityReport" class="tabcontent"> -<div class="content"> -<<include "securityReport">> -</div> + <div class="content"> + <<include "securityReport">> + </div> </div> <div id="Reputation" class="tabcontent"> -<div class="content"> -<<include "Reputation">> -</div> + <div class="content"> + <<include "Reputation">> + </div> </div> <div id="Business" class="tabcontent"> -<div class="content"> -<<include "Personal Business">> -</div> + <div class="content"> + <<include "Personal Business">> + </div> </div> <<if ($PC.boobs == 1 && $PC.boobsBonus > 0) || $PC.pregKnown == 1 || $playerAging != 0>> <div id="Personal" class="tabcontent"> - <div class="content"> - <<include "Personal Notes">> - </div> + <div class="content"> + <<include "Personal Notes">> + </div> </div> <</if>> diff --git a/src/uncategorized/fsDevelopments.tw b/src/uncategorized/fsDevelopments.tw index 66267d422cf36fe3b71184b0f41b3d429ade3fc9..5fff75208f2982f729c34aac6aee2061c37e4850 100644 --- a/src/uncategorized/fsDevelopments.tw +++ b/src/uncategorized/fsDevelopments.tw @@ -7,8 +7,8 @@ [6000,9000,12000,15000], [6000,9000,12000,15000,18000], [6000,9000,12000,15000,17000,19000]]>> -<<set _FSRepDescriptors = ["solid","high","remarkable","great","excellent","unparalleled"]>> -<<set _ordinalNames = ["second","third","fourth","fifth","sixth","seventh"]>> +<<set _FSRepDescriptors = ["solid", "high", "remarkable", "great", "excellent", "unparalleled"]>> +<<set _ordinalNames = ["second", "third", "fourth", "fifth", "sixth", "seventh"]>> <<if $FSCredits > 0>> @@.yellow;$arcologies[0].name's society is ready to begin accepting a new societal direction.@@ <</if>> @@ -209,14 +209,14 @@ <<case 7>>Maintaining seven societal goals requires @@.red;extremely unfocused social engineering.@@ <</switch>> <<else>> -<<set _broadProgress += 2 - _societies>> -<<switch _societies>> -<<case 1>>Maintaining a single societal goal allows @@.green;very focused social engineering.@@ -<<case 2>>Maintaining two societal goals allows @@.green;focused social engineering.@@ -<<case 3>>Maintaining three societal goals requires @@.yellow;broad social engineering.@@ -<<case 4>>Maintaining four societal goals requires @@.red;unfocused social engineering.@@ -<<case 5>>Maintaining five societal goals requires @@.red;very unfocused social engineering.@@ -<</switch>> + <<set _broadProgress += 2 - _societies>> + <<switch _societies>> + <<case 1>>Maintaining a single societal goal allows @@.green;very focused social engineering.@@ + <<case 2>>Maintaining two societal goals allows @@.green;focused social engineering.@@ + <<case 3>>Maintaining three societal goals requires @@.yellow;broad social engineering.@@ + <<case 4>>Maintaining four societal goals requires @@.red;unfocused social engineering.@@ + <<case 5>>Maintaining five societal goals requires @@.red;very unfocused social engineering.@@ + <</switch>> <</if>> /*closes FS count changes */ <<if _broadProgress != 0>> <<if $arcologies[0].FSSupremacist != "unset">> diff --git a/src/uncategorized/longSlaveDescription.tw b/src/uncategorized/longSlaveDescription.tw index 0a2fe8f10395dffd0d8df209a0cf17f45d4b6230..35e18d9a3b5898e7cea12ef3313ea1b98da5cb46 100644 --- a/src/uncategorized/longSlaveDescription.tw +++ b/src/uncategorized/longSlaveDescription.tw @@ -1150,7 +1150,7 @@ is <<if $activeSlave.fuckdoll == 0>> <<if $showBodyMods == 1>> - <<if ["neck", "left cheek", "right cheek", "cheeks", "left ears", "right ears", "ears"].includes($activeSlave.brandLocation)>> + <<if ["cheeks", "ears", "left cheek", "left ears", "neck", "right cheek", "right ears"].includes($activeSlave.brandLocation)>> <<brandDescription>> <</if>> <</if>> @@ -1707,19 +1707,19 @@ and <<if $arcologies[0].FSHedonisticDecadence != "unset">> <<print either("perfectly curvy", "perfectly plush")>>. <<else>> - @@.red;<<print either("dangerously overweight", "extremely obese", "dangerously fat")>>.@@ + @@.red;<<print either("dangerously fat", "dangerously overweight", "extremely obese")>>.@@ <</if>> <<elseif $activeSlave.weight > 160 >> <<if $arcologies[0].FSHedonisticDecadence != "unset">> <<print either("spectacularly curvy", "spectacularly plush")>>. <<else>> - @@.red;<<print either("extremely overweight", "very obese", "extremely fat")>>.@@ + @@.red;<<print either("extremely fat", "extremely overweight", "very obese")>>.@@ <</if>> <<elseif $activeSlave.weight > 130 >> <<if $arcologies[0].FSHedonisticDecadence != "unset">> <<print either("amazingly curvy", "amazingly plush")>>. <<else>> - @@.red;<<print either("very overweight", "obese", "very fat")>>.@@ + @@.red;<<print either("obese", "very fat", "very overweight")>>.@@ <</if>> <<elseif $activeSlave.weight > 95>> <<if $activeSlave.hips > 1>> @@ -1727,7 +1727,7 @@ and <<elseif $arcologies[0].FSHedonisticDecadence != "unset">> <<print either("extremely curvy", "extremely plush")>>. <<else>> - @@.red;<<print either("overweight", "carrying a lot of extra weight", "fat")>>.@@ + @@.red;<<print either("carrying a lot of extra weight", "fat", "overweight")>>.@@ <</if>> <<elseif $activeSlave.weight > 30>> <<if $activeSlave.hips > 1>> @@ -1735,7 +1735,7 @@ and <<elseif $arcologies[0].FSHedonisticDecadence != "unset">> <<print either("quite curvy", "very plush")>>. <<else>> - @@.red;<<print either("chubby", "carrying extra weight")>>.@@ + @@.red;<<print either("carrying extra weight", "chubby")>>.@@ <</if>> <<elseif $activeSlave.weight > 10 >><<print either("nicely plush", "pleasingly curvy")>>. <<elseif $activeSlave.weight >= -10>><<print either("a healthy weight", "an attractive weight for $his frame", "neither too fat nor too skinny")>>. @@ -1946,7 +1946,7 @@ $He is <<if $activeSlave.fuckdoll == 0>> <<if $showBodyMods == 1>> /* Check it's not a facial brand: */ - <<if ["back", "lower back", "chest", "right shoulder", "left shoulder", "shoulders", "right upper arm", "left upper arm", "upper arms", "right lower arm", "left lower arm", "lower arms", "right wrist", "left wrist", "wrists", "right hand", "left hand", "hands", "left ankle", "right ankle", "ankles", "right calf", "left calf", "calves", "right foot", "left foot", "feet"].includes($activeSlave.brandLocation)>> + <<if ["ankles", "back", "calves", "chest", "feet", "hands", "left ankle", "left calf", "left foot", "left hand", "left lower arm", "left shoulder", "left upper arm", "left wrist", "lower arms", "lower back", "right ankle", "right calf", "right foot", "right hand", "right lower arm", "right shoulder", "right upper arm", "right wrist", "shoulders", "upper arms", "wrists"].includes($activeSlave.brandLocation)>> <<brandDescription>> <</if>> <</if>> diff --git a/src/uncategorized/main.tw b/src/uncategorized/main.tw index 0f8a78e26df06f187a4299e786f8eda846a4212f..21d38c23b16c03f180ee773de37176b7b906951b 100644 --- a/src/uncategorized/main.tw +++ b/src/uncategorized/main.tw @@ -74,7 +74,7 @@ <</if>> /* Saves use the first eight printed words to make the "file name", the below line cheats and makes saves here nicer named. */ -@@font-size: 0; $arcologies[0].name, Week $week, $slaves.length Slaves, <<print cashFormat($cash)>> … … … @@ +@@font-size: 0; $arcologies[0].name, Week $week, $slaves.length Slaves, <<print cashFormat($cash)>> … … … @@ <<if $newModelUI == 1>><<DisplayBuilding>><</if>> <<if $seeArcology == 1>> <<include "Arcology Description">> | [[Hide|Main][$seeArcology = 0]]<br><</if>> @@ -462,7 +462,7 @@ Filter by assignment: | <<set $slaves.filter(function(x){return x.assignment != ($jobTypes[" + _i + "].asgn)}).map(function(y){y.assignmentVisible = 0})>> <<replace '#summarylist'>><<include 'Slave Summary'>><</replace>> <</link>> - ">> | + ">> | <</if>> <</for>> diff --git a/src/uncategorized/marketsReport.tw b/src/uncategorized/marketsReport.tw index ce4c2582000e923efebf44fcc99916e8fa9afe1c..5706634f77f1b63902d47f39cdd5369e471fb3cb 100644 --- a/src/uncategorized/marketsReport.tw +++ b/src/uncategorized/marketsReport.tw @@ -2,8 +2,8 @@ //FC Markets Report:// -<<set _assetAffected = either("general", "slaves", "entrapment", "capture", "training", "surgical", "drugs")>> -<<set _assetDirection = either("up", "down")>> +<<set _assetAffected = either("capture", "drugs", "entrapment", "general", "slaves", "surgical", "training")>> +<<set _assetDirection = either("down", "up")>> <<if _assetAffected == "general">> <<if _assetDirection == "up">> diff --git a/src/uncategorized/motherDaughterWorkaround.tw b/src/uncategorized/motherDaughterWorkaround.tw index 7b4655921d5de53f891e7ed9a3e8ab31ca057c95..e21e5f7e5b37ce00554ae068c13b8fad73d4e0b9 100644 --- a/src/uncategorized/motherDaughterWorkaround.tw +++ b/src/uncategorized/motherDaughterWorkaround.tw @@ -46,12 +46,12 @@ Your new pair of slaves look frightened and uncertain, but seem encouraged by ea <<set _secondSlave.attrXY = Math.clamp(_secondSlave.attrXY, 0, 100)>> <<set _secondSlave.energy += random(-20,20)>> <<set _secondSlave.fetishStrength = random(0,90)>> -<<set _secondSlave.fetish = either("none", "none", "none", "none", "none", "none", "submissive", "cumslut", "humiliation", "buttslut", "pregnancy", "sadist", "dom", "masochist")>> -<<set _secondSlave.behavioralFlaw = either("none", "none", "none", "arrogant", "bitchy", "odd", "hates men", "hates women", "hates women", "anorexic", "masochist", "gluttonous", "devout", "liberated")>> +<<set _secondSlave.fetish = either("buttslut", "cumslut", "dom", "humiliation", "masochist", "none", "none", "none", "none", "none", "none", "pregnancy", "sadist", "submissive")>> +<<set _secondSlave.behavioralFlaw = either("anorexic", "arrogant", "bitchy", "devout", "gluttonous", "hates men", "hates women", "hates women", "liberated", "masochist", "none", "none", "none", "odd")>> <<if (_secondSlave.behavioralFlaw == "devout")>> - <<set _secondSlave.sexualFlaw = either("none", "repressed", "shamefast", "apathetic")>> + <<set _secondSlave.sexualFlaw = either("apathetic", "none", "repressed", "shamefast")>> <<else>> - <<set _secondSlave.sexualFlaw = either("none", "none", "none", "none", "hates oral", "hates anal", "hates penetration", "repressed", "idealistic", "shamefast", "apathetic", "crude", "judgemental")>> + <<set _secondSlave.sexualFlaw = either("apathetic", "crude", "hates anal", "hates oral", "hates penetration", "idealistic", "judgemental", "none", "none", "none", "none", "repressed", "shamefast")>> <</if>> <<if $familyTesting == 1>> diff --git a/src/uncategorized/newSlaveIntro.tw b/src/uncategorized/newSlaveIntro.tw index 2b931074b7dfe62c9fbe7d6dc9058e3f81ee0ef9..05373db71919ebb3254df969ed2cffee92a0e549 100644 --- a/src/uncategorized/newSlaveIntro.tw +++ b/src/uncategorized/newSlaveIntro.tw @@ -992,7 +992,7 @@ The legalities completed, ''__@@.pink;<<= SlaveFullName($activeSlave)>>@@__'' << <<if $activeSlave.stampTat == 0>> <br> <<link "Give $him a lewd tramp stamp">> - <<set $activeSlave.stampTat = either("advertisements", "rude words", "degradation")>> + <<set $activeSlave.stampTat = either("advertisements", "degradation", "rude words")>> <<replace "#introResult">> You <<if $activeSlave.devotion > 20>>bring $him down to the studio, lay the compliant<<else>>drag $him down to the studio, strap the reluctant<</if>> slave in the chair face-down, and select a sufficiently lewd pattern to decorate $his lower back. When the automated tattooing is done, a topical application of analgesics leaves $him with nothing more than a slight ache there. When allowed to stand, $he immediately turns $his back to one of the studio's full length mirrors and cranes around to read the writing just over $his butt. It's difficult, since of course it's reversed, and $he mouths the words letter by letter. <<if $activeSlave.stampTat == "advertisements">> @@ -1259,7 +1259,7 @@ The legalities completed, ''__@@.pink;<<= SlaveFullName($activeSlave)>>@@__'' << <</if>> <</if>> <br><br> - Whenever you feel able, you drain your balls into $his <<if $activeSlave.mpreg == 1>>ass<<else>>cunt<</if>>, only releasing $him for other duties when scans verify a fertilized ovum. + Whenever you feel able, you drain your balls into $his <<if $activeSlave.mpreg == 1>>ass<<else>>cunt<</if>>, only releasing $him for other duties when scans verify a fertilized ovum. <<if $activeSlave.intelligence+$activeSlave.intelligenceImplant < -50>> $He didn't properly understand the scans, so $he just thought it was bound, forced sex; $he won't realize what happened for some weeks at least. <<elseif $activeSlave.fetish == "pregnancy">> @@ -1267,8 +1267,8 @@ The legalities completed, ''__@@.pink;<<= SlaveFullName($activeSlave)>>@@__'' << <<else>> $He wasn't sure what this was all about, but $he has $his suspicions. <</if>> - - + + <<if $activeSlave.mpreg == 1>> <<= AnalVCheck()>> <<else>> diff --git a/src/uncategorized/pRivalryCapture.tw b/src/uncategorized/pRivalryCapture.tw index 26b8b8331c5467bb2cc2fc622b18f9a94e855318..c2441845e91239dc5863c87f973d5d85f0208ae2 100644 --- a/src/uncategorized/pRivalryCapture.tw +++ b/src/uncategorized/pRivalryCapture.tw @@ -258,7 +258,7 @@ <<set $activeSlave.pregAdaptation = $activeSlave.birthsTotal*2>> <<else>> <<set $activeSlave.vagina = 5>> - <<set $activeSlave.pregType = either(3,3,4,4,4,5,5,6,6,7,7,8,8,8)>> + <<set $activeSlave.pregType = either(3, 3, 4, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 8)>> <<set $activeSlave.birthsTotal = random(18,27)>> <<set $activeSlave.bellySag = 2, $activeSlave.bellySagPreg = 2>> <<set $activeSlave.pregAdaptation = random(60,100)>> diff --git a/src/uncategorized/prestigiousSlave.tw b/src/uncategorized/prestigiousSlave.tw index 1af9266b843e4c6ee00f94d709827b4a43a99006..53450b58a32afb905469e274835054a6d6fd921e 100644 --- a/src/uncategorized/prestigiousSlave.tw +++ b/src/uncategorized/prestigiousSlave.tw @@ -52,7 +52,7 @@ You check to see if any especially prestigious slaves are on auction. <<if $pres <<set $activeSlave.career = "a porn star">> <<set $activeSlave.boobsImplant += random(4,6)*200>> <<set $activeSlave.boobs += $activeSlave.boobsImplant>> - <<set $activeSlave.nipples = either("cute", "puffy", "huge")>> + <<set $activeSlave.nipples = either("cute", "huge", "puffy")>> <<set $activeSlave.areolae = 1>> <<set $activeSlave.butt += 1>> <<set $activeSlave.buttImplant += 1>> diff --git a/src/uncategorized/previousSlaveInLine.tw b/src/uncategorized/previousSlaveInLine.tw index 9df0c2e9e303b8e340eb038d4c7434cfabc3a56d..dea877bde169068827c36517f22bb87d253b7f0b 100644 --- a/src/uncategorized/previousSlaveInLine.tw +++ b/src/uncategorized/previousSlaveInLine.tw @@ -11,4 +11,3 @@ <<goto "Slave Interact">> <</silently>> - diff --git a/src/uncategorized/reFSAcquisition.tw b/src/uncategorized/reFSAcquisition.tw index 3369a3ad59e8709663dfe91b905e8c8eb257c97e..96c6ea4c59a5d8720562e7a8e980b887fba07aec 100644 --- a/src/uncategorized/reFSAcquisition.tw +++ b/src/uncategorized/reFSAcquisition.tw @@ -1321,7 +1321,7 @@ The call comes in from an office, and you suppress the urge to check whether $as <br><br> -<<include "Long Slave Description">> +<<set $saleDescription = 0>><<include "Long Slave Description">> <br><br> diff --git a/src/uncategorized/reFSNonconformist.tw b/src/uncategorized/reFSNonconformist.tw index ba64b75122696aeb2f884e06cb937e2cf159677f..4cf088fa276be94a3c09e2e94f585de2bfb5cfe9 100644 --- a/src/uncategorized/reFSNonconformist.tw +++ b/src/uncategorized/reFSNonconformist.tw @@ -274,7 +274,7 @@ The nonconformist is far too prominent and prosperous to make this an easy dilem <</nobr>><</replace>> <</link>> //This will cost <<print cashFormat(10000)>>// <<else>> -//You lack the necessary ready cash to manage a nuanced solution// + //You lack the necessary ready cash to manage a nuanced solution// <</if>> <<if $PC.rumor == "force">> <br><<link "Leverage your reputation with some credible threats">> diff --git a/src/uncategorized/rePokerNight.tw b/src/uncategorized/rePokerNight.tw index feaa75f287641943d961cbbc72ca207f92ab8881..585549e2be43b89c2cdab2e035aa72de5cca46ba 100644 --- a/src/uncategorized/rePokerNight.tw +++ b/src/uncategorized/rePokerNight.tw @@ -103,13 +103,13 @@ On a particularly lackadaisical evening, you find yourself alerted to a message <<link "A year of servitude">> <<replace "#aliveresult">> <<if random(1,100) > 50>> - For all your skillful maneuvering to reach this position, ultimately the win comes down to chance. This time, however, luck was not on your side. As the victor sweeps up $his spoils, the other mercenaries clap you on the back and offer their condolences for your defeat. Though you may have lost your ¤, it seems you've @@.green;made some friends.@@ - <<set $rep += 1000>> - <<run cashX(-5000, "event")>> + For all your skillful maneuvering to reach this position, ultimately the win comes down to chance. This time, however, luck was not on your side. As the victor sweeps up $his spoils, the other mercenaries clap you on the back and offer their condolences for your defeat. Though you may have lost your ¤, it seems you've @@.green;made some friends.@@ + <<set $rep += 1000>> + <<run cashX(-5000, "event")>> <<else>> - For all your skillful maneuvering to reach this position, ultimately the win comes down to chance. This time, however, luck has rendered you the victor. A silence falls over the room as the result is declared, but after some time your opponent breaks the hush by joking that life as your slave is probably easier than fighting for $arcologies[0].name. After some awkward laughter the night continues, and at the end your former mercenary joins you on your trip back to the penthouse to submit to processing and to begin $his new life as your sexual servant. $He's not young, but $he's tough and not distrusting of you due to $his service in the $mercenariesTitle. - <br> - <<include "New Slave Intro">> + For all your skillful maneuvering to reach this position, ultimately the win comes down to chance. This time, however, luck has rendered you the victor. A silence falls over the room as the result is declared, but after some time your opponent breaks the hush by joking that life as your slave is probably easier than fighting for $arcologies[0].name. After some awkward laughter the night continues, and at the end your former mercenary joins you on your trip back to the penthouse to submit to processing and to begin $his new life as your sexual servant. $He's not young, but $he's tough and not distrusting of you due to $his service in the $mercenariesTitle. + <br> + <<include "New Slave Intro">> <</if>> <</replace>> <</link>> @@ -119,13 +119,13 @@ On a particularly lackadaisical evening, you find yourself alerted to a message <<link "Dock $his wages">> <<replace "#aliveresult">> <<if random(1,100) > 50>> - For all your skillful maneuvering to reach this position, ultimately the win comes down to chance. This time, however, luck was not on your side. As the victor sweeps up $his spoils, the other mercenaries clap you on the back and offer their condolences for your defeat. Though you may have lost your ¤, it seems you've @@.green;made some friends.@@ - <<set $rep += 1000>> - <<run cashX(-5000, "event")>> + For all your skillful maneuvering to reach this position, ultimately the win comes down to chance. This time, however, luck was not on your side. As the victor sweeps up $his spoils, the other mercenaries clap you on the back and offer their condolences for your defeat. Though you may have lost your ¤, it seems you've @@.green;made some friends.@@ + <<set $rep += 1000>> + <<run cashX(-5000, "event")>> <<else>> - For all your skillful maneuvering to reach this position, ultimately the win comes down to chance. This time, however, luck has rendered you the victor. Your opponent accepts $his defeat with grace and jokes to $his comrades that $he'll be fighting in $his underwear for the next few months, and their uproar of laughter fills the room. Though you take the lion's share of the ¤, your mercenaries also @@.green;had a good time fraternizing with you.@@ - <<set $rep += 200>> - <<run cashX(5000, "event")>> + For all your skillful maneuvering to reach this position, ultimately the win comes down to chance. This time, however, luck has rendered you the victor. Your opponent accepts $his defeat with grace and jokes to $his comrades that $he'll be fighting in $his underwear for the next few months, and their uproar of laughter fills the room. Though you take the lion's share of the ¤, your mercenaries also @@.green;had a good time fraternizing with you.@@ + <<set $rep += 200>> + <<run cashX(5000, "event")>> <</if>> <</replace>> <</link>> diff --git a/src/uncategorized/reRecruit.tw b/src/uncategorized/reRecruit.tw index 8c5b0829ade6b80e5cdfbefe205e6d1fa862c432..aab01f727b1a7e80971a32b6ae440907a0cce8c3 100644 --- a/src/uncategorized/reRecruit.tw +++ b/src/uncategorized/reRecruit.tw @@ -2203,7 +2203,7 @@ After the fighting died down, they found a dickgirl inside the compound, harshly A report about a successful operation by your mercenaries waits at your desk when you come in the office this morning. Turns out they tracked a brutal gang that was waylaying travelers near the Free City and stormed their hideout last night. All of the criminals were killed in the process, preventing proper punishments or more... creative uses for them. From the videos of the raid and the fanatic way the men fought to the last man, it seems that this was unavoidable, so you send a quick note of approval to their commander. <br><br> -After the fighting died down, they found a woman inside the compound, harshly used and seemingly the center of many gang-bangs there. A scan of $his biometric data revealed that $he is in fact a slave that ran away about two months ago — into a much worse situation after being caught by the gang, as it turns out. Countless dicks have stretched $his pussy and ass wide, $he<<if $activeSlave.physicalAge >= $activeSlave.pubertyAge>> is pregnant with some dead criminal's offspring,<</if>> has been crudely gelded, and they've decorated $him with numerous piercings. As you notify the owner that her property has been retrieved, the woman is distraught at the state of her merchandise, grumbling that a once quite valuable $girl is now worth almost nothing. Seems she's unwilling to invest her time and money in caring for the slave. With a sigh, the slave-mistress whips out her smart-phone and starts to set up a selling offer in one of the popular slave trading apps. +After the fighting died down, they found a $woman inside the compound, harshly used and seemingly the center of many gangbangs there. A scan of $his biometric data revealed that $he is in fact a slave that ran away about two months ago — into a much worse situation after being caught by the gang, as it turns out. Countless dicks have stretched $his pussy and ass wide, <<if $activeSlave.physicalAge >= $activeSlave.pubertyAge>> $he is pregnant with some dead criminal's offspring,<</if>> $he has been crudely gelded, and they've decorated $him with numerous piercings. As you notify the owner that her property has been retrieved, the woman is distraught at the state of her merchandise, grumbling that a once quite valuable $girl is now worth almost nothing. Seems she's unwilling to invest her time and money in caring for the slave. With a sigh, the slave-mistress whips out her smart-phone and starts to set up a selling offer in one of the popular slave trading apps. <br><br> //The young dickgirl has been used and abused quite a bit, making $him deathly terrified about what might happen to $him next. $He has partially resigned to be nothing but a fuckhole. You can get $him cheap from the owner, it'll be just <<print cashFormat(1000)>>.// @@ -2211,9 +2211,9 @@ After the fighting died down, they found a woman inside the compound, harshly us A report about a successful operation by your mercenaries waits at your desk when you come in the office this morning. Turns out they tracked a brutal gang that was waylaying travelers near the Free City and stormed their hideout last night. All of the criminals were killed in the process, preventing proper punishments or more... creative uses for them. From the videos of the raid and the fanatic way the men fought to the last man, it seems that this was unavoidable, so you send a quick note of approval to their commander. <br><br> -After the fighting died down, your men found a woman inside the compound, harshly used and seemingly the center of many gang-bangs there. A scan of $his biometric data revealed that $he is in fact a slave that ran away about two months ago — into a much worse situation after being caught by the gang, as it turns out. Countless dicks have stretched $his pussy and ass wide,<<if $activeSlave.physicalAge >= $activeSlave.pubertyAge>> $he is pregnant with some dead criminal bastard's offspring and<</if>> they've decorated $him with numerous piercings. As you notify the owner that her property has been retrieved, the woman is distraught at the state of her merchandise, grumbling that a once quite valuable $girl is now worth almost nothing. Seems she's unwilling to invest her time and money in caring for the slave. With a sigh, the slave-mistress whips out her smart-phone and starts to set up a selling offer in one of the popular slave trading apps. +After the fighting died down, your men found a $woman inside the compound, harshly used and seemingly the center of many gangbangs there. A scan of $his biometric data revealed that $he is in fact a slave that ran away about two months ago — into a much worse situation after being caught by the gang, as it turns out. Countless dicks have stretched $his pussy and ass wide,<<if $activeSlave.physicalAge >= $activeSlave.pubertyAge>> $he is pregnant with some dead criminal bastard's offspring,<</if>> and they've decorated $him with numerous piercings. As you notify the owner that her property has been retrieved, the woman is distraught at the state of her merchandise, grumbling that a once quite valuable $girl is now worth almost nothing. Seems she's unwilling to invest her time and money in caring for the slave. With a sigh, the slave-mistress whips out her smart-phone and starts to set up a selling offer in one of the popular slave trading apps. <br><br> -//The young woman has been used and abused quite a bit, making $him deathly terrified about what might happen to $him next. $He has partially resigned to be nothing but a fuckhole. You can get $him cheap from the owner, it'll be just <<print cashFormat(1000)>>.// +//The young $woman has been used and abused quite a bit, making $him deathly terrified about what might happen to $him next. $He has partially resigned to be nothing but a fuckhole. You can get $him cheap from the owner, it'll be just <<print cashFormat(1000)>>.// <<case "CCS angel">> diff --git a/src/uncategorized/remoteSurgery.tw b/src/uncategorized/remoteSurgery.tw index 5293968c479c9d5a005fa774274ea1e8ece72f4b..8d6764819ecf3831494a85b152997e95d8448e56 100644 --- a/src/uncategorized/remoteSurgery.tw +++ b/src/uncategorized/remoteSurgery.tw @@ -155,9 +155,8 @@ $His $activeSlave.faceShape face is <</if>> <</if>> -<</if>> - <br> - $He has +<br> +$He has <<if $activeSlave.earShape == "normal">> normal shaped ears. [[Elongate ears|Surgery Degradation][$activeSlave.earShape = "elfin", cashX(forceNeg($surgeryCost), "slaveSurgery"), $activeSlave.health -= 10, $surgeryType = "earShape"]] diff --git a/src/uncategorized/reputation.tw b/src/uncategorized/reputation.tw index b5a7031558e34ce1dd51006c57dcb7ccf777b65c..6f3547dfcb96b59f272445474bb3ea6008bf0154 100644 --- a/src/uncategorized/reputation.tw +++ b/src/uncategorized/reputation.tw @@ -572,8 +572,13 @@ On formal occasions, you are announced as $PCTitle. Society @@.green;approves@@ of your poor treatment of slave infants. <<set $rep += 5*$FSSingleSlaveRep*($arcologies[0].FSDegradationist/$FSLockinLevel)>> <<elseif $arcologies[0].FSRestart != "unset">> - The Societal Elite @@.red;strongly disapproves@@ of your creating an economic incentive for the lower classes to breed and sell infants, holding back acceptance of your new society. - <<set $failedElite += 5, $arcologies[0].FSRestart -= $FSSingleSlaveRep, $rep -= (5*$FSSingleSlaveRep*($arcologies[0].FSRestart/$FSLockinLevel))+($rep/40)>> + <<if $eugenicsFullControl != 1>> + The Societal Elite @@.red;strongly disapproves@@ of your creating an economic incentive for the lower classes to breed and sell infants, holding back acceptance of your new society. + <<set $failedElite += 5>> + <<else>> + Society @@.red;strongly disapproves@@ of your creating an economic incentive for the lower classes to breed and sell infants, holding back acceptance of your new society. + <</if>> + <<set $arcologies[0].FSRestart -= $FSSingleSlaveRep, $rep -= (5*$FSSingleSlaveRep*($arcologies[0].FSRestart/$FSLockinLevel))+($rep/40)>> <<elseif $arcologies[0].FSPaternalist != "unset">> Society @@.red;greatly despises@@ your poor treatment of slave infants. <<set $rep -= (25*$FSSingleSlaveRep*($arcologies[0].FSPaternalist/$FSLockinLevel))+($rep/20)>> @@ -727,19 +732,19 @@ On formal occasions, you are announced as $PCTitle. <</if>> <<if $alwaysSubsidizeRep == 1>> -<<if $rep <= 19900>> - <<set $rep += 100>> - Reputation subsidized as planned. - <<if $PC.degeneracy > 1>> + <<if $rep <= 19900>> + <<set $rep += 100>> + Reputation subsidized as planned. + <<if $PC.degeneracy > 1>> + <<set $PC.degeneracy -= 1>> + <</if>> + <<elseif $PC.degeneracy > 1>> <<set $PC.degeneracy -= 1>> + Rumors quelled as planned. + <<else>> + <<run cashX(1000, "policies")>> + Reputation subsidy reclaimed this week since your reputation is capped. <</if>> -<<elseif $PC.degeneracy > 1>> - <<set $PC.degeneracy -= 1>> - Rumors quelled as planned. -<<else>> - <<run cashX(1000, "policies")>> - Reputation subsidy reclaimed this week since your reputation is capped. -<</if>> <</if>> <<if $failedElite > 1>> @@ -778,7 +783,7 @@ On formal occasions, you are announced as $PCTitle. <<set $eliteFail = $topClass - 20>> <</if>> <<if $arcologies[0].prosperity > 50>> - <<set $arcologies[0].prosperity -= random(20,40)>> + <<set $arcologies[0].prosperity -= random(20,40)>> <</if>> <<elseif $failedElite > 250>> The Societal Elite @@.red;are openly discussing leaving.@@ It would be in your best interests to appease them. diff --git a/src/uncategorized/saLongTermEffects.tw b/src/uncategorized/saLongTermEffects.tw index 94a4171a2d06d2bf2beb068620844bb482067b22..b0ea34c0242432ff62cbc22054628299dd41f8ce 100644 --- a/src/uncategorized/saLongTermEffects.tw +++ b/src/uncategorized/saLongTermEffects.tw @@ -3060,12 +3060,26 @@ During $his weekly monitoring, it is discovered that $his womb is now home to @@.orange;less ova than last checkup.@@ <<if $slaves[$i].pregType == 0>> For all intent and purposes, @@.yellow;$he is no longer pregnant.@@ - <<set WombFlush($slaves[$i]), $slaves[$i].pregKnown = 0, $slaves[$i].pregWeek = 0>> + <<set WombFlush($slaves[$i]), $slaves[$i].pregKnown = 0>> + <<if $slaves[$i].geneticQuirks.fertility+$slaves[$i].geneticQuirks.hyperFertility >= 4>> + <<set $slaves[$i].pregWeek = -2>> + <<elseif $slaves[$i].geneticQuirks.hyperFertility > 1>> + <<set $slaves[$i].pregWeek = -3>> + <<else>> + <<set $slaves[$i].pregWeek = -4>> + <</if>> <<run SetBellySize($slaves[$i])>> <</if>> <</if>> <<elseif _oldCount > $slaves[$i].pregType && $slaves[$i].pregType == 0>> - <<set WombFlush($slaves[$i]), $slaves[$i].pregKnown = 0, $slaves[$i].pregWeek = 0>> + <<set WombFlush($slaves[$i]), $slaves[$i].pregKnown = 0>> + <<if $slaves[$i].geneticQuirks.fertility+$slaves[$i].geneticQuirks.hyperFertility >= 4>> + <<set $slaves[$i].pregWeek = -2>> + <<elseif $slaves[$i].geneticQuirks.hyperFertility > 1>> + <<set $slaves[$i].pregWeek = -3>> + <<else>> + <<set $slaves[$i].pregWeek = -4>> + <</if>> <<run SetBellySize($slaves[$i])>> <</if>> diff --git a/src/uncategorized/saServeThePublic.tw b/src/uncategorized/saServeThePublic.tw index eb16a3971393317f8bc70bf98d23af1fda924d95..d2b349bcbc3a0d80b5972602e796928bcb5d68d9 100644 --- a/src/uncategorized/saServeThePublic.tw +++ b/src/uncategorized/saServeThePublic.tw @@ -867,7 +867,7 @@ $His appearance attracted $beauty members of the public (<<print Math.trunc($bea <</if>> <</if>> <<case "mindbroken">> - $He receives less attention because $he just lies there, mindbroken. + $He receives less attention because $he just lies there, totally unresponsive. <</switch>> <</if>> diff --git a/src/uncategorized/saWhore.tw b/src/uncategorized/saWhore.tw index d92d42876653c20c02ac8a79c7955cf09da912c9..449a586a851977476656a6d22f48b0e8b6b2eec0 100644 --- a/src/uncategorized/saWhore.tw +++ b/src/uncategorized/saWhore.tw @@ -878,7 +878,7 @@ $His appearance attracted $beauty customers (<<print Math.trunc($beauty/7)>> a d <</if>> <</if>> <<case "mindbroken">> - $He gets less ¤ because $he just lies there, mindbroken. + $He gets less ¤ because $he just lies there, totally unresponsive. <</switch>> <</if>> <</if>> diff --git a/src/uncategorized/seNonlethalPit.tw b/src/uncategorized/seNonlethalPit.tw index a1917f985ea06e70a8a13a10d8c41824f4ba4d74..9e88d0f42e40e59ba87b129b510996a67107fde3 100644 --- a/src/uncategorized/seNonlethalPit.tw +++ b/src/uncategorized/seNonlethalPit.tw @@ -1008,7 +1008,7 @@ <<if $pitBG == 0 || ($Bodyguard.ID != _loser.ID)>> <<set $fighterIDs.push(_loser.ID)>> <</if>> -<<else>> /*if an animal is using the slave*/ +<<else>> /*if an animal is using the slave*/ <<set $activeSlave = _fighterOne>> <<if canDoVaginal($activeSlave)>> diff --git a/src/uncategorized/seWedding.tw b/src/uncategorized/seWedding.tw index df25345e6c89c5f06c7e305b822d58b6921c32de..a52b1f0ec802511f87e08101d3afbcbd04627244 100644 --- a/src/uncategorized/seWedding.tw +++ b/src/uncategorized/seWedding.tw @@ -1,6 +1,6 @@ :: SE wedding [nobr] -<<set $nextButton = "Continue", $nextLink = "AS Dump", $returnTo = "Scheduled Event">> +<<set $nextButton = "Continue", $nextLink = "Scheduled Event">> <<set _ML = $marrying.length>> <<if _ML == 1>> diff --git a/src/uncategorized/seWeddingDouble.tw b/src/uncategorized/seWeddingDouble.tw index 05c9adf6511e2c34ded63fa3c0af0fa5dc4e7ee7..b72f1d7f6f3a4de7c62a4ea5cff71f75976904c8 100644 --- a/src/uncategorized/seWeddingDouble.tw +++ b/src/uncategorized/seWeddingDouble.tw @@ -914,14 +914,24 @@ There is no ring for you, since this marriage does not bind you. <br> - <<if $PC.surname && _slave1.slaveSurname != $PC.surname>> + <<if $PC.surname && (_slave1.slaveSurname != $PC.surname && _slave2.surname != $PC.surname)>> <br><br><span id="surnaming"> <<link "Give them both your surname too">> <<replace "#surnaming">> - <<set _slave1.slaveSurname = $PC.surname, _slave2.slaveSurname = $PC.surname>> - You also proclaim your new slave wives _slave1.slaveName and _slave2.slaveName $PC.surname. - The new Mrs. <<print $PC.surname>>s hear this, of course, and - <<if (_slave1.fetish == "mindbroken" && _slave2.fetish == "mindbroken") || (_slave1.devotion+_slave1.trust >= 175 && _slave2.devotion+_slave2.trust >= 175) || ((_slave1.devotion < -20 && _slave1.trust > 20) && (_slave2.devotion < -20 && _slave2.trust > 20)) || (_slave1.devotion < -20 && _slave2.devotion < -20) || (_slave1.devotion >= -20 && _slave1.devotion >= -20)>> + <<set _c = 0>> + You also proclaim + <<if _slave1.surname != $PC.surname && _slave2.surname != $PC.surname>> + your new slave wives _slave1.slaveName and _slave2.slaveName $PC.surname. + <<set _c += 2>> + <<elseif _slave1.surname != $PC.surname>> + _slave1.slaveName Mrs. _slave1.slaveName $PC.surname. + <<set _c += 1>> + <<elseif _slave2.surname != $PC.surname>> + _slave2.slaveName Mrs. _slave2.slaveName $PC.surname. + <<set _c += 1>> + <</if>> + The new Mrs. <<print $PC.surname>><<if _c > 1>>s<</if>> hear<<if _c == 1>>s<</if>> this, of course, and + <<if (_slave1.surname != $PC.surname && _slave2.surname != $PC.surname) && ((_slave1.fetish == "mindbroken" && _slave2.fetish == "mindbroken") || (_slave1.devotion+_slave1.trust >= 175 && _slave2.devotion+_slave2.trust >= 175) || ((_slave1.devotion < -20 && _slave1.trust > 20) && (_slave2.devotion < -20 && _slave2.trust > 20)) || (_slave1.devotion < -20 && _slave2.devotion < -20) || (_slave1.devotion >= -20 && _slave1.devotion >= -20))>> <<if _slave1.fetish == "mindbroken">> show no reaction. Like many things, names mean nothing to them now. Your guests, on the other hand, appreciate the gift. <<elseif _slave1.devotion+_slave1.trust >= 175>> @@ -934,30 +944,37 @@ nod acceptingly. Your will is their will, after all. <</if>> <<else>> - <<if _slave2.fetish == "mindbroken">> - _slave1.slaveName shows no reaction. Like many things, names mean nothing to _him2 now. Your guests, on the other hand, appreciate the gift. - <<elseif _slave2.devotion+_slave2.trust >= 175>> - _slave1.slaveName breaks down again. Not only is _he2 to be blessed with your child, but _he2's to take your surname as well. - <<elseif _slave2.devotion < -20 && _slave2.trust > 20>> - _slave1.slaveName scoffs audibly. Just another burden for _him2 to carry; like the child soon to be growing in _his2 womb. - <<elseif _slave2.devotion < -20>> - _slave1.slaveName breaks down again. Not only are you binding _him2 to you with your child, but with your name as well. - <<else>> - _slave1.slaveName nods acceptingly. Your will is _his2 will, after all. + <<if _c > 1 && _slave1.surname != $PC.surname>> + <<if _slave1.fetish == "mindbroken">> + <<if _c < 1>>_slave1.slaveName <</if>>shows no reaction. Like many things, names mean nothing to $him now. Your guests, on the other hand, appreciate the gift. + <<elseif _slave1.devotion+_slave1.trust >= 175>> + <<if _c < 1>>_slave1.slaveName <</if>>breaks down again. Not only is $he to be blessed with your child, but _he2's to take your surname as well. + <<elseif _slave1.devotion < -20 && _slave1.trust > 20>> + <<if _c < 1>>_slave1.slaveName <</if>>scoffs audibly. Just another burden for $him to carry; like the child soon to be growing in _his2 womb. + <<elseif _slave1.devotion < -20>> + <<if _c < 1>>_slave1.slaveName <</if>>breaks down again. Not only are you binding $him to you with your child, but with your name as well. + <<else>> + <<if _c < 1>>_slave1.slaveName <</if>>nods acceptingly. Your will is $his will, after all. + <</if>> <</if>> - _slave2.slaveName, meanwhile, - <<if _slave2.fetish == "mindbroken">> - shows no reaction. Like many things, names mean nothing to _him2 now. Your guests, on the other hand, appreciate the gift. - <<elseif _slave2.devotion+_slave2.trust >= 175>> - breaks down again. Not only is _he2 to be blessed with your child, but _he2's to take your surname as well. - <<elseif _slave2.devotion < -20 && _slave2.trust > 20>> - scoffs audibly. Just another burden for _him2 to carry; like the child soon to be growing in _his2 womb. - <<elseif _slave2.devotion < -20>> - breaks down again. Not only are you binding _him2 to you with your child, but with your name as well. - <<else>> - nods acceptingly. Your will is _his2 will, after all. + <<if _c > 1 && _slave2.surname != $PC.surname>> + _slave2.slaveName, meanwhile, + <</if>> + <<if _slave2.surname != $PC.surname>> + <<if _slave2.fetish == "mindbroken">> + shows no reaction. Like many things, names mean nothing to _him2 now. Your guests, on the other hand, appreciate the gift. + <<elseif _slave2.devotion+_slave2.trust >= 175>> + breaks down again. Not only is _he2 to be blessed with your child, but _he2's to take your surname as well. + <<elseif _slave2.devotion < -20 && _slave2.trust > 20>> + scoffs audibly. Just another burden for _him2 to carry; like the child soon to be growing in _his2 womb. + <<elseif _slave2.devotion < -20>> + breaks down again. Not only are you binding _him2 to you with your child, but with your name as well. + <<else>> + nods acceptingly. Your will is _his2 will, after all. + <</if>> <</if>> <</if>> + <<set _slave1.slaveSurname = $PC.surname, _slave2.slaveSurname = $PC.surname>> <</replace>> <</link>> </span> @@ -1519,50 +1536,67 @@ <</if>> <</if>> <br> - <<if $PC.surname && _slave1.slaveSurname != $PC.surname>> + <<if $PC.surname && (_slave1.slaveSurname != $PC.surname && _slave2.surname != $PC.surname)>> <br><br><span id="surnaming"> <<link "Give them both your surname too">> <<replace "#surnaming">> - <<set _slave1.slaveSurname = $PC.surname, _slave2.slaveSurname = $PC.surname>> - You also proclaim your new slave wives _slave1.slaveName and _slave2.slaveName $PC.surname. - The new Mrs. <<print $PC.surname>>s hear this, of course, and - <<if (_slave1.fetish == "mindbroken" && _slave2.fetish == "mindbroken") || (_slave1.devotion+_slave1.trust >= 175 && _slave2.devotion+_slave2.trust >= 175) || ((_slave1.devotion < -20 && _slave1.trust > 20) && (_slave2.devotion < -20 && _slave2.trust > 20)) || (_slave1.devotion < -20 && _slave2.devotion < -20)>> + <<set _c = 0>> + You also proclaim + <<if _slave1.surname != $PC.surname && _slave2.surname != $PC.surname>> + your new slave wives _slave1.slaveName and _slave2.slaveName $PC.surname. + <<set _c += 2>> + <<elseif _slave1.surname != $PC.surname>> + _slave1.slaveName Mrs. _slave1.slaveName $PC.surname. + <<set _c += 1>> + <<elseif _slave2.surname != $PC.surname>> + _slave2.slaveName Mrs. _slave2.slaveName $PC.surname. + <<set _c += 1>> + <</if>> + The new Mrs. <<print $PC.surname>><<if _c > 1>>s<</if>> hear<<if _c == 1>>s<</if>> this, of course, and + <<if (_slave1.surname != $PC.surname && _slave2.surname != $PC.surname) && ((_slave1.fetish == "mindbroken" && _slave2.fetish == "mindbroken") || (_slave1.devotion+_slave1.trust >= 175 && _slave2.devotion+_slave2.trust >= 175) || ((_slave1.devotion < -20 && _slave1.trust > 20) && (_slave2.devotion < -20 && _slave2.trust > 20)) || (_slave1.devotion < -20 && _slave2.devotion < -20) || (_slave1.devotion >= -20 && _slave1.devotion >= -20))>> <<if _slave1.fetish == "mindbroken">> show no reaction. Like many things, names mean nothing to them now. Your guests, on the other hand, appreciate the gift. <<elseif _slave1.devotion+_slave1.trust >= 175>> - break down again. Not only are they to be blessed with your children, but they're to take your surname as well. + break down again; it's like a dream come true. <<elseif _slave1.devotion < -20 && _slave1.trust > 20>> - scoff audibly. Just another burden for them to carry; like the child soon to be growing in their wombs. + scoff audibly; just another burden for them to carry. <<elseif _slave1.devotion < -20>> - break down again. Not only are you binding them to you with your children, but with your name as well. + break down again; this is nothing more than another unwanted link to you. <<else>> nod acceptingly. Your will is their will, after all. <</if>> <<else>> - <<if _slave2.fetish == "mindbroken">> - _slave1.slaveName shows no reaction. Like many things, names mean nothing to _him2 now. Your guests, on the other hand, appreciate the gift. - <<elseif _slave2.devotion+_slave2.trust >= 175>> - _slave1.slaveName breaks down again. Not only is _he2 to be blessed with your child, but _he2's to take your surname as well. - <<elseif _slave2.devotion < -20 && _slave2.trust > 20>> - _slave1.slaveName scoffs audibly. Just another burden for _him2 to carry; like the child soon to be growing in _his2 womb. - <<elseif _slave2.devotion < -20>> - _slave1.slaveName breaks down again. Not only are you binding _him2 to you with your child, but with your name as well. - <<else>> - _slave1.slaveName nods acceptingly. Your will is _his2 will, after all. + <<if _c > 1 && _slave1.surname != $PC.surname>> + <<if _slave1.fetish == "mindbroken">> + <<if _c < 1>>_slave1.slaveName <</if>>shows no reaction. Like many things, names mean nothing to $him now. Your guests, on the other hand, appreciate the gift. + <<elseif _slave1.devotion+_slave1.trust >= 175>> + <<if _c < 1>>_slave1.slaveName <</if>>breaks down again; it's like a dream come true. + <<elseif _slave1.devotion < -20 && _slave1.trust > 20>> + <<if _c < 1>>_slave1.slaveName <</if>>scoffs audibly; just another burden for $him to carry. + <<elseif _slave1.devotion < -20>> + <<if _c < 1>>_slave1.slaveName <</if>>breaks down again; this is nothing more than another unwanted link to you. + <<else>> + <<if _c < 1>>_slave1.slaveName <</if>>nods acceptingly. Your will is $his will, after all. + <</if>> <</if>> - _slave2.slaveName, meanwhile, - <<if _slave2.fetish == "mindbroken">> - shows no reaction. Like many things, names mean nothing to _him2 now. Your guests, on the other hand, appreciate the gift. - <<elseif _slave2.devotion+_slave2.trust >= 175>> - breaks down again. Not only is _he2 to be blessed with your child, but _he2's to take your surname as well. - <<elseif _slave2.devotion < -20 && _slave2.trust > 20>> - scoffs audibly. Just another burden for _him2 to carry; like the child soon to be growing in _his2 womb. - <<elseif _slave2.devotion < -20>> - breaks down again. Not only are you binding _him2 to you with your child, but with your name as well. - <<else>> - nods acceptingly. Your will is _his2 will, after all. + <<if _c > 1 && _slave2.surname != $PC.surname>> + _slave2.slaveName, meanwhile, + <</if>> + <<if _slave2.surname != $PC.surname>> + <<if _slave2.fetish == "mindbroken">> + shows no reaction. Like many things, names mean nothing to _him2 now. Your guests, on the other hand, appreciate the gift. + <<elseif _slave2.devotion+_slave2.trust >= 175>> + breaks down again; it's like a dream come true. + <<elseif _slave2.devotion < -20 && _slave2.trust > 20>> + scoffs audibly; just another burden for _him2 to carry. + <<elseif _slave2.devotion < -20>> + breaks down again; this is nothing more than another unwanted link to you. + <<else>> + nods acceptingly. Your will is _his2 will, after all. + <</if>> <</if>> <</if>> + <<set _slave1.slaveSurname = $PC.surname, _slave2.slaveSurname = $PC.surname>> <</replace>> <</link>> </span> @@ -2165,50 +2199,67 @@ /* good luck trying to read this line */ When they are in front of you, <<if (_slave1.amp == 1) && (_slave2.amp == 1)>>the slaves carrying their limbless torsos sets them down on the floor in front of you and props them up so their heads are level with your crotch<<else>>they gets down on their knees so their heads are level with your crotch<</if>>. <<if $assistantName == "your personal assistant">>Your personal assistant<<else>>$assistantName<</if>> reads the short recitation for them, and you place a simple steel ring <<if (_slave1.amp == 1 && _slave2.amp == 1)>>on a cord around both of their necks, since they lack fingers to wear it on.<<elseif (_slave1.devotion >= -20 && _slave1.trust > 20) && (_slave2.devotion >= -20 && _slave2.trust > 20)>>on both of their middle fingers.<<elseif (_slave1.devotion < -20 && _slave1.trust <= 20) && (_slave1.devotion < -20 && _slave1.trust <= 20)>>on both of their trembling middle fingers.<<else>><<if _slave1.amp == 1>>on a cord around _slave1.slaveName's neck, since $he lacks fingers to wear it on<<else>>on _slave1.slaveName's <<if _slave1.devotion < -20 && _slave1.trust <= 20>>trembling <</if>>finger<</if>>and another ring<<if _slave2.amp == 1>>on a cord around _slave2.slaveName's neck, since $he lacks fingers to wear it on.<<else>>on _slave2.slaveName's <<if _slave2.devotion < -20 && _slave2.trust <= 20>>trembling <</if>>finger.<</if>><</if>> There is no ring for you, since this marriage does not bind you. <br> - <<if $PC.surname && ((_slave1.slaveSurname != $PC.surname) || (_slave2.slaveSurname != $PC.surname))>> + <<if $PC.surname && (_slave1.slaveSurname != $PC.surname && _slave2.surname != $PC.surname)>> <br><br><span id="surnaming"> <<link "Give them both your surname too">> <<replace "#surnaming">> - <<set _slave1.slaveSurname = $PC.surname, _slave2.slaveSurname = $PC.surname>> - You also proclaim your new slave wives _slave1.slaveName and _slave2.slaveName $PC.surname. - The new Mrs. <<print $PC.surname>>s hear this, of course, and - <<if (_slave1.fetish == "mindbroken" && _slave2.fetish == "mindbroken") || (_slave1.devotion+_slave1.trust >= 175 && _slave2.devotion+_slave2.trust >= 175) || ((_slave1.devotion < -20 && _slave1.trust > 20) && (_slave2.devotion < -20 && _slave2.trust > 20)) || (_slave1.devotion < -20 && _slave2.devotion < -20)>> + <<set _c = 0>> + You also proclaim + <<if _slave1.surname != $PC.surname && _slave2.surname != $PC.surname>> + your new slave wives _slave1.slaveName and _slave2.slaveName $PC.surname. + <<set _c += 2>> + <<elseif _slave1.surname != $PC.surname>> + _slave1.slaveName Mrs. _slave1.slaveName $PC.surname. + <<set _c += 1>> + <<elseif _slave2.surname != $PC.surname>> + _slave2.slaveName Mrs. _slave2.slaveName $PC.surname. + <<set _c += 1>> + <</if>> + The new Mrs. <<print $PC.surname>><<if _c > 1>>s<</if>> hear<<if _c == 1>>s<</if>> this, of course, and + <<if (_slave1.surname != $PC.surname && _slave2.surname != $PC.surname) && ((_slave1.fetish == "mindbroken" && _slave2.fetish == "mindbroken") || (_slave1.devotion+_slave1.trust >= 175 && _slave2.devotion+_slave2.trust >= 175) || ((_slave1.devotion < -20 && _slave1.trust > 20) && (_slave2.devotion < -20 && _slave2.trust > 20)) || (_slave1.devotion < -20 && _slave2.devotion < -20) || (_slave1.devotion >= -20 && _slave1.devotion >= -20))>> <<if _slave1.fetish == "mindbroken">> show no reaction. Like many things, names mean nothing to them now. Your guests, on the other hand, appreciate the gift. <<elseif _slave1.devotion+_slave1.trust >= 175>> - break down again. Not only are they to be blessed with your children, but they're to take your surname as well. + break down again; it's like a dream come true. <<elseif _slave1.devotion < -20 && _slave1.trust > 20>> - scoff audibly. Just another burden for them to carry; like the child soon to be growing in their wombs. + scoff audibly; just another burden for them to carry. <<elseif _slave1.devotion < -20>> - break down again. Not only are you binding them to you with your children, but with your name as well. + break down again; this is nothing more than another unwanted link to you. <<else>> nod acceptingly. Your will is their will, after all. <</if>> <<else>> - <<if _slave2.fetish == "mindbroken">> - _slave1.slaveName shows no reaction. Like many things, names mean nothing to _him2 now. Your guests, on the other hand, appreciate the gift. - <<elseif _slave2.devotion+_slave2.trust >= 175>> - _slave1.slaveName breaks down again. Not only is _he2 to be blessed with your child, but _he2's to take your surname as well. - <<elseif _slave2.devotion < -20 && _slave2.trust > 20>> - _slave1.slaveName scoffs audibly. Just another burden for _him2 to carry; like the child soon to be growing in _his2 womb. - <<elseif _slave2.devotion < -20>> - _slave1.slaveName breaks down again. Not only are you binding _him2 to you with your child, but with your name as well. - <<else>> - _slave1.slaveName nods acceptingly. Your will is _his2 will, after all. + <<if _c > 1 && _slave1.surname != $PC.surname>> + <<if _slave1.fetish == "mindbroken">> + <<if _c < 1>>_slave1.slaveName <</if>>shows no reaction. Like many things, names mean nothing to $him now. Your guests, on the other hand, appreciate the gift. + <<elseif _slave1.devotion+_slave1.trust >= 175>> + <<if _c < 1>>_slave1.slaveName <</if>>breaks down again.; it's like a dream come true. + <<elseif _slave1.devotion < -20 && _slave1.trust > 20>> + <<if _c < 1>>_slave1.slaveName <</if>>scoffs audibly.; just another burden for $him to carry. + <<elseif _slave1.devotion < -20>> + <<if _c < 1>>_slave1.slaveName <</if>>breaks down again.; this is nothing more than another unwanted link to you. + <<else>> + <<if _c < 1>>_slave1.slaveName <</if>>nods acceptingly. Your will is $his will, after all. + <</if>> <</if>> - _slave2.slaveName, meanwhile, - <<if _slave2.fetish == "mindbroken">> - shows no reaction. Like many things, names mean nothing to _him2 now. Your guests, on the other hand, appreciate the gift. - <<elseif _slave2.devotion+_slave2.trust >= 175>> - breaks down again. Not only is _he2 to be blessed with your child, but _he2's to take your surname as well. - <<elseif _slave2.devotion < -20 && _slave2.trust > 20>> - scoffs audibly. Just another burden for _him2 to carry; like the child soon to be growing in _his2 womb. - <<elseif _slave2.devotion < -20>> - breaks down again. Not only are you binding _him2 to you with your child, but with your name as well. - <<else>> - nods acceptingly. Your will is _his2 will, after all. + <<if _c > 1 && _slave2.surname != $PC.surname>> + _slave2.slaveName, meanwhile, + <</if>> + <<if _slave2.surname != $PC.surname>> + <<if _slave2.fetish == "mindbroken">> + shows no reaction. Like many things, names mean nothing to _him2 now. Your guests, on the other hand, appreciate the gift. + <<elseif _slave2.devotion+_slave2.trust >= 175>> + breaks down again; it's like a dream come true. + <<elseif _slave2.devotion < -20 && _slave2.trust > 20>> + scoffs audibly; just another burden for _him2 to carry. + <<elseif _slave2.devotion < -20>> + breaks down again; this is nothing more than another unwanted link to you. + <<else>> + nods acceptingly. Your will is _his2 will, after all. + <</if>> <</if>> <</if>> + <<set _slave1.slaveSurname = $PC.surname, _slave2.slaveSurname = $PC.surname>> <</replace>> <</link>> </span> diff --git a/src/uncategorized/shops.tw b/src/uncategorized/shops.tw index dada283f36dc8a2d80196792fce1e2ac6f1f4064..f37b51480fdad7907267a75f5364299c5ae1461f 100644 --- a/src/uncategorized/shops.tw +++ b/src/uncategorized/shops.tw @@ -37,7 +37,7 @@ This is a section of the promenade dedicated to Maturity Preferentialism. It's not immediately apparent, though the stores here offer fashions that are obviously designed to flatter mature women, and anti-aging products of all kinds are prominently displayed. What there are, though, are quite a number of pretty, scantily clad female citizens here, obviously retired from sexual slavery and looking to slake their still trained libidos with any handsome fellow citizen interested. <span id="result"><<link "Hook up with a MILF">><<replace "#result">>Many of them recognize you, and it's immediately apparent that you have your choice of pretty much every retired slave present. You select the prettiest and make out with her for a while, among many admirers, until you feel like bringing her over to a nearby bench and doing her. <<if $PC.dick == 0>>She's as eager as a teenager to have a lesbian experience in public, and can't stop giggling as you fuck.<<elseif $arcologies[0].FSGenderFundamentalist != "unset">>Like many recently retired slaves in your arcology, she's gotten pregnant as a free woman, and it's supercharged her sex drive. No matter what you do to her, she just wants more.<<elseif $arcologies[0].FSGenderRadicalist != "unset">>She's got a big dick, and clearly has close friends among the other recently retired girls, but is very willing to be your bottom, especially in public.<<else>>She was horny to begin with, but the foreplay and the naughtiness of doing it out in public has her as eager as a teenager, and she goes wild.<</if>><</replace>><</link>></span> <<case "Slimness Enthusiast">> - dedicated to Slimness Enthusiasm. The shops here are quite varied. Some, like the tailors, only betray their focus on slim slaves by their selections of lingerie for petite breasts and trim hips. There are a large number of contract slave exercisers and slave dieticians, since many citizens who can afford a slave need assistance there. + dedicated to Slimness Enthusiasm. The shops here are quite varied. Some, like the tailors, only betray their focus on slim slaves by their selections of lingerie for petite breasts and trim hips. There are a large number of contract slave exercisers and slave dietitians, since many citizens who can afford a slave need assistance there. <span id="result"><<link "Tour the trainers">><<replace "#result">>You decide to put in an appearance and look around the trainers. They're very eager to show you around, of course, and have you seen looking around; your expertise in keeping slaves slender is well known. The most inspiring sight you're shown is a long row of slaves on treadmills, running as fast as their individual fitness can support. They do this nude, since none of them have boobs big enough to require support, offering the sight of a long row of cute butts covered in a sheen of feminine sweat.<</replace>><</link>></span> <<case "Asset Expansionist">> dedicated to Asset Expansionism. The sector's focus is unmissable, even in the clothes stores. Many of the bras on offer look like a cross between an engineering marvel and a bad joke, and there are dresses that look like parachutes when they aren't on a mannequin or worn by a slave salesgirl. Then there's the crane store. diff --git a/src/uncategorized/siblingsWorkaround.tw b/src/uncategorized/siblingsWorkaround.tw index ef5763064efd05dc778f4a36d1677305b8153b11..3c3035f7774b971cc72bfcb0294a4861695a657b 100644 --- a/src/uncategorized/siblingsWorkaround.tw +++ b/src/uncategorized/siblingsWorkaround.tw @@ -39,17 +39,17 @@ Your new pair of slaves look frightened and uncertain, but seem encouraged by ea <<set _secondSlave.attrXY = Math.clamp(_secondSlave.attrXY, 0, 100)>> <<set _secondSlave.energy += random(-20,20)>> <<set _secondSlave.fetishStrength = random(0,90)>> -<<set _secondSlave.fetish = either("none", "none", "none", "none", "none", "none", "submissive", "cumslut", "humiliation", "buttslut", "pregnancy", "sadist", "dom", "masochist")>> -<<set _secondSlave.behavioralFlaw = either("none", "none", "none", "arrogant", "bitchy", "odd", "hates men", "hates women", "hates women", "anorexic", "masochist", "gluttonous", "devout", "liberated")>> +<<set _secondSlave.fetish = either("buttslut", "cumslut", "dom", "humiliation", "masochist", "none", "none", "none", "none", "none", "none", "pregnancy", "sadist", "submissive")>> +<<set _secondSlave.behavioralFlaw = either("anorexic", "arrogant", "bitchy", "devout", "gluttonous", "hates men", "hates women", "hates women", "liberated", "masochist", "none", "none", "none", "odd")>> <<if (_secondSlave.behavioralFlaw == "devout")>> - <<set _secondSlave.sexualFlaw = either("none", "repressed", "shamefast", "apathetic")>> + <<set _secondSlave.sexualFlaw = either("apathetic", "none", "repressed", "shamefast")>> <<else>> - <<set _secondSlave.sexualFlaw = either("none", "none", "none", "none", "hates oral", "hates anal", "hates penetration", "repressed", "idealistic", "shamefast", "apathetic", "crude", "judgemental")>> + <<set _secondSlave.sexualFlaw = either("apathetic", "crude", "hates anal", "hates oral", "hates penetration", "idealistic", "judgemental", "none", "none", "none", "none", "repressed", "shamefast")>> <</if>> <<if $familyTesting == 0>> -<<set _secondSlave.relation = "sister">> -<<set _secondSlave.relationTarget = _secondSlave.ID - 1000>> + <<set _secondSlave.relation = "sister">> + <<set _secondSlave.relationTarget = _secondSlave.ID - 1000>> <</if>> <<if _secondSlave.actualAge < $minimumSlaveAge>> diff --git a/src/uncategorized/slaveInteract.tw b/src/uncategorized/slaveInteract.tw index 075b559b56dfe4c9e0a7d381db74e4ca92e695eb..90b8a50dec72e2622d41f04e6b5055202168e86b 100644 --- a/src/uncategorized/slaveInteract.tw +++ b/src/uncategorized/slaveInteract.tw @@ -37,7 +37,7 @@ <</switch>> <</if>> -<<set $encyclopedia = either("Drugs and Their Effects", "From Rebellious to Devoted", "Costs Summary", "Disease in the Free Cities", "Slave Couture", "Nymphomania", "Gender", "Independent Slaves", "Modern Anal")>> +<<set $encyclopedia = either("Costs Summary", "Disease in the Free Cities", "Drugs and Their Effects", "From Rebellious to Devoted", "Gender", "Independent Slaves", "Modern Anal", "Nymphomania", "Slave Couture")>> <<if $activeSlave.dick > 0>><<set $showEncyclopedia = 1, $encyclopedia = "Gender">><</if>> <<set _CL = $canines.length, _HL = $hooved.length, _FL = $felines.length>> @@ -1116,7 +1116,7 @@ | Breasts <</if>> <<if $arcologies[0].FSAssetExpansionistResearch == 1>> - <<if ($activeSlave.boobs < 25000)>> + <<if ($activeSlave.boobs < 48000)>> | <<link "Hyper-Breasts">><<set $activeSlave.drugs = "hyper breast injections">><<SlaveInteractDrugs>><</link>> <<else>> | Hyper Breasts diff --git a/src/uncategorized/slaveShelter.tw b/src/uncategorized/slaveShelter.tw index 2f9568493bdd777f3781435ee2b73e79b12b4197..3e5cea4d830878115fc77d26a4f81fc554a4f04a 100644 --- a/src/uncategorized/slaveShelter.tw +++ b/src/uncategorized/slaveShelter.tw @@ -34,7 +34,6 @@ You contact the Slave Shelter to review the profile of the slave the Shelter is <<set _possibleOrigins.push("degraded DoL")>> <</if>> - <<set _origin = _possibleOrigins.random()>> <<switch _origin>> @@ -192,7 +191,7 @@ You contact the Slave Shelter to review the profile of the slave the Shelter is <<set $shelterSlave.weight = random(-90,-30)>> <<set $shelterSlave.muscles = random(-75,0)>> <<set $shelterSlave.energy = random(0,30)>> - <<set $shelterSlave.fetish = either("none", "none", "submissive", "masochist", "humiliation", "humiliation")>> + <<set $shelterSlave.fetish = either("humiliation", "humiliation", "masochist", "none", "none", "submissive")>> <<set $shelterSlave.boobsTat = either("degradation", "rude words", "none")>> <<set $shelterSlave.buttTat = either("degradation", "rude words", 0)>> <<set $shelterSlave.lipsTat = either("degradation", "rude words", 0)>> @@ -214,7 +213,7 @@ You contact the Slave Shelter to review the profile of the slave the Shelter is <</if>> <<if $shelterSlave.vagina > -1>> <<set $shelterSlave.vagina = random(1,4)>> - <<set $shelterSlave.vaginaSkill = random(10,25)>> + <<set $shelterSlave.vaginalSkill = random(10,25)>> <<set $shelterSlave.vaginalTat = either("degradation", "rude words", 0)>> <</if>> <<if $shelterSlave.dick > 1>> @@ -370,6 +369,8 @@ You contact the Slave Shelter to review the profile of the slave the Shelter is <</if>> <<set $slaveCost = 1000>> +<<setLocalPronouns $shelterSlave>> + The placement fee is <<print cashFormat($slaveCost)>>. <br><br> diff --git a/src/uncategorized/slaveSold.tw b/src/uncategorized/slaveSold.tw index 24eab6835a248de1af41699156886d9c61ec25b7..e55052e5383f2fcd77eb24e4e81ec41041e8f7af 100644 --- a/src/uncategorized/slaveSold.tw +++ b/src/uncategorized/slaveSold.tw @@ -6,184 +6,184 @@ <<set $display = 0>> <<if !["abortion TV", "elite auction", "eugenics arcology", "organ crafter", "peacekeepers", "repopulationist arcology", "tentacle bred", "womb filler"].includes($buyer) && ((($activeSlave.actualAge < $retirementAge-1) && $PhysicalRetirementAgePolicy != 1) || (($activeSlave.physicalAge < $retirementAge-1) && $PhysicalRetirementAgePolicy == 1))>> /* organ crafter is not viable now, the elite won't part so easily with a prize, some take place x months later when the event's max is 15 weeks, and the rest are snuff events. You don't want that slave back. */ -<<if !$boomerangSlave || $boomerangWeeks > 15>> - <<if $activeSlave.fuckdoll == 0>> - <<if canWalk($activeSlave)>> - <<if canTalk($activeSlave)>> - <<if $activeSlave.fetish != "mindbroken">> - <<if $activeSlave.devotion > 50>> - <<if $activeSlave.trust > 95 || $activeSlave.trust < -20 || ($activeSlave.intelligence+$activeSlave.intelligenceImplant < -15)>> - <<set $boomerangSlave = clone($activeSlave), $boomerangWeeks = 1, $boomerangBuyer = $buyer>> - <<set $boomerangSlave.assignment = "rest">> - <<set $boomerangStats = {PCpregSource: 0, PCmother: 0, PCfather: 0, boomerangMother: [], boomerangFather: [], boomerangPregSources: [], boomerangMotherTank: [], boomerangFatherTank: [], boomerangRelationship: 0, boomerangRivalry: 0, boomerangRelation: 0, boomerangBody: 0}>> - <<if $familyTesting == 1>> - <<if $activeSlave.ID == $PC.pregSource>> - <<set $boomerangStats.PCpregSource = $activeSlave.ID>> - <</if>> - <<if $PC.mother == $activeSlave.ID>> - <<set $boomerangStats.PCmother = $activeSlave.ID>> - <</if>> - <<if $PC.father == $activeSlave.ID>> - <<set $boomerangStats.PCfather = $activeSlave.ID>> - <</if>> - <<for _ss = 0; _ss < $slaves.length; _ss++>> - <<if $slaves[_ss].ID != $activeSlave.ID>> - <<if $slaves[_ss].mother == $activeSlave.ID>> - <<set $boomerangStats.boomerangMother.push($slaves[_ss].ID)>> - <</if>> - <<if $slaves[_ss].father == $activeSlave.ID>> - <<set $boomerangStats.boomerangFather.push($slaves[_ss].ID)>> - <</if>> - <<if $activeSlave.ID == $slaves[_ss].pregSource>> - <<set $boomerangStats.boomerangPregSources.push($slaves[_ss].ID)>> + <<if !$boomerangSlave || $boomerangWeeks > 15>> + <<if $activeSlave.fuckdoll == 0>> + <<if canWalk($activeSlave)>> + <<if canTalk($activeSlave)>> + <<if $activeSlave.fetish != "mindbroken">> + <<if $activeSlave.devotion > 50>> + <<if $activeSlave.trust > 95 || $activeSlave.trust < -20 || ($activeSlave.intelligence+$activeSlave.intelligenceImplant < -15)>> + <<set $boomerangSlave = clone($activeSlave), $boomerangWeeks = 1, $boomerangBuyer = $buyer>> + <<set $boomerangSlave.assignment = "rest">> + <<set $boomerangStats = {PCpregSource: 0, PCmother: 0, PCfather: 0, boomerangMother: [], boomerangFather: [], boomerangPregSources: [], boomerangMotherTank: [], boomerangFatherTank: [], boomerangRelationship: 0, boomerangRivalry: 0, boomerangRelation: 0, boomerangBody: 0}>> + <<if $familyTesting == 1>> + <<if $activeSlave.ID == $PC.pregSource>> + <<set $boomerangStats.PCpregSource = $activeSlave.ID>> + <</if>> + <<if $PC.mother == $activeSlave.ID>> + <<set $boomerangStats.PCmother = $activeSlave.ID>> + <</if>> + <<if $PC.father == $activeSlave.ID>> + <<set $boomerangStats.PCfather = $activeSlave.ID>> + <</if>> + <<for _ss = 0; _ss < $slaves.length; _ss++>> + <<if $slaves[_ss].ID != $activeSlave.ID>> + <<if $slaves[_ss].mother == $activeSlave.ID>> + <<set $boomerangStats.boomerangMother.push($slaves[_ss].ID)>> + <</if>> + <<if $slaves[_ss].father == $activeSlave.ID>> + <<set $boomerangStats.boomerangFather.push($slaves[_ss].ID)>> + <</if>> + <<if $activeSlave.ID == $slaves[_ss].pregSource>> + <<set $boomerangStats.boomerangPregSources.push($slaves[_ss].ID)>> + <</if>> + <</if>> + <</for>> + <<if $incubator > 0>> + <<for _z = 0; _z < $tanks.length; _z++>> + <<if $activeSlave.ID == $tanks[_z].mother>> + <<set $boomerangStats.boomerangMotherTank.push($slaves[_z].ID)>> + <</if>> + <<if $activeSlave.ID == $tanks[_z].father>> + <<set $boomerangStats.boomerangFatherTank.push($slaves[_z].ID)>> + <</if>> + <</for>> + <</if>> + <<if $nursery > 0>> + <<for _z = 0; _z < $cribs.length; _z++>> + <<if $activeSlave.ID == $cribs[_z].mother>> + <<set $boomerangStats.boomerangMotherTank.push($slaves[_z].ID)>> + <</if>> + <<if $activeSlave.ID == $cribs[_z].father>> + <<set $boomerangStats.boomerangFatherTank.push($slaves[_z].ID)>> + <</if>> + <</for>> + <</if>> + <<set $boomerangSlave.sisters = 0, $boomerangSlave.daughters = 0>> + <<else>> + <<if $activeSlave.relation != 0>> + <<set $boomerangStats.boomerangRelation = $activeSlave.relationTarget>> + <</if>> + <<for _ss = 0; _ss < $slaves.length; _ss++>> + <<if $slaves[_ss].ID != $activeSlave.ID>> + <<if $activeSlave.ID == $slaves[_ss].pregSource>> + <<set $boomerangStats.boomerangPregSources.push($slaves[_ss].ID)>> + <</if>> + <</if>> + <</for>> + <</if>> + <<if $activeSlave.relationship > 0>> + <<set $boomerangStats.boomerangRelationship = $activeSlave.relationshipTarget>> + <</if>> + <<if $activeSlave.rivalry > 0>> + <<set $boomerangStats.boomerangRivalry = $activeSlave.rivalryTarget>> + <</if>> + <<if $activeSlave.bodySwap > 0>> + <<set _myBody = $slaves.findIndex(function(s) { return s.origBodyOwnerID == $activeSlave.ID; })>> + <<if _myBody != -1>> + <<set $boomerangStats.boomerangBody = $slaves[_myBody].ID>> + <</if>> + <</if>> + <</if>> <</if>> <</if>> - <</for>> - <<if $incubator > 0>> - <<for _z = 0; _z < $tanks.length; _z++>> - <<if $activeSlave.ID == $tanks[_z].mother>> - <<set $boomerangStats.boomerangMotherTank.push($slaves[_z].ID)>> - <</if>> - <<if $activeSlave.ID == $tanks[_z].father>> - <<set $boomerangStats.boomerangFatherTank.push($slaves[_z].ID)>> - <</if>> - <</for>> - <</if>> - <<if $nursery > 0>> - <<for _z = 0; _z < $cribs.length; _z++>> - <<if $activeSlave.ID == $cribs[_z].mother>> - <<set $boomerangStats.boomerangMotherTank.push($slaves[_z].ID)>> - <</if>> - <<if $activeSlave.ID == $cribs[_z].father>> - <<set $boomerangStats.boomerangFatherTank.push($slaves[_z].ID)>> - <</if>> - <</for>> - <</if>> - <<set $boomerangSlave.sisters = 0, $boomerangSlave.daughters = 0>> - <<else>> - <<if $activeSlave.relation != 0>> - <<set $boomerangStats.boomerangRelation = $activeSlave.relationTarget>> - <</if>> - <<for _ss = 0; _ss < $slaves.length; _ss++>> - <<if $slaves[_ss].ID != $activeSlave.ID>> - <<if $activeSlave.ID == $slaves[_ss].pregSource>> - <<set $boomerangStats.boomerangPregSources.push($slaves[_ss].ID)>> - <</if>> - <</if>> - <</for>> - <</if>> - <<if $activeSlave.relationship > 0>> - <<set $boomerangStats.boomerangRelationship = $activeSlave.relationshipTarget>> - <</if>> - <<if $activeSlave.rivalry > 0>> - <<set $boomerangStats.boomerangRivalry = $activeSlave.rivalryTarget>> - <</if>> - <<if $activeSlave.bodySwap > 0>> - <<set _myBody = $slaves.findIndex(function(s) { return s.origBodyOwnerID == $activeSlave.ID; })>> - <<if _myBody != -1>> - <<set $boomerangStats.boomerangBody = $slaves[_myBody].ID>> <</if>> <</if>> <</if>> <</if>> - <</if>> - <</if>> - <</if>> - <</if>> -<</if>> <</if>> - <<if $familyTesting == 1>> - <<for _ss = 0; _ss < $slaves.length; _ss++>> - <<setLocalPronouns $slaves[_ss] 2>> - <<if $activeSlave.mother == $slaves[_ss].ID>> - $slaves[_ss].slaveName is @@.mediumorchid;grieved@@ that you are selling _his2 daughter. - <<run clearSummaryCache($slaves[_ss])>> - <br><br> - <<set $slaves[_ss].devotion -= 20>> - <</if>> - <<if $activeSlave.father == $slaves[_ss].ID>> - $slaves[_ss].slaveName is @@.mediumorchid;disappointed@@ that you are selling _his2 daughter. - <<run clearSummaryCache($slaves[_ss])>> - <br><br> - <<set $slaves[_ss].devotion -= 10>> - <</if>> - <<if $activeSlave.ID == $slaves[_ss].father>> - $slaves[_ss].slaveName is @@.mediumorchid;saddened@@ that you are selling _his2 father. - <<run clearSummaryCache($slaves[_ss])>> - <br><br> - <<set $slaves[_ss].devotion -= 10>> - <</if>> - <<if $activeSlave.ID == $slaves[_ss].mother>> - $slaves[_ss].slaveName is @@.mediumorchid;grieved@@ that you are selling _his2 mother. - <<run clearSummaryCache($slaves[_ss])>> - <br><br> - <<set $slaves[_ss].devotion -= 20>> - <</if>> - <<switch areSisters($activeSlave, $slaves[_ss])>> - <<case 1>> - $slaves[_ss].slaveName is @@.mediumorchid;devastated@@ that you are selling _his2 twin. - <<run clearSummaryCache($slaves[_ss])>> - <br><br> - <<set $slaves[_ss].devotion -= 30>> - <<case 2>> - $slaves[_ss].slaveName is @@.mediumorchid;grieved@@ that you are selling _his2 sister. - <<run clearSummaryCache($slaves[_ss])>> - <br><br> - <<set $slaves[_ss].devotion -= 20>> - <<case 3>> - $slaves[_ss].slaveName is @@.mediumorchid;disheartened@@ that you are selling _his2 half-sister. - <<run clearSummaryCache($slaves[_ss])>> - <br><br> - <<set $slaves[_ss].devotion -= 10>> - <</switch>> - <</for>> - <<else>> - <<if $activeSlave.relation != 0>> - <<set _ss = $slaveIndices[$activeSlave.relationTarget]>> - <<if def _ss && $slaves[_ss].fetish != "mindbroken">> - <<setLocalPronouns $slaves[_ss] 2>> - $slaves[_ss].slaveName is @@.mediumorchid;grieved@@ that you are selling _his2 $activeSlave.relation. - <<run clearSummaryCache($slaves[_ss])>> - <br><br> - <<set $slaves[_ss].devotion -= 20>> - <<set $display = 1>> - <</if>> +<<if $familyTesting == 1>> + <<for _ss = 0; _ss < $slaves.length; _ss++>> + <<setLocalPronouns $slaves[_ss] 2>> + <<if $activeSlave.mother == $slaves[_ss].ID>> + $slaves[_ss].slaveName is @@.mediumorchid;grieved@@ that you are selling _his2 daughter. + <<run clearSummaryCache($slaves[_ss])>> + <br><br> + <<set $slaves[_ss].devotion -= 20>> <</if>> - <</if>> - <<if $activeSlave.relationship > 0>> - <<set _ss = $slaveIndices[$activeSlave.relationshipTarget]>> + <<if $activeSlave.father == $slaves[_ss].ID>> + $slaves[_ss].slaveName is @@.mediumorchid;disappointed@@ that you are selling _his2 daughter. + <<run clearSummaryCache($slaves[_ss])>> + <br><br> + <<set $slaves[_ss].devotion -= 10>> + <</if>> + <<if $activeSlave.ID == $slaves[_ss].father>> + $slaves[_ss].slaveName is @@.mediumorchid;saddened@@ that you are selling _his2 father. + <<run clearSummaryCache($slaves[_ss])>> + <br><br> + <<set $slaves[_ss].devotion -= 10>> + <</if>> + <<if $activeSlave.ID == $slaves[_ss].mother>> + $slaves[_ss].slaveName is @@.mediumorchid;grieved@@ that you are selling _his2 mother. + <<run clearSummaryCache($slaves[_ss])>> + <br><br> + <<set $slaves[_ss].devotion -= 20>> + <</if>> + <<switch areSisters($activeSlave, $slaves[_ss])>> + <<case 1>> + $slaves[_ss].slaveName is @@.mediumorchid;devastated@@ that you are selling _his2 twin. + <<run clearSummaryCache($slaves[_ss])>> + <br><br> + <<set $slaves[_ss].devotion -= 30>> + <<case 2>> + $slaves[_ss].slaveName is @@.mediumorchid;grieved@@ that you are selling _his2 sister. + <<run clearSummaryCache($slaves[_ss])>> + <br><br> + <<set $slaves[_ss].devotion -= 20>> + <<case 3>> + $slaves[_ss].slaveName is @@.mediumorchid;disheartened@@ that you are selling _his2 half-sister. + <<run clearSummaryCache($slaves[_ss])>> + <br><br> + <<set $slaves[_ss].devotion -= 10>> + <</switch>> + <</for>> +<<else>> + <<if $activeSlave.relation != 0>> + <<set _ss = $slaveIndices[$activeSlave.relationTarget]>> <<if def _ss && $slaves[_ss].fetish != "mindbroken">> <<setLocalPronouns $slaves[_ss] 2>> - $slaves[_ss].slaveName is @@.mediumorchid;grieved@@ that you are selling _his2 best source of comfort and companionship in a life of bondage. + $slaves[_ss].slaveName is @@.mediumorchid;grieved@@ that you are selling _his2 $activeSlave.relation. <<run clearSummaryCache($slaves[_ss])>> <br><br> - <<set $slaves[_ss].devotion -= $slaves[_ss].relationship*10>> + <<set $slaves[_ss].devotion -= 20>> <<set $display = 1>> <</if>> - <<elseif $activeSlave.relationship == -3>> - Selling one of your slave wives is @@.red;socially unacceptable.@@ In addition, your other devoted slaves are @@.gold;worried@@ that you may not respect their status. - <<run clearSummaryCache()>> + <</if>> +<</if>> +<<if $activeSlave.relationship > 0>> + <<set _ss = $slaveIndices[$activeSlave.relationshipTarget]>> + <<if def _ss && $slaves[_ss].fetish != "mindbroken">> + <<setLocalPronouns $slaves[_ss] 2>> + $slaves[_ss].slaveName is @@.mediumorchid;grieved@@ that you are selling _his2 best source of comfort and companionship in a life of bondage. + <<run clearSummaryCache($slaves[_ss])>> <br><br> - <<set $rep -= 200>> + <<set $slaves[_ss].devotion -= $slaves[_ss].relationship*10>> <<set $display = 1>> - <<for _ss = 0; _ss < $slaves.length; _ss++>> - <<if $slaves[_ss].devotion > 50>> - <<set $slaves[_ss].trust -= 5>> - <</if>> - <</for>> <</if>> - <<if $activeSlave.rivalry != 0>> - <<set _ss = $slaveIndices[$activeSlave.rivalryTarget]>> - <<if def _ss && $slaves[_ss].fetish != "mindbroken">> - <<setLocalPronouns $slaves[_ss] 2>> - $slaves[_ss].slaveName is @@.hotpink;pleased@@ that _he2 won't have to see _his2 rival any more. - <<run clearSummaryCache($slaves[_ss])>> - <br><br> - <<set $slaves[_ss].devotion += $slaves[_ss].rivalry*3>> - <<set $display = 1>> +<<elseif $activeSlave.relationship == -3>> + Selling one of your slave wives is @@.red;socially unacceptable.@@ In addition, your other devoted slaves are @@.gold;worried@@ that you may not respect their status. + <<run clearSummaryCache()>> + <br><br> + <<set $rep -= 200>> + <<set $display = 1>> + <<for _ss = 0; _ss < $slaves.length; _ss++>> + <<if $slaves[_ss].devotion > 50>> + <<set $slaves[_ss].trust -= 5>> <</if>> + <</for>> +<</if>> +<<if $activeSlave.rivalry != 0>> + <<set _ss = $slaveIndices[$activeSlave.rivalryTarget]>> + <<if def _ss && $slaves[_ss].fetish != "mindbroken">> + <<setLocalPronouns $slaves[_ss] 2>> + $slaves[_ss].slaveName is @@.hotpink;pleased@@ that _he2 won't have to see _his2 rival any more. + <<run clearSummaryCache($slaves[_ss])>> + <br><br> + <<set $slaves[_ss].devotion += $slaves[_ss].rivalry*3>> + <<set $display = 1>> <</if>> +<</if>> <<set _slaveImpact = 0>> <<switch $buyer>> diff --git a/src/uncategorized/slaveSummary.tw b/src/uncategorized/slaveSummary.tw index 98ea7560a738da631a4ff71bdb762bedb4e574c3..8b9444e82235598e555303b37cfe2beb2110d8ea 100644 --- a/src/uncategorized/slaveSummary.tw +++ b/src/uncategorized/slaveSummary.tw @@ -105,12 +105,12 @@ <<set _tableCount = _tableCount || 0>> <<set _tableCount++>> /* - * we want <button data-quick-index="<<= _tableCount>>"> ... + * we want <button data-quick-index="<<= _tableCount>>">... */ <<set _buttonAttributes = { 'data-quick-index': _tableCount }>> <<htag _buttonAttributes 'button'>>Quick Index<</htag>> /* - * we want <div id="list_index3" class=" hidden">... + * we want <div id="list_index3" class=" hidden">... */ <<set _divAttributes = { id: 'list_index' + _tableCount, class: 'hidden'}>> <<htag _divAttributes>> diff --git a/src/uncategorized/spaReport.tw b/src/uncategorized/spaReport.tw index c848d8562b87b96878918b1513bca1e7a289c477..7c2760101b7ac3f6251a3753cb568760d0bceb2e 100644 --- a/src/uncategorized/spaReport.tw +++ b/src/uncategorized/spaReport.tw @@ -163,8 +163,8 @@ <<case "She is remembered for winning best in show as a breeder.">> <<if $slaves[$i].bellyPreg >= 5000>> <<if $Attendant.fetish == "pregnancy">> - $He can't keep $his hands off $slaves[$i].slaveName's pregnancy, but _he2 doesn't mind _his2 full belly being fondled. - <<set $Attendant.fetishStrength += 4, $slaves[_FLs].fetishStrength += 4>> + $He can't keep $his hands off $slaves[$i].slaveName's pregnancy, but _he2 doesn't mind _his2 full belly being fondled. + <<set $Attendant.fetishStrength += 4, $slaves[_FLs].fetishStrength += 4>> <<else>> $He does $his 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 && $Attendant.fetish == "none">> diff --git a/src/uncategorized/stewardessWorkaround.tw b/src/uncategorized/stewardessWorkaround.tw index 7efd7ede9c6f08f6007e9e3a663a9deae01a8030..99c517aa1df49bda08582aa8d438d569a6f9c8ed 100644 --- a/src/uncategorized/stewardessWorkaround.tw +++ b/src/uncategorized/stewardessWorkaround.tw @@ -10,4 +10,3 @@ <</if>> <<goto "Servants' Quarters">> - diff --git a/src/uncategorized/storyCaption.tw b/src/uncategorized/storyCaption.tw index 4ba552a5e51d8b18497a4ab4d03e0b39e7d09134..c24ff8913cb629b46118b93106e283f5abce936a 100644 --- a/src/uncategorized/storyCaption.tw +++ b/src/uncategorized/storyCaption.tw @@ -27,7 +27,7 @@ <span id="cost"><<SlaveCostDescription>></span> <<elseif $ui == "disclaimer">>\ -<span id="nextButton"><strong><<link [[($nextButton)|($nextLink)]]>><</link>></strong></span> + <span id="nextButton"><strong><<link [[($nextButton)|($nextLink)]]>><</link>></strong></span> <<elseif $ui != "start">>\ <<nobr>> @@ -139,7 +139,7 @@ </span> <br> - + <<set _TFood2 = ($food-$foodLastWeek)>> <span id="oldfood"> <<if _TFood2 < 0>> diff --git a/src/uncategorized/walkPast.tw b/src/uncategorized/walkPast.tw index 95ca971db81ab3b65ccb16062526d8eb31296231..4e5e36f7711d0659036d20bfe300f862189742c6 100644 --- a/src/uncategorized/walkPast.tw +++ b/src/uncategorized/walkPast.tw @@ -462,7 +462,7 @@ <<if _seed > 50>> displaying _his2 <<if $seeRace == 1>>_partnerSlave.race <</if>>body, keeping citizens company, and flirting with anyone who shows interest. <<else>> - or rather just off it, having taken a prominent citizen back to a discreet room so he can use _his2 <<if $seeRace == 1>>_partnerSlave.race <</if>>body. + or rather just off it, having taken a prominent citizen back to a discreet room so he can use _his2 <<if $seeRace == 1>>_partnerSlave.race <</if>>body. <</if>> <<case "work as a servant">> <<if _seed > 50>> @@ -855,7 +855,7 @@ <<case "clubslut netting">> As $he moves, $his clubslut netting moves with $him, leaving nothing to the imagination. <<case "a cheerleader outfit">> - As $he moves, $his pleated cheerleader bounces up and down flirtily. + As $he moves, $his pleated cheerleader bounces up and down flirtatiously. <<case "cutoffs and a t-shirt">> As $he moves, $his cutoffs hug $his butt. <<case "spats and a tank top">> diff --git a/src/uncategorized/wardrobeUse.tw b/src/uncategorized/wardrobeUse.tw index 8b0a772206b65f7e011e73f27b5fd68d9c9566b4..f24ba56c5a00f4d0f74276caca652b1bb3a42568 100644 --- a/src/uncategorized/wardrobeUse.tw +++ b/src/uncategorized/wardrobeUse.tw @@ -847,7 +847,7 @@ Clothes: ''<span id="clothes">$activeSlave.clothes</span>.'' <<set $activeSlave.collar = "cruel retirement counter">> <<replace "#collar">>$activeSlave.collar<</replace>> <<replace "#collarDescription">><br>//<<collarDescription>>//<</replace>> - <</link>> + <</link>> <</if>> | <<link "Uncomfortable leather">> <<set $activeSlave.collar = "uncomfortable leather">> diff --git a/src/utility/descriptionWidgets.tw b/src/utility/descriptionWidgets.tw index 3afa05280e2c8e98b7316d1b38dcab460792c93b..5d22b2e77889e57947222cf2b264c8a0e288bdb5 100644 --- a/src/utility/descriptionWidgets.tw +++ b/src/utility/descriptionWidgets.tw @@ -280,6 +280,15 @@ fertile. <</if>> <</if>> + <<if $activeSlave.geneticQuirks.wellHung == 2>> + <<if $activeSlave.physicalAge <= 16 && $activeSlave.hormoneBalance < 100 && $activeSlave.dick > 0>> + $He is likely to experience an inordinate amount of penile growth during $his physical development. + <<elseif $activeSlave.dick > 0>> + $He is predisposed to having an enormous dick, though it is unlikely to naturally grow any larger than it currently is. + <<else>> + $He is predisposed to having an enormous dick, or would, if $he had one. + <</if>> + <</if>> <</if>> <</widget>> diff --git a/src/utility/descriptionWidgetsPiercings.tw b/src/utility/descriptionWidgetsPiercings.tw index 51668090538088ed5186568739a3ecb05c96e864..b061c126c13dcf64c8c7e1a360e4119782bd5024 100644 --- a/src/utility/descriptionWidgetsPiercings.tw +++ b/src/utility/descriptionWidgetsPiercings.tw @@ -480,7 +480,7 @@ $He has a corset piercing, a ladder of steel rings running up each side of $his <<case "a tube top" "a tube top and thong" "a slutty klan robe" "a slutty pony outfit" "a sports bra" "a tank-top and panties" "leather pants and a tube top">> the piercings are only partly visible on $his back. -<<case "a button-up shirt" "a button-up shirt and panties" "a police uniform" "a t-shirt" "a t-shirt and jeans" "a t-shirt and panties" "a t-shirt and thong" "a tank-top" "an oversized t-shirt" "an oversized t-shirt and boyshorts" "sport shorts and a sports bra" "sport shorts and a t-shirt">> +<<case "a button-up shirt" "a button-up shirt and panties" "a police uniform" "a t-shirt and jeans" "a t-shirt and panties" "a t-shirt and thong" "a t-shirt" "a tank-top" "an oversized t-shirt and boyshorts" "an oversized t-shirt" "sport shorts and a sports bra" "sport shorts and a t-shirt">> $his shirt hides them completely, but they're laced tightly, so $he's aware they're there. <<case "a sweater" "a sweater and cutoffs" "a sweater and panties">> diff --git a/src/utility/descriptionWidgetsTattoos.tw b/src/utility/descriptionWidgetsTattoos.tw index 7845bb320ca02bd6cef176b3bf89afd4a945bef0..ce619004b72a9ae4a06bcb0ac670f862acc2dd09 100644 --- a/src/utility/descriptionWidgetsTattoos.tw +++ b/src/utility/descriptionWidgetsTattoos.tw @@ -404,7 +404,7 @@ $activeSlave.buttTat <</switch>> <</if>> -<<if ($activeSlave.brand != 0) && ["left buttock", "right buttock", "buttocks", "left thigh", "right thigh", "thighs"].includes($activeSlave.brandLocation)>> +<<if ($activeSlave.brand != 0) && ["buttocks", "left buttock", "left thigh", "right buttock", "right thigh", "thighs"].includes($activeSlave.brandLocation)>> <<brandDescription>> <</if>> <</widget>> diff --git a/src/utility/extendedFamilyWidgets.tw b/src/utility/extendedFamilyWidgets.tw index 85501d63f4de3b32187403d89c410899bfb645bc..bf96b5f826801d071eeaf6c19d2def020ae778f1 100644 --- a/src/utility/extendedFamilyWidgets.tw +++ b/src/utility/extendedFamilyWidgets.tw @@ -334,15 +334,15 @@ /*testtest uncle passage - determines how many uncles a slave has*/ <<for $i = 0; $i < $slaves.length; $i++>> <<if $slaves[$i].ID != $activeSlave.ID>> - <<if $slaves[$i].ID == $activeSlave.mother || $slaves[$i].ID == $activeSlave.father>> - <<for $j = 0; $j < $slaves.length; $j++>> - <<if $slaves[$j].genes == "XY">> - <<if areSisters($slaves[$j], $slaves[$i]) == 1 || areSisters($slaves[$j], $slaves[$i]) == 2>> - <<set $children.push($slaves[$j])>> - <</if>> - <</if>> - <</for>> - <</if>> + <<if $slaves[$i].ID == $activeSlave.mother || $slaves[$i].ID == $activeSlave.father>> + <<for $j = 0; $j < $slaves.length; $j++>> + <<if $slaves[$j].genes == "XY">> + <<if areSisters($slaves[$j], $slaves[$i]) == 1 || areSisters($slaves[$j], $slaves[$i]) == 2>> + <<set $children.push($slaves[$j])>> + <</if>> + <</if>> + <</for>> + <</if>> <</if>> <</for>> <<if $children.length > 0>> diff --git a/src/utility/slaveCreationWidgets.tw b/src/utility/slaveCreationWidgets.tw index 1d855bc7a0c23266ece9d0dc6bfb3d564002cc0c..b21d6e46cdbfc25bcaa1cdcab523cfada1cb6134 100644 --- a/src/utility/slaveCreationWidgets.tw +++ b/src/utility/slaveCreationWidgets.tw @@ -788,7 +788,7 @@ <<widget "ToggleFetish">> <<if ($args[0] == 0)>> - <<set $activeSlave.fetish = either("none", "none", "none", "none", "none", "none", "none", "none", "none", "none", "submissive", "cumslut", "humiliation", "buttslut", "boobs", "pregnancy", "dom", "sadist", "masochist"), $activeSlave.fetishKnown = 0>> + <<set $activeSlave.fetish = either("boobs", "buttslut", "cumslut", "dom", "humiliation", "masochist", "none", "none", "none", "none", "none", "none", "none", "none", "none", "none", "pregnancy", "sadist", "submissive"), $activeSlave.fetishKnown = 0>> <<replace "#fetishblock">> //Not known.// <<link "Known">> @@ -2075,25 +2075,6 @@ <<else>> The corporation does not use cosmetic surgery to improve its slaves for sale. <</if>> - <<if $corpSpecImplants == 1>> - Slaves are given tasteful breast, butt, and lip implants. - <<set $activeSlave.buttImplant = 1>> - <<set $activeSlave.butt = Math.clamp($activeSlave.butt+$activeSlave.buttImplant, 0, 10)>> - <<set $activeSlave.boobsImplant = 600>> - <<set $activeSlave.boobs = Math.clamp($activeSlave.boobs+$activeSlave.boobsImplant, 0, 10000)>> - <<set $activeSlave.lipsImplant = 20>> - <<set $activeSlave.lips = Math.clamp($activeSlave.lips+$activeSlave.lipsImplant, 0, 55)>> - <<elseif $corpSpecImplants == 2>> - Slaves are given absurd breast, butt, and lip implants. - <<set $activeSlave.buttImplant = 4>> - <<set $activeSlave.butt = Math.clamp($activeSlave.butt+$activeSlave.buttImplant, 0, 10, $activeSlave.butt+$activeSlave.buttImplant)>> - <<set $activeSlave.boobsImplant = 2400>> - <<set $activeSlave.boobs = Math.clamp($activeSlave.boobs+$activeSlave.boobsImplant, 0, 10000)>> - <<set $activeSlave.lipsImplant = 60>> - <<set $activeSlave.lips = Math.clamp($activeSlave.lipsImplant+$activeSlave.buttImplant, 0, 100)>> - <<else>> - Slaves are not given breast, butt, or lip implants. - <</if>> <<if $corpSpecPussy == 1>> The corporation adds pussies where needed. <<set $activeSlave.vagina = 0, @@ -2218,7 +2199,7 @@ <</if>> <<if $corpSpecInjection > 0>> <<if $corpSpecInjection == 1>> - If anything, hormones are used to reduce assets sizes. + If anything, hormones are used to reduce asset sizes. <<set $activeSlave.lips = random(0, 20), $activeSlave.butt = random(1, 2), $activeSlave.boobs = 10 * random(30, 60), @@ -2281,6 +2262,25 @@ <<else>> Growth hormones are not applied. <</if>> + <<if $corpSpecImplants == 1>> + Slaves are given tasteful breast, butt, and lip implants. + <<set $activeSlave.buttImplant = 1>> + <<set $activeSlave.butt = Math.clamp($activeSlave.butt+$activeSlave.buttImplant, 0, 10)>> + <<set $activeSlave.boobsImplant = 600>> + <<set $activeSlave.boobs = Math.clamp($activeSlave.boobs+$activeSlave.boobsImplant, 0, 10000)>> + <<set $activeSlave.lipsImplant = 20>> + <<set $activeSlave.lips = Math.clamp($activeSlave.lips+$activeSlave.lipsImplant, 0, 55)>> + <<elseif $corpSpecImplants == 2>> + Slaves are given absurd breast, butt, and lip implants. + <<set $activeSlave.buttImplant = 4>> + <<set $activeSlave.butt = Math.clamp($activeSlave.butt+$activeSlave.buttImplant, 0, 10, $activeSlave.butt+$activeSlave.buttImplant)>> + <<set $activeSlave.boobsImplant = 2400>> + <<set $activeSlave.boobs = Math.clamp($activeSlave.boobs+$activeSlave.boobsImplant, 0, 10000)>> + <<set $activeSlave.lipsImplant = 60>> + <<set $activeSlave.lips = Math.clamp($activeSlave.lipsImplant+$activeSlave.buttImplant, 0, 100)>> + <<else>> + Slaves are not given breast, butt, or lip implants. + <</if>> <<if $corpSpecAmputee == 1>> The corporation removes all limbs from its slaves. <<set $activeSlave.amp = 1>> @@ -2617,7 +2617,7 @@ <<set $activeSlave.behavioralFlaw = "gluttonous">> <</if>> <<if $activeSlave.fetish == "none">> - <<set $activeSlave.fetish = either("submissive", "cumslut", "humiliation", "buttslut", "boobs", "pregnancy", "dom", "sadist", "masochist")>> + <<set $activeSlave.fetish = either("boobs", "buttslut", "cumslut", "dom", "humiliation", "masochist", "pregnancy", "sadist", "submissive")>> <</if>> <<set $activeSlave.fetishStrength = random(60,90)>> <<if random(1,100) <= 5 && $activeSlave.fetish != "mindbroken">> @@ -2818,7 +2818,7 @@ <<set $activeSlave.nationality = "Stateless">> <<set $activeSlave.devotion = 40>> <<set $activeSlave.trust = -100>> - <<set $activeSlave.career = either("a politician", "a college scout", "a business owner", "a house DJ", "a soldier", "a prison guard", "a doctor", "a counselor", "a dairy worker", "a secretary", "a teacher")>> + <<set $activeSlave.career = either("a business owner", "a college scout", "a counselor", "a dairy worker", "a doctor", "a house DJ", "a politician", "a prison guard", "a secretary", "a soldier", "a teacher")>> <<set $activeSlave.intelligence = Intelligence.random({limitIntelligence: [20,100]})>> <<set $activeSlave.intelligenceImplant = 30>> <<set $activeSlave.health = random(-99,-50)>> @@ -2967,8 +2967,8 @@ <<set $activeSlave.analSkill = random(15,100)>> <<set $activeSlave.anus = random(1,3)>> <<set $activeSlave.weight = Math.clamp(-25, 25, $activeSlave.weight)>> - <<set $activeSlave.behavioralFlaw = either("arrogant", "bitchy", "odd", "hates men", "hates women", "hates women", "anorexic", "gluttonous", "devout", "liberated")>> - <<set $activeSlave.sexualFlaw = either("hates oral", "hates anal", "hates penetration", "repressed", "idealistic", "shamefast", "apathetic", "crude", "judgemental")>> + <<set $activeSlave.behavioralFlaw = either("anorexic", "arrogant", "bitchy", "devout", "gluttonous", "hates men", "hates women", "hates women", "liberated", "odd")>> + <<set $activeSlave.sexualFlaw = either("apathetic", "crude", "hates anal", "hates oral", "hates penetration", "idealistic", "judgemental", "repressed", "shamefast")>> <<if random(1,2) == 1>> <<set _slaveGen = random(2,8)*200>> <<set $activeSlave.boobs += _slaveGen>> @@ -3366,8 +3366,8 @@ <<set $activeSlave.pubicHStyle = "waxed">> <<set $activeSlave.underArmHStyle = "waxed">> <<set $activeSlave.birthWeek = 0>> - <<set $activeSlave.sexualFlaw = either("none", "apathetic")>> - <<set $activeSlave.behavioralFlaw = either("none", "arrogant", "odd")>> + <<set $activeSlave.sexualFlaw = either("apathetic", "none")>> + <<set $activeSlave.behavioralFlaw = either("arrogant", "none", "odd")>> <<set $activeSlave.hStyle = "short">> <<set $activeSlave.hLength = 2>> <<set $activeSlave.customTat = "She has the baroque crest of the Gymnasium-Academy that trained her branded into her left cheek.">> @@ -3528,7 +3528,7 @@ <</if>> <<set $activeSlave.origin = "You bought her from the enigmatic Futanari Sisters after they sold her into slavery.">> <<set $activeSlave.career = "a Futanari Sister">> - <<set $activeSlave.faceShape = either("sensual", "exotic")>> + <<set $activeSlave.faceShape = either("exotic", "sensual")>> <<set $activeSlave.pubertyXY = 1>> <<set _sisterAge = random(1,5)>> <<if _sisterAge == 1>> @@ -3590,7 +3590,7 @@ <<set $activeSlave.waist = random(-30,10)>> <<set $activeSlave.vagina = 2>> <<set $activeSlave.anus = 2>> - <<set $activeSlave.fetish = either("submissive", "buttslut", "cumslut")>> + <<set $activeSlave.fetish = either("buttslut", "cumslut", "submissive")>> <<elseif _sisterAge == 3>> <<set $activeSlave.intelligence = 0>> <<set $activeSlave.hips = 2>>