Catch attempting to tick uninitialized wombs

This commit is contained in:
lutepickle 2022-09-09 09:38:16 -07:00
parent 0e8c025429
commit 003f5d6d29
2 changed files with 13 additions and 0 deletions

Binary file not shown.

View file

@ -72,6 +72,7 @@ namespace RJW_Menstruation
public Stage curStage = Stage.Follicular; public Stage curStage = Stage.Follicular;
public int curStageHrs = 0; public int curStageHrs = 0;
public bool loaded = false; public bool loaded = false;
public bool initError = false;
public int ovarypower = -100000; public int ovarypower = -100000;
public int eggstack = 0; public int eggstack = 0;
public bool DoCleanWomb = false; public bool DoCleanWomb = false;
@ -610,6 +611,13 @@ namespace RJW_Menstruation
// If an exception makes it out, RW will remove the hediff, so catch it here // If an exception makes it out, RW will remove the hediff, so catch it here
try try
{ {
// Initialize immediately if needed, but if there's an error, then don't spam it every tick
if (!loaded && !initError)
{
Log.Warning($"{Pawn}'s womb is ticking, but was not initialized first");
Initialize();
}
if ( if (
!Pawn.IsHashIntervalTick(tickInterval) || !Pawn.IsHashIntervalTick(tickInterval) ||
!ShouldSimulate() !ShouldSimulate()
@ -618,6 +626,8 @@ namespace RJW_Menstruation
return; return;
} }
if (initError) Log.Warning($"Attempting to process {Pawn}'s womb uninitialized");
if (Pregnancy != null && curStage != Stage.Pregnant) if (Pregnancy != null && curStage != Stage.Pregnant)
{ {
Log.Warning($"{Pawn}'s womb has a pregnancy, but was not in the pregnant stage"); Log.Warning($"{Pawn}'s womb has a pregnancy, but was not in the pregnant stage");
@ -994,6 +1004,7 @@ namespace RJW_Menstruation
public void Initialize() public void Initialize()
{ {
initError = true;
Props = (CompProperties_Menstruation)props; Props = (CompProperties_Menstruation)props;
if (Props.infertile) if (Props.infertile)
@ -1001,6 +1012,7 @@ namespace RJW_Menstruation
if (cums == null) cums = new List<Cum>(); if (cums == null) cums = new List<Cum>();
curStage = Stage.None; curStage = Stage.None;
loaded = true; loaded = true;
initError = false;
return; return;
} }
@ -1028,6 +1040,7 @@ namespace RJW_Menstruation
//Log.Message(Pawn.Label + " - Initialized menstruation comp"); //Log.Message(Pawn.Label + " - Initialized menstruation comp");
loaded = true; loaded = true;
initError = false;
} }
protected virtual float RaceCyclesPerYear() protected virtual float RaceCyclesPerYear()