2023-04-23 12:15:07 +00:00
|
|
|
|
using RimWorld;
|
|
|
|
|
using rjw;
|
|
|
|
|
using System;
|
2022-07-26 03:55:56 +00:00
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using Verse;
|
|
|
|
|
using Verse.AI;
|
|
|
|
|
|
|
|
|
|
namespace RJWSexperience.Ideology
|
|
|
|
|
{
|
2023-04-23 12:15:07 +00:00
|
|
|
|
public class JobGiver_GangbangConsensual : ThinkNode_JobGiver
|
|
|
|
|
{
|
|
|
|
|
protected override Job TryGiveJob(Pawn pawn)
|
|
|
|
|
{
|
|
|
|
|
if (pawn.Drafted || pawn.mindState == null)
|
|
|
|
|
{
|
|
|
|
|
return null;
|
|
|
|
|
}
|
2022-07-26 03:55:56 +00:00
|
|
|
|
|
2023-04-23 12:15:07 +00:00
|
|
|
|
PawnDuty duty = pawn.mindState.duty;
|
2022-07-26 03:55:56 +00:00
|
|
|
|
|
2023-04-23 12:15:07 +00:00
|
|
|
|
if (duty.def == DutyDefOf.TravelOrLeave || !xxx.can_do_loving(pawn))
|
|
|
|
|
{
|
|
|
|
|
return null;
|
|
|
|
|
}
|
2022-07-26 03:55:56 +00:00
|
|
|
|
|
2023-04-23 12:15:07 +00:00
|
|
|
|
Pawn target = duty.focusSecond.Pawn;
|
2022-07-26 03:55:56 +00:00
|
|
|
|
|
2023-04-23 12:15:07 +00:00
|
|
|
|
if (!pawn.CanReach(target, PathEndMode.ClosestTouch, Danger.None))
|
|
|
|
|
return null;
|
2022-07-26 03:55:56 +00:00
|
|
|
|
|
2023-04-23 12:15:07 +00:00
|
|
|
|
return JobMaker.MakeJob(RsiDefOf.Job.Gangbang, target);
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-07-26 03:55:56 +00:00
|
|
|
|
|
|
|
|
|
public class JobDriver_Gangbang : JobDriver_SexBaseInitiator
|
|
|
|
|
{
|
|
|
|
|
public override bool TryMakePreToilReservations(bool errorOnFailed)
|
|
|
|
|
{
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected override IEnumerable<Toil> MakeNewToils()
|
|
|
|
|
{
|
|
|
|
|
setup_ticks();
|
|
|
|
|
|
|
|
|
|
this.FailOnDespawnedNullOrForbidden(iTarget);
|
|
|
|
|
this.FailOn(() => Partner == null);
|
|
|
|
|
this.FailOn(() => pawn.Drafted);
|
|
|
|
|
this.FailOn(() => Partner.Drafted);
|
|
|
|
|
yield return Toils_Goto.GotoThing(iTarget, PathEndMode.OnCell);
|
|
|
|
|
|
2023-04-23 12:15:07 +00:00
|
|
|
|
Toil StartPartnerJob = new Toil
|
2022-07-26 03:55:56 +00:00
|
|
|
|
{
|
2023-04-23 12:15:07 +00:00
|
|
|
|
defaultCompleteMode = ToilCompleteMode.Instant,
|
|
|
|
|
socialMode = RandomSocialMode.Off,
|
|
|
|
|
initAction = delegate
|
|
|
|
|
{
|
|
|
|
|
if (!(Partner.jobs.curDriver is JobDriver_SexBaseRecieverRaped))
|
|
|
|
|
{
|
|
|
|
|
Job gettin_loved = JobMaker.MakeJob(RsiDefOf.Job.GettinGangbang, pawn, Bed);
|
|
|
|
|
Partner.jobs.StartJob(gettin_loved, JobCondition.InterruptForced);
|
|
|
|
|
}
|
2022-07-26 03:55:56 +00:00
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
yield return StartPartnerJob;
|
|
|
|
|
|
2023-04-23 12:15:07 +00:00
|
|
|
|
Toil SexToil = new Toil
|
|
|
|
|
{
|
|
|
|
|
defaultCompleteMode = ToilCompleteMode.Never,
|
|
|
|
|
defaultDuration = duration,
|
|
|
|
|
handlingFacing = true
|
|
|
|
|
};
|
2023-04-23 11:41:27 +00:00
|
|
|
|
SexToil.FailOn(() => Partner.CurJob.def != RsiDefOf.Job.GettinGangbang);
|
2022-07-26 03:55:56 +00:00
|
|
|
|
SexToil.initAction = delegate
|
|
|
|
|
{
|
|
|
|
|
Start();
|
|
|
|
|
Sexprops.usedCondom = CondomUtility.TryUseCondom(pawn) || CondomUtility.TryUseCondom(Partner);
|
|
|
|
|
};
|
|
|
|
|
SexToil.AddPreTickAction(delegate
|
|
|
|
|
{
|
|
|
|
|
SexTick(pawn, Partner);
|
|
|
|
|
SexUtility.reduce_rest(Partner, 1);
|
|
|
|
|
SexUtility.reduce_rest(pawn, 2);
|
|
|
|
|
if (ticks_left <= 0)
|
|
|
|
|
ReadyForNextToil();
|
|
|
|
|
});
|
|
|
|
|
SexToil.AddFinishAction(delegate
|
|
|
|
|
{
|
|
|
|
|
End();
|
|
|
|
|
});
|
|
|
|
|
yield return SexToil;
|
|
|
|
|
|
|
|
|
|
yield return new Toil
|
|
|
|
|
{
|
|
|
|
|
initAction = delegate
|
|
|
|
|
{
|
|
|
|
|
// Trying to add some interactions and social logs
|
|
|
|
|
SexUtility.ProcessSex(Sexprops);
|
|
|
|
|
},
|
|
|
|
|
defaultCompleteMode = ToilCompleteMode.Instant
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public class JobDriver_GangbangReceiver : JobDriver_SexBaseRecieverLoved
|
2023-04-23 12:15:07 +00:00
|
|
|
|
{
|
2022-07-26 03:55:56 +00:00
|
|
|
|
protected override IEnumerable<Toil> MakeNewToils()
|
|
|
|
|
{
|
|
|
|
|
setup_ticks();
|
|
|
|
|
parteners.Add(Partner);// add job starter, so this wont fail, before Initiator starts his job
|
|
|
|
|
|
2023-04-23 12:15:07 +00:00
|
|
|
|
Toil get_banged = new Toil
|
2022-07-26 03:55:56 +00:00
|
|
|
|
{
|
2023-04-23 12:15:07 +00:00
|
|
|
|
defaultCompleteMode = ToilCompleteMode.Never,
|
|
|
|
|
handlingFacing = true,
|
|
|
|
|
initAction = delegate
|
|
|
|
|
{
|
|
|
|
|
pawn.pather.StopDead();
|
|
|
|
|
pawn.jobs.curDriver.asleep = false;
|
|
|
|
|
},
|
|
|
|
|
tickAction = delegate
|
|
|
|
|
{
|
|
|
|
|
if ((parteners.Count > 0) && pawn.IsHashIntervalTick(ticks_between_hearts / parteners.Count) && pawn.IsHashIntervalTick(ticks_between_hearts))
|
|
|
|
|
ThrowMetaIconF(pawn.Position, pawn.Map, FleckDefOf.Heart);
|
|
|
|
|
}
|
2022-07-26 03:55:56 +00:00
|
|
|
|
};
|
|
|
|
|
get_banged.AddEndCondition(new Func<JobCondition>(() =>
|
|
|
|
|
{
|
2023-04-23 12:15:07 +00:00
|
|
|
|
if (parteners.Count == 0)
|
2022-07-26 03:55:56 +00:00
|
|
|
|
{
|
|
|
|
|
return JobCondition.Succeeded;
|
|
|
|
|
}
|
|
|
|
|
return JobCondition.Ongoing;
|
|
|
|
|
}));
|
|
|
|
|
get_banged.AddFinishAction(delegate
|
|
|
|
|
{
|
|
|
|
|
if (xxx.is_human(pawn))
|
2024-04-29 16:02:37 +00:00
|
|
|
|
{
|
|
|
|
|
CompRJW comp = CompRJW.Comp(pawn);
|
|
|
|
|
if (comp != null)
|
|
|
|
|
{
|
|
|
|
|
comp.drawNude = false;
|
|
|
|
|
pawn.Drawer.renderer.SetAllGraphicsDirty();
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-07-26 03:55:56 +00:00
|
|
|
|
GlobalTextureAtlasManager.TryMarkPawnFrameSetDirty(pawn);
|
|
|
|
|
|
|
|
|
|
if (Bed != null && pawn.Downed)
|
|
|
|
|
{
|
|
|
|
|
Job tobed = JobMaker.MakeJob(JobDefOf.Rescue, pawn, Bed);
|
|
|
|
|
tobed.count = 1;
|
|
|
|
|
Partner.jobs.jobQueue.EnqueueFirst(tobed);
|
|
|
|
|
}
|
|
|
|
|
else if (pawn.HostileTo(Partner))
|
2023-04-23 12:15:07 +00:00
|
|
|
|
{
|
2022-07-26 03:55:56 +00:00
|
|
|
|
pawn.health.AddHediff(xxx.submitting);
|
2023-04-23 12:15:07 +00:00
|
|
|
|
}
|
2022-07-26 03:55:56 +00:00
|
|
|
|
});
|
|
|
|
|
get_banged.socialMode = RandomSocialMode.Off;
|
|
|
|
|
yield return get_banged;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|