From 34a53e1a8f43dbc069e08d5f71d02ec5812b6821 Mon Sep 17 00:00:00 2001 From: edbmods Date: Sun, 21 Jul 2019 17:19:17 -0700 Subject: [PATCH 01/11] Stop using ThingDef.IsWithinCategory() to avoid recursion issues with parent categories. --- Source/EquipmentDatabase.cs | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) diff --git a/Source/EquipmentDatabase.cs b/Source/EquipmentDatabase.cs index 4381569..fb76a93 100644 --- a/Source/EquipmentDatabase.cs +++ b/Source/EquipmentDatabase.cs @@ -242,10 +242,10 @@ public EquipmentType ClassifyThingDef(ThingDef def) { if (def.isUnfinishedThing) { return TypeDiscard; } - if (def.IsWithinCategory(ThingCategoryDefOf.Corpses)) { + if (BelongsToCategoryOrParentCategory(def, ThingCategoryDefOf.Corpses)) { return TypeDiscard; } - if (def.IsWithinCategory(ThingCategoryDefOf.Chunks)) { + if (BelongsToCategoryOrParentCategory(def, ThingCategoryDefOf.Chunks)) { return TypeDiscard; } if (def.IsBlueprint) { @@ -334,6 +334,24 @@ public EquipmentType ClassifyThingDef(ThingDef def) { return null; } + private HashSet categoryLookup = new HashSet(); + // A duplicate of ThingDef.IsWithinCategory(), but with checks to prevent infinite recursion. + public bool BelongsToCategoryOrParentCategory(ThingDef def, ThingCategoryDef categoryDef) { + if (categoryDef == null || def.thingCategories == null) { + return false; + } + categoryLookup.Clear(); + for (int i = 0; i < def.thingCategories.Count; i++) { + for (ThingCategoryDef thingCategoryDef = def.thingCategories[i]; thingCategoryDef != null && !categoryLookup.Contains(thingCategoryDef.defName); thingCategoryDef = thingCategoryDef.parent) { + categoryLookup.Add(thingCategoryDef.defName); + if (thingCategoryDef.defName == categoryDef.defName) { + return true; + } + } + } + return false; + } + public bool BelongsToCategory(ThingDef def, ThingCategoryDef categoryDef) { if (categoryDef == null || def.thingCategories == null) { return false; From eb6b196e05c1837bac0e2d25e5d86891b60124f6 Mon Sep 17 00:00:00 2001 From: edbmods Date: Sun, 21 Jul 2019 20:00:34 -0700 Subject: [PATCH 02/11] Incremented version 1.0.13. --- Properties/AssemblyInfo.cs | 2 +- Resources/About/About.xml | 2 +- Resources/CHANGELOG.txt | 7 +++++++ 3 files changed, 9 insertions(+), 2 deletions(-) diff --git a/Properties/AssemblyInfo.cs b/Properties/AssemblyInfo.cs index bb900ed..22d834a 100644 --- a/Properties/AssemblyInfo.cs +++ b/Properties/AssemblyInfo.cs @@ -17,7 +17,7 @@ // The form "{Major}.{Minor}.*" will automatically update the build and revision, // and "{Major}.{Minor}.{Build}.*" will update just the revision. -[assembly: AssemblyVersion("1.0.12")] +[assembly: AssemblyVersion("1.0.13")] // The following attributes are used to specify the signing key for the assembly, // if desired. See the Mono documentation for more information about signing. diff --git a/Resources/About/About.xml b/Resources/About/About.xml index 8d8aa6b..cd36dca 100644 --- a/Resources/About/About.xml +++ b/Resources/About/About.xml @@ -10,6 +10,6 @@ If you get a set of starting colonists that you like, save them as a preset so that you can start your game the same way next time. -[Version 1.0.12] +[Version 1.0.13] \ No newline at end of file diff --git a/Resources/CHANGELOG.txt b/Resources/CHANGELOG.txt index bc4d5e1..a640f0b 100644 --- a/Resources/CHANGELOG.txt +++ b/Resources/CHANGELOG.txt @@ -1,3 +1,10 @@ + _____________________________________________________________________________ + + Version 1.0.13 + _____________________________________________________________________________ + + - Bug-fix for item categories with multiple parent categories. + _____________________________________________________________________________ Version 1.0.12 From 23acae8a91c5e0d29ed449ca7c8c0c0b9e29fca7 Mon Sep 17 00:00:00 2001 From: edbmods Date: Mon, 22 Jul 2019 21:59:46 -0700 Subject: [PATCH 03/11] Added a manifest file to support the Mod Manager mod. --- Resources/About/Manifest.xml | 13 +++++++++++++ 1 file changed, 13 insertions(+) create mode 100644 Resources/About/Manifest.xml diff --git a/Resources/About/Manifest.xml b/Resources/About/Manifest.xml new file mode 100644 index 0000000..05125e3 --- /dev/null +++ b/Resources/About/Manifest.xml @@ -0,0 +1,13 @@ + + + EdBPrepareCarefully + 1.0.12 + +
  • Core
  • +
  • HugsLib
  • +
  • JecsTools
  • +
    + false + https://github.com/edbmods/EdBPrepareCarefully/raw/master/Resources/About/Manifest.xml + https://github.com/edbmods/EdBPrepareCarefully/releases/latest +
    \ No newline at end of file From 41f02a423a9f3c91229c717ee8d6d6e90a94eedf Mon Sep 17 00:00:00 2001 From: edbmods Date: Mon, 22 Jul 2019 23:15:55 -0700 Subject: [PATCH 04/11] Issue #263. Fixed body part selection for injuries that affect specific body parts (i.e. cataracts, asthma, etc.) --- Source/OptionsHealth.cs | 17 ++++++++++++----- Source/PanelHealth.cs | 19 +++++++++++++++---- Source/ProviderHealthOptions.cs | 5 +++-- 3 files changed, 30 insertions(+), 11 deletions(-) diff --git a/Source/OptionsHealth.cs b/Source/OptionsHealth.cs index 1a6c7c4..dd65916 100644 --- a/Source/OptionsHealth.cs +++ b/Source/OptionsHealth.cs @@ -100,8 +100,7 @@ public UniqueBodyPart FindBodyPartByName(string name, int index) { return null; } public UniqueBodyPart FindBodyPartsForRecord(BodyPartRecord record) { - UniqueBodyPart result; - if (bodyPartRecordLookup.TryGetValue(record, out result)) { + if (bodyPartRecordLookup.TryGetValue(record, out UniqueBodyPart result)) { return result; } else { @@ -109,8 +108,7 @@ public UniqueBodyPart FindBodyPartsForRecord(BodyPartRecord record) { } } public List FindBodyPartsForDef(BodyPartDef def) { - List result; - if (bodyPartDefLookup.TryGetValue(def, out result)) { + if (bodyPartDefLookup.TryGetValue(def, out List result)) { return result; } else { @@ -187,7 +185,16 @@ public List InjuryOptions { } } public IEnumerable BodyPartsForInjury(InjuryOption option) { - return SkinCoveredBodyParts.Select((UniqueBodyPart p) => { return p.Record; }); + if (option.ValidParts == null || option.ValidParts.Count == 0) { + return SkinCoveredBodyParts.Select((UniqueBodyPart p) => { return p.Record; }); + } + else { + List records = new List(); + foreach (var part in option.ValidParts) { + records.AddRange(FindBodyPartsForDef(part).ConvertAll(p => p.Record)); + } + return records; + } } } } diff --git a/Source/PanelHealth.cs b/Source/PanelHealth.cs index 88a6dcb..b07609d 100644 --- a/Source/PanelHealth.cs +++ b/Source/PanelHealth.cs @@ -246,7 +246,7 @@ public void DrawAddButton() { }, ConfirmValidation = () => { if (selectedSeverity == null) { - return "EdB.PC.Error.MustSelectSeverity"; + return "EdB.PC.Panel.Health.Error.MustSelectSeverity"; } else { return null; @@ -314,6 +314,9 @@ public void DrawAddButton() { if (option.ValidParts == null && !option.WholeBody) { bodyPartSelectionRequired = true; } + else if (option.ValidParts != null && option.ValidParts.Count > 0) { + bodyPartSelectionRequired = true; + } else { bodyPartSelectionRequired = false; } @@ -333,10 +336,18 @@ public void DrawAddButton() { ResetSeverityOptions(selectedInjury); if (bodyPartSelectionRequired) { bodyPartDialog.Options = healthOptions.BodyPartsForInjury(selectedInjury); - ResetDisabledBodyParts(bodyPartDialog.Options, customPawn); - Find.WindowStack.Add(bodyPartDialog); + int count = bodyPartDialog.Options.Count(); + if (count > 1) { + ResetDisabledBodyParts(bodyPartDialog.Options, customPawn); + Find.WindowStack.Add(bodyPartDialog); + return; + } + else if (count == 1) { + selectedBodyPart = bodyPartDialog.Options.First(); + } } - else if (severityOptions.Count > 1) { + + if (severityOptions.Count > 1) { Find.WindowStack.Add(severityDialog); } else { diff --git a/Source/ProviderHealthOptions.cs b/Source/ProviderHealthOptions.cs index 7428da0..cbb6f96 100644 --- a/Source/ProviderHealthOptions.cs +++ b/Source/ProviderHealthOptions.cs @@ -110,7 +110,8 @@ protected void InitializeHediffGiverInjuries(OptionsHealth options, HediffGiver if (giver.partsToAffect != null && !giver.canAffectAnyLivePart) { List validParts = new List(); foreach (var def in giver.partsToAffect) { - if (options.FindBodyPartsForDef(def) != null) { + List parts = options.FindBodyPartsForDef(def); + if (parts != null) { validParts.Add(def); } } @@ -146,7 +147,7 @@ protected void InitializeInjuryOptions(OptionsHealth options, ThingDef pawnThing } } } - // Go though all of the chemical defs, looking for hediff givers. + // Go through all of the chemical defs, looking for hediff givers. foreach (var chemicalDef in DefDatabase.AllDefs) { if (chemicalDef.onGeneratedAddictedEvents != null) { foreach (var giver in chemicalDef.onGeneratedAddictedEvents) { From 82d365a61ad2ce6e494a3b35af8034f776d63416 Mon Sep 17 00:00:00 2001 From: edbmods Date: Wed, 24 Jul 2019 18:06:45 -0700 Subject: [PATCH 05/11] Added manifest file to the project. Fixed the version number in the manifest --- EdBPrepareCarefully.csproj | 4 +++- Resources/About/Manifest.xml | 2 +- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/EdBPrepareCarefully.csproj b/EdBPrepareCarefully.csproj index 86f34b7..49e673d 100644 --- a/EdBPrepareCarefully.csproj +++ b/EdBPrepareCarefully.csproj @@ -216,7 +216,9 @@ - + + + diff --git a/Resources/About/Manifest.xml b/Resources/About/Manifest.xml index 05125e3..656969c 100644 --- a/Resources/About/Manifest.xml +++ b/Resources/About/Manifest.xml @@ -1,7 +1,7 @@ EdBPrepareCarefully - 1.0.12 + 1.0.13
  • Core
  • HugsLib
  • From 7f3276482a8b1f3974daaa8962230087ee3c9a1c Mon Sep 17 00:00:00 2001 From: edbmods Date: Wed, 24 Jul 2019 18:09:05 -0700 Subject: [PATCH 06/11] Classified Combat Extended ammunition items as weapons in the equipment database. --- Source/EquipmentDatabase.cs | 36 +++++++++++++++--------------------- 1 file changed, 15 insertions(+), 21 deletions(-) diff --git a/Source/EquipmentDatabase.cs b/Source/EquipmentDatabase.cs index fb76a93..212ef02 100644 --- a/Source/EquipmentDatabase.cs +++ b/Source/EquipmentDatabase.cs @@ -124,7 +124,7 @@ protected void CountDefs() { protected void ProcessStuff() { for (int i = 0; i < LoadingProgress.stuffToProcessPerFrame; i++) { if (!LoadingProgress.enumerator.MoveNext()) { - Log.Message("Prepare Carefully loaded equipment database with " + LoadingProgress.stuffCount + " material(s)"); + Log.Message("Prepare Carefully :: Loaded equipment database with " + LoadingProgress.stuffCount + " material(s)"); NextPhase(); return; } @@ -138,7 +138,7 @@ protected void ProcessStuff() { protected void ProcessThings() { for (int i=0; i.AllDefs) { - try { - if (def != null) { - EquipmentType type = ClassifyThingDef(def); - if (type != null && type != TypeDiscard) { - AddThingDef(def, type); - } - } - } - catch (Exception e) { - Log.Warning("Prepare Carefully failed to classify thing definition while building equipment lists: " + def.defName); - Log.Message(" Exception: " + e.Message); - } - } - } - */ - private bool FoodTypeIsClassifiedAsFood(ThingDef def) { int foodTypes = (int)def.ingestible.foodType; if ((foodTypes & (int)FoodTypeFlags.Liquor) > 0) { @@ -295,6 +276,10 @@ public EquipmentType ClassifyThingDef(ThingDef def) { } if (def.CountAsResource) { + // Ammunition should be counted under the weapons category + if (HasTradeTag(def, "CE_Ammo")) { + return TypeWeapons; + } if (def.IsShell) { return TypeWeapons; } @@ -397,6 +382,15 @@ public bool BelongsToCategory(ThingDef def, string categoryName) { }) != null; } + public bool HasTradeTag(ThingDef def, string tradeTag) { + if (tradeTag.NullOrEmpty() || def.tradeTags == null) { + return false; + } + return def.tradeTags.FirstOrDefault(t => { + return tradeTag == t; + }) != null; + } + public IEnumerable AllEquipmentOfType(EquipmentType type) { return entries.Values.Where((EquipmentRecord e) => { return e.type == type; From 066a7edc205ab713e6916676ec042ca5cbb605fd Mon Sep 17 00:00:00 2001 From: edbmods Date: Wed, 24 Jul 2019 18:09:44 -0700 Subject: [PATCH 07/11] Updated the changelog --- Resources/CHANGELOG.txt | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Resources/CHANGELOG.txt b/Resources/CHANGELOG.txt index a640f0b..067d0c9 100644 --- a/Resources/CHANGELOG.txt +++ b/Resources/CHANGELOG.txt @@ -4,6 +4,8 @@ _____________________________________________________________________________ - Bug-fix for item categories with multiple parent categories. + - Bug fix for choosing body parts for injuries that affect specific parts. + - Updated the version of Harmony to 1.2.0.1 _____________________________________________________________________________ From 624a8355419cf290aa6d8f4de940b373eec3302f Mon Sep 17 00:00:00 2001 From: edbmods Date: Wed, 24 Jul 2019 18:16:01 -0700 Subject: [PATCH 08/11] Removed unused method. --- Source/Controller.cs | 12 ------------ 1 file changed, 12 deletions(-) diff --git a/Source/Controller.cs b/Source/Controller.cs index 48ad881..e490d77 100644 --- a/Source/Controller.cs +++ b/Source/Controller.cs @@ -103,18 +103,6 @@ public void SavePreset(string name) { state.AddMessage("SavedAs".Translate(PrepareCarefully.Instance.Filename)); } - private Pawn ConvertPawn(CustomPawn customPawn) { - customPawn.Pawn.SetFactionDirect(Faction.OfPlayer); - if (customPawn.Type == CustomPawnType.Colonist) { - customPawn.Pawn.SetFactionDirect(Faction.OfPlayer); - } - if (customPawn.Pawn.workSettings == null) { - customPawn.Pawn.workSettings = new Pawn_WorkSettings(customPawn.Pawn); - } - customPawn.Pawn.workSettings.EnableAndInitialize(); - return customPawn.Pawn; - } - public void PrepareGame() { PrepareColonists(); PrepareWorldPawns(); From e736f3f633654438ed668ee700d6bb501b7f42e7 Mon Sep 17 00:00:00 2001 From: edbmods Date: Sun, 28 Jul 2019 09:56:31 -0700 Subject: [PATCH 09/11] Issue #264: Added null-pointer check when retrieving the age generation curve to determine minimum and maximum age values. Defaults to the default pawn generator age generation curve if the curve is not found. --- Source/ProviderAgeLimits.cs | 51 ++++++++++++++++++++++++++++++++++--- 1 file changed, 47 insertions(+), 4 deletions(-) diff --git a/Source/ProviderAgeLimits.cs b/Source/ProviderAgeLimits.cs index 59a2ade..98913f6 100644 --- a/Source/ProviderAgeLimits.cs +++ b/Source/ProviderAgeLimits.cs @@ -1,6 +1,7 @@ using System; using System.Collections.Generic; using System.Linq; +using System.Reflection; using System.Text; using UnityEngine; using Verse; @@ -8,13 +9,29 @@ namespace EdB.PrepareCarefully { public class ProviderAgeLimits { + public static readonly int DEFAULT_MIN_AGE = 15; + public static readonly int DEFAULT_MAX_AGE = 100; private Dictionary minAgeLookup = new Dictionary(); private Dictionary maxAgeLookup = new Dictionary(); public int MinAgeForPawn(Pawn pawn) { if (!minAgeLookup.TryGetValue(pawn.def, out int age)) { - CurvePoint point = pawn.def.race.ageGenerationCurve.First(); - age = (int)point.x; + SimpleCurve simpleCurve = pawn.def.race.ageGenerationCurve; + if (simpleCurve == null) { + Log.Warning("Prepare Carefully :: No age generation curve defined for " + pawn.def.defName + ". Using default age generation curve to determine minimum age."); + simpleCurve = DefaultAgeGenerationCurve; + if (simpleCurve == null) { + Log.Warning("Prepare Carefully :: Failed to get default age generation curve. Using default minimum age of " + DEFAULT_MIN_AGE); + age = DEFAULT_MIN_AGE; + } + else { + age = Mathf.CeilToInt(pawn.def.race.lifeExpectancy * simpleCurve.First().x); + } + } + else { + CurvePoint point = simpleCurve.First(); + age = (int)point.x; + } minAgeLookup.Add(pawn.def, age); } return age; @@ -22,11 +39,37 @@ public int MinAgeForPawn(Pawn pawn) { public int MaxAgeForPawn(Pawn pawn) { if (!maxAgeLookup.TryGetValue(pawn.def, out int age)) { - CurvePoint point = pawn.def.race.ageGenerationCurve.Last(); - age = (int)(point.x * 1.2f); + SimpleCurve simpleCurve = pawn.def.race.ageGenerationCurve; + if (simpleCurve == null) { + Log.Warning("Prepare Carefully :: No age generation curve defined for " + pawn.def.defName + ". Using default age generation curve to determine maximum age."); + simpleCurve = DefaultAgeGenerationCurve; + if (simpleCurve == null) { + Log.Warning("Prepare Carefully :: Failed to get default age generation curve. Using default maximum age of " + DEFAULT_MAX_AGE); + age = DEFAULT_MAX_AGE; + } + else { + age = Mathf.CeilToInt(pawn.def.race.lifeExpectancy * simpleCurve.Last().x); + } + } + else { + CurvePoint point = simpleCurve.Last(); + age = (int)(point.x * 1.2f); + } maxAgeLookup.Add(pawn.def, age); } return age; } + + protected SimpleCurve DefaultAgeGenerationCurve { + get { + FieldInfo field = ReflectionUtil.GetNonPublicStaticField(typeof(Verse.PawnGenerator), "DefaultAgeGenerationCurve"); + if (field != null) { + return field.GetValue(null) as SimpleCurve; + } + else { + return null; + } + } + } } } From 3eac98743d85e9d67e4f3dc12f5026233bf03018 Mon Sep 17 00:00:00 2001 From: edbmods Date: Sun, 28 Jul 2019 10:43:22 -0700 Subject: [PATCH 10/11] The equipment database no longer classifies "toy" items as weapons. --- Source/EquipmentDatabase.cs | 3 +++ 1 file changed, 3 insertions(+) diff --git a/Source/EquipmentDatabase.cs b/Source/EquipmentDatabase.cs index 212ef02..84d07e0 100644 --- a/Source/EquipmentDatabase.cs +++ b/Source/EquipmentDatabase.cs @@ -235,6 +235,9 @@ public EquipmentType ClassifyThingDef(ThingDef def) { if (def.IsFrame) { return TypeDiscard; } + if (BelongsToCategory(def, "Toy")) { + return TypeResources; + } if (def.weaponTags != null && def.weaponTags.Count > 0 && def.IsWeapon) { return TypeWeapons; } From b9b1dcef21c3f46f9f479da5ae590b8e5fec64f7 Mon Sep 17 00:00:00 2001 From: edbmods Date: Sun, 28 Jul 2019 10:50:21 -0700 Subject: [PATCH 11/11] Additional change log items for 1.0.13 --- Resources/CHANGELOG.txt | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/Resources/CHANGELOG.txt b/Resources/CHANGELOG.txt index 067d0c9..60cfca4 100644 --- a/Resources/CHANGELOG.txt +++ b/Resources/CHANGELOG.txt @@ -5,7 +5,11 @@ - Bug-fix for item categories with multiple parent categories. - Bug fix for choosing body parts for injuries that affect specific parts. - - Updated the version of Harmony to 1.2.0.1 + - Bug fix for races with no defined age generation curve. + - Updated the version of Harmony to 1.2.0.1. + - Added "manifest" file to support the Mod Manager mod. + - Ammunition equipment from Combat Extended is now classified under the + "Weapons" category. _____________________________________________________________________________