Compare commits

..

No commits in common. "ba7b72b42668e2c0f467df6d85bd1f5dfb85427d" and "6ea89c189cbcf5f51644b679b7b40da147337651" have entirely different histories.

21 changed files with 132 additions and 261 deletions

View file

@ -6,7 +6,6 @@ Features:
- Orgasm Rush got a Hediff - Orgasm Rush got a Hediff
- Unbreakable Gene - Unbreakable Gene
- Age-Transfer and Youth-Fountain per Sex Gene - Age-Transfer and Youth-Fountain per Sex Gene
- Bisexual and Homosexual Genes with Placeholder Icon
- Balancing some Genes by changing metabolism and complexity - Balancing some Genes by changing metabolism and complexity
Succubus: Succubus:
@ -15,8 +14,6 @@ Fixes:
- Issue with Breast-Size (#8) fixed by lowercasing breast-match (Shabakur) - Issue with Breast-Size (#8) fixed by lowercasing breast-match (Shabakur)
- Error on Game Load when Licentia Genes are tried to be added to Xenotypes for players without Licentia (#5) - Error on Game Load when Licentia Genes are tried to be added to Xenotypes for players without Licentia (#5)
- Futa Gene only triggers if Pawn is not a futa already (#2)
- Genitalia Resizing triggers on 20th Birthday (#11)
# 1.0.1 (2022-12-20) # 1.0.1 (2022-12-20)

View file

@ -57,7 +57,7 @@
<GeneCategoryDef> <GeneCategoryDef>
<defName>rjw_genes_special</defName> <defName>rjw_genes_special</defName>
<label>Genital Based Special Abilities</label> <label>Genital Related Damage</label>
<displayPriorityInXenotype>8</displayPriorityInXenotype> <displayPriorityInXenotype>8</displayPriorityInXenotype>
</GeneCategoryDef> </GeneCategoryDef>

View file

@ -9,7 +9,7 @@
<GeneDef ParentName="GeneGenitaliaSizeBase"> <GeneDef ParentName="GeneGenitaliaSizeBase">
<defName>rjw_genes_big_male_genitalia</defName> <defName>rjw_genes_big_male_genitalia</defName>
<label>Big Male Genitaliasize</label> <label>Big Male Genitaliasize</label>
<description>Penises of this Xenotype are bigger.(Resizing takes place at 20th Birthday)</description> <description>Penises of this Xenotype are bigger.</description>
<iconPath>Genes/Icons/Small_Male_Genitalia</iconPath> <iconPath>Genes/Icons/Small_Male_Genitalia</iconPath>
<geneClass>RJW_Genes.Gene_BigMaleGenitalia</geneClass> <geneClass>RJW_Genes.Gene_BigMaleGenitalia</geneClass>
<displayOrderInCategory>751</displayOrderInCategory> <displayOrderInCategory>751</displayOrderInCategory>
@ -21,7 +21,7 @@
<GeneDef ParentName="GeneGenitaliaSizeBase"> <GeneDef ParentName="GeneGenitaliaSizeBase">
<defName>rjw_genes_small_male_genitalia</defName> <defName>rjw_genes_small_male_genitalia</defName>
<label>Small Male Genitaliasize</label> <label>Small Male Genitaliasize</label>
<description>Penises of this Xenotype are smaller. (Resizing takes place at 20th Birthday)</description> <description>Penises of this Xenotype are smaller.</description>
<iconPath>Genes/Icons/Big_Male_Genitalia</iconPath> <iconPath>Genes/Icons/Big_Male_Genitalia</iconPath>
<geneClass>RJW_Genes.Gene_SmallMaleGenitalia</geneClass> <geneClass>RJW_Genes.Gene_SmallMaleGenitalia</geneClass>
<displayOrderInCategory>753</displayOrderInCategory> <displayOrderInCategory>753</displayOrderInCategory>
@ -34,7 +34,7 @@
<GeneDef ParentName="GeneGenitaliaSizeBase"> <GeneDef ParentName="GeneGenitaliaSizeBase">
<defName>rjw_genes_loose_female_genitalia</defName> <defName>rjw_genes_loose_female_genitalia</defName>
<label>Loose Female Genitalia</label> <label>Loose Female Genitalia</label>
<description>Vaginas of this Xenotype are quite spacy. (Resizing takes place at 20th Birthday)</description> <description>Vaginas of this Xenotype are quite spacy.</description>
<iconPath>Genes/Icons/Loose_Female_Genitalia</iconPath> <iconPath>Genes/Icons/Loose_Female_Genitalia</iconPath>
<geneClass>RJW_Genes.Gene_LooseFemaleGenitalia</geneClass> <geneClass>RJW_Genes.Gene_LooseFemaleGenitalia</geneClass>
<displayOrderInCategory>754</displayOrderInCategory> <displayOrderInCategory>754</displayOrderInCategory>
@ -46,7 +46,7 @@
<GeneDef ParentName="GeneGenitaliaSizeBase"> <GeneDef ParentName="GeneGenitaliaSizeBase">
<defName>rjw_genes_tight_female_genitalia</defName> <defName>rjw_genes_tight_female_genitalia</defName>
<label>Tight Female Genitalia</label> <label>Tight Female Genitalia</label>
<description>Vaginas of this Xenotype are pretty tight.(Resizing takes place at 20th Birthday)</description> <description>Vaginas of this Xenotype are pretty tight.</description>
<iconPath>Genes/Icons/Tight_Female_Genitalia</iconPath> <iconPath>Genes/Icons/Tight_Female_Genitalia</iconPath>
<geneClass>RJW_Genes.Gene_TightFemaleGenitalia</geneClass> <geneClass>RJW_Genes.Gene_TightFemaleGenitalia</geneClass>
<displayOrderInCategory>756</displayOrderInCategory> <displayOrderInCategory>756</displayOrderInCategory>
@ -59,7 +59,7 @@
<GeneDef ParentName="GeneGenitaliaSizeBase"> <GeneDef ParentName="GeneGenitaliaSizeBase">
<defName>rjw_genes_big_breasts</defName> <defName>rjw_genes_big_breasts</defName>
<label>Big Breasts</label> <label>Big Breasts</label>
<description>Females of this Xenotype have big honkers.(Resizing takes place at 20th Birthday)</description> <description>Females of this Xenotype have big honkers.</description>
<iconPath>Genes/Icons/Big_Breasts</iconPath> <iconPath>Genes/Icons/Big_Breasts</iconPath>
<geneClass>RJW_Genes.Gene_BigBreasts</geneClass> <geneClass>RJW_Genes.Gene_BigBreasts</geneClass>
<displayOrderInCategory>757</displayOrderInCategory> <displayOrderInCategory>757</displayOrderInCategory>
@ -71,7 +71,7 @@
<GeneDef ParentName="GeneGenitaliaSizeBase"> <GeneDef ParentName="GeneGenitaliaSizeBase">
<defName>rjw_genes_small_breasts</defName> <defName>rjw_genes_small_breasts</defName>
<label>Small Breasts</label> <label>Small Breasts</label>
<description>Females of this Xenotype have smaller breasts.(Resizing takes place at 20th Birthday)</description> <description>Females of this Xenotype have smaller breasts.</description>
<iconPath>Genes/Icons/Small_Breasts</iconPath> <iconPath>Genes/Icons/Small_Breasts</iconPath>
<geneClass>RJW_Genes.Gene_SmallBreasts</geneClass> <geneClass>RJW_Genes.Gene_SmallBreasts</geneClass>
<displayOrderInCategory>759</displayOrderInCategory> <displayOrderInCategory>759</displayOrderInCategory>
@ -84,7 +84,7 @@
<GeneDef ParentName="GeneGenitaliaSizeBase"> <GeneDef ParentName="GeneGenitaliaSizeBase">
<defName>rjw_genes_loose_anus</defName> <defName>rjw_genes_loose_anus</defName>
<label>Loose Anus</label> <label>Loose Anus</label>
<description>The Anus of this Xenotype is roomy.(Resizing takes place at 20th Birthday)</description> <description>The Anus of this Xenotype is roomy.</description>
<iconPath>Genes/Icons/Loose_Anus</iconPath> <iconPath>Genes/Icons/Loose_Anus</iconPath>
<geneClass>RJW_Genes.Gene_LooseAnus</geneClass> <geneClass>RJW_Genes.Gene_LooseAnus</geneClass>
<displayOrderInCategory>760</displayOrderInCategory> <displayOrderInCategory>760</displayOrderInCategory>
@ -96,7 +96,7 @@
<GeneDef ParentName="GeneGenitaliaSizeBase"> <GeneDef ParentName="GeneGenitaliaSizeBase">
<defName>rjw_genes_tight_anus</defName> <defName>rjw_genes_tight_anus</defName>
<label>Tight Anus</label> <label>Tight Anus</label>
<description>The anus of this Xenotype is small.(Resizing takes place at 20th Birthday)</description> <description>The anus of this Xenotype is small.</description>
<iconPath>Genes/Icons/Tight_Anus</iconPath> <iconPath>Genes/Icons/Tight_Anus</iconPath>
<geneClass>RJW_Genes.Gene_TightAnus</geneClass> <geneClass>RJW_Genes.Gene_TightAnus</geneClass>
<displayOrderInCategory>762</displayOrderInCategory> <displayOrderInCategory>762</displayOrderInCategory>

View file

@ -29,41 +29,4 @@
</li> </li>
</forcedTraits> </forcedTraits>
</GeneDef> </GeneDef>
<GeneDef>
<defName>rjw_genes_homosexual</defName>
<label>Homosexual</label>
<displayCategory>Reproduction</displayCategory>
<description>This Gene makes you gay.</description>
<iconPath>UI\Ideoligions\Universal\RoundC</iconPath>
<biostatMet>0</biostatMet>
<displayOrderInCategory>3</displayOrderInCategory>
<forcedTraits>
<li>
<def>Gay</def>
</li>
</forcedTraits>
<exclusionTags>
<li>rjw_genes_sexual_orientation</li>
</exclusionTags>
</GeneDef>
<GeneDef>
<defName>rjw_genes_bisexual</defName>
<label>Bisexual</label>
<displayCategory>Reproduction</displayCategory>
<description>Carriers of this Gene are Bisexual.</description>
<iconPath>UI\Ideoligions\Universal\RoundC</iconPath>
<biostatMet>0</biostatMet>
<displayOrderInCategory>4</displayOrderInCategory>
<forcedTraits>
<li>
<def>Bisexual</def>
</li>
</forcedTraits>
<exclusionTags>
<li>rjw_genes_sexual_orientation</li>
</exclusionTags>
</GeneDef>
</Defs> </Defs>

View file

@ -1,8 +1,11 @@
using rjw; using System;
using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;
using System.Text;
using System.Threading.Tasks;
using rjw;
using Verse; using Verse;
using RimWorld;
namespace RJW_BGS namespace RJW_BGS
{ {
@ -41,7 +44,6 @@ namespace RJW_BGS
}).ToList<RaceGeneDef>(); }).ToList<RaceGeneDef>();
if (pawnKindDefs.Count() > 0) if (pawnKindDefs.Count() > 0)
return pawnKindDefs; return pawnKindDefs;
List<RaceGeneDef> raceKindDefs = allDefs.Where(delegate (RaceGeneDef group) List<RaceGeneDef> raceKindDefs = allDefs.Where(delegate (RaceGeneDef group)
{ {
List<string> raceNames = group.raceNames; List<string> raceNames = group.raceNames;
@ -49,7 +51,6 @@ namespace RJW_BGS
}).ToList<RaceGeneDef>(); }).ToList<RaceGeneDef>();
if (raceKindDefs.Count() > 0) if (raceKindDefs.Count() > 0)
return raceKindDefs; return raceKindDefs;
List<RaceGeneDef> raceGroupDefs = new List<RaceGeneDef>(); List<RaceGeneDef> raceGroupDefs = new List<RaceGeneDef>();
if (raceGroupDef != null) if (raceGroupDef != null)
{ {
@ -59,10 +60,8 @@ namespace RJW_BGS
return raceGroupDefName != null && raceGroupDefName == raceGroupDef.defName; return raceGroupDefName != null && raceGroupDefName == raceGroupDef.defName;
}).ToList<RaceGeneDef>(); }).ToList<RaceGeneDef>();
} }
if (raceGroupDefs.Count() > 0) if (raceGroupDefs.Count() > 0)
return raceGroupDefs; return raceGroupDefs;
return new List<RaceGeneDef>(); return new List<RaceGeneDef>();
} }
} }

View file

@ -1,34 +0,0 @@
using Verse;
namespace RJW_Genes
{
internal class ModLog
{
public static string ModId => "RJW-Genes";
/// <summary>
/// Logs the given message with [SaveStorage.ModId] appended.
/// </summary>
public static void Error(string message)
{
Log.Error($"[{ModId}] {message}");
}
/// <summary>
/// Logs the given message with [SaveStorage.ModId] appended.
/// </summary>
public static void Message(string message)
{
Log.Message($"[{ModId}] {message}");
}
/// <summary>
/// Logs the given message with [SaveStorage.ModId] appended.
/// </summary>
public static void Warning(string message)
{
Log.Warning($"[{ModId}] {message}");
}
}
}

View file

@ -51,7 +51,6 @@ namespace RJW_Genes
public static readonly GeneDef rjw_genes_mechbreeder; public static readonly GeneDef rjw_genes_mechbreeder;
public static readonly GeneDef rjw_genes_insectincubator; public static readonly GeneDef rjw_genes_insectincubator;
public static readonly GeneDef rjw_genes_insectbreeder; public static readonly GeneDef rjw_genes_insectbreeder;
public static readonly GeneDef rjw_genes_zoophile;
// Cum // Cum
public static readonly GeneDef rjw_genes_no_cum; public static readonly GeneDef rjw_genes_no_cum;
@ -64,8 +63,7 @@ namespace RJW_Genes
// Reproduction // Reproduction
public static readonly GeneDef rjw_genes_hypersexual; public static readonly GeneDef rjw_genes_hypersexual;
public static readonly GeneDef rjw_genes_rapist; public static readonly GeneDef rjw_genes_rapist;
public static readonly GeneDef rjw_genes_homosexual; public static readonly GeneDef rjw_genes_zoophile;
public static readonly GeneDef rjw_genes_bisexual;
// Damage & Side Effects // Damage & Side Effects
[MayRequire("LustLicentia.RJWLabs")] public static readonly GeneDef rjw_genes_elasticity; [MayRequire("LustLicentia.RJWLabs")] public static readonly GeneDef rjw_genes_elasticity;

