mirror of
https://github.com/vegapnk/RJW-Genes.git
synced 2024-08-15 00:23:31 +00:00
resplice patch
This commit is contained in:
parent
0617ea4995
commit
07a0ab0600
11 changed files with 227 additions and 12 deletions
122
Source/Genes/Patches/LustFeeding.cs
Normal file
122
Source/Genes/Patches/LustFeeding.cs
Normal file
|
@ -0,0 +1,122 @@
|
|||
using RimWorld;
|
||||
using rjw;
|
||||
using Verse;
|
||||
using System;
|
||||
using RimWorld.Planet;
|
||||
|
||||
|
||||
|
||||
namespace RJWLoveFeeding
|
||||
{
|
||||
static class LustFeeding
|
||||
{
|
||||
//[HarmonyPostfix]
|
||||
static Def LoveFeed = DefDatabase<GeneDef>.GetNamed("RS_LoveFeed", false);
|
||||
static Def VampireLover = DefDatabase<GeneDef>.GetNamed("VU_VampireLover", false);
|
||||
public static void Postfix(SexProps props)
|
||||
{
|
||||
try
|
||||
{
|
||||
LustFeeding.RJWLustFeeding(props);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
Log.Error(e.ToString());
|
||||
}
|
||||
}
|
||||
|
||||
public static void RJWLustFeeding(SexProps props)
|
||||
{
|
||||
if((props.pawn != null) && (props.partner != null) && !xxx.is_animal(props.pawn) && !xxx.is_animal(props.partner))
|
||||
{
|
||||
//ModLog.Message($" Patch Worked");
|
||||
if(!props.pawn.IsCaravanMember() && !props.partner.IsCaravanMember())
|
||||
{
|
||||
RJWTryTakeBlood(props.pawn, props.partner);
|
||||
RJWTryTakeBlood(props.partner, props.pawn);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
public static bool RJWTryTakeBlood(Pawn pawn, Pawn bloodBag)
|
||||
{
|
||||
|
||||
|
||||
Pawn_GeneTracker genes = bloodBag.genes;
|
||||
if ((genes.GetFirstGeneOfType<Gene_Hemogen>() != null))
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
genes = pawn.genes;
|
||||
|
||||
if (genes == null)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
bool isLoveFeeder = false;
|
||||
|
||||
if(LoveFeed != null)
|
||||
{
|
||||
if (RJWSettings.DevMode) RJW_Genes.ModLog.Message("LoveFeed checks");
|
||||
if (genes.HasActiveGene(RJW_Genes.GeneDefOf.RS_LoveFeed))
|
||||
{
|
||||
|
||||
isLoveFeeder = true;
|
||||
}
|
||||
}
|
||||
if (VampireLover != null)
|
||||
{
|
||||
if (RJWSettings.DevMode) RJW_Genes.ModLog.Message("LoveFeed checks");
|
||||
if (genes.HasActiveGene(RJW_Genes.GeneDefOf.VU_VampireLover))
|
||||
{
|
||||
isLoveFeeder = true;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if (isLoveFeeder && (genes.GetFirstGeneOfType<Gene_Hemogen>() != null))
|
||||
{
|
||||
ModLog.Message($" Lovefeeder just finished loving: {xxx.get_pawnname(pawn)}");
|
||||
|
||||
Gene_Hemogen gene_Hemogen = genes.GetFirstGeneOfType<Gene_Hemogen>();
|
||||
if (gene_Hemogen != null)
|
||||
{
|
||||
if (gene_Hemogen.Value < gene_Hemogen.targetValue)
|
||||
{
|
||||
Hediff bloodBagBloodLoss = bloodBag.health.hediffSet.GetFirstHediffOfDef(HediffDefOf.BloodLoss, false);
|
||||
if (bloodBagBloodLoss != null)
|
||||
{
|
||||
float afterBite = bloodBagBloodLoss.Severity + 0.25f;
|
||||
if ((afterBite > HediffDefOf.BloodLoss.lethalSeverity) || (afterBite > 0.49f))
|
||||
{
|
||||
//ModLog.Message($"{xxx.get_pawnname(pawn)} would have killed someone. {afterBite} > {HediffDefOf.BloodLoss.lethalSeverity}");
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
||||
SanguophageUtility.DoBite(pawn, bloodBag, 0.2f, 0.1f, 0.2f, 1f, IntRange.one, ThoughtDefOf.FedOn, ThoughtDefOf.FedOn_Social);
|
||||
ModLog.Message($"{xxx.get_pawnname(pawn)} snacked on {xxx.get_pawnname(bloodBag)}");
|
||||
return true;
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
ModLog.Message($"{xxx.get_pawnname(pawn)} not hungry. {gene_Hemogen.Value} > {gene_Hemogen.targetValue}");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
return false; ;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue