Compare commits

..

5 commits

Author SHA1 Message Date
Akiyami Solo
44f7b692d3 Merge branch 'dev' into 'dev'
Breast fullness is not displayed and the "milk yourself" action is not invoked on a pawn when the rjw-mc-biotech mod is present

See merge request lutepickle/rjw_menstruation!6
2024-08-04 22:57:59 +00:00
lutepickle
36c88d2752 Null check for pawn job in GetOvaryIcon 2024-08-03 08:59:06 -07:00
lutepickle
3d9b22776e Remove vaginal washing order for pawns that don't cycle 2024-07-31 15:20:07 -07:00
lutepickle
80611882c9 Don't show stage or time to next stage for pawns that don't cycle 2024-07-31 15:16:06 -07:00
lutepickle
f70c2ad585 Put a warning in the log when loading a pregnancy with mother == father 2024-07-31 07:22:20 -07:00
3 changed files with 18 additions and 6 deletions

View file

@ -639,10 +639,14 @@ namespace RJW_Menstruation
if (Scribe.mode == LoadSaveMode.PostLoadInit)
{
Initialize();
if (pregnancy is HediffWithParents vanillaPreg && vanillaPreg.Mother == vanillaPreg.Father) // Fix mother == father issue
// Biotech labor errors if the mother is also the father, so don't let that happen
if (pregnancy is HediffWithParents vanillaPreg && vanillaPreg.Mother == vanillaPreg.Father && vanillaPreg.Mother != null)
{
Log.Warning($"Pregnancy of {Pawn} has same mother and father, setting father to null");
vanillaPreg.SetParents(vanillaPreg.Mother, null, vanillaPreg.geneSet);
}
}
}
public override void CompPostPostAdd(DamageInfo? dinfo)
@ -790,7 +794,7 @@ namespace RJW_Menstruation
{
get
{
if (Pawn.Dead) return null;
if (Pawn.Dead || !Pawn.ShouldCycle()) return null;
StringBuilder tip = new StringBuilder();
tip.Append(Translations.Dialog_WombInfo01);
tip.Append(": ");
@ -812,7 +816,11 @@ namespace RJW_Menstruation
public override string CompDebugString()
{
if (Pawn.Dead || curStage == Stage.None || curStage == Stage.Infertile || curStage == Stage.Pregnant) return null;
if (Pawn.Dead ||
!Pawn.ShouldCycle() ||
curStage == Stage.None ||
curStage == Stage.Infertile ||
curStage == Stage.Pregnant) return null;
StringBuilder debugString = new StringBuilder();
debugString.Append($"Time to next state: ");
debugString.Append(GenDate.ToStringTicksToPeriod(TicksToNextStage()));

View file

@ -242,7 +242,7 @@ namespace RJW_Menstruation
bool isInduced = comp is HediffComp_InducedOvulator;
if (comp.curStage == HediffComp_Menstruation.Stage.Follicular &&
isInduced &&
comp.Pawn.jobs.curDriver is JobDriver_Sex job &&
comp.Pawn.jobs?.curDriver is JobDriver_Sex job &&
job.Sexprops != null &&
!UsingCondom(comp.Pawn, job.Partner) &&
(job.Sexprops.sexType == xxx.rjwSextype.Vaginal || job.Sexprops.sexType == xxx.rjwSextype.DoublePenetration))

View file

@ -33,10 +33,14 @@ namespace RJW_Menstruation
foreach (LocalTargetInfo t in selftargets)
{
if (t.Pawn == pawn && pawn.HasMenstruationComp()) opts.AddDistinct(MakeSelfMenu(pawn, t));
if (t.Pawn == pawn)
{
if (pawn.HasMenstruationComp() && pawn.ShouldCycle())
opts.AddDistinct(MakeSelfMenu(pawn, t));
break;
}
}
}
public static FloatMenuOption MakeSelfMenu(Pawn pawn, LocalTargetInfo target)
{