View file

@ -13,12 +13,6 @@ namespace RJW_Genes
{ {
base.PostMake(); base.PostMake();
// If the Pawn is already a Futa, do not do anything. Can Happen by Base-RJW Spawn Chance or potentially races / other mods.
if (IsAlreadyFuta(pawn))
{
return;
}
if (GenderUtility.IsFemale(pawn) && additional_genital == null) if (GenderUtility.IsFemale(pawn) && additional_genital == null)
{ {
createAndAddPenis(); createAndAddPenis();
@ -33,12 +27,6 @@ namespace RJW_Genes
{ {
base.PostAdd(); base.PostAdd();
// If the Pawn is already a Futa, do not do anything. Can Happen by Base-RJW Spawn Chance or potentially races / other mods.
if (IsAlreadyFuta(pawn))
{
return;
}
if (pawn.gender == Gender.Female && additional_genital == null) if (pawn.gender == Gender.Female && additional_genital == null)
{ {
createAndAddPenis(); createAndAddPenis();
@ -91,15 +79,5 @@ namespace RJW_Genes
pawn.health.AddHediff(additional_genital, partBPR); pawn.health.AddHediff(additional_genital, partBPR);
} }
private static bool IsAlreadyFuta(Pawn pawn)
{
if (pawn == null)
return false;
if (!Genital_Helper.has_genitals(pawn))
return false;
return
(Genital_Helper.has_penis_fertile(pawn) || Genital_Helper.has_penis_infertile(pawn))
&& Genital_Helper.has_vagina(pawn) ;
}
} }
} }

View file

@ -1,5 +1,4 @@
using System; using System;
using System.Collections.Generic;
using Verse; using Verse;
namespace RJW_Genes namespace RJW_Genes
@ -33,7 +32,7 @@ namespace RJW_Genes
return pawn.genes.HasGene(GeneDefOf.rjw_genes_youth_fountain); return pawn.genes.HasGene(GeneDefOf.rjw_genes_youth_fountain);
} }
public static bool IsAgeDrainer(Pawn pawn) internal static bool IsAgeDrainer(Pawn pawn)
{ {
if (pawn.genes == null) if (pawn.genes == null)
{ {
@ -96,25 +95,5 @@ namespace RJW_Genes
return pawn.genes.HasGene(GeneDefOf.rjw_genes_unbreakable); return pawn.genes.HasGene(GeneDefOf.rjw_genes_unbreakable);
} }
public static bool HasGenitaliaResizingGenes(Pawn pawn)
{
return !GetGenitaliaResizingGenes(pawn).NullOrEmpty();
}
public static List<Gene_GenitaliaResizingGene> GetGenitaliaResizingGenes(Pawn pawn)
{
var ResizingGenes = new List<Gene_GenitaliaResizingGene>();
// Error Handling: Issue with Pawn or Genes return empty.
if (pawn == null || pawn.genes == null)
return ResizingGenes;
foreach (Gene gene in pawn.genes.GenesListForReading)
if (gene is Gene_GenitaliaResizingGene resizing_gene)
ResizingGenes.Add(resizing_gene);
return ResizingGenes;
}
} }
} }

