From 73390bdcc7e8c8e341b4e04a53420b1206ea1a8e Mon Sep 17 00:00:00 2001 From: roxik0 Date: Tue, 2 Jan 2024 14:38:54 +0100 Subject: [PATCH] Possible #81 Fix of applying inventory --- source/ScrapYard/InventoryPart.cs | 72 ++++++++++--------- .../Utilities/InventoryManagement.cs | 16 +++-- 2 files changed, 47 insertions(+), 41 deletions(-) diff --git a/source/ScrapYard/InventoryPart.cs b/source/ScrapYard/InventoryPart.cs index 7d23f76..a211b68 100644 --- a/source/ScrapYard/InventoryPart.cs +++ b/source/ScrapYard/InventoryPart.cs @@ -128,7 +128,7 @@ public InventoryPart(Part originPart) { _dryCost -= (float)(resource.maxAmount * PartResourceLibrary.Instance.GetDefinition(resource.resourceName).unitCost); } - + ID = originPart.persistentId; //Save modules if (originPart.Modules != null) { @@ -137,6 +137,7 @@ public InventoryPart(Part originPart) { string name = module.moduleName; bool isTracker = name.Equals("ModuleSYPartTracker"); + if (isTracker) { ConfigNode saved = new ConfigNode("MODULE"); @@ -145,13 +146,14 @@ public InventoryPart(Part originPart) if (isTracker) { TrackerModule = new TrackerModuleWrapper(saved); + ID = TrackerModule.ID ?? ID; } } _cachedModules.Add(module); } } - - ID = originPart.persistentId; + + } /// @@ -160,33 +162,34 @@ public InventoryPart(Part originPart) /// The to use as the basis of the . public InventoryPart(ProtoPartSnapshot originPartSnapshot) { - _name = originPartSnapshot.partInfo.name; - if (ScrapYard.Instance.Settings.PartBlacklist.Contains(Name)) - { - DoNotStore = true; - } - float fuelCost; - ShipConstruction.GetPartCosts(originPartSnapshot, originPartSnapshot.partInfo, out _dryCost, out fuelCost); - - //Save modules - if (originPartSnapshot.modules != null) + _name = originPartSnapshot.partInfo.name; + if (ScrapYard.Instance.Settings.PartBlacklist.Contains(Name)) + { + DoNotStore = true; + } + float fuelCost; + ShipConstruction.GetPartCosts(originPartSnapshot, originPartSnapshot.partInfo, out _dryCost, out fuelCost); + ID = originPartSnapshot.persistentId; + //Save modules + if (originPartSnapshot.modules != null) + { + foreach (ProtoPartModuleSnapshot module in originPartSnapshot.modules) { - foreach (ProtoPartModuleSnapshot module in originPartSnapshot.modules) + string name = module.moduleName; + bool isTracker = name.Equals("ModuleSYPartTracker"); + if (isTracker || moduleNameMatchesAnything(name)) //only save if there is a potential match { - string name = module.moduleName; - bool isTracker = name.Equals("ModuleSYPartTracker"); - if (isTracker || moduleNameMatchesAnything(name)) //only save if there is a potential match + ConfigNode saved = module.moduleValues; + _allModules.Add(saved); + if (isTracker) { - ConfigNode saved = module.moduleValues; - _allModules.Add(saved); - if (isTracker) - { - TrackerModule = new TrackerModuleWrapper(saved); - } + TrackerModule = new TrackerModuleWrapper(saved); + ID = TrackerModule.ID ?? ID; } } } - ID = originPartSnapshot.persistentId; + } + } /// @@ -213,7 +216,15 @@ public InventoryPart(ConfigNode originPartConfigNode) float dryMass, fuelMass, fuelCost; ShipConstruction.GetPartCostsAndMass(originPartConfigNode, availablePartForNode, out _dryCost, out fuelCost, out dryMass, out fuelMass); } - + uint id = 0; + if (originPartConfigNode.TryGetValue("persistentId", ref id)) + { + ID = id; + } + else + { + Logging.Log($"Could not find a persistent ID for part {_name}", Logging.LogType.ERROR); + } if (originPartConfigNode.HasNode("MODULE")) { foreach (ConfigNode module in originPartConfigNode.GetNodes("MODULE")) @@ -224,19 +235,12 @@ public InventoryPart(ConfigNode originPartConfigNode) if (isTracker) { TrackerModule = new TrackerModuleWrapper(module); + ID = TrackerModule.ID ?? ID; } } } - uint id = 0; - if (originPartConfigNode.TryGetValue("persistentId", ref id)) - { - ID = id; - } - else - { - Logging.Log($"Could not find a persistent ID for part {_name}", Logging.LogType.ERROR); - } + } } diff --git a/source/ScrapYard/Utilities/InventoryManagement.cs b/source/ScrapYard/Utilities/InventoryManagement.cs index 4306c15..ce10177 100644 --- a/source/ScrapYard/Utilities/InventoryManagement.cs +++ b/source/ScrapYard/Utilities/InventoryManagement.cs @@ -41,7 +41,7 @@ public static void SplitParts(IEnumerable input, out IList /// The vessel as a list of parts public static void ApplyInventoryToVessel(IEnumerable input) { - PartInventory copy = ScrapYard.Instance.TheInventory.Copy(); + PartInventory copy = ScrapYard.Instance.TheInventory.Copy(); foreach (Part part in input) { //convert it to an inventorypart @@ -57,19 +57,20 @@ public static void ApplyInventoryToVessel(IEnumerable input) //if one was found... if (inInventory != null) { - Logging.DebugLog("Found a part in inventory for " + inInventory.Name); + Logging.DebugLog("A: Found a part in inventory for " + inInventory.Name); //copy it's part tracker over if (inInventory.TrackerModule != null && part.Modules?.Contains("ModuleSYPartTracker") == true) { ModuleSYPartTracker tracker = part.Modules["ModuleSYPartTracker"] as ModuleSYPartTracker; tracker.TimesRecovered = inInventory.TrackerModule.TimesRecovered; tracker.Inventoried = inInventory.TrackerModule.Inventoried; - Logging.Log($"Copied tracker. Recovered {tracker.TimesRecovered} times with id {inInventory.ID}"); + tracker.ID = inInventory.ID; + Logging.Log($"A: Copied tracker. Recovered {tracker.TimesRecovered} times with id {inInventory.ID}"); } } } - ScrapYardEvents.OnSYInventoryAppliedToVessel.Fire(); + ScrapYardEvents.OnSYInventoryAppliedToVessel.Fire(); GameEvents.onEditorShipModified.Fire(EditorLogic.fetch.ship); } @@ -94,7 +95,7 @@ public static void ApplyInventoryToVessel(IEnumerable input) //if one was found... if (inInventory != null) { - Logging.DebugLog("Found a part in inventory for " + inInventory.Name); + Logging.DebugLog("B:Found a part in inventory for " + inInventory.Name); //copy it's part tracker over ConfigNode trackerNode; if (inInventory.TrackerModule != null && (trackerNode = partNode.GetModuleNode("ModuleSYPartTracker")) != null) @@ -105,11 +106,12 @@ public static void ApplyInventoryToVessel(IEnumerable input) trackerNode.SetValue("ID", id); trackerNode.SetValue("TimesRecovered", recovered); trackerNode.SetValue("Inventoried", inventoried); - Logging.DebugLog($"Copied tracker. Recovered {recovered} times with id {id}"); + Logging.DebugLog($"B:Copied tracker. Recovered {recovered} times with id {id}"); + } } } - ScrapYardEvents.OnSYInventoryAppliedToVessel.Fire(); + ScrapYardEvents.OnSYInventoryAppliedToVessel.Fire(); GameEvents.onEditorShipModified.Fire(EditorLogic.fetch.ship); }