From ee92e6b679cd203600b02de2ab5a110e96091b9d Mon Sep 17 00:00:00 2001 From: Sn1p3rr3c0n Date: Thu, 20 Jul 2023 17:27:30 +0200 Subject: [PATCH] #723 Added Error handeling checks --- .../AutoMachineTool/Building_BeltConveyor.cs | 35 +++++++++++++++++-- 1 file changed, 32 insertions(+), 3 deletions(-) diff --git a/Source/ProjectRimFactory/AutoMachineTool/Building_BeltConveyor.cs b/Source/ProjectRimFactory/AutoMachineTool/Building_BeltConveyor.cs index dd18d4c1..bc8d491d 100644 --- a/Source/ProjectRimFactory/AutoMachineTool/Building_BeltConveyor.cs +++ b/Source/ProjectRimFactory/AutoMachineTool/Building_BeltConveyor.cs @@ -463,7 +463,23 @@ public override bool AcceptsThing(Thing newThing, IPRF_Building giver = null) } else { - var target = this.State == WorkingState.Working ? this.Working : this.products[0]; + //Product must be empty for that error + + Thing target; + if (this.State == WorkingState.Working) + { + target = this.Working; + } + else + { + if(this.products.Count == 0) + { + Log.Error("PRF Belt - products List is Empty"); + this.Reset(); + } + target = this.products[0]; + } + Debug.Message(Debug.Flag.Conveyors, " but busy with " + target + ". Will try to absorb"); return target.TryAbsorbStack(newThing, true); @@ -491,8 +507,16 @@ public bool CanAcceptNow(Thing thing) return false; } } - protected bool ThisCanAcceptThat(Thing t1, Thing t2) => - t1.CanStackWith(t2) && t1.stackCount < t1.def.stackLimit; + protected bool ThisCanAcceptThat(Thing t1, Thing t2) + { + if(t1 == null || t2 == null) + { + Log.Error($"PRF ThisCanAcceptThat On thing is Null! t1: {t1} t2: {t2}"); + return false; + } + return t1.CanStackWith(t2) && t1.stackCount < t1.def.stackLimit; + } + // We (LWM) are mean and don't allow conveyors to change the "Obey Storage Filters" // setting. Maybe if zymex is really nice we can change this.... public override PRFBSetting SettingsOptions @@ -702,6 +726,11 @@ private void NotifyAroundSender() protected override bool WorkInterruption(Thing working) { + if (working == null) + { + Log.Error("PRF - WorkInterruption Null Thing"); + return true; + } return working.holdingOwner != thingOwnerInt; }