View file

@ -1,12 +1,24 @@
using Verse; using Verse;
namespace RJW_Genes namespace RJW_Genes
{ {
public class Gene_BigBreasts : Gene_GenitaliaResizingGene public class Gene_BigBreasts : RJW_Gene
{ {
public override void Resize()
public override void PostMake()
{ {
base.PostMake();
if (pawn.gender == Gender.Female)
SizeAdjuster.AdjustAllBreastSizes(pawn,0.5f,1.0f);
}
public override void PostAdd()
{
base.PostAdd();
if (pawn.gender == Gender.Female) if (pawn.gender == Gender.Female)
SizeAdjuster.AdjustAllBreastSizes(pawn, 0.5f, 1.0f); SizeAdjuster.AdjustAllBreastSizes(pawn, 0.5f, 1.0f);
} }
} }
} }

View file

@ -1,10 +1,20 @@
namespace RJW_Genes namespace RJW_Genes
{ {
public class Gene_BigMaleGenitalia : Gene_GenitaliaResizingGene public class Gene_BigMaleGenitalia : RJW_Gene
{ {
public override void Resize()
public override void PostMake()
{ {
base.PostMake();
SizeAdjuster.AdjustAllPenisSizes(pawn,0.5f,1.0f);
}
public override void PostAdd()
{
base.PostAdd();
SizeAdjuster.AdjustAllPenisSizes(pawn, 0.5f, 1.0f); SizeAdjuster.AdjustAllPenisSizes(pawn, 0.5f, 1.0f);
} }
} }
} }

View file

@ -1,49 +0,0 @@
namespace RJW_Genes
{
/// <summary>
/// Parent Gene for Genitalia Resizing. All Resizing genes should inherit for this class.
///
/// This helps with some functions (e.g. "hasGenitaliaResizingGenes(pawn)") but also to fire genitalia resizing later in life for Pawns.
/// (No Children with huge ding dongs, and I don't want kids with tight anuses I am not that degenerate)
/// </summary>
public abstract class Gene_GenitaliaResizingGene : RJW_Gene
{
public const int RESIZING_AGE = 20;
public bool WasApplied { get; set; }
public override void PostMake()
{
base.PostMake();
if (pawn.ageTracker.AgeBiologicalYears >= RESIZING_AGE)
{
Resize();
WasApplied = true;
}
}
public override void PostAdd()
{
base.PostAdd();
if (pawn.ageTracker.AgeBiologicalYears >= RESIZING_AGE)
{
Resize();
WasApplied = true;
}
}
/// <summary>
/// Used to resize the pawns genitalia.
/// All Logic should be put here:
/// 1. Filters for Gender
/// 2. Filters for Genitalia Existance
/// 3. Selection of right Genitalia
/// 4. Adjustment of Size
///
/// I kept it intentionally broad, so that e.g. the Penis Resize can resize multiple penises and also for futas,
/// while the breast-gene is female only.
/// </summary>
public abstract void Resize();
}
}

View file

@ -1,12 +1,22 @@
using Verse; namespace RJW_Genes
namespace RJW_Genes
{ {
public class Gene_LooseAnus : Gene_GenitaliaResizingGene public class Gene_LooseAnus : RJW_Gene
{ {
public override void Resize()
public override void PostMake()
{ {
base.PostMake();
SizeAdjuster.AdjustAllAnusSizes(pawn, 0.5f, 1.0f); SizeAdjuster.AdjustAllAnusSizes(pawn, 0.5f, 1.0f);
} }
public override void PostAdd()
{
base.PostAdd();
SizeAdjuster.AdjustAllAnusSizes(pawn, 0.5f, 1.0f);
}
} }
} }

View file

@ -1,12 +1,22 @@
using Verse; namespace RJW_Genes
namespace RJW_Genes
{ {
public class Gene_LooseFemaleGenitalia : Gene_GenitaliaResizingGene public class Gene_LooseFemaleGenitalia : RJW_Gene
{ {
public override void Resize()
public override void PostMake()
{ {
base.PostMake();
SizeAdjuster.AdjustAllVaginaSizes(pawn, 0.5f, 1.0f); SizeAdjuster.AdjustAllVaginaSizes(pawn, 0.5f, 1.0f);
} }
public override void PostAdd()
{
base.PostAdd();
SizeAdjuster.AdjustAllVaginaSizes(pawn, 0.5f, 1.0f);
}
} }
} }

View file

@ -1,11 +1,18 @@
using Verse; namespace RJW_Genes
namespace RJW_Genes
{ {
public class Gene_SmallBreasts : Gene_GenitaliaResizingGene public class Gene_SmallBreasts : RJW_Gene
{ {
public override void Resize()
public override void PostMake()
{ {
base.PostMake();
SizeAdjuster.AdjustAllBreastSizes(pawn, 0.0f, 0.5f);
}
public override void PostAdd()
{
base.PostAdd();
SizeAdjuster.AdjustAllBreastSizes(pawn, 0.0f, 0.5f); SizeAdjuster.AdjustAllBreastSizes(pawn, 0.0f, 0.5f);
} }
} }

View file

@ -1,10 +1,20 @@
namespace RJW_Genes namespace RJW_Genes
{ {
public class Gene_SmallMaleGenitalia : Gene_GenitaliaResizingGene public class Gene_SmallMaleGenitalia : RJW_Gene
{ {
public override void Resize()
public override void PostMake()
{ {
base.PostMake();
SizeAdjuster.AdjustAllPenisSizes(pawn,0.0f,0.5f);
}
public override void PostAdd()
{
base.PostAdd();
SizeAdjuster.AdjustAllPenisSizes(pawn, 0.0f, 0.5f); SizeAdjuster.AdjustAllPenisSizes(pawn, 0.0f, 0.5f);
} }
} }
} }

View file

@ -1,10 +1,21 @@
namespace RJW_Genes namespace RJW_Genes
{ {
public class Gene_TightAnus : Gene_GenitaliaResizingGene public class Gene_TightAnus : RJW_Gene
{ {
public override void Resize()
public override void PostMake()
{ {
base.PostMake();
SizeAdjuster.AdjustAllAnusSizes(pawn, 0.0f, 0.5f); SizeAdjuster.AdjustAllAnusSizes(pawn, 0.0f, 0.5f);
} }
public override void PostAdd()
{
base.PostAdd();
SizeAdjuster.AdjustAllAnusSizes(pawn, 0.0f, 0.5f);
}
} }
} }

View file

@ -1,10 +1,20 @@
namespace RJW_Genes namespace RJW_Genes
{ {
public class Gene_TightFemaleGenitalia : Gene_GenitaliaResizingGene public class Gene_TightFemaleGenitalia : RJW_Gene
{ {
public override void Resize()
public override void PostMake()
{ {
base.PostMake();
SizeAdjuster.AdjustAllVaginaSizes(pawn, 0.0f, 0.5f); SizeAdjuster.AdjustAllVaginaSizes(pawn, 0.0f, 0.5f);
} }
public override void PostAdd()
{
base.PostAdd();
SizeAdjuster.AdjustAllVaginaSizes(pawn, 0.0f, 0.5f);
}
} }
} }

View file

@ -1,30 +0,0 @@
using HarmonyLib;
using Verse;
namespace RJW_Genes
{
/// <summary>
/// This Patch adds behavior to all resizing genes:
/// At Age RESIZING_MIN_AGE the Pawns Resizing Genes will trigger again, if not already triggered somewhere else.
/// This is meant to allow kids to grow up without resized genitals, and resize later (Fixing #11).
/// </summary>
[HarmonyPatch(typeof(Pawn_AgeTracker), "BirthdayBiological")]
public class Patch_ResizingOnAdulthood
{
static void Postfix(Pawn ___pawn, int birthdayAge)
{
if (birthdayAge >= Gene_GenitaliaResizingGene.RESIZING_AGE)
{
foreach(Gene_GenitaliaResizingGene gene in GeneUtility.GetGenitaliaResizingGenes(___pawn))
{
if (!gene.WasApplied)
{
gene.Resize();
gene.WasApplied = true;
}
}
}
}
}
}

View file

@ -13,11 +13,9 @@ namespace RJW_Genes.Genes.Special
{ {
const long AGE_TRANSFERED = 120000; // 120k == 2 days const long AGE_TRANSFERED = 120000; // 120k == 2 days
// 20 Years * 60 Days / Year * 60k Ticks/Day + 1 for safety
const long MINIMUM_AGE = 20 * 60 * 60000 + 1;
// Comment Below in for debugging, changes years // Comment Below in for debugging, changes years
// const long AGE_TRANSFERED = 12000000; // const long AGE_TRANSFERED = 6000000; // 6000k == 100 days
public static void Postfix(SexProps props) public static void Postfix(SexProps props)
{ {
if (props == null || props.pawn == null || props.partner == null || props.partner.IsAnimal() ) if (props == null || props.pawn == null || props.partner == null || props.partner.IsAnimal() )
@ -27,12 +25,12 @@ namespace RJW_Genes.Genes.Special
if (GeneUtility.IsAgeDrainer(props.pawn)) if (GeneUtility.IsAgeDrainer(props.pawn))
{ {
var pawnAge = props.pawn.ageTracker.AgeBiologicalTicks; var pawnAge = props.pawn.ageTracker.AgeBiologicalTicks;
//ModLog.Error($"Firing Age Drain \nMinimum Age is \t{MINIMUM_AGE} \nPawn Age is \t{pawnAge} \nTransferred \t{AGE_TRANSFERED}\nResulting in \t{pawnAge - AGE_TRANSFERED}"); var pawnMinAge = props.pawn.ageTracker.AdultMinAgeTicks;
// Make Partner older // Make Partner older
props.partner.ageTracker.AgeBiologicalTicks += AGE_TRANSFERED; props.partner.ageTracker.AgeBiologicalTicks += AGE_TRANSFERED;
// Make Pawn younger // Make Pawn younger
props.pawn.ageTracker.AgeBiologicalTicks = Math.Max(MINIMUM_AGE, (pawnAge - AGE_TRANSFERED)); props.pawn.ageTracker.AgeBiologicalTicks = Math.Max(pawnMinAge, pawnAge - AGE_TRANSFERED);
} }
} }

View file

@ -13,11 +13,9 @@ namespace RJW_Genes.Genes.Special
{ {
const long AGE_REDUCTION = 60000; // 60k == 1 day const long AGE_REDUCTION = 60000; // 60k == 1 day
// 20 Years * 60 Days / Year * 60k Ticks/Day + 1 for safety
const long MINIMUM_AGE = 20 * 60 * 60000 + 1;
// Comment Below in for debugging // Comment Below in for debugging
// const long AGE_REDUCTION = 6000000; // 6000k == 100 days //const long AGE_REDUCTION = 6000000; // 6000k == 100 days
public static void Postfix(SexProps props) public static void Postfix(SexProps props)
{ {
if (props == null || props.pawn == null || props.partner == null || props.partner.IsAnimal()) if (props == null || props.pawn == null || props.partner == null || props.partner.IsAnimal())
@ -27,18 +25,12 @@ namespace RJW_Genes.Genes.Special
if (GeneUtility.IsYouthFountain(props.pawn)) if (GeneUtility.IsYouthFountain(props.pawn))
{ {
var partnerAge = props.partner.ageTracker.AgeBiologicalTicks; var partnerAge = props.partner.ageTracker.AgeBiologicalTicks;
var minAge = props.partner.ageTracker.AdultMinAgeTicks;
//ModLog.Error($"Firing Youth Fountain \nMinimum Age is \t{MINIMUM_AGE}\t{ticksToYears(MINIMUM_AGE)}y\nPawn Age is \t{partnerAge}\t{ticksToYears(partnerAge)}y \nTransferred \t {AGE_REDUCTION}\t{ticksToYears(AGE_REDUCTION)}y\nResulting in \t{partnerAge - AGE_REDUCTION}\t{ticksToYears(partnerAge - AGE_REDUCTION)}y"); props.partner.ageTracker.AgeBiologicalTicks = Math.Max(minAge, partnerAge - AGE_REDUCTION);
props.partner.ageTracker.AgeBiologicalTicks = Math.Max(MINIMUM_AGE, partnerAge - AGE_REDUCTION);
} }
} }
private static float ticksToYears(long ticks)
{
return (ticks / 60000f) / 60f;
} }
}
